balala-revogrid 1.0.0

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 (760) hide show
  1. package/LICENSE +21 -0
  2. package/dist/cjs/app-globals-D67EXhgK.js +16 -0
  3. package/dist/cjs/app-globals-D67EXhgK.js.map +1 -0
  4. package/dist/cjs/cell-renderer-B87qecTb.js +57 -0
  5. package/dist/cjs/cell-renderer-B87qecTb.js.map +1 -0
  6. package/dist/cjs/debounce-CcpHiH2p.js +498 -0
  7. package/dist/cjs/debounce-CcpHiH2p.js.map +1 -0
  8. package/dist/cjs/dimension.helpers-DA9-xqPT.js +3606 -0
  9. package/dist/cjs/dimension.helpers-DA9-xqPT.js.map +1 -0
  10. package/dist/cjs/edit.utils-CKsIiHlD.js +113 -0
  11. package/dist/cjs/edit.utils-CKsIiHlD.js.map +1 -0
  12. package/dist/cjs/events-DeLDyZlb.js +46 -0
  13. package/dist/cjs/events-DeLDyZlb.js.map +1 -0
  14. package/dist/cjs/filter.button-DSsWNs23.js +49 -0
  15. package/dist/cjs/filter.button-DSsWNs23.js.map +1 -0
  16. package/dist/cjs/grouping.row.renderer-BqR0ytMi.js +64 -0
  17. package/dist/cjs/grouping.row.renderer-BqR0ytMi.js.map +1 -0
  18. package/dist/cjs/header-cell-renderer-D-RjAVfe.js +1766 -0
  19. package/dist/cjs/header-cell-renderer-D-RjAVfe.js.map +1 -0
  20. package/dist/cjs/index-BF1c1pO3.js +2549 -0
  21. package/dist/cjs/index-BF1c1pO3.js.map +1 -0
  22. package/dist/cjs/index.cjs.js +6426 -0
  23. package/dist/cjs/index.cjs.js.map +1 -0
  24. package/dist/cjs/loader.cjs.js +19 -0
  25. package/dist/cjs/loader.cjs.js.map +1 -0
  26. package/dist/cjs/revo-grid.cjs.entry.js +3215 -0
  27. package/dist/cjs/revo-grid.cjs.entry.js.map +1 -0
  28. package/dist/cjs/revo-grid.cjs.js +31 -0
  29. package/dist/cjs/revo-grid.cjs.js.map +1 -0
  30. package/dist/cjs/revo-grid.entry.cjs.js.map +1 -0
  31. package/dist/cjs/revogr-attribution.revogr-extra.revogr-focus.revogr-grouping-overlay.revogr-header-unified.revogr-overlay-selection.revogr-row-headers.revogr-scroll-virtual.revogr-temp-range.entry.cjs.js.map +1 -0
  32. package/dist/cjs/revogr-attribution_9.cjs.entry.js +2629 -0
  33. package/dist/cjs/revogr-attribution_9.cjs.entry.js.map +1 -0
  34. package/dist/cjs/revogr-clipboard.revogr-edit.revogr-order-editor.entry.cjs.js.map +1 -0
  35. package/dist/cjs/revogr-clipboard_3.cjs.entry.js +471 -0
  36. package/dist/cjs/revogr-clipboard_3.cjs.entry.js.map +1 -0
  37. package/dist/cjs/revogr-data.revogr-header.revogr-viewport-scroll.vnode-html.entry.cjs.js.map +1 -0
  38. package/dist/cjs/revogr-data_4.cjs.entry.js +1420 -0
  39. package/dist/cjs/revogr-data_4.cjs.entry.js.map +1 -0
  40. package/dist/cjs/revogr-filter-panel.cjs.entry.js +382 -0
  41. package/dist/cjs/revogr-filter-panel.cjs.entry.js.map +1 -0
  42. package/dist/cjs/revogr-filter-panel.entry.cjs.js.map +1 -0
  43. package/dist/cjs/row-renderer-BTE7VKD9.js +49 -0
  44. package/dist/cjs/row-renderer-BTE7VKD9.js.map +1 -0
  45. package/dist/cjs/text-editor-BdhmcrkS.js +81 -0
  46. package/dist/cjs/text-editor-BdhmcrkS.js.map +1 -0
  47. package/dist/cjs/throttle-2ZxfGjEI.js +533 -0
  48. package/dist/cjs/throttle-2ZxfGjEI.js.map +1 -0
  49. package/dist/cjs/tree-data.plugin-BRjwZtxI.js +5350 -0
  50. package/dist/cjs/tree-data.plugin-BRjwZtxI.js.map +1 -0
  51. package/dist/cjs/viewport.helpers-BAovztDd.js +61 -0
  52. package/dist/cjs/viewport.helpers-BAovztDd.js.map +1 -0
  53. package/dist/cjs/viewport.store-BTbPlyF-.js +525 -0
  54. package/dist/cjs/viewport.store-BTbPlyF-.js.map +1 -0
  55. package/dist/collection/collection-manifest.json +30 -0
  56. package/dist/collection/components/attribution/revogr-attribution.js +20 -0
  57. package/dist/collection/components/attribution/revogr-attribution.js.map +1 -0
  58. package/dist/collection/components/clipboard/revogr-clipboard.js +411 -0
  59. package/dist/collection/components/clipboard/revogr-clipboard.js.map +1 -0
  60. package/dist/collection/components/data/cell-renderer.js +44 -0
  61. package/dist/collection/components/data/cell-renderer.js.map +1 -0
  62. package/dist/collection/components/data/column.service.js +333 -0
  63. package/dist/collection/components/data/column.service.js.map +1 -0
  64. package/dist/collection/components/data/revogr-data-style.css +95 -0
  65. package/dist/collection/components/data/revogr-data.js +939 -0
  66. package/dist/collection/components/data/revogr-data.js.map +1 -0
  67. package/dist/collection/components/data/row-highlight.plugin.js +51 -0
  68. package/dist/collection/components/data/row-highlight.plugin.js.map +1 -0
  69. package/dist/collection/components/data/row-renderer.js +37 -0
  70. package/dist/collection/components/data/row-renderer.js.map +1 -0
  71. package/dist/collection/components/editors/edit.utils.js +13 -0
  72. package/dist/collection/components/editors/edit.utils.js.map +1 -0
  73. package/dist/collection/components/editors/revogr-edit-style.css +16 -0
  74. package/dist/collection/components/editors/revogr-edit.js +346 -0
  75. package/dist/collection/components/editors/revogr-edit.js.map +1 -0
  76. package/dist/collection/components/editors/text-editor.js +74 -0
  77. package/dist/collection/components/editors/text-editor.js.map +1 -0
  78. package/dist/collection/components/extra/revogr-extra.js +125 -0
  79. package/dist/collection/components/extra/revogr-extra.js.map +1 -0
  80. package/dist/collection/components/grouping-overlay/revogr-grouping-overlay.css +62 -0
  81. package/dist/collection/components/grouping-overlay/revogr-grouping-overlay.js +644 -0
  82. package/dist/collection/components/grouping-overlay/revogr-grouping-overlay.js.map +1 -0
  83. package/dist/collection/components/header/header-cell-renderer.js +49 -0
  84. package/dist/collection/components/header/header-cell-renderer.js.map +1 -0
  85. package/dist/collection/components/header/header-group-renderer.js +29 -0
  86. package/dist/collection/components/header/header-group-renderer.js.map +1 -0
  87. package/dist/collection/components/header/header-renderer.js +100 -0
  88. package/dist/collection/components/header/header-renderer.js.map +1 -0
  89. package/dist/collection/components/header/resizable.directive.js +274 -0
  90. package/dist/collection/components/header/resizable.directive.js.map +1 -0
  91. package/dist/collection/components/header/resizable.element.js +36 -0
  92. package/dist/collection/components/header/resizable.element.js.map +1 -0
  93. package/dist/collection/components/header/revogr-header-style.css +164 -0
  94. package/dist/collection/components/header/revogr-header-unified-style.css +205 -0
  95. package/dist/collection/components/header/revogr-header-unified.js +1013 -0
  96. package/dist/collection/components/header/revogr-header-unified.js.map +1 -0
  97. package/dist/collection/components/header/revogr-header.js +852 -0
  98. package/dist/collection/components/header/revogr-header.js.map +1 -0
  99. package/dist/collection/components/order/order-renderer.js +50 -0
  100. package/dist/collection/components/order/order-renderer.js.map +1 -0
  101. package/dist/collection/components/order/order-row.service.js +72 -0
  102. package/dist/collection/components/order/order-row.service.js.map +1 -0
  103. package/dist/collection/components/order/revogr-order-editor.js +461 -0
  104. package/dist/collection/components/order/revogr-order-editor.js.map +1 -0
  105. package/dist/collection/components/overlay/autofill.service.js +221 -0
  106. package/dist/collection/components/overlay/autofill.service.js.map +1 -0
  107. package/dist/collection/components/overlay/keyboard.service.js +178 -0
  108. package/dist/collection/components/overlay/keyboard.service.js.map +1 -0
  109. package/dist/collection/components/overlay/revogr-overlay-selection.js +1606 -0
  110. package/dist/collection/components/overlay/revogr-overlay-selection.js.map +1 -0
  111. package/dist/collection/components/overlay/revogr-overlay-style.css +95 -0
  112. package/dist/collection/components/overlay/selection.utils.js +136 -0
  113. package/dist/collection/components/overlay/selection.utils.js.map +1 -0
  114. package/dist/collection/components/revoGrid/grid.helpers.js +33 -0
  115. package/dist/collection/components/revoGrid/grid.helpers.js.map +1 -0
  116. package/dist/collection/components/revoGrid/plugin.service.js +81 -0
  117. package/dist/collection/components/revoGrid/plugin.service.js.map +1 -0
  118. package/dist/collection/components/revoGrid/revo-grid-style.css +897 -0
  119. package/dist/collection/components/revoGrid/revo-grid.js +4717 -0
  120. package/dist/collection/components/revoGrid/revo-grid.js.map +1 -0
  121. package/dist/collection/components/revoGrid/viewport.helpers.js +51 -0
  122. package/dist/collection/components/revoGrid/viewport.helpers.js.map +1 -0
  123. package/dist/collection/components/revoGrid/viewport.resize.service.js +55 -0
  124. package/dist/collection/components/revoGrid/viewport.resize.service.js.map +1 -0
  125. package/dist/collection/components/revoGrid/viewport.scrolling.service.js +139 -0
  126. package/dist/collection/components/revoGrid/viewport.scrolling.service.js.map +1 -0
  127. package/dist/collection/components/revoGrid/viewport.service.js +253 -0
  128. package/dist/collection/components/revoGrid/viewport.service.js.map +1 -0
  129. package/dist/collection/components/rowHeaders/revogr-row-headers.js +291 -0
  130. package/dist/collection/components/rowHeaders/revogr-row-headers.js.map +1 -0
  131. package/dist/collection/components/rowHeaders/row-header-render.js +5 -0
  132. package/dist/collection/components/rowHeaders/row-header-render.js.map +1 -0
  133. package/dist/collection/components/scroll/revogr-viewport-scroll-style.css +70 -0
  134. package/dist/collection/components/scroll/revogr-viewport-scroll.js +938 -0
  135. package/dist/collection/components/scroll/revogr-viewport-scroll.js.map +1 -0
  136. package/dist/collection/components/scrollable/autohide-scroll.plugin.js +44 -0
  137. package/dist/collection/components/scrollable/autohide-scroll.plugin.js.map +1 -0
  138. package/dist/collection/components/scrollable/revogr-scroll-style.css +34 -0
  139. package/dist/collection/components/scrollable/revogr-scroll-virtual.js +346 -0
  140. package/dist/collection/components/scrollable/revogr-scroll-virtual.js.map +1 -0
  141. package/dist/collection/components/selectionFocus/revogr-focus-style.css +7 -0
  142. package/dist/collection/components/selectionFocus/revogr-focus.js +429 -0
  143. package/dist/collection/components/selectionFocus/revogr-focus.js.map +1 -0
  144. package/dist/collection/components/selectionTempRange/revogr-temp-range-style.css +28 -0
  145. package/dist/collection/components/selectionTempRange/revogr-temp-range.js +171 -0
  146. package/dist/collection/components/selectionTempRange/revogr-temp-range.js.map +1 -0
  147. package/dist/collection/components/vnode/vnode-converter.js +84 -0
  148. package/dist/collection/components/vnode/vnode-converter.js.map +1 -0
  149. package/dist/collection/components/vnode/vnode.utils.js +18 -0
  150. package/dist/collection/components/vnode/vnode.utils.js.map +1 -0
  151. package/dist/collection/global/global.js +19 -0
  152. package/dist/collection/global/global.js.map +1 -0
  153. package/dist/collection/index.js +13 -0
  154. package/dist/collection/index.js.map +1 -0
  155. package/dist/collection/plugins/add-rows-on-paste.plugin.js +40 -0
  156. package/dist/collection/plugins/add-rows-on-paste.plugin.js.map +1 -0
  157. package/dist/collection/plugins/base.plugin.js +90 -0
  158. package/dist/collection/plugins/base.plugin.js.map +1 -0
  159. package/dist/collection/plugins/column-hide.plugin.js +532 -0
  160. package/dist/collection/plugins/column-hide.plugin.js.map +1 -0
  161. package/dist/collection/plugins/column-manage.plugin.js +1218 -0
  162. package/dist/collection/plugins/column-manage.plugin.js.map +1 -0
  163. package/dist/collection/plugins/column-stretch.plugin.js +921 -0
  164. package/dist/collection/plugins/column-stretch.plugin.js.map +1 -0
  165. package/dist/collection/plugins/column.auto-size.plugin.js +308 -0
  166. package/dist/collection/plugins/column.auto-size.plugin.js.map +1 -0
  167. package/dist/collection/plugins/column.stretch.plugin.js +96 -0
  168. package/dist/collection/plugins/column.stretch.plugin.js.map +1 -0
  169. package/dist/collection/plugins/customColumnDrag/column-move.helper.js +361 -0
  170. package/dist/collection/plugins/customColumnDrag/column-move.helper.js.map +1 -0
  171. package/dist/collection/plugins/customColumnDrag/custom-column-drag.plugin.js +145 -0
  172. package/dist/collection/plugins/customColumnDrag/custom-column-drag.plugin.js.map +1 -0
  173. package/dist/collection/plugins/customColumnDrag/drag.handler.js +726 -0
  174. package/dist/collection/plugins/customColumnDrag/drag.handler.js.map +1 -0
  175. package/dist/collection/plugins/customColumnDrag/example.js +282 -0
  176. package/dist/collection/plugins/customColumnDrag/example.js.map +1 -0
  177. package/dist/collection/plugins/customColumnDrag/index.js +8 -0
  178. package/dist/collection/plugins/customColumnDrag/index.js.map +1 -0
  179. package/dist/collection/plugins/customColumnDrag/types.js +2 -0
  180. package/dist/collection/plugins/customColumnDrag/types.js.map +1 -0
  181. package/dist/collection/plugins/dispatcher.js +40 -0
  182. package/dist/collection/plugins/dispatcher.js.map +1 -0
  183. package/dist/collection/plugins/enhanced-scrollbar.plugin.js +493 -0
  184. package/dist/collection/plugins/enhanced-scrollbar.plugin.js.map +1 -0
  185. package/dist/collection/plugins/export/csv.js +72 -0
  186. package/dist/collection/plugins/export/csv.js.map +1 -0
  187. package/dist/collection/plugins/export/export.plugin.js +157 -0
  188. package/dist/collection/plugins/export/export.plugin.js.map +1 -0
  189. package/dist/collection/plugins/export/types.js +2 -0
  190. package/dist/collection/plugins/export/types.js.map +1 -0
  191. package/dist/collection/plugins/filter/conditions/equal.js +21 -0
  192. package/dist/collection/plugins/filter/conditions/equal.js.map +1 -0
  193. package/dist/collection/plugins/filter/conditions/number/greaterThan.js +14 -0
  194. package/dist/collection/plugins/filter/conditions/number/greaterThan.js.map +1 -0
  195. package/dist/collection/plugins/filter/conditions/number/greaterThanOrEqual.js +11 -0
  196. package/dist/collection/plugins/filter/conditions/number/greaterThanOrEqual.js.map +1 -0
  197. package/dist/collection/plugins/filter/conditions/number/lessThan.js +16 -0
  198. package/dist/collection/plugins/filter/conditions/number/lessThan.js.map +1 -0
  199. package/dist/collection/plugins/filter/conditions/number/lessThanOrEqual.js +11 -0
  200. package/dist/collection/plugins/filter/conditions/number/lessThanOrEqual.js.map +1 -0
  201. package/dist/collection/plugins/filter/conditions/set.js +7 -0
  202. package/dist/collection/plugins/filter/conditions/set.js.map +1 -0
  203. package/dist/collection/plugins/filter/conditions/string/beginswith.js +21 -0
  204. package/dist/collection/plugins/filter/conditions/string/beginswith.js.map +1 -0
  205. package/dist/collection/plugins/filter/conditions/string/contains.js +25 -0
  206. package/dist/collection/plugins/filter/conditions/string/contains.js.map +1 -0
  207. package/dist/collection/plugins/filter/filter.button.js +28 -0
  208. package/dist/collection/plugins/filter/filter.button.js.map +1 -0
  209. package/dist/collection/plugins/filter/filter.indexed.js +49 -0
  210. package/dist/collection/plugins/filter/filter.indexed.js.map +1 -0
  211. package/dist/collection/plugins/filter/filter.panel.js +610 -0
  212. package/dist/collection/plugins/filter/filter.panel.js.map +1 -0
  213. package/dist/collection/plugins/filter/filter.plugin.js +388 -0
  214. package/dist/collection/plugins/filter/filter.plugin.js.map +1 -0
  215. package/dist/collection/plugins/filter/filter.style.css +165 -0
  216. package/dist/collection/plugins/filter/filter.types.js +9 -0
  217. package/dist/collection/plugins/filter/filter.types.js.map +1 -0
  218. package/dist/collection/plugins/grid-setup.js +131 -0
  219. package/dist/collection/plugins/grid-setup.js.map +1 -0
  220. package/dist/collection/plugins/groupingRow/grouping.const.js +18 -0
  221. package/dist/collection/plugins/groupingRow/grouping.const.js.map +1 -0
  222. package/dist/collection/plugins/groupingRow/grouping.row.expand.service.js +122 -0
  223. package/dist/collection/plugins/groupingRow/grouping.row.expand.service.js.map +1 -0
  224. package/dist/collection/plugins/groupingRow/grouping.row.plugin.js +252 -0
  225. package/dist/collection/plugins/groupingRow/grouping.row.plugin.js.map +1 -0
  226. package/dist/collection/plugins/groupingRow/grouping.row.renderer.js +49 -0
  227. package/dist/collection/plugins/groupingRow/grouping.row.renderer.js.map +1 -0
  228. package/dist/collection/plugins/groupingRow/grouping.row.types.js +2 -0
  229. package/dist/collection/plugins/groupingRow/grouping.row.types.js.map +1 -0
  230. package/dist/collection/plugins/groupingRow/grouping.service.js +215 -0
  231. package/dist/collection/plugins/groupingRow/grouping.service.js.map +1 -0
  232. package/dist/collection/plugins/groupingRow/grouping.trimmed.service.js +61 -0
  233. package/dist/collection/plugins/groupingRow/grouping.trimmed.service.js.map +1 -0
  234. package/dist/collection/plugins/index.js +26 -0
  235. package/dist/collection/plugins/index.js.map +1 -0
  236. package/dist/collection/plugins/manual-focus.plugin.js +353 -0
  237. package/dist/collection/plugins/manual-focus.plugin.js.map +1 -0
  238. package/dist/collection/plugins/moveColumn/column.drag.plugin.js +171 -0
  239. package/dist/collection/plugins/moveColumn/column.drag.plugin.js.map +1 -0
  240. package/dist/collection/plugins/moveColumn/order-column.handler.js +69 -0
  241. package/dist/collection/plugins/moveColumn/order-column.handler.js.map +1 -0
  242. package/dist/collection/plugins/pin-shadow.plugin.js +487 -0
  243. package/dist/collection/plugins/pin-shadow.plugin.js.map +1 -0
  244. package/dist/collection/plugins/resize-indicator.plugin.js +430 -0
  245. package/dist/collection/plugins/resize-indicator.plugin.js.map +1 -0
  246. package/dist/collection/plugins/row-select-plugin-2026228.js +1803 -0
  247. package/dist/collection/plugins/row-select-plugin-2026228.js.map +1 -0
  248. package/dist/collection/plugins/row-select.plugin.js +2096 -0
  249. package/dist/collection/plugins/row-select.plugin.js.map +1 -0
  250. package/dist/collection/plugins/rtl/rtl.plugin.js +110 -0
  251. package/dist/collection/plugins/rtl/rtl.plugin.js.map +1 -0
  252. package/dist/collection/plugins/sorting/sorting.func.js +82 -0
  253. package/dist/collection/plugins/sorting/sorting.func.js.map +1 -0
  254. package/dist/collection/plugins/sorting/sorting.plugin.js +224 -0
  255. package/dist/collection/plugins/sorting/sorting.plugin.js.map +1 -0
  256. package/dist/collection/plugins/sorting/sorting.sign.js +9 -0
  257. package/dist/collection/plugins/sorting/sorting.sign.js.map +1 -0
  258. package/dist/collection/plugins/sorting/sorting.types.js +2 -0
  259. package/dist/collection/plugins/sorting/sorting.types.js.map +1 -0
  260. package/dist/collection/plugins/tree-data.plugin.js +447 -0
  261. package/dist/collection/plugins/tree-data.plugin.js.map +1 -0
  262. package/dist/collection/plugins/wcag/index.js +84 -0
  263. package/dist/collection/plugins/wcag/index.js.map +1 -0
  264. package/dist/collection/serve/controller.js +344 -0
  265. package/dist/collection/serve/data.js +201 -0
  266. package/dist/collection/serve/realData.js +4148 -0
  267. package/dist/collection/services/cell.helpers.js +12 -0
  268. package/dist/collection/services/cell.helpers.js.map +1 -0
  269. package/dist/collection/services/column.data.provider.js +122 -0
  270. package/dist/collection/services/column.data.provider.js.map +1 -0
  271. package/dist/collection/services/data.provider.js +89 -0
  272. package/dist/collection/services/data.provider.js.map +1 -0
  273. package/dist/collection/services/dimension.provider.js +257 -0
  274. package/dist/collection/services/dimension.provider.js.map +1 -0
  275. package/dist/collection/services/local.scroll.service.js +136 -0
  276. package/dist/collection/services/local.scroll.service.js.map +1 -0
  277. package/dist/collection/services/local.scroll.timer.js +84 -0
  278. package/dist/collection/services/local.scroll.timer.js.map +1 -0
  279. package/dist/collection/services/selection.store.connector.js +274 -0
  280. package/dist/collection/services/selection.store.connector.js.map +1 -0
  281. package/dist/collection/services/viewport.provider.js +17 -0
  282. package/dist/collection/services/viewport.provider.js.map +1 -0
  283. package/dist/collection/store/dataSource/data.proxy.js +45 -0
  284. package/dist/collection/store/dataSource/data.proxy.js.map +1 -0
  285. package/dist/collection/store/dataSource/data.store.js +146 -0
  286. package/dist/collection/store/dataSource/data.store.js.map +1 -0
  287. package/dist/collection/store/dataSource/index.js +7 -0
  288. package/dist/collection/store/dataSource/index.js.map +1 -0
  289. package/dist/collection/store/dataSource/trimmed.plugin.js +34 -0
  290. package/dist/collection/store/dataSource/trimmed.plugin.js.map +1 -0
  291. package/dist/collection/store/dimension/dimension.helpers.js +101 -0
  292. package/dist/collection/store/dimension/dimension.helpers.js.map +1 -0
  293. package/dist/collection/store/dimension/dimension.recalculate.plugin.js +29 -0
  294. package/dist/collection/store/dimension/dimension.recalculate.plugin.js.map +1 -0
  295. package/dist/collection/store/dimension/dimension.store.js +124 -0
  296. package/dist/collection/store/dimension/dimension.store.js.map +1 -0
  297. package/dist/collection/store/dimension/dimension.trim.plugin.js +61 -0
  298. package/dist/collection/store/dimension/dimension.trim.plugin.js.map +1 -0
  299. package/dist/collection/store/dimension/index.js +6 -0
  300. package/dist/collection/store/dimension/index.js.map +1 -0
  301. package/dist/collection/store/index.js +17 -0
  302. package/dist/collection/store/index.js.map +1 -0
  303. package/dist/collection/store/selection/index.js +6 -0
  304. package/dist/collection/store/selection/index.js.map +1 -0
  305. package/dist/collection/store/selection/selection.helpers.js +49 -0
  306. package/dist/collection/store/selection/selection.helpers.js.map +1 -0
  307. package/dist/collection/store/selection/selection.store.js +85 -0
  308. package/dist/collection/store/selection/selection.store.js.map +1 -0
  309. package/dist/collection/store/vp/index.js +6 -0
  310. package/dist/collection/store/vp/index.js.map +1 -0
  311. package/dist/collection/store/vp/viewport.helpers.js +251 -0
  312. package/dist/collection/store/vp/viewport.helpers.js.map +1 -0
  313. package/dist/collection/store/vp/viewport.store.js +256 -0
  314. package/dist/collection/store/vp/viewport.store.js.map +1 -0
  315. package/dist/collection/themeManager/theme.compact.js +9 -0
  316. package/dist/collection/themeManager/theme.compact.js.map +1 -0
  317. package/dist/collection/themeManager/theme.default.js +9 -0
  318. package/dist/collection/themeManager/theme.default.js.map +1 -0
  319. package/dist/collection/themeManager/theme.material.js +9 -0
  320. package/dist/collection/themeManager/theme.material.js.map +1 -0
  321. package/dist/collection/themeManager/theme.service.js +53 -0
  322. package/dist/collection/themeManager/theme.service.js.map +1 -0
  323. package/dist/collection/types/dimension.js +2 -0
  324. package/dist/collection/types/dimension.js.map +1 -0
  325. package/dist/collection/types/events.js +124 -0
  326. package/dist/collection/types/events.js.map +1 -0
  327. package/dist/collection/types/index.js +12 -0
  328. package/dist/collection/types/index.js.map +1 -0
  329. package/dist/collection/types/interfaces.js +6 -0
  330. package/dist/collection/types/interfaces.js.map +1 -0
  331. package/dist/collection/types/plugin.js +2 -0
  332. package/dist/collection/types/plugin.js.map +1 -0
  333. package/dist/collection/types/plugin.types.js +2 -0
  334. package/dist/collection/types/plugin.types.js.map +1 -0
  335. package/dist/collection/types/selection.js +2 -0
  336. package/dist/collection/types/selection.js.map +1 -0
  337. package/dist/collection/types/theme.js +2 -0
  338. package/dist/collection/types/theme.js.map +1 -0
  339. package/dist/collection/types/viewport.interfaces.js +2 -0
  340. package/dist/collection/types/viewport.interfaces.js.map +1 -0
  341. package/dist/collection/utils/batchGroupCollapse.js +190 -0
  342. package/dist/collection/utils/batchGroupCollapse.js.map +1 -0
  343. package/dist/collection/utils/browser.js +7 -0
  344. package/dist/collection/utils/browser.js.map +1 -0
  345. package/dist/collection/utils/cell-template-helper.js +181 -0
  346. package/dist/collection/utils/cell-template-helper.js.map +1 -0
  347. package/dist/collection/utils/closest.polifill.js +22 -0
  348. package/dist/collection/utils/closest.polifill.js.map +1 -0
  349. package/dist/collection/utils/column.utils.js +448 -0
  350. package/dist/collection/utils/column.utils.js.map +1 -0
  351. package/dist/collection/utils/consts.js +26 -0
  352. package/dist/collection/utils/consts.js.map +1 -0
  353. package/dist/collection/utils/events.js +39 -0
  354. package/dist/collection/utils/events.js.map +1 -0
  355. package/dist/collection/utils/header.utils.js +24 -0
  356. package/dist/collection/utils/header.utils.js.map +1 -0
  357. package/dist/collection/utils/index.js +133 -0
  358. package/dist/collection/utils/index.js.map +1 -0
  359. package/dist/collection/utils/key.codes.js +80 -0
  360. package/dist/collection/utils/key.codes.js.map +1 -0
  361. package/dist/collection/utils/key.utils.js +86 -0
  362. package/dist/collection/utils/key.utils.js.map +1 -0
  363. package/dist/collection/utils/mobile.js +7 -0
  364. package/dist/collection/utils/mobile.js.map +1 -0
  365. package/dist/collection/utils/platform.js +9 -0
  366. package/dist/collection/utils/platform.js.map +1 -0
  367. package/dist/collection/utils/row-header-utils.js +9 -0
  368. package/dist/collection/utils/row-header-utils.js.map +1 -0
  369. package/dist/collection/utils/store.types.js +2 -0
  370. package/dist/collection/utils/store.types.js.map +1 -0
  371. package/dist/collection/utils/store.utils.js +15 -0
  372. package/dist/collection/utils/store.utils.js.map +1 -0
  373. package/dist/esm/app-globals-C3ZHKjnB.js +14 -0
  374. package/dist/esm/app-globals-C3ZHKjnB.js.map +1 -0
  375. package/dist/esm/cell-renderer-C2Td6LKY.js +54 -0
  376. package/dist/esm/cell-renderer-C2Td6LKY.js.map +1 -0
  377. package/dist/esm/debounce-BfO9dz9v.js +488 -0
  378. package/dist/esm/debounce-BfO9dz9v.js.map +1 -0
  379. package/dist/esm/dimension.helpers-DDil7Dg0.js +3546 -0
  380. package/dist/esm/dimension.helpers-DDil7Dg0.js.map +1 -0
  381. package/dist/esm/edit.utils-ClxXX_x9.js +99 -0
  382. package/dist/esm/edit.utils-ClxXX_x9.js.map +1 -0
  383. package/dist/esm/events-BvSmBueA.js +43 -0
  384. package/dist/esm/events-BvSmBueA.js.map +1 -0
  385. package/dist/esm/filter.button-DmOE7VCJ.js +39 -0
  386. package/dist/esm/filter.button-DmOE7VCJ.js.map +1 -0
  387. package/dist/esm/grouping.row.renderer-6NYszUJA.js +60 -0
  388. package/dist/esm/grouping.row.renderer-6NYszUJA.js.map +1 -0
  389. package/dist/esm/header-cell-renderer-BVHTuFGE.js +1715 -0
  390. package/dist/esm/header-cell-renderer-BVHTuFGE.js.map +1 -0
  391. package/dist/esm/index-Dyptvvxf.js +2519 -0
  392. package/dist/esm/index-Dyptvvxf.js.map +1 -0
  393. package/dist/esm/index.js +6232 -0
  394. package/dist/esm/index.js.map +1 -0
  395. package/dist/esm/loader.js +17 -0
  396. package/dist/esm/loader.js.map +1 -0
  397. package/dist/esm/revo-grid.entry.js +3213 -0
  398. package/dist/esm/revo-grid.entry.js.map +1 -0
  399. package/dist/esm/revo-grid.js +27 -0
  400. package/dist/esm/revo-grid.js.map +1 -0
  401. package/dist/esm/revogr-attribution.revogr-extra.revogr-focus.revogr-grouping-overlay.revogr-header-unified.revogr-overlay-selection.revogr-row-headers.revogr-scroll-virtual.revogr-temp-range.entry.js.map +1 -0
  402. package/dist/esm/revogr-attribution_9.entry.js +2619 -0
  403. package/dist/esm/revogr-attribution_9.entry.js.map +1 -0
  404. package/dist/esm/revogr-clipboard.revogr-edit.revogr-order-editor.entry.js.map +1 -0
  405. package/dist/esm/revogr-clipboard_3.entry.js +467 -0
  406. package/dist/esm/revogr-clipboard_3.entry.js.map +1 -0
  407. package/dist/esm/revogr-data.revogr-header.revogr-viewport-scroll.vnode-html.entry.js.map +1 -0
  408. package/dist/esm/revogr-data_4.entry.js +1415 -0
  409. package/dist/esm/revogr-data_4.entry.js.map +1 -0
  410. package/dist/esm/revogr-filter-panel.entry.js +380 -0
  411. package/dist/esm/revogr-filter-panel.entry.js.map +1 -0
  412. package/dist/esm/row-renderer-sb6QTqH-.js +46 -0
  413. package/dist/esm/row-renderer-sb6QTqH-.js.map +1 -0
  414. package/dist/esm/text-editor-CxXqoicM.js +79 -0
  415. package/dist/esm/text-editor-CxXqoicM.js.map +1 -0
  416. package/dist/esm/throttle-DXYrmEeb.js +525 -0
  417. package/dist/esm/throttle-DXYrmEeb.js.map +1 -0
  418. package/dist/esm/tree-data.plugin-C2eXkf9_.js +5319 -0
  419. package/dist/esm/tree-data.plugin-C2eXkf9_.js.map +1 -0
  420. package/dist/esm/viewport.helpers-VXhsJZtn.js +55 -0
  421. package/dist/esm/viewport.helpers-VXhsJZtn.js.map +1 -0
  422. package/dist/esm/viewport.store-C-GnV31k.js +512 -0
  423. package/dist/esm/viewport.store-C-GnV31k.js.map +1 -0
  424. package/dist/index.cjs.js +1 -0
  425. package/dist/index.js +1 -0
  426. package/dist/revo-grid/app-globals-C3ZHKjnB.js +14 -0
  427. package/dist/revo-grid/app-globals-C3ZHKjnB.js.map +1 -0
  428. package/dist/revo-grid/cell-renderer-C2Td6LKY.js +54 -0
  429. package/dist/revo-grid/cell-renderer-C2Td6LKY.js.map +1 -0
  430. package/dist/revo-grid/debounce-BfO9dz9v.js +488 -0
  431. package/dist/revo-grid/debounce-BfO9dz9v.js.map +1 -0
  432. package/dist/revo-grid/dimension.helpers-DDil7Dg0.js +3546 -0
  433. package/dist/revo-grid/dimension.helpers-DDil7Dg0.js.map +1 -0
  434. package/dist/revo-grid/edit.utils-ClxXX_x9.js +99 -0
  435. package/dist/revo-grid/edit.utils-ClxXX_x9.js.map +1 -0
  436. package/dist/revo-grid/events-BvSmBueA.js +43 -0
  437. package/dist/revo-grid/events-BvSmBueA.js.map +1 -0
  438. package/dist/revo-grid/filter.button-DmOE7VCJ.js +39 -0
  439. package/dist/revo-grid/filter.button-DmOE7VCJ.js.map +1 -0
  440. package/dist/revo-grid/grouping.row.renderer-6NYszUJA.js +60 -0
  441. package/dist/revo-grid/grouping.row.renderer-6NYszUJA.js.map +1 -0
  442. package/dist/revo-grid/header-cell-renderer-BVHTuFGE.js +1715 -0
  443. package/dist/revo-grid/header-cell-renderer-BVHTuFGE.js.map +1 -0
  444. package/dist/revo-grid/index-Dyptvvxf.js +2490 -0
  445. package/dist/revo-grid/index-Dyptvvxf.js.map +1 -0
  446. package/dist/revo-grid/index.esm.js +6232 -0
  447. package/dist/revo-grid/index.esm.js.map +1 -0
  448. package/dist/revo-grid/loader.esm.js.map +1 -0
  449. package/dist/revo-grid/revo-grid.entry.esm.js.map +1 -0
  450. package/dist/revo-grid/revo-grid.entry.js +3213 -0
  451. package/dist/revo-grid/revo-grid.entry.js.map +1 -0
  452. package/dist/revo-grid/revo-grid.esm.js +27 -0
  453. package/dist/revo-grid/revo-grid.esm.js.map +1 -0
  454. package/dist/revo-grid/revogr-attribution.revogr-extra.revogr-focus.revogr-grouping-overlay.revogr-header-unified.revogr-overlay-selection.revogr-row-headers.revogr-scroll-virtual.revogr-temp-range.entry.esm.js.map +1 -0
  455. package/dist/revo-grid/revogr-attribution_9.entry.js +2619 -0
  456. package/dist/revo-grid/revogr-attribution_9.entry.js.map +1 -0
  457. package/dist/revo-grid/revogr-clipboard.revogr-edit.revogr-order-editor.entry.esm.js.map +1 -0
  458. package/dist/revo-grid/revogr-clipboard_3.entry.js +467 -0
  459. package/dist/revo-grid/revogr-clipboard_3.entry.js.map +1 -0
  460. package/dist/revo-grid/revogr-data.revogr-header.revogr-viewport-scroll.vnode-html.entry.esm.js.map +1 -0
  461. package/dist/revo-grid/revogr-data_4.entry.js +1415 -0
  462. package/dist/revo-grid/revogr-data_4.entry.js.map +1 -0
  463. package/dist/revo-grid/revogr-filter-panel.entry.esm.js.map +1 -0
  464. package/dist/revo-grid/revogr-filter-panel.entry.js +380 -0
  465. package/dist/revo-grid/revogr-filter-panel.entry.js.map +1 -0
  466. package/dist/revo-grid/row-renderer-sb6QTqH-.js +46 -0
  467. package/dist/revo-grid/row-renderer-sb6QTqH-.js.map +1 -0
  468. package/dist/revo-grid/text-editor-CxXqoicM.js +79 -0
  469. package/dist/revo-grid/text-editor-CxXqoicM.js.map +1 -0
  470. package/dist/revo-grid/throttle-DXYrmEeb.js +525 -0
  471. package/dist/revo-grid/throttle-DXYrmEeb.js.map +1 -0
  472. package/dist/revo-grid/tree-data.plugin-C2eXkf9_.js +5319 -0
  473. package/dist/revo-grid/tree-data.plugin-C2eXkf9_.js.map +1 -0
  474. package/dist/revo-grid/viewport.helpers-VXhsJZtn.js +55 -0
  475. package/dist/revo-grid/viewport.helpers-VXhsJZtn.js.map +1 -0
  476. package/dist/revo-grid/viewport.store-C-GnV31k.js +512 -0
  477. package/dist/revo-grid/viewport.store-C-GnV31k.js.map +1 -0
  478. package/dist/types/components/attribution/revogr-attribution.d.ts +12 -0
  479. package/dist/types/components/clipboard/revogr-clipboard.d.ts +89 -0
  480. package/dist/types/components/data/cell-renderer.d.ts +12 -0
  481. package/dist/types/components/data/column.service.d.ts +65 -0
  482. package/dist/types/components/data/revogr-data.d.ts +132 -0
  483. package/dist/types/components/data/row-highlight.plugin.d.ts +10 -0
  484. package/dist/types/components/data/row-renderer.d.ts +13 -0
  485. package/dist/types/components/editors/edit.utils.d.ts +3 -0
  486. package/dist/types/components/editors/revogr-edit.d.ts +63 -0
  487. package/dist/types/components/editors/text-editor.d.ts +43 -0
  488. package/dist/types/components/extra/revogr-extra.d.ts +38 -0
  489. package/dist/types/components/grouping-overlay/revogr-grouping-overlay.d.ts +71 -0
  490. package/dist/types/components/header/header-cell-renderer.d.ts +10 -0
  491. package/dist/types/components/header/header-group-renderer.d.ts +17 -0
  492. package/dist/types/components/header/header-renderer.d.ts +24 -0
  493. package/dist/types/components/header/resizable.directive.d.ts +60 -0
  494. package/dist/types/components/header/resizable.element.d.ts +5 -0
  495. package/dist/types/components/header/revogr-header-unified.d.ts +168 -0
  496. package/dist/types/components/header/revogr-header.d.ts +131 -0
  497. package/dist/types/components/order/order-renderer.d.ts +29 -0
  498. package/dist/types/components/order/order-row.service.d.ts +27 -0
  499. package/dist/types/components/order/revogr-order-editor.d.ts +56 -0
  500. package/dist/types/components/overlay/autofill.service.d.ts +80 -0
  501. package/dist/types/components/overlay/keyboard.service.d.ts +29 -0
  502. package/dist/types/components/overlay/revogr-overlay-selection.d.ts +295 -0
  503. package/dist/types/components/overlay/selection.utils.d.ts +47 -0
  504. package/dist/types/components/revoGrid/grid.helpers.d.ts +17 -0
  505. package/dist/types/components/revoGrid/plugin.service.d.ts +37 -0
  506. package/dist/types/components/revoGrid/revo-grid.d.ts +801 -0
  507. package/dist/types/components/revoGrid/viewport.helpers.d.ts +42 -0
  508. package/dist/types/components/revoGrid/viewport.resize.service.d.ts +17 -0
  509. package/dist/types/components/revoGrid/viewport.scrolling.service.d.ts +24 -0
  510. package/dist/types/components/revoGrid/viewport.service.d.ts +59 -0
  511. package/dist/types/components/rowHeaders/revogr-row-headers.d.ts +51 -0
  512. package/dist/types/components/rowHeaders/row-header-render.d.ts +9 -0
  513. package/dist/types/components/scroll/revogr-viewport-scroll.d.ts +159 -0
  514. package/dist/types/components/scrollable/autohide-scroll.plugin.d.ts +22 -0
  515. package/dist/types/components/scrollable/revogr-scroll-virtual.d.ts +49 -0
  516. package/dist/types/components/selectionFocus/revogr-focus.d.ts +63 -0
  517. package/dist/types/components/selectionTempRange/revogr-temp-range.d.ts +28 -0
  518. package/dist/types/components/vnode/vnode-converter.d.ts +19 -0
  519. package/dist/types/components/vnode/vnode.utils.d.ts +9 -0
  520. package/dist/types/components.d.ts +2928 -0
  521. package/dist/types/global/global.d.ts +1 -0
  522. package/dist/types/index.d.ts +9 -0
  523. package/dist/types/plugins/add-rows-on-paste.plugin.d.ts +14 -0
  524. package/dist/types/plugins/base.plugin.d.ts +51 -0
  525. package/dist/types/plugins/column-hide.plugin.d.ts +110 -0
  526. package/dist/types/plugins/column-manage.plugin.d.ts +225 -0
  527. package/dist/types/plugins/column-stretch.plugin.d.ts +159 -0
  528. package/dist/types/plugins/column.auto-size.plugin.d.ts +69 -0
  529. package/dist/types/plugins/column.stretch.plugin.d.ts +20 -0
  530. package/dist/types/plugins/customColumnDrag/column-move.helper.d.ts +71 -0
  531. package/dist/types/plugins/customColumnDrag/custom-column-drag.plugin.d.ts +35 -0
  532. package/dist/types/plugins/customColumnDrag/drag.handler.d.ts +112 -0
  533. package/dist/types/plugins/customColumnDrag/example.d.ts +31 -0
  534. package/dist/types/plugins/customColumnDrag/index.d.ts +5 -0
  535. package/dist/types/plugins/customColumnDrag/types.d.ts +46 -0
  536. package/dist/types/plugins/dispatcher.d.ts +20 -0
  537. package/dist/types/plugins/enhanced-scrollbar.plugin.d.ts +76 -0
  538. package/dist/types/plugins/export/csv.d.ts +9 -0
  539. package/dist/types/plugins/export/export.plugin.d.ts +24 -0
  540. package/dist/types/plugins/export/types.d.ts +23 -0
  541. package/dist/types/plugins/filter/conditions/equal.d.ts +4 -0
  542. package/dist/types/plugins/filter/conditions/number/greaterThan.d.ts +3 -0
  543. package/dist/types/plugins/filter/conditions/number/greaterThanOrEqual.d.ts +3 -0
  544. package/dist/types/plugins/filter/conditions/number/lessThan.d.ts +3 -0
  545. package/dist/types/plugins/filter/conditions/number/lessThanOrEqual.d.ts +3 -0
  546. package/dist/types/plugins/filter/conditions/set.d.ts +4 -0
  547. package/dist/types/plugins/filter/conditions/string/beginswith.d.ts +3 -0
  548. package/dist/types/plugins/filter/conditions/string/contains.d.ts +4 -0
  549. package/dist/types/plugins/filter/filter.button.d.ts +14 -0
  550. package/dist/types/plugins/filter/filter.indexed.d.ts +20 -0
  551. package/dist/types/plugins/filter/filter.panel.d.ts +53 -0
  552. package/dist/types/plugins/filter/filter.plugin.d.ts +73 -0
  553. package/dist/types/plugins/filter/filter.types.d.ts +129 -0
  554. package/dist/types/plugins/grid-setup.d.ts +65 -0
  555. package/dist/types/plugins/groupingRow/grouping.const.d.ts +14 -0
  556. package/dist/types/plugins/groupingRow/grouping.row.expand.service.d.ts +15 -0
  557. package/dist/types/plugins/groupingRow/grouping.row.plugin.d.ts +39 -0
  558. package/dist/types/plugins/groupingRow/grouping.row.renderer.d.ts +6 -0
  559. package/dist/types/plugins/groupingRow/grouping.row.types.d.ts +144 -0
  560. package/dist/types/plugins/groupingRow/grouping.service.d.ts +36 -0
  561. package/dist/types/plugins/groupingRow/grouping.trimmed.service.d.ts +10 -0
  562. package/dist/types/plugins/index.d.ts +22 -0
  563. package/dist/types/plugins/manual-focus.plugin.d.ts +113 -0
  564. package/dist/types/plugins/moveColumn/column.drag.plugin.d.ts +50 -0
  565. package/dist/types/plugins/moveColumn/order-column.handler.d.ts +16 -0
  566. package/dist/types/plugins/pin-shadow.plugin.d.ts +73 -0
  567. package/dist/types/plugins/resize-indicator.plugin.d.ts +71 -0
  568. package/dist/types/plugins/row-select-plugin-2026228.d.ts +367 -0
  569. package/dist/types/plugins/row-select.plugin.d.ts +378 -0
  570. package/dist/types/plugins/rtl/rtl.plugin.d.ts +37 -0
  571. package/dist/types/plugins/sorting/sorting.func.d.ts +9 -0
  572. package/dist/types/plugins/sorting/sorting.plugin.d.ts +48 -0
  573. package/dist/types/plugins/sorting/sorting.sign.d.ts +6 -0
  574. package/dist/types/plugins/sorting/sorting.types.d.ts +14 -0
  575. package/dist/types/plugins/tree-data.plugin.d.ts +56 -0
  576. package/dist/types/plugins/wcag/index.d.ts +26 -0
  577. package/dist/types/services/cell.helpers.d.ts +2 -0
  578. package/dist/types/services/column.data.provider.d.ts +27 -0
  579. package/dist/types/services/data.provider.d.ts +36 -0
  580. package/dist/types/services/dimension.provider.d.ts +71 -0
  581. package/dist/types/services/local.scroll.service.d.ts +36 -0
  582. package/dist/types/services/local.scroll.timer.d.ts +32 -0
  583. package/dist/types/services/selection.store.connector.d.ts +74 -0
  584. package/dist/types/services/viewport.provider.d.ts +9 -0
  585. package/dist/types/stencil-public-runtime.d.ts +1709 -0
  586. package/dist/types/store/dataSource/data.proxy.d.ts +14 -0
  587. package/dist/types/store/dataSource/data.store.d.ts +77 -0
  588. package/dist/types/store/dataSource/index.d.ts +3 -0
  589. package/dist/types/store/dataSource/trimmed.plugin.d.ts +12 -0
  590. package/dist/types/store/dimension/dimension.helpers.d.ts +24 -0
  591. package/dist/types/store/dimension/dimension.recalculate.plugin.d.ts +15 -0
  592. package/dist/types/store/dimension/dimension.store.d.ts +34 -0
  593. package/dist/types/store/dimension/dimension.trim.plugin.d.ts +13 -0
  594. package/dist/types/store/dimension/index.d.ts +2 -0
  595. package/dist/types/store/index.d.ts +8 -0
  596. package/dist/types/store/selection/index.d.ts +2 -0
  597. package/dist/types/store/selection/selection.helpers.d.ts +5 -0
  598. package/dist/types/store/selection/selection.store.d.ts +22 -0
  599. package/dist/types/store/vp/index.d.ts +7 -0
  600. package/dist/types/store/vp/viewport.helpers.d.ts +54 -0
  601. package/dist/types/store/vp/viewport.store.d.ts +38 -0
  602. package/dist/types/themeManager/theme.compact.d.ts +4 -0
  603. package/dist/types/themeManager/theme.default.d.ts +4 -0
  604. package/dist/types/themeManager/theme.material.d.ts +4 -0
  605. package/dist/types/themeManager/theme.service.d.ts +13 -0
  606. package/dist/types/types/dimension.d.ts +8 -0
  607. package/dist/types/types/events.d.ts +2 -0
  608. package/dist/types/types/index.d.ts +8 -0
  609. package/dist/types/types/interfaces.d.ts +795 -0
  610. package/dist/types/types/plugin.d.ts +9 -0
  611. package/dist/types/types/plugin.types.d.ts +48 -0
  612. package/dist/types/types/selection.d.ts +178 -0
  613. package/dist/types/types/theme.d.ts +7 -0
  614. package/dist/types/types/viewport.interfaces.d.ts +45 -0
  615. package/dist/types/utils/batchGroupCollapse.d.ts +77 -0
  616. package/dist/types/utils/browser.d.ts +1 -0
  617. package/dist/types/utils/cell-template-helper.d.ts +74 -0
  618. package/dist/types/utils/closest.polifill.d.ts +0 -0
  619. package/dist/types/utils/column.utils.d.ts +110 -0
  620. package/dist/types/utils/consts.d.ts +22 -0
  621. package/dist/types/utils/events.d.ts +5 -0
  622. package/dist/types/utils/header.utils.d.ts +2 -0
  623. package/dist/types/utils/index.d.ts +32 -0
  624. package/dist/types/utils/key.codes.d.ts +73 -0
  625. package/dist/types/utils/key.utils.d.ts +12 -0
  626. package/dist/types/utils/mobile.d.ts +1 -0
  627. package/dist/types/utils/platform.d.ts +4 -0
  628. package/dist/types/utils/row-header-utils.d.ts +2 -0
  629. package/dist/types/utils/store.types.d.ts +97 -0
  630. package/dist/types/utils/store.utils.d.ts +10 -0
  631. package/hydrate/index.d.ts +273 -0
  632. package/hydrate/index.js +39851 -0
  633. package/hydrate/index.mjs +39843 -0
  634. package/hydrate/package.json +12 -0
  635. package/loader/cdn.js +4 -0
  636. package/loader/index.cjs.js +4 -0
  637. package/loader/index.d.ts +24 -0
  638. package/loader/index.es2017.js +4 -0
  639. package/loader/index.js +5 -0
  640. package/package.json +149 -0
  641. package/readme.md +303 -0
  642. package/standalone/column.service.js +1110 -0
  643. package/standalone/column.service.js.map +1 -0
  644. package/standalone/consts.js +30 -0
  645. package/standalone/consts.js.map +1 -0
  646. package/standalone/data.store.js +3101 -0
  647. package/standalone/data.store.js.map +1 -0
  648. package/standalone/debounce.js +215 -0
  649. package/standalone/debounce.js.map +1 -0
  650. package/standalone/dimension.helpers.js +229 -0
  651. package/standalone/dimension.helpers.js.map +1 -0
  652. package/standalone/filter.button.js +39 -0
  653. package/standalone/filter.button.js.map +1 -0
  654. package/standalone/grouping.service.js +234 -0
  655. package/standalone/grouping.service.js.map +1 -0
  656. package/standalone/header-group-renderer.js +634 -0
  657. package/standalone/header-group-renderer.js.map +1 -0
  658. package/standalone/index.d.ts +72 -0
  659. package/standalone/index.js +6272 -0
  660. package/standalone/index.js.map +1 -0
  661. package/standalone/index2.js +131 -0
  662. package/standalone/index2.js.map +1 -0
  663. package/standalone/local.scroll.timer.js +222 -0
  664. package/standalone/local.scroll.timer.js.map +1 -0
  665. package/standalone/platform.js +90 -0
  666. package/standalone/platform.js.map +1 -0
  667. package/standalone/revo-grid.d.ts +11 -0
  668. package/standalone/revo-grid.js +8734 -0
  669. package/standalone/revo-grid.js.map +1 -0
  670. package/standalone/revogr-attribution.d.ts +11 -0
  671. package/standalone/revogr-attribution.js +12 -0
  672. package/standalone/revogr-attribution.js.map +1 -0
  673. package/standalone/revogr-attribution2.js +32 -0
  674. package/standalone/revogr-attribution2.js.map +1 -0
  675. package/standalone/revogr-clipboard.d.ts +11 -0
  676. package/standalone/revogr-clipboard.js +12 -0
  677. package/standalone/revogr-clipboard.js.map +1 -0
  678. package/standalone/revogr-clipboard2.js +179 -0
  679. package/standalone/revogr-clipboard2.js.map +1 -0
  680. package/standalone/revogr-data.d.ts +11 -0
  681. package/standalone/revogr-data.js +12 -0
  682. package/standalone/revogr-data.js.map +1 -0
  683. package/standalone/revogr-data2.js +503 -0
  684. package/standalone/revogr-data2.js.map +1 -0
  685. package/standalone/revogr-edit.d.ts +11 -0
  686. package/standalone/revogr-edit.js +12 -0
  687. package/standalone/revogr-edit.js.map +1 -0
  688. package/standalone/revogr-edit2.js +330 -0
  689. package/standalone/revogr-edit2.js.map +1 -0
  690. package/standalone/revogr-extra.d.ts +11 -0
  691. package/standalone/revogr-extra.js +12 -0
  692. package/standalone/revogr-extra.js.map +1 -0
  693. package/standalone/revogr-extra2.js +73 -0
  694. package/standalone/revogr-extra2.js.map +1 -0
  695. package/standalone/revogr-filter-panel.d.ts +11 -0
  696. package/standalone/revogr-filter-panel.js +411 -0
  697. package/standalone/revogr-filter-panel.js.map +1 -0
  698. package/standalone/revogr-focus.d.ts +11 -0
  699. package/standalone/revogr-focus.js +12 -0
  700. package/standalone/revogr-focus.js.map +1 -0
  701. package/standalone/revogr-focus2.js +119 -0
  702. package/standalone/revogr-focus2.js.map +1 -0
  703. package/standalone/revogr-grouping-overlay.d.ts +11 -0
  704. package/standalone/revogr-grouping-overlay.js +12 -0
  705. package/standalone/revogr-grouping-overlay.js.map +1 -0
  706. package/standalone/revogr-grouping-overlay2.js +356 -0
  707. package/standalone/revogr-grouping-overlay2.js.map +1 -0
  708. package/standalone/revogr-header-unified.d.ts +11 -0
  709. package/standalone/revogr-header-unified.js +12 -0
  710. package/standalone/revogr-header-unified.js.map +1 -0
  711. package/standalone/revogr-header-unified2.js +781 -0
  712. package/standalone/revogr-header-unified2.js.map +1 -0
  713. package/standalone/revogr-header.d.ts +11 -0
  714. package/standalone/revogr-header.js +12 -0
  715. package/standalone/revogr-header.js.map +1 -0
  716. package/standalone/revogr-header2.js +343 -0
  717. package/standalone/revogr-header2.js.map +1 -0
  718. package/standalone/revogr-order-editor.d.ts +11 -0
  719. package/standalone/revogr-order-editor.js +12 -0
  720. package/standalone/revogr-order-editor.js.map +1 -0
  721. package/standalone/revogr-order-editor2.js +201 -0
  722. package/standalone/revogr-order-editor2.js.map +1 -0
  723. package/standalone/revogr-overlay-selection.d.ts +11 -0
  724. package/standalone/revogr-overlay-selection.js +12 -0
  725. package/standalone/revogr-overlay-selection.js.map +1 -0
  726. package/standalone/revogr-overlay-selection2.js +1068 -0
  727. package/standalone/revogr-overlay-selection2.js.map +1 -0
  728. package/standalone/revogr-row-headers.d.ts +11 -0
  729. package/standalone/revogr-row-headers.js +12 -0
  730. package/standalone/revogr-row-headers.js.map +1 -0
  731. package/standalone/revogr-row-headers2.js +625 -0
  732. package/standalone/revogr-row-headers2.js.map +1 -0
  733. package/standalone/revogr-scroll-virtual.d.ts +11 -0
  734. package/standalone/revogr-scroll-virtual.js +12 -0
  735. package/standalone/revogr-scroll-virtual.js.map +1 -0
  736. package/standalone/revogr-scroll-virtual2.js +235 -0
  737. package/standalone/revogr-scroll-virtual2.js.map +1 -0
  738. package/standalone/revogr-temp-range.d.ts +11 -0
  739. package/standalone/revogr-temp-range.js +12 -0
  740. package/standalone/revogr-temp-range.js.map +1 -0
  741. package/standalone/revogr-temp-range2.js +93 -0
  742. package/standalone/revogr-temp-range2.js.map +1 -0
  743. package/standalone/revogr-viewport-scroll.d.ts +11 -0
  744. package/standalone/revogr-viewport-scroll.js +12 -0
  745. package/standalone/revogr-viewport-scroll.js.map +1 -0
  746. package/standalone/revogr-viewport-scroll2.js +761 -0
  747. package/standalone/revogr-viewport-scroll2.js.map +1 -0
  748. package/standalone/row-renderer.js +41 -0
  749. package/standalone/row-renderer.js.map +1 -0
  750. package/standalone/selection.utils.js +179 -0
  751. package/standalone/selection.utils.js.map +1 -0
  752. package/standalone/throttle.js +75 -0
  753. package/standalone/throttle.js.map +1 -0
  754. package/standalone/toNumber.js +282 -0
  755. package/standalone/toNumber.js.map +1 -0
  756. package/standalone/vnode-converter.js +46 -0
  757. package/standalone/vnode-converter.js.map +1 -0
  758. package/standalone/vnode-html.d.ts +11 -0
  759. package/standalone/vnode-html.js +12 -0
  760. package/standalone/vnode-html.js.map +1 -0
@@ -0,0 +1,1218 @@
1
+ /*!
2
+ * Built by Revolist OU ❤️
3
+ */
4
+ /**
5
+ * 列管理插件
6
+ * 实现表格列的隐藏、显示、冻结、插入、删除等功能
7
+ */
8
+ import { BasePlugin } from "./base.plugin";
9
+ import { ColumnStretchPlugin } from "./column-stretch.plugin";
10
+ import { convertCollectionToColumns, getStretchColumnOptions, mergeAdjacentGroups } from "../utils/column.utils";
11
+ /**
12
+ * 深拷贝列配置(保留函数属性)
13
+ */
14
+ function deepCloneColumns(cols) {
15
+ return cols.map(col => {
16
+ const colAny = col;
17
+ if (colAny.children) {
18
+ return Object.assign(Object.assign({}, col), { children: deepCloneColumns(colAny.children) });
19
+ }
20
+ return Object.assign({}, col);
21
+ });
22
+ }
23
+ export class ColumnManagePlugin extends BasePlugin {
24
+ constructor(revogrid, providers, config) {
25
+ super(revogrid, providers);
26
+ this.hiddenProps = new Set();
27
+ this.originalColumns = null;
28
+ this.uniqueId = undefined;
29
+ // 优先使用传入的 config,否则从 additionalData 读取
30
+ const additionalData = revogrid.additionalData || {};
31
+ this.config = config || additionalData.columnManage || {};
32
+ this.autoDetectHiddenColumns(additionalData.allColumns);
33
+ }
34
+ /**
35
+ * 获取当前保存的 uniqueId
36
+ */
37
+ getUniqueId() {
38
+ return this.uniqueId;
39
+ }
40
+ /**
41
+ * 自动检测隐藏的列(通过对比 allColumns 和当前 columns)
42
+ */
43
+ autoDetectHiddenColumns(allColumns) {
44
+ // 获取当前可见列的 prop 集合
45
+ const visibleProps = new Set();
46
+ const collectVisibleProps = (cols) => {
47
+ cols.forEach(col => {
48
+ const colAny = col;
49
+ if (colAny.children) {
50
+ collectVisibleProps(colAny.children);
51
+ }
52
+ else if (col.prop !== undefined) {
53
+ visibleProps.add(col.prop);
54
+ }
55
+ });
56
+ };
57
+ collectVisibleProps(this.revogrid.columns);
58
+ // 找出 allColumns 中不在 visibleProps 中的列
59
+ allColumns.forEach(col => {
60
+ if (col.prop !== undefined && !visibleProps.has(col.prop)) {
61
+ this.hiddenProps.add(String(col.prop));
62
+ }
63
+ });
64
+ }
65
+ // ==================== 隐藏/显示列 ====================
66
+ /**
67
+ * 隐藏列
68
+ * 逻辑:
69
+ * 准备: 当前列配置
70
+ * 1. 遍历要隐藏的列
71
+ * 2. 查找列的位置
72
+ * - 是分组下的列: 从分组中移除该列,如果分组为空则删除分组
73
+ * - 是普通列: 从列数组中移除该列
74
+ * 3. 标记列为隐藏
75
+ */
76
+ hideColumns(columns) {
77
+ var _a, _b;
78
+ const props = this.normalizeColumnConfig(columns);
79
+ // 准备:获取当前列配置
80
+ const stretchPlugin = this.providers.plugins.getByClass(ColumnStretchPlugin);
81
+ const options = getStretchColumnOptions(this.providers, stretchPlugin);
82
+ const currentColumns = convertCollectionToColumns(this.providers, options);
83
+ // 遍历要隐藏的列
84
+ props.forEach(prop => {
85
+ // 查找列的位置和分组信息
86
+ let found = false;
87
+ for (let i = currentColumns.length - 1; i >= 0; i--) {
88
+ const col = currentColumns[i];
89
+ if (col.children) {
90
+ // 当前是分组
91
+ const childIdx = col.children.findIndex((child) => child.prop === prop);
92
+ if (childIdx !== -1) {
93
+ // 从分组中移除该列
94
+ col.children.splice(childIdx, 1);
95
+ // 如果分组为空,删除分组
96
+ if (col.children.length === 0) {
97
+ currentColumns.splice(i, 1);
98
+ }
99
+ found = true;
100
+ break;
101
+ }
102
+ }
103
+ else if (col.prop === prop) {
104
+ // 是普通列,从列数组中移除
105
+ currentColumns.splice(i, 1);
106
+ found = true;
107
+ break;
108
+ }
109
+ }
110
+ if (found) {
111
+ // 标记列为隐藏
112
+ this.hiddenProps.add(prop);
113
+ }
114
+ });
115
+ // 更新列配置
116
+ this.revogrid.columns = [...currentColumns];
117
+ // 触发隐藏变化回调
118
+ (_b = (_a = this.config).onHiddenChange) === null || _b === void 0 ? void 0 : _b.call(_a, this.getHiddenColumns(), props);
119
+ }
120
+ /**
121
+ * 获取当前隐藏的列
122
+ */
123
+ getHiddenColumns() {
124
+ return Array.from(this.hiddenProps);
125
+ }
126
+ /**
127
+ * 检查列是否隐藏
128
+ */
129
+ isColumnHidden(prop) {
130
+ return this.hiddenProps.has(prop);
131
+ }
132
+ // ==================== 冻结列 ====================
133
+ /**
134
+ * 设置列冻结
135
+ * @param prop 列的 prop
136
+ * @param pin 冻结类型:'colPinStart' 左冻结,'colPinEnd' 右冻结,undefined 取消冻结
137
+ * 冻结逻辑:
138
+ * pin值为:
139
+ * - 'colPinStart': 列冻结到左侧,放到左侧冻结的最后一个
140
+ * - 'colPinEnd': 列冻结到右侧,放到右侧冻结的第一个
141
+ * - undefined: 取消冻结。如果之前是左侧冻结,那就放在未冻结的第一个;如果之前是右侧冻结,那就放在未冻结的最后一个
142
+ */
143
+ setColumnPin(prop, pin) {
144
+ var _a, _b;
145
+ // 准备:获取当前列配置
146
+ const stretchPlugin = this.providers.plugins.getByClass(ColumnStretchPlugin);
147
+ const options = getStretchColumnOptions(this.providers, stretchPlugin);
148
+ const columns = convertCollectionToColumns(this.providers, options);
149
+ // 查找列的位置和分组信息
150
+ const { groupIndex: columnGroupIndex, childIndex: columnChildIndex, group: columnGroup, columnData } = this.findColumnInColumns(columns, prop);
151
+ if (!columnData) {
152
+ console.warn(`[ColumnManagePlugin] 找不到列 "${prop}"`);
153
+ return false;
154
+ }
155
+ // 获取当前列的冻结状态(从 columns 中获取)
156
+ const currentPin = columnData.pin;
157
+ // 如果冻结状态没有变化,直接返回
158
+ if (currentPin === pin) {
159
+ return true;
160
+ }
161
+ // 如果是分组中的子列,需要特殊处理
162
+ if (columnGroup && columnChildIndex !== -1) {
163
+ const groupName = columnGroup.name;
164
+ // 从编组中移除该列
165
+ const removed = columnGroup.children.splice(columnChildIndex, 1)[0];
166
+ // 如果编组中没有列了,删除编组
167
+ if (columnGroup.children.length === 0) {
168
+ columns.splice(columnGroupIndex, 1);
169
+ }
170
+ // 设置列的 pin 状态
171
+ if (pin) {
172
+ removed.pin = pin;
173
+ }
174
+ else {
175
+ delete removed.pin;
176
+ }
177
+ // 找到插入位置(传入 currentPin 用于判断取消冻结时的位置)
178
+ const insertIndex = this.findInsertPositionForPinInColumns(columns, pin, currentPin);
179
+ // 创建新编组,插入到目标位置
180
+ const newGroup = {
181
+ name: groupName,
182
+ children: [removed],
183
+ };
184
+ if (pin) {
185
+ newGroup.pin = pin;
186
+ }
187
+ columns.splice(insertIndex, 0, newGroup);
188
+ }
189
+ else {
190
+ // 移除单个列
191
+ const removed = columns.splice(columnGroupIndex, 1)[0];
192
+ // 设置新的 pin 状态
193
+ if (pin) {
194
+ removed.pin = pin;
195
+ }
196
+ else {
197
+ delete removed.pin;
198
+ }
199
+ // 找到插入位置(传入 currentPin 用于判断取消冻结时的位置)
200
+ const insertIndex = this.findInsertPositionForPinInColumns(columns, pin, currentPin);
201
+ // 插入到新位置
202
+ columns.splice(insertIndex, 0, removed);
203
+ }
204
+ // 合并相邻的同名同pin编组
205
+ mergeAdjacentGroups(columns);
206
+ // 更新列配置
207
+ this.revogrid.columns = [...columns];
208
+ (_b = (_a = this.config).onPinChange) === null || _b === void 0 ? void 0 : _b.call(_a, prop, pin);
209
+ return true;
210
+ }
211
+ /**
212
+ * 左冻结列
213
+ */
214
+ pinColumnLeft(prop) {
215
+ return this.setColumnPin(prop, 'colPinStart');
216
+ }
217
+ /**
218
+ * 右冻结列
219
+ */
220
+ pinColumnRight(prop) {
221
+ return this.setColumnPin(prop, 'colPinEnd');
222
+ }
223
+ /**
224
+ * 取消列冻结
225
+ */
226
+ unpinColumn(prop) {
227
+ return this.setColumnPin(prop, undefined);
228
+ }
229
+ /**
230
+ * 获取列的冻结状态
231
+ */
232
+ getColumnPin(prop) {
233
+ const cols = this.originalColumns || this.revogrid.columns;
234
+ if (!cols)
235
+ return undefined;
236
+ const col = this.findColumnByProp(cols, prop);
237
+ return col ? col.pin : undefined;
238
+ }
239
+ /**
240
+ * 检查列是否冻结
241
+ */
242
+ isColumnPinned(prop) {
243
+ return !!this.getColumnPin(prop);
244
+ }
245
+ // ==================== 位置调整 ====================
246
+ /**
247
+ * 将隐藏的列显示在指定列的左侧或右侧
248
+ * 逻辑:
249
+ * 准备: additionalData.allColumns、当前是否分组、当前列所属分组数据、目标列数据
250
+ * 1. 是否分组下的列
251
+ * - 是: 获取列在分组下的索引,根据 position 和索引插入目标列数据
252
+ * - 否: 根据 column 获取索引,再根据 position 和索引插入目标列数据
253
+ * 2. 目标列数据的pin继承当前列的pin
254
+ */
255
+ showColumnAt(column, target, position = 'after') {
256
+ var _a, _b;
257
+ // 验证列是否隐藏
258
+ if (!this.hiddenProps.has(column)) {
259
+ console.warn(`[ColumnManagePlugin] 列 "${column}" 未被隐藏`);
260
+ return false;
261
+ }
262
+ // 准备:获取 allColumns
263
+ const additionalData = this.revogrid.additionalData || {};
264
+ const allColumns = additionalData.allColumns;
265
+ if (!allColumns || !Array.isArray(allColumns)) {
266
+ console.warn('[ColumnManagePlugin] 找不到 allColumns');
267
+ return false;
268
+ }
269
+ // 准备:获取目标列数据(要显示的列)
270
+ const targetColumnData = allColumns.find((col) => col.prop === column);
271
+ if (!targetColumnData) {
272
+ console.warn(`[ColumnManagePlugin] 在 allColumns 中找不到列 "${column}"`);
273
+ return false;
274
+ }
275
+ // 准备:获取当前列配置
276
+ const stretchPlugin = this.providers.plugins.getByClass(ColumnStretchPlugin);
277
+ const options = getStretchColumnOptions(this.providers, stretchPlugin);
278
+ const columns = convertCollectionToColumns(this.providers, options);
279
+ // 准备:查找当前列(target)的位置和分组信息
280
+ const { groupIndex: targetGroupIndex, childIndex: targetChildIndex, group: targetGroup, columnData: currentColumn } = this.findColumnInColumns(columns, target);
281
+ if (!currentColumn) {
282
+ console.warn(`[ColumnManagePlugin] 找不到目标列 "${target}"`);
283
+ return false;
284
+ }
285
+ // 创建要插入的列数据(继承当前列的 pin)
286
+ const insertColumn = Object.assign({}, targetColumnData);
287
+ if (currentColumn.pin) {
288
+ insertColumn.pin = currentColumn.pin;
289
+ }
290
+ else {
291
+ delete insertColumn.pin;
292
+ }
293
+ // 1. 判断是否分组下的列
294
+ if (targetGroup && targetChildIndex !== -1) {
295
+ // 是:获取列在分组下的索引,根据 position 和索引插入目标列数据
296
+ const insertChildIndex = position === 'before' ? targetChildIndex : targetChildIndex + 1;
297
+ targetGroup.children.splice(insertChildIndex, 0, insertColumn);
298
+ }
299
+ else {
300
+ // 否:根据 column 获取索引,再根据 position 和索引插入目标列数据
301
+ const insertIndex = position === 'before' ? targetGroupIndex : targetGroupIndex + 1;
302
+ columns.splice(insertIndex, 0, insertColumn);
303
+ }
304
+ // 更新列配置
305
+ this.revogrid.columns = [...columns];
306
+ this.hiddenProps.delete(column);
307
+ // 触发隐藏变化回调
308
+ (_b = (_a = this.config).onHiddenChange) === null || _b === void 0 ? void 0 : _b.call(_a, this.getHiddenColumns(), [column]);
309
+ return true;
310
+ }
311
+ /**
312
+ * 批量将隐藏的列显示在指定列的左侧或右侧
313
+ */
314
+ showColumnsAt(columns, target, position = 'after') {
315
+ const orderedColumns = position === 'after' ? [...columns].reverse() : columns;
316
+ let success = true;
317
+ for (const col of orderedColumns) {
318
+ if (!this.showColumnAt(col, target, position)) {
319
+ success = false;
320
+ }
321
+ }
322
+ return success;
323
+ }
324
+ /**
325
+ * 替换列:将可见列隐藏,同时将隐藏列显示在可见列的位置
326
+ * @param hiddenColumn 当前隐藏的列(要显示)
327
+ * @param visibleColumn 当前可见的列(要隐藏)
328
+ * 逻辑:
329
+ * 准备: additionalData.allColumns、当前列配置、可见列位置和分组信息、隐藏列数据
330
+ * 1. 查找可见列的位置
331
+ * - 是分组下的列: 获取分组和子列索引,替换该位置的列
332
+ * - 是普通列: 获取列索引,替换该位置的列
333
+ * 2. 替换列数据的pin和size继承可见列的pin和size
334
+ * 3. 将可见列标记为隐藏
335
+ */
336
+ replaceColumn(hiddenColumn, visibleColumn) {
337
+ var _a, _b;
338
+ // 验证隐藏列状态
339
+ if (!this.hiddenProps.has(hiddenColumn)) {
340
+ console.warn(`[ColumnManagePlugin] 列 "${hiddenColumn}" 未被隐藏`);
341
+ return false;
342
+ }
343
+ // 验证可见列状态
344
+ if (this.hiddenProps.has(visibleColumn)) {
345
+ console.warn(`[ColumnManagePlugin] 列 "${visibleColumn}" 已被隐藏`);
346
+ return false;
347
+ }
348
+ // 准备:获取 allColumns
349
+ const additionalData = this.revogrid.additionalData || {};
350
+ const allColumns = additionalData.allColumns;
351
+ if (!allColumns || !Array.isArray(allColumns)) {
352
+ console.warn('[ColumnManagePlugin] 找不到 allColumns');
353
+ return false;
354
+ }
355
+ // 准备:获取隐藏列数据(要显示的列)
356
+ const hiddenColumnData = allColumns.find((col) => col.prop === hiddenColumn);
357
+ if (!hiddenColumnData) {
358
+ console.warn(`[ColumnManagePlugin] 在 allColumns 中找不到列 "${hiddenColumn}"`);
359
+ return false;
360
+ }
361
+ // 准备:获取当前列配置
362
+ const stretchPlugin = this.providers.plugins.getByClass(ColumnStretchPlugin);
363
+ const options = getStretchColumnOptions(this.providers, stretchPlugin);
364
+ const columns = convertCollectionToColumns(this.providers, options);
365
+ // 准备:查找可见列的位置和分组信息
366
+ const { groupIndex: visibleGroupIndex, childIndex: visibleChildIndex, group: visibleGroup, columnData: visibleColumnData } = this.findColumnInColumns(columns, visibleColumn);
367
+ if (!visibleColumnData) {
368
+ console.warn(`[ColumnManagePlugin] 找不到可见列 "${visibleColumn}"`);
369
+ return false;
370
+ }
371
+ // 创建替换列数据(继承可见列的 pin 和 size)
372
+ const replaceColumn = Object.assign({}, hiddenColumnData);
373
+ if (visibleColumnData.pin) {
374
+ replaceColumn.pin = visibleColumnData.pin;
375
+ }
376
+ else {
377
+ delete replaceColumn.pin;
378
+ }
379
+ // 1. 判断是否分组下的列
380
+ if (visibleGroup && visibleChildIndex !== -1) {
381
+ // 是:替换分组中的列
382
+ visibleGroup.children.splice(visibleChildIndex, 1, replaceColumn);
383
+ }
384
+ else {
385
+ // 否:替换普通列
386
+ columns.splice(visibleGroupIndex, 1, replaceColumn);
387
+ }
388
+ // 更新列配置
389
+ this.revogrid.columns = [...columns];
390
+ // 标记可见列为隐藏,移除隐藏列的隐藏标记
391
+ this.hiddenProps.add(visibleColumn);
392
+ this.hiddenProps.delete(hiddenColumn);
393
+ // 触发隐藏变化回调
394
+ (_b = (_a = this.config).onHiddenChange) === null || _b === void 0 ? void 0 : _b.call(_a, this.getHiddenColumns(), [hiddenColumn, visibleColumn]);
395
+ // 触发列替换事件
396
+ this.emit('columnreplaced', {
397
+ hiddenColumn,
398
+ visibleColumn,
399
+ hiddenColumns: this.getHiddenColumns(),
400
+ });
401
+ return true;
402
+ }
403
+ /**
404
+ * 导出当前列配置(用于保存到接口)
405
+ * 只导出可见列(从 grid.columns 获取,包含拖拽后的新顺序和实际宽度)
406
+ * 返回列配置数组,包含列顺序、冻结状态、宽度等
407
+ */
408
+ exportColumnConfig() {
409
+ // 1. 获取当前可见列(包含拖拽后的新顺序)
410
+ const columns = this.revogrid.columns;
411
+ if (!columns || columns.length === 0) {
412
+ return [];
413
+ }
414
+ // 2. 获取当前列宽度(从 DOM 中读取实际宽度)
415
+ const sizeMap = this.buildSizeMap(columns);
416
+ // 3. 获取 ColumnStretchPlugin 实例
417
+ const stretchPlugin = this.providers.plugins.getByClass(ColumnStretchPlugin);
418
+ // 4. 获取自动宽度列配置
419
+ const stretchOptions = getStretchColumnOptions(this.providers, stretchPlugin);
420
+ const stretchColumnProps = (stretchOptions === null || stretchOptions === void 0 ? void 0 : stretchOptions.stretchColumnProps) || new Set();
421
+ const manuallyResizedProps = (stretchOptions === null || stretchOptions === void 0 ? void 0 : stretchOptions.manuallyResizedProps) || new Set();
422
+ const result = [];
423
+ // 构建单列配置
424
+ const buildColumnItem = (col, parentPin) => {
425
+ const prop = col.prop;
426
+ const item = { prop };
427
+ // 判断是否是自动宽度列
428
+ const isStretchColumn = stretchColumnProps.has(prop);
429
+ if (isStretchColumn) {
430
+ // 自动宽度列:只有被手动调整过才导出 size
431
+ if (manuallyResizedProps.has(prop)) {
432
+ const size = sizeMap.get(prop) || col.size;
433
+ if (size) {
434
+ item.size = size;
435
+ }
436
+ }
437
+ }
438
+ else {
439
+ // 普通列:直接导出 size
440
+ const size = sizeMap.get(prop) || col.size;
441
+ if (size) {
442
+ item.size = size;
443
+ }
444
+ }
445
+ // 优先使用子列自己的 pin,如果没有则继承父级的 pin
446
+ const colAny = col;
447
+ const pin = colAny.pin || parentPin;
448
+ if (pin) {
449
+ item.pin = pin;
450
+ }
451
+ return item;
452
+ };
453
+ // 导出可见列(只保留 prop、size、pin)
454
+ for (const col of columns) {
455
+ const colAny = col;
456
+ if (colAny.children) {
457
+ // 分组列
458
+ const parentPin = colAny.pin;
459
+ const groupChildren = colAny.children
460
+ .filter((child) => child.prop)
461
+ .map((child) => buildColumnItem(child, parentPin));
462
+ if (groupChildren.length > 0) {
463
+ const groupItem = {
464
+ name: colAny.name,
465
+ children: groupChildren,
466
+ };
467
+ if (parentPin) {
468
+ groupItem.pin = parentPin;
469
+ }
470
+ result.push(groupItem);
471
+ }
472
+ }
473
+ else if (col.prop) {
474
+ // 普通列
475
+ result.push(buildColumnItem(col));
476
+ }
477
+ }
478
+ return result;
479
+ }
480
+ /**
481
+ * 导入列配置(从接口恢复)
482
+ * @param config 列配置数据(与 exportColumnConfig 格式一致)
483
+ * @param uniqueId 可选的唯一标识符,用于防抖
484
+ * @returns Promise<boolean> 返回 Promise,在渲染完成后 resolve
485
+ */
486
+ async importColumnConfig(config, uniqueId) {
487
+ // 保存 uniqueId 到全局变量
488
+ if (uniqueId !== undefined) {
489
+ this.uniqueId = uniqueId;
490
+ }
491
+ // 从 additionalData.allColumns 获取基础列定义
492
+ const additionalData = this.revogrid.additionalData || {};
493
+ const base = additionalData.allColumns;
494
+ if (!base || !Array.isArray(base) || !config || config.length === 0) {
495
+ console.warn('[ColumnManagePlugin] importColumnConfig 失败: 缺少 additionalData.allColumns 或 config');
496
+ return false;
497
+ }
498
+ // 获取 ColumnStretchPlugin 实例和配置
499
+ const stretchPlugin = this.providers.plugins.getByClass(ColumnStretchPlugin);
500
+ const stretchColumnConfig = stretchPlugin === null || stretchPlugin === void 0 ? void 0 : stretchPlugin.getStretchColumnConfig();
501
+ // 确定哪些列是自动宽度列
502
+ const stretchColumnProps = new Set();
503
+ if (stretchColumnConfig && base) {
504
+ if (stretchColumnConfig === 'last') {
505
+ // 最后一列
506
+ const lastCol = base[base.length - 1];
507
+ if (lastCol === null || lastCol === void 0 ? void 0 : lastCol.prop) {
508
+ stretchColumnProps.add(lastCol.prop);
509
+ }
510
+ }
511
+ else if (stretchColumnConfig === 'all') {
512
+ // 所有列
513
+ base.forEach((col) => {
514
+ if (col.prop) {
515
+ stretchColumnProps.add(col.prop);
516
+ }
517
+ });
518
+ }
519
+ else if (typeof stretchColumnConfig === 'number') {
520
+ // 指定索引的列
521
+ const col = base[stretchColumnConfig];
522
+ if (col === null || col === void 0 ? void 0 : col.prop) {
523
+ stretchColumnProps.add(col.prop);
524
+ }
525
+ }
526
+ else if (typeof stretchColumnConfig === 'string') {
527
+ // 指定 prop 的列
528
+ stretchColumnProps.add(stretchColumnConfig);
529
+ }
530
+ }
531
+ // 构建 prop -> 基础列配置 的映射
532
+ const baseColMap = new Map();
533
+ base.forEach((col) => {
534
+ if (col.prop) {
535
+ baseColMap.set(col.prop, col);
536
+ }
537
+ });
538
+ const newColumns = [];
539
+ this.hiddenProps.clear();
540
+ // 收集配置中的所有 prop,用于标记隐藏列
541
+ const visibleProps = new Set();
542
+ const collectVisibleProps = (items) => {
543
+ for (const item of items) {
544
+ const itemAny = item;
545
+ if (itemAny.children) {
546
+ itemAny.children.forEach((child) => {
547
+ visibleProps.add(child.prop);
548
+ });
549
+ }
550
+ else {
551
+ visibleProps.add(item.prop);
552
+ }
553
+ }
554
+ };
555
+ collectVisibleProps(config);
556
+ // 标记所有不在配置中的列为隐藏
557
+ baseColMap.forEach((_, prop) => {
558
+ if (!visibleProps.has(prop)) {
559
+ this.hiddenProps.add(prop);
560
+ }
561
+ });
562
+ // 处理列配置并更新 ColumnStretchPlugin 的 manuallyResizedColumns
563
+ const processColumn = (colItem, baseCol) => {
564
+ const isStretchColumn = stretchColumnProps.has(colItem.prop);
565
+ const newCol = Object.assign({}, baseCol);
566
+ if (isStretchColumn) {
567
+ if (colItem.size) {
568
+ newCol.size = colItem.size;
569
+ stretchPlugin === null || stretchPlugin === void 0 ? void 0 : stretchPlugin.markAsManuallyResized(colItem.prop);
570
+ }
571
+ else {
572
+ // 完全不设置 size,让 ColumnStretchPlugin 自动计算
573
+ delete newCol.size;
574
+ stretchPlugin === null || stretchPlugin === void 0 ? void 0 : stretchPlugin.unmarkAsManuallyResized(colItem.prop);
575
+ }
576
+ }
577
+ else {
578
+ newCol.size = colItem.size || baseCol.size;
579
+ }
580
+ return newCol;
581
+ };
582
+ for (const item of config) {
583
+ const itemAny = item;
584
+ if (itemAny.children) {
585
+ // 分组列
586
+ const groupChildren = [];
587
+ for (const child of itemAny.children) {
588
+ const baseCol = baseColMap.get(child.prop);
589
+ if (!baseCol)
590
+ continue;
591
+ const newCol = processColumn(child, baseCol);
592
+ // 优先使用子列的 pin,如果没有则使用分组的 pin
593
+ const pin = child.pin || itemAny.pin;
594
+ if (pin) {
595
+ newCol.pin = pin;
596
+ }
597
+ else {
598
+ delete newCol.pin;
599
+ }
600
+ groupChildren.push(newCol);
601
+ }
602
+ if (groupChildren.length > 0) {
603
+ const groupCol = {
604
+ name: itemAny.name,
605
+ children: groupChildren,
606
+ };
607
+ if (itemAny.pin) {
608
+ groupCol.pin = itemAny.pin;
609
+ }
610
+ newColumns.push(groupCol);
611
+ }
612
+ }
613
+ else {
614
+ // 普通列
615
+ const colItem = item;
616
+ const baseCol = baseColMap.get(colItem.prop);
617
+ if (!baseCol)
618
+ continue;
619
+ const newCol = processColumn(colItem, baseCol);
620
+ if (colItem.pin) {
621
+ newCol.pin = colItem.pin;
622
+ }
623
+ else {
624
+ delete newCol.pin;
625
+ }
626
+ newColumns.push(newCol);
627
+ }
628
+ }
629
+ // 更新 originalColumns
630
+ this.originalColumns = deepCloneColumns(newColumns);
631
+ // 如果提供了 uniqueId,按照优先级设置到列配置中
632
+ // 优先级:非冻结列的第一个 > 冻结列的第一个
633
+ if (uniqueId !== undefined && newColumns.length > 0) {
634
+ let targetCol = null;
635
+ // 1. 先查找非冻结列的第一个
636
+ for (const col of newColumns) {
637
+ const colAny = col;
638
+ if (colAny.children) {
639
+ // 分组列:查找第一个非冻结的子列
640
+ const firstNonPinChild = colAny.children.find((child) => !child.pin);
641
+ if (firstNonPinChild) {
642
+ targetCol = firstNonPinChild;
643
+ break;
644
+ }
645
+ }
646
+ else if (!colAny.pin) {
647
+ // 普通非冻结列
648
+ targetCol = colAny;
649
+ break;
650
+ }
651
+ }
652
+ // 2. 如果没有非冻结列,使用第一个列(不管是否冻结)
653
+ if (!targetCol) {
654
+ const firstCol = newColumns[0];
655
+ if (firstCol.children && firstCol.children.length > 0) {
656
+ targetCol = firstCol.children[0];
657
+ }
658
+ else {
659
+ targetCol = firstCol;
660
+ }
661
+ }
662
+ // 3. 设置 uniqueId
663
+ if (targetCol) {
664
+ targetCol.uniqueId = uniqueId;
665
+ }
666
+ }
667
+ // 返回 Promise,在渲染完成后 resolve
668
+ return new Promise((resolve) => {
669
+ var _a;
670
+ // 监听 aftercolumnsset 事件,确保渲染完成
671
+ const handleImportComplete = () => {
672
+ var _a, _b;
673
+ // 触发配置回调
674
+ (_b = (_a = this.config).onImportComplete) === null || _b === void 0 ? void 0 : _b.call(_a, config);
675
+ // resolve Promise
676
+ resolve(true);
677
+ };
678
+ this.revogrid.addEventListener('aftercolumnsset', handleImportComplete, { once: true });
679
+ // 应用配置
680
+ this.revogrid.columns = [...newColumns];
681
+ // 重置自动列宽列的宽度
682
+ if (stretchPlugin && ((_a = this.providers) === null || _a === void 0 ? void 0 : _a.dimension)) {
683
+ // 监听下一次 beforecolumnapplied 事件,确保列数据已更新
684
+ const handleColumnApplied = (e) => {
685
+ var _a;
686
+ // 使用事件中的新列数据,而不是 columnCollection.columns(旧数据)
687
+ const columnsData = (_a = e.detail) === null || _a === void 0 ? void 0 : _a.columns;
688
+ if (!columnsData) {
689
+ stretchPlugin.applyStretch();
690
+ return;
691
+ }
692
+ const dimensionTypes = ['rgCol', 'colPinStart', 'colPinEnd'];
693
+ dimensionTypes.forEach(type => {
694
+ var _a, _b;
695
+ const columns = columnsData[type];
696
+ if (!columns)
697
+ return;
698
+ const dimensionStore = (_b = (_a = this.providers) === null || _a === void 0 ? void 0 : _a.dimension) === null || _b === void 0 ? void 0 : _b.stores[type];
699
+ if (!dimensionStore)
700
+ return;
701
+ const sizes = dimensionStore.store.get('sizes') || {};
702
+ let hasChanges = false;
703
+ columns.forEach((col, idx) => {
704
+ const prop = col.prop;
705
+ if (prop && stretchColumnProps.has(prop) && !stretchPlugin.isManuallyResized(prop) && sizes[idx]) {
706
+ delete sizes[idx];
707
+ hasChanges = true;
708
+ }
709
+ });
710
+ if (hasChanges) {
711
+ dimensionStore.store.set('sizes', Object.assign({}, sizes));
712
+ }
713
+ });
714
+ stretchPlugin.applyStretch();
715
+ };
716
+ // 监听一次 beforecolumnapplied 事件
717
+ this.revogrid.addEventListener('beforecolumnapplied', handleColumnApplied, { once: true });
718
+ }
719
+ });
720
+ }
721
+ // ==================== 编组管理 ====================
722
+ /**
723
+ * 设置列的编组(统一入口方法)
724
+ * @param columnProp 列的 prop
725
+ * @param groupName 编组名称,如果为空则移除编组
726
+ * @returns 是否成功
727
+ *
728
+ * 使用示例:
729
+ * - setColumnGroup('priority', '基础信息') // 将 priority 列设置到 "基础信息" 编组
730
+ * - setColumnGroup('priority', '') // 移除 priority 列的编组
731
+ */
732
+ setColumnGroup(columnProp, groupName) {
733
+ const stretchPlugin = this.providers.plugins.getByClass(ColumnStretchPlugin);
734
+ const options = getStretchColumnOptions(this.providers, stretchPlugin);
735
+ const columns = convertCollectionToColumns(this.providers, options);
736
+ const trimmedGroupName = (groupName === null || groupName === void 0 ? void 0 : groupName.trim()) || '';
737
+ const currentGroup = this.getColumnGroup(columns, columnProp);
738
+ // 如果目标编组和当前编组相同,无需操作
739
+ if (currentGroup === trimmedGroupName || (!currentGroup && !trimmedGroupName)) {
740
+ return true;
741
+ }
742
+ let result = false;
743
+ /**
744
+ * 无编组名称: 移除编组
745
+ * 有编组名称:
746
+ * 1. 当前有编组: 从编组中分离出来
747
+ * 2. 是否有相邻编组且名称一样
748
+ * - 有: 合并进去
749
+ * - 无: 新建编组
750
+ */
751
+ if (!trimmedGroupName) {
752
+ // 无编组名称: 移除编组
753
+ result = currentGroup ? this.removeColumnFromGroup(columns, currentGroup, columnProp) : true;
754
+ }
755
+ else {
756
+ // 当前有编组: 从编组中分离出来
757
+ if (currentGroup) {
758
+ this.removeColumnFromGroup(columns, currentGroup, columnProp);
759
+ }
760
+ // 是否有相邻编组且名称一样
761
+ const adjacentGroup = this.findAdjacentGroup(columns, columnProp, trimmedGroupName);
762
+ if (adjacentGroup) {
763
+ // 合并到同名编组
764
+ result = this.addColumnToGroup(columns, adjacentGroup);
765
+ // 合并完成后,检查是否需要合并相邻的同名编组(处理前后都有同名编组的情况)
766
+ mergeAdjacentGroups(columns);
767
+ }
768
+ else {
769
+ // 创建新编组
770
+ result = this.createColumnGroup(columns, trimmedGroupName, [columnProp]);
771
+ }
772
+ }
773
+ // 触发编组变化事件
774
+ if (result) {
775
+ this.emit('columngroupchanged', {
776
+ columnProp,
777
+ groupName: trimmedGroupName || null,
778
+ previousGroup: currentGroup || null,
779
+ });
780
+ }
781
+ this.revogrid.columns = [...columns];
782
+ return result;
783
+ }
784
+ /**
785
+ * 查找列相邻的同名编组
786
+ * @private
787
+ */
788
+ findAdjacentGroup(columns, columnProp, groupName) {
789
+ const columnIndex = columns.findIndex((item) => item.prop === columnProp);
790
+ if (columnIndex === -1)
791
+ return null;
792
+ const columnInfo = columns[columnIndex];
793
+ const columnPin = columnInfo.pin;
794
+ let prevGroup = null;
795
+ let nextGroup = null;
796
+ // 检查前一个
797
+ if (columnIndex > 0) {
798
+ const prevColumn = columns[columnIndex - 1];
799
+ if (prevColumn.children &&
800
+ prevColumn.name === groupName &&
801
+ prevColumn.pin === columnPin) {
802
+ prevGroup = {
803
+ position: 'end',
804
+ groupIndex: columnIndex - 1,
805
+ columnIndex: columnIndex
806
+ }; // 添加到前一个编组的末尾
807
+ }
808
+ }
809
+ // 检查后一个
810
+ if (columnIndex < columns.length - 1) {
811
+ const nextColumn = columns[columnIndex + 1];
812
+ if (nextColumn.children &&
813
+ nextColumn.name === groupName &&
814
+ nextColumn.pin === columnPin) {
815
+ nextGroup = {
816
+ position: 'start',
817
+ groupIndex: columnIndex + 1,
818
+ columnIndex: columnIndex
819
+ }; // 添加到后一个编组的开头
820
+ }
821
+ }
822
+ // 如果前后都有同名编组,优先合并到前一个(添加到前一个编组的末尾)
823
+ // 这样可以保持列的顺序更自然
824
+ if (prevGroup) {
825
+ return prevGroup;
826
+ }
827
+ return nextGroup;
828
+ }
829
+ /**
830
+ * 创建列编组
831
+ * @param columns 列数据源
832
+ * @param groupName 编组名称
833
+ * @param columnProps 要编组的列 prop 数组
834
+ * @param pin 可选的冻结位置
835
+ * @private
836
+ */
837
+ createColumnGroup(columns, groupName, columnProps, pin) {
838
+ if (columnProps.length === 0) {
839
+ console.warn('[ColumnManagePlugin] 编组列不能为空');
840
+ return false;
841
+ }
842
+ // 收集要编组的列及其索引
843
+ const columnsData = [];
844
+ for (const prop of columnProps) {
845
+ const index = columns.findIndex((item) => item.prop === prop);
846
+ columnsData.push({
847
+ column: columns[index],
848
+ index: index
849
+ });
850
+ }
851
+ if (columnsData.length === 0)
852
+ return false;
853
+ // 按索引倒序删除列
854
+ columnsData
855
+ .sort((a, b) => b.index - a.index)
856
+ .forEach(({ index }) => columns.splice(index, 1));
857
+ // 创建编组
858
+ const groupColumn = {
859
+ name: groupName,
860
+ children: columnsData.map(({ column }) => {
861
+ const newCol = Object.assign({}, column);
862
+ if (pin)
863
+ newCol.pin = pin;
864
+ return newCol;
865
+ }),
866
+ };
867
+ if (pin)
868
+ groupColumn.pin = pin;
869
+ // 插入到第一个被删除列的位置
870
+ const insertIndex = Math.min(...columnsData.map(d => d.index));
871
+ columns.splice(insertIndex, 0, groupColumn);
872
+ this.revogrid.columns = [...columns];
873
+ return true;
874
+ }
875
+ /**
876
+ * 向编组添加列
877
+ * @param columns 列数据源
878
+ * @param adjacentGroup 相邻编组信息(包含 groupIndex、columnIndex、position)
879
+ * @private
880
+ */
881
+ addColumnToGroup(columns, adjacentGroup) {
882
+ const { groupIndex, columnIndex, position } = adjacentGroup;
883
+ // 1. 通过索引找到目标分组
884
+ const group = columns[groupIndex];
885
+ if (!group || !group.children) {
886
+ console.warn(`[ColumnManagePlugin] 索引 ${groupIndex} 处不是有效的编组`);
887
+ return false;
888
+ }
889
+ // 获取原始列
890
+ const column = columns[columnIndex];
891
+ if (!column) {
892
+ console.warn(`[ColumnManagePlugin] 索引 ${columnIndex} 处找不到列`);
893
+ return false;
894
+ }
895
+ // 2. 先删除原始列,再插入到编组
896
+ // 注意:删除操作会影响后续索引,所以需要先删除
897
+ columns.splice(columnIndex, 1);
898
+ // 3. 重新计算编组索引(如果列在编组前面,删除后编组索引会减1)
899
+ const adjustedGroupIndex = columnIndex < groupIndex ? groupIndex - 1 : groupIndex;
900
+ const adjustedGroup = columns[adjustedGroupIndex];
901
+ // 4. 根据 position 插入到编组
902
+ if (position === 'start') {
903
+ adjustedGroup.children.unshift(column);
904
+ }
905
+ else {
906
+ adjustedGroup.children.push(column);
907
+ }
908
+ this.revogrid.columns = [...columns];
909
+ return true;
910
+ }
911
+ /**
912
+ * 从编组移除列
913
+ * @param columns 列数据源
914
+ * @param groupName 编组名称
915
+ * @param columnProp 要移除的列 prop
916
+ * @private
917
+ */
918
+ removeColumnFromGroup(columns, groupName, columnProp) {
919
+ // 先从子级找到包含该列的编组
920
+ let groupIndex = -1;
921
+ let childIndex = -1;
922
+ for (let i = 0; i < columns.length; i++) {
923
+ const col = columns[i];
924
+ if (col.children) {
925
+ const idx = col.children.findIndex((child) => child.prop === columnProp);
926
+ if (idx !== -1) {
927
+ // 找到了包含该列的编组,验证编组名称是否匹配
928
+ if (col.name === groupName) {
929
+ groupIndex = i;
930
+ childIndex = idx;
931
+ break;
932
+ }
933
+ }
934
+ }
935
+ }
936
+ if (groupIndex === -1 || childIndex === -1) {
937
+ console.warn(`[ColumnManagePlugin] 在编组 "${groupName}" 中找不到列 "${columnProp}"`);
938
+ return false;
939
+ }
940
+ const group = columns[groupIndex];
941
+ // 拆分编组:移除列之前的、移除的列、移除列之后的
942
+ const beforeColumns = group.children.slice(0, childIndex);
943
+ const removedColumn = group.children[childIndex];
944
+ const afterColumns = group.children.slice(childIndex + 1);
945
+ // 删除原编组
946
+ columns.splice(groupIndex, 1);
947
+ // 重建结构
948
+ const newItems = [];
949
+ if (beforeColumns.length > 0) {
950
+ newItems.push(this.createGroupObject(group.name, beforeColumns, group.pin));
951
+ }
952
+ newItems.push(removedColumn);
953
+ if (afterColumns.length > 0) {
954
+ newItems.push(this.createGroupObject(group.name, afterColumns, group.pin));
955
+ }
956
+ // 插入新结构
957
+ columns.splice(groupIndex, 0, ...newItems);
958
+ this.revogrid.columns = columns;
959
+ return true;
960
+ }
961
+ /**
962
+ * 创建编组对象
963
+ * @private
964
+ */
965
+ createGroupObject(name, children, pin) {
966
+ const group = { name, children };
967
+ if (pin)
968
+ group.pin = pin;
969
+ return group;
970
+ }
971
+ /**
972
+ * 获取所有编组信息
973
+ */
974
+ getGroups() {
975
+ const columns = this.originalColumns || this.revogrid.columns;
976
+ if (!columns)
977
+ return [];
978
+ return columns
979
+ .filter((col) => col.children)
980
+ .map((col) => ({
981
+ name: col.name,
982
+ columns: col.children.map((child) => child.prop),
983
+ pin: col.pin,
984
+ }));
985
+ }
986
+ /**
987
+ * 检查列是否在编组中
988
+ */
989
+ isColumnInGroup(columnProp) {
990
+ const columns = this.originalColumns || this.revogrid.columns;
991
+ if (!columns)
992
+ return false;
993
+ for (const col of columns) {
994
+ const colAny = col;
995
+ if (colAny.children) {
996
+ if (colAny.children.some((child) => child.prop === columnProp)) {
997
+ return true;
998
+ }
999
+ }
1000
+ }
1001
+ return false;
1002
+ }
1003
+ /**
1004
+ * 获取列所在的编组名称
1005
+ */
1006
+ getColumnGroup(columns, columnProp) {
1007
+ if (!columns)
1008
+ return null;
1009
+ for (const col of columns) {
1010
+ const colAny = col;
1011
+ if (colAny.children) {
1012
+ if (colAny.children.some((child) => child.prop === columnProp)) {
1013
+ return colAny.name;
1014
+ }
1015
+ }
1016
+ }
1017
+ return null;
1018
+ }
1019
+ // ==================== 插入/删除列 ====================
1020
+ // ==================== 内部方法 ====================
1021
+ /**
1022
+ * 从 columns 数组中查找列的位置和分组信息
1023
+ * @param columns 列数组
1024
+ * @param prop 列的 prop
1025
+ * @returns 列信息对象,包含索引、分组信息和列数据
1026
+ */
1027
+ findColumnInColumns(columns, prop) {
1028
+ let groupIndex = -1;
1029
+ let childIndex = -1;
1030
+ let group = null;
1031
+ let columnData = null;
1032
+ // 遍历查找列
1033
+ for (let i = 0; i < columns.length; i++) {
1034
+ const col = columns[i];
1035
+ if (col.children) {
1036
+ // 当前是分组
1037
+ const idx = col.children.findIndex((child) => child.prop === prop);
1038
+ if (idx !== -1) {
1039
+ groupIndex = i;
1040
+ childIndex = idx;
1041
+ group = col;
1042
+ columnData = col.children[idx];
1043
+ break;
1044
+ }
1045
+ }
1046
+ else if (col.prop === prop) {
1047
+ // 当前是普通列
1048
+ groupIndex = i;
1049
+ childIndex = -1;
1050
+ columnData = col;
1051
+ break;
1052
+ }
1053
+ }
1054
+ return { groupIndex, childIndex, group, columnData };
1055
+ }
1056
+ buildSizeMap(columns) {
1057
+ const propToWidth = new Map();
1058
+ const headerCells = this.revogrid.querySelectorAll('.rgHeaderCell');
1059
+ const flatCols = this.flattenColumns(columns);
1060
+ headerCells.forEach(cell => {
1061
+ const width = cell.getBoundingClientRect().width;
1062
+ if (width <= 0)
1063
+ return;
1064
+ const colIndex = cell.getAttribute('data-rgcol');
1065
+ if (colIndex === null)
1066
+ return;
1067
+ const localIdx = parseInt(colIndex, 10);
1068
+ let viewportType = 'rgCol';
1069
+ // 适配统一表头的新 DOM 结构
1070
+ if (cell.closest('.header-area-colPinStart')) {
1071
+ viewportType = 'colPinStart';
1072
+ }
1073
+ else if (cell.closest('.header-area-colPinEnd')) {
1074
+ viewportType = 'colPinEnd';
1075
+ }
1076
+ else if (cell.closest('.header-area-rgCol')) {
1077
+ viewportType = 'rgCol';
1078
+ }
1079
+ let currentIdx = 0;
1080
+ for (const col of flatCols) {
1081
+ const pin = col.pin;
1082
+ const colViewport = pin === 'colPinStart' ? 'colPinStart'
1083
+ : pin === 'colPinEnd' ? 'colPinEnd'
1084
+ : 'rgCol';
1085
+ if (colViewport === viewportType) {
1086
+ if (currentIdx === localIdx && col.prop) {
1087
+ propToWidth.set(col.prop, width);
1088
+ break;
1089
+ }
1090
+ currentIdx++;
1091
+ }
1092
+ }
1093
+ });
1094
+ return propToWidth;
1095
+ }
1096
+ normalizeColumnConfig(config) {
1097
+ const items = Array.isArray(config) ? config : [config];
1098
+ const currentColumns = this.revogrid.columns || [];
1099
+ const flatColumns = this.flattenColumns(currentColumns);
1100
+ return items
1101
+ .map(item => {
1102
+ if (typeof item === 'string') {
1103
+ return item;
1104
+ }
1105
+ const col = flatColumns[item];
1106
+ return (col === null || col === void 0 ? void 0 : col.prop) || '';
1107
+ })
1108
+ .filter(Boolean);
1109
+ }
1110
+ flattenColumns(cols) {
1111
+ const result = [];
1112
+ for (const col of cols) {
1113
+ const colAny = col;
1114
+ if (colAny.children) {
1115
+ result.push(...colAny.children);
1116
+ }
1117
+ else {
1118
+ result.push(col);
1119
+ }
1120
+ }
1121
+ return result;
1122
+ }
1123
+ /**
1124
+ * 找到列应该插入的位置(基于传入的 columns 数组)
1125
+ * @param columns 列数组
1126
+ * @param newPin 新的冻结状态
1127
+ * @param previousPin 之前的冻结状态(用于取消冻结时判断插入位置)
1128
+ */
1129
+ findInsertPositionForPinInColumns(columns, newPin, previousPin) {
1130
+ if (!columns || columns.length === 0)
1131
+ return 0;
1132
+ if (newPin === 'colPinStart') {
1133
+ // 左冻结:插入到所有左冻结列的末尾
1134
+ let lastPinStartIndex = -1;
1135
+ for (let i = 0; i < columns.length; i++) {
1136
+ const col = columns[i];
1137
+ if (col.pin === 'colPinStart') {
1138
+ lastPinStartIndex = i;
1139
+ }
1140
+ else {
1141
+ break; // 遇到非左冻结列就停止
1142
+ }
1143
+ }
1144
+ return lastPinStartIndex + 1;
1145
+ }
1146
+ else if (newPin === 'colPinEnd') {
1147
+ // 右冻结:插入到第一个右冻结列前面
1148
+ for (let i = 0; i < columns.length; i++) {
1149
+ const col = columns[i];
1150
+ // 判断是否是右冻结列(检查自身或子列的 pin)
1151
+ let isColPinEnd = col.pin === 'colPinEnd';
1152
+ if (!isColPinEnd && col.children) {
1153
+ // 如果是编组,检查子列的 pin
1154
+ isColPinEnd = col.children.some((child) => child.pin === 'colPinEnd');
1155
+ }
1156
+ if (isColPinEnd) {
1157
+ return i;
1158
+ }
1159
+ }
1160
+ // 如果没有找到右冻结列,插入到末尾
1161
+ return columns.length;
1162
+ }
1163
+ else {
1164
+ // 取消冻结:根据之前的冻结状态决定插入位置
1165
+ if (previousPin === 'colPinEnd') {
1166
+ // 之前是右侧冻结,放在未冻结区域的最后一个
1167
+ // 找到第一个右冻结列的位置
1168
+ for (let i = 0; i < columns.length; i++) {
1169
+ const col = columns[i];
1170
+ // 判断是否是右冻结列(检查自身或子列的 pin)
1171
+ let isColPinEnd = col.pin === 'colPinEnd';
1172
+ if (!isColPinEnd && col.children) {
1173
+ isColPinEnd = col.children.some((child) => child.pin === 'colPinEnd');
1174
+ }
1175
+ if (isColPinEnd) {
1176
+ return i; // 插入到第一个右冻结列之前
1177
+ }
1178
+ }
1179
+ // 如果没有右冻结列,插入到末尾
1180
+ return columns.length;
1181
+ }
1182
+ else {
1183
+ // 之前是左侧冻结或无冻结,放在未冻结区域的第一个
1184
+ let firstNonPinIndex = 0;
1185
+ for (let i = 0; i < columns.length; i++) {
1186
+ const col = columns[i];
1187
+ if (col.pin === 'colPinStart') {
1188
+ firstNonPinIndex = i + 1;
1189
+ }
1190
+ else if (!col.pin) {
1191
+ break;
1192
+ }
1193
+ }
1194
+ return firstNonPinIndex;
1195
+ }
1196
+ }
1197
+ }
1198
+ findColumnByProp(cols, prop) {
1199
+ for (const col of cols) {
1200
+ const colAny = col;
1201
+ if (colAny.children) {
1202
+ const found = this.findColumnByProp(colAny.children, prop);
1203
+ if (found)
1204
+ return found;
1205
+ }
1206
+ else if (col.prop === prop) {
1207
+ return col;
1208
+ }
1209
+ }
1210
+ return null;
1211
+ }
1212
+ destroy() {
1213
+ this.hiddenProps.clear();
1214
+ this.originalColumns = null;
1215
+ super.destroy();
1216
+ }
1217
+ }
1218
+ //# sourceMappingURL=column-manage.plugin.js.map