@eo-sdk/client 11.5.0-rc.3 → 11.6.0-rc.2

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 (308) hide show
  1. package/app/eo-client/about-state/about-state.component.d.ts.map +1 -1
  2. package/app/eo-client/dashboard/dashboard.component.d.ts.map +1 -1
  3. package/app/eo-client/dashboard/widgets/charts-widget/charts-setup/charts-setup.component.d.ts +1 -1
  4. package/app/eo-client/dashboard/widgets/charts-widget/charts-setup/charts-setup.component.d.ts.map +1 -1
  5. package/app/eo-client/eo-client.module.d.ts +4 -5
  6. package/app/eo-client/eo-client.module.d.ts.map +1 -1
  7. package/app/eo-client/index.d.ts +3 -0
  8. package/app/eo-client/index.d.ts.map +1 -1
  9. package/app/eo-client/process-state/filter-label.d.ts +10 -0
  10. package/app/eo-client/process-state/filter-label.d.ts.map +1 -0
  11. package/app/eo-framework/actions/actions/custom-actions/custom-actions.component.d.ts.map +1 -1
  12. package/app/eo-framework/actions/actions/workflow-action/simple-workflow-action.component.d.ts.map +1 -1
  13. package/app/eo-framework/app-shell/app-bar/app-search/app-search.component.d.ts +1 -1
  14. package/app/eo-framework/app-shell/app-bar/app-search/app-search.component.d.ts.map +1 -1
  15. package/app/eo-framework/form-elements/datetime-range/datetime-range.component.d.ts.map +1 -1
  16. package/app/eo-framework/form-elements/organization/organization.component.d.ts +1 -0
  17. package/app/eo-framework/form-elements/organization/organization.component.d.ts.map +1 -1
  18. package/app/eo-framework/grid/grid.component.d.ts +9 -1
  19. package/app/eo-framework/grid/grid.component.d.ts.map +1 -1
  20. package/app/eo-framework/media/media.component.d.ts +3 -2
  21. package/app/eo-framework/media/media.component.d.ts.map +1 -1
  22. package/app/eo-framework/object-details/object-details.component.d.ts +13 -4
  23. package/app/eo-framework/object-details/object-details.component.d.ts.map +1 -1
  24. package/app/eo-framework/object-details/object-history/object-history.component.d.ts +3 -2
  25. package/app/eo-framework/object-details/object-history/object-history.component.d.ts.map +1 -1
  26. package/app/eo-framework/object-form/object-form/form-element-table/form-element-table.component.d.ts +1 -0
  27. package/app/eo-framework/object-form/object-form/form-element-table/form-element-table.component.d.ts.map +1 -1
  28. package/app/eo-framework/result-list/result-list.component.d.ts.map +1 -1
  29. package/app/eo-framework/ui/indexdata-summary/indexdata-summary.component.d.ts +50 -0
  30. package/app/eo-framework/ui/indexdata-summary/indexdata-summary.component.d.ts.map +1 -1
  31. package/app/eo-framework/ui/indexdata-summary/indexdata-summary.interface.d.ts +10 -0
  32. package/app/eo-framework/ui/indexdata-summary/indexdata-summary.interface.d.ts.map +1 -0
  33. package/app/eo-framework/ui/ui.module.d.ts +10 -11
  34. package/app/eo-framework/ui/ui.module.d.ts.map +1 -1
  35. package/app/eo-framework-core/agent/agent.service.d.ts.map +1 -1
  36. package/app/eo-framework-core/eo-framework-core.module.d.ts +1 -2
  37. package/app/eo-framework-core/eo-framework-core.module.d.ts.map +1 -1
  38. package/app/eo-framework-core/error-handler/error-handler.service.d.ts.map +1 -1
  39. package/app/eo-framework-core/search/app-search.service.d.ts +12 -1
  40. package/app/eo-framework-core/search/app-search.service.d.ts.map +1 -1
  41. package/assets/_default/i18n/de.json +5 -3
  42. package/assets/_default/i18n/en.json +10 -8
  43. package/esm2022/app/eo-client/about-state/about-state.component.mjs +6 -6
  44. package/esm2022/app/eo-client/dashboard/dashboard.component.mjs +4 -4
  45. package/esm2022/app/eo-client/dashboard/widgets/charts-widget/charts-setup/charts-setup.component.mjs +14 -12
  46. package/esm2022/app/eo-client/dashboard/widgets/charts-widget/charts-widget.component.mjs +3 -3
  47. package/esm2022/app/eo-client/dashboard/widgets/count-objects-widget/count-objects-setup/count-objects-setup.component.mjs +3 -3
  48. package/esm2022/app/eo-client/dashboard/widgets/count-objects-widget/count-objects-widget.component.mjs +3 -3
  49. package/esm2022/app/eo-client/dashboard/widgets/hitlist-widget/hitlist-setup/hitlist-setup.component.mjs +3 -3
  50. package/esm2022/app/eo-client/dashboard/widgets/hitlist-widget/hitlist-widget.component.mjs +3 -3
  51. package/esm2022/app/eo-client/dashboard/widgets/iframe-widget/iframe-setup/iframe-setup.component.mjs +3 -3
  52. package/esm2022/app/eo-client/dashboard/widgets/iframe-widget/iframe-widget.component.mjs +6 -6
  53. package/esm2022/app/eo-client/dashboard/widgets/info-inbox-widget/info-inbox-setup/info-inbox-setup.component.mjs +3 -3
  54. package/esm2022/app/eo-client/dashboard/widgets/info-inbox-widget/info-inbox-widget.component.mjs +3 -3
  55. package/esm2022/app/eo-client/dashboard/widgets/info-intray-widget/info-intray-setup/info-intray-setup.component.mjs +3 -3
  56. package/esm2022/app/eo-client/dashboard/widgets/info-intray-widget/info-intray-widget.component.mjs +3 -3
  57. package/esm2022/app/eo-client/dashboard/widgets/last-edited-widget/last-edited-and-created-setup/last-edited-and-created-setup.component.mjs +3 -3
  58. package/esm2022/app/eo-client/dashboard/widgets/last-edited-widget/last-edited-and-created.component.mjs +3 -3
  59. package/esm2022/app/eo-client/dashboard/widgets/picture-widget/picture-widget-setup/picture-widget-setup.component.mjs +3 -3
  60. package/esm2022/app/eo-client/dashboard/widgets/picture-widget/picture-widget.component.mjs +3 -3
  61. package/esm2022/app/eo-client/dashboard/widgets/search-widget/search-widget.component.mjs +3 -3
  62. package/esm2022/app/eo-client/dashboard/widgets/todowidget/todo-setup/todo-setup.component.mjs +3 -3
  63. package/esm2022/app/eo-client/dashboard/widgets/todowidget/todo-widget.component.mjs +3 -3
  64. package/esm2022/app/eo-client/eo-client-routing.module.mjs +4 -4
  65. package/esm2022/app/eo-client/eo-client.module.mjs +26 -28
  66. package/esm2022/app/eo-client/favorite-state/favorite-state.component.mjs +3 -3
  67. package/esm2022/app/eo-client/inbox-state/inbox-state/inbox-state.component.mjs +3 -3
  68. package/esm2022/app/eo-client/inbox-state/inbox-state-routing.module.mjs +4 -4
  69. package/esm2022/app/eo-client/inbox-state/inbox-state.module.mjs +4 -4
  70. package/esm2022/app/eo-client/index.mjs +4 -1
  71. package/esm2022/app/eo-client/login/login.component.mjs +3 -3
  72. package/esm2022/app/eo-client/notifications-state/notifications-state.component.mjs +3 -3
  73. package/esm2022/app/eo-client/object-state/object-state/object-state.component.mjs +3 -3
  74. package/esm2022/app/eo-client/object-state/object-state-routing.module.mjs +4 -4
  75. package/esm2022/app/eo-client/object-state/object-state-service/object-state.service.mjs +3 -3
  76. package/esm2022/app/eo-client/object-state/object-state.module.mjs +4 -4
  77. package/esm2022/app/eo-client/prepare-state/prepare-state/prepare-state.component.mjs +3 -3
  78. package/esm2022/app/eo-client/prepare-state/prepare-state-routing.module.mjs +4 -4
  79. package/esm2022/app/eo-client/prepare-state/prepare-state.module.mjs +4 -4
  80. package/esm2022/app/eo-client/process-state/filter-label.mjs +11 -0
  81. package/esm2022/app/eo-client/process-state/process-state.component.mjs +3 -3
  82. package/esm2022/app/eo-client/recyclebin-state/recyclebin-state.component.mjs +3 -3
  83. package/esm2022/app/eo-client/result-state/result-state.component.mjs +3 -3
  84. package/esm2022/app/eo-client/settings/settings.component.mjs +3 -3
  85. package/esm2022/app/eo-client/stored-queries-state/stored-queries-state.component.mjs +3 -3
  86. package/esm2022/app/eo-client/version-state/version-state.component.mjs +3 -3
  87. package/esm2022/app/eo-framework/accordion/accordion.module.mjs +4 -4
  88. package/esm2022/app/eo-framework/accordion/simple-accordion/simple-accordion.component.mjs +3 -3
  89. package/esm2022/app/eo-framework/actions/action-menu/action-component-anchor/action-component-anchor.directive.mjs +3 -3
  90. package/esm2022/app/eo-framework/actions/action-menu/action-menu.component.mjs +3 -3
  91. package/esm2022/app/eo-framework/actions/action-service/action.service.mjs +3 -3
  92. package/esm2022/app/eo-framework/actions/action.module.mjs +4 -4
  93. package/esm2022/app/eo-framework/actions/actions/add-resubmission-action/add-resubmission/add-resubmission.component.mjs +3 -3
  94. package/esm2022/app/eo-framework/actions/actions/add-resubmission-action/add-resubmission-action.mjs +3 -3
  95. package/esm2022/app/eo-framework/actions/actions/add-subscription-action/add-subscription/add-subscription.component.mjs +3 -3
  96. package/esm2022/app/eo-framework/actions/actions/add-subscription-action/add-subscription-action.mjs +3 -3
  97. package/esm2022/app/eo-framework/actions/actions/cancel-signing-action/cancel-signing/cancel-signing.component.mjs +3 -3
  98. package/esm2022/app/eo-framework/actions/actions/cancel-signing-action/cancel-signing-action.mjs +3 -3
  99. package/esm2022/app/eo-framework/actions/actions/clipboard/clipboard-action.mjs +3 -3
  100. package/esm2022/app/eo-framework/actions/actions/clipboard/clipboard-object-action/clipboard-object-action.component.mjs +3 -3
  101. package/esm2022/app/eo-framework/actions/actions/copy-action/copy-action.mjs +3 -3
  102. package/esm2022/app/eo-framework/actions/actions/custom-actions/custom-actions.component.mjs +5 -4
  103. package/esm2022/app/eo-framework/actions/actions/cut-action/cut-action.mjs +3 -3
  104. package/esm2022/app/eo-framework/actions/actions/delete-action/delete/delete.component.mjs +3 -3
  105. package/esm2022/app/eo-framework/actions/actions/delete-action/delete-action.mjs +3 -3
  106. package/esm2022/app/eo-framework/actions/actions/delete-action/delete-prepared-action.mjs +3 -3
  107. package/esm2022/app/eo-framework/actions/actions/delete-content-action/delete-content/delete-content.component.mjs +3 -3
  108. package/esm2022/app/eo-framework/actions/actions/delete-content-action/delete-content-action.mjs +3 -3
  109. package/esm2022/app/eo-framework/actions/actions/download-action/download-action.mjs +3 -3
  110. package/esm2022/app/eo-framework/actions/actions/download-action/download-object-action/download-object-action.component.mjs +3 -3
  111. package/esm2022/app/eo-framework/actions/actions/email/email/email.component.mjs +3 -3
  112. package/esm2022/app/eo-framework/actions/actions/email/email-action.mjs +3 -3
  113. package/esm2022/app/eo-framework/actions/actions/favorite-action/favorite-action.mjs +3 -3
  114. package/esm2022/app/eo-framework/actions/actions/finalize/definalize-action.mjs +3 -3
  115. package/esm2022/app/eo-framework/actions/actions/finalize/finalize-action.mjs +4 -4
  116. package/esm2022/app/eo-framework/actions/actions/finalize/finalize-object-action/finalize-object-action.component.mjs +3 -3
  117. package/esm2022/app/eo-framework/actions/actions/open-context-action/open-context-action.mjs +3 -3
  118. package/esm2022/app/eo-framework/actions/actions/open-document-action/open-document-action.component.mjs +3 -3
  119. package/esm2022/app/eo-framework/actions/actions/open-document-action/open-document-action.mjs +3 -3
  120. package/esm2022/app/eo-framework/actions/actions/open-versions-action/open-versions-action.mjs +3 -3
  121. package/esm2022/app/eo-framework/actions/actions/remove-subscription-action/remove-subscription-action.mjs +3 -3
  122. package/esm2022/app/eo-framework/actions/actions/restore-version-action/restore-version-action.mjs +3 -3
  123. package/esm2022/app/eo-framework/actions/actions/share-object-action/share-object/share-object.component.mjs +3 -3
  124. package/esm2022/app/eo-framework/actions/actions/share-object-action/share-object-action.mjs +3 -3
  125. package/esm2022/app/eo-framework/actions/actions/signature-action/sequence-list/sequence-list.component.mjs +3 -3
  126. package/esm2022/app/eo-framework/actions/actions/signature-action/sequence-list-item/sequence-list-item.component.mjs +3 -3
  127. package/esm2022/app/eo-framework/actions/actions/signature-action/signature/signature.component.mjs +3 -3
  128. package/esm2022/app/eo-framework/actions/actions/signature-action/signature-action.component.mjs +3 -3
  129. package/esm2022/app/eo-framework/actions/actions/unlock-action/unlock-action.mjs +3 -3
  130. package/esm2022/app/eo-framework/actions/actions/update-resubmission-action/update-resubmission-action.mjs +3 -3
  131. package/esm2022/app/eo-framework/actions/actions/workflow-action/simple-workflow-action.component.mjs +5 -5
  132. package/esm2022/app/eo-framework/actions/actions/workflow-action/workflow/workflow.component.mjs +3 -3
  133. package/esm2022/app/eo-framework/actions/actions/workflow-action/workflow-action.component.mjs +3 -3
  134. package/esm2022/app/eo-framework/app-shell/app-bar/app-add/app-add-dialog/app-add-dialog.component.mjs +3 -3
  135. package/esm2022/app/eo-framework/app-shell/app-bar/app-add/app-add.component.mjs +3 -3
  136. package/esm2022/app/eo-framework/app-shell/app-bar/app-bar.component.mjs +3 -3
  137. package/esm2022/app/eo-framework/app-shell/app-bar/app-process/app-process.component.mjs +3 -3
  138. package/esm2022/app/eo-framework/app-shell/app-bar/app-search/app-search.component.mjs +20 -6
  139. package/esm2022/app/eo-framework/app-shell/app-bar/context-search/context-search.component.mjs +3 -3
  140. package/esm2022/app/eo-framework/app-shell/app-bar/side-bar/side-bar.component.mjs +3 -3
  141. package/esm2022/app/eo-framework/app-shell/app-bar/user-avatar-overlay/user-avatar-overlay.component.mjs +3 -3
  142. package/esm2022/app/eo-framework/app-shell/app-shell-routing.module.mjs +4 -4
  143. package/esm2022/app/eo-framework/app-shell/app-shell.module.mjs +4 -4
  144. package/esm2022/app/eo-framework/app-shell/license-warning/license-warning.component.mjs +3 -3
  145. package/esm2022/app/eo-framework/cta/component/cta.component.mjs +3 -3
  146. package/esm2022/app/eo-framework/cta/cta.module.mjs +4 -4
  147. package/esm2022/app/eo-framework/eo-framework.module.mjs +4 -4
  148. package/esm2022/app/eo-framework/error/error.module.mjs +4 -4
  149. package/esm2022/app/eo-framework/error/error404/error404.component.mjs +3 -3
  150. package/esm2022/app/eo-framework/error/not-found/not-found.component.mjs +3 -3
  151. package/esm2022/app/eo-framework/form-elements/checkbox/checkbox.component.mjs +3 -3
  152. package/esm2022/app/eo-framework/form-elements/codesystem/codesystem.component.mjs +3 -3
  153. package/esm2022/app/eo-framework/form-elements/date/date.component.mjs +3 -3
  154. package/esm2022/app/eo-framework/form-elements/date/year-range/year-range.directive.mjs +3 -3
  155. package/esm2022/app/eo-framework/form-elements/datetime-range/datetime-range.component.mjs +5 -4
  156. package/esm2022/app/eo-framework/form-elements/dynamic-list/dynamic-list.component.mjs +6 -6
  157. package/esm2022/app/eo-framework/form-elements/form-elements.module.mjs +4 -4
  158. package/esm2022/app/eo-framework/form-elements/form-input/form-input.component.mjs +3 -3
  159. package/esm2022/app/eo-framework/form-elements/form-input/input-focus/input-focus.directive.mjs +3 -3
  160. package/esm2022/app/eo-framework/form-elements/id-reference/id-reference.component.mjs +3 -3
  161. package/esm2022/app/eo-framework/form-elements/id-reference/reference-finder/reference-finder.component.mjs +3 -3
  162. package/esm2022/app/eo-framework/form-elements/id-reference/reference-finder-entry/reference-finder-entry.component.mjs +3 -3
  163. package/esm2022/app/eo-framework/form-elements/id-reference/service/reference-finder.service.mjs +3 -3
  164. package/esm2022/app/eo-framework/form-elements/number/number.component.mjs +3 -3
  165. package/esm2022/app/eo-framework/form-elements/number-range/number-range.component.mjs +3 -3
  166. package/esm2022/app/eo-framework/form-elements/organization/organization.component.mjs +28 -19
  167. package/esm2022/app/eo-framework/form-elements/password/password.component.mjs +3 -3
  168. package/esm2022/app/eo-framework/form-elements/reference/reference.component.mjs +3 -3
  169. package/esm2022/app/eo-framework/form-elements/string/string.component.mjs +3 -3
  170. package/esm2022/app/eo-framework/frame/frame.component.mjs +3 -3
  171. package/esm2022/app/eo-framework/grid/column-configurator/column-configurator.component.mjs +3 -3
  172. package/esm2022/app/eo-framework/grid/extensions/custom-sort/custom-sort.component.mjs +3 -3
  173. package/esm2022/app/eo-framework/grid/extensions/empty/empty.component.mjs +3 -3
  174. package/esm2022/app/eo-framework/grid/extensions/filter/abstract-filter.component.mjs +3 -3
  175. package/esm2022/app/eo-framework/grid/extensions/filter/custom/custom-filter.component.mjs +3 -3
  176. package/esm2022/app/eo-framework/grid/extensions/filter/setFilters/set-filter.component.mjs +3 -3
  177. package/esm2022/app/eo-framework/grid/extensions/filter/text/text-filter.component.mjs +5 -5
  178. package/esm2022/app/eo-framework/grid/extensions/pagination/pagination.component.mjs +3 -3
  179. package/esm2022/app/eo-framework/grid/extensions/quick-filter/quick-filter.component.mjs +3 -3
  180. package/esm2022/app/eo-framework/grid/extensions/reset-filter/reset-filter.component.mjs +3 -3
  181. package/esm2022/app/eo-framework/grid/extensions/services/list-settings.service.mjs +3 -3
  182. package/esm2022/app/eo-framework/grid/extensions/total-count/total-count.component.mjs +3 -3
  183. package/esm2022/app/eo-framework/grid/filters/codesystem-filter.component.mjs +3 -3
  184. package/esm2022/app/eo-framework/grid/filters/datetime-filter.component.mjs +3 -3
  185. package/esm2022/app/eo-framework/grid/filters/dynamic-list-filter.component.mjs +3 -3
  186. package/esm2022/app/eo-framework/grid/filters/list-filter.component.mjs +3 -3
  187. package/esm2022/app/eo-framework/grid/filters/organization-filter.component.mjs +3 -3
  188. package/esm2022/app/eo-framework/grid/grid.component.mjs +55 -25
  189. package/esm2022/app/eo-framework/grid/grid.module.mjs +4 -4
  190. package/esm2022/app/eo-framework/inbox-details/duetimeInfo/duetimeInfo.component.mjs +3 -3
  191. package/esm2022/app/eo-framework/inbox-details/inbox-details.component.mjs +3 -3
  192. package/esm2022/app/eo-framework/list-container/list-container.component.mjs +3 -3
  193. package/esm2022/app/eo-framework/list-container/list-container.module.mjs +4 -4
  194. package/esm2022/app/eo-framework/media/content-preview.service.mjs +3 -3
  195. package/esm2022/app/eo-framework/media/media.component.mjs +11 -7
  196. package/esm2022/app/eo-framework/media/media.module.mjs +4 -4
  197. package/esm2022/app/eo-framework/object-details/edit-icon/edit-icon.component.mjs +3 -3
  198. package/esm2022/app/eo-framework/object-details/favorite-icon/favorite-icon.component.mjs +3 -3
  199. package/esm2022/app/eo-framework/object-details/object-details.component.mjs +31 -16
  200. package/esm2022/app/eo-framework/object-details/object-details.module.mjs +4 -4
  201. package/esm2022/app/eo-framework/object-details/object-history/history-filter/history-filter-pipe/history-filter.pipe.mjs +3 -3
  202. package/esm2022/app/eo-framework/object-details/object-history/history-filter/history-filter.component.mjs +3 -3
  203. package/esm2022/app/eo-framework/object-details/object-history/object-history.component.mjs +12 -7
  204. package/esm2022/app/eo-framework/object-details/object-links/object-links.component.mjs +3 -3
  205. package/esm2022/app/eo-framework/object-form/object-form/form-element/form-element-template.directive.mjs +3 -3
  206. package/esm2022/app/eo-framework/object-form/object-form/form-element/form-element.component.mjs +3 -3
  207. package/esm2022/app/eo-framework/object-form/object-form/form-element-table/form-element-table.component.mjs +22 -20
  208. package/esm2022/app/eo-framework/object-form/object-form/form-element-table/row-edit/row-edit.component.mjs +3 -3
  209. package/esm2022/app/eo-framework/object-form/object-form/object-form-group/object-form-group.component.mjs +3 -3
  210. package/esm2022/app/eo-framework/object-form/object-form/object-form-script/object-form-script.service.mjs +4 -4
  211. package/esm2022/app/eo-framework/object-form/object-form/object-form.component.mjs +3 -3
  212. package/esm2022/app/eo-framework/object-form/object-form-edit/object-form-edit.component.mjs +3 -3
  213. package/esm2022/app/eo-framework/object-form/object-form-helper.service.mjs +3 -3
  214. package/esm2022/app/eo-framework/object-form/object-form.module.mjs +4 -4
  215. package/esm2022/app/eo-framework/object-state-details/object-state-details.component.mjs +3 -3
  216. package/esm2022/app/eo-framework/plugins/plugin.component.mjs +9 -9
  217. package/esm2022/app/eo-framework/plugins/plugin.directive.mjs +3 -3
  218. package/esm2022/app/eo-framework/plugins/plugin.service.mjs +3 -3
  219. package/esm2022/app/eo-framework/plugins/plugins.module.mjs +4 -4
  220. package/esm2022/app/eo-framework/prepare-details/prepare-content-exists-info/prepare-content-exists-info.component.mjs +3 -3
  221. package/esm2022/app/eo-framework/prepare-details/prepare-details.component.mjs +3 -3
  222. package/esm2022/app/eo-framework/process/details/process-details.component.mjs +3 -3
  223. package/esm2022/app/eo-framework/process/history/process-history.component.mjs +3 -3
  224. package/esm2022/app/eo-framework/process/process-file/process-file.component.mjs +3 -3
  225. package/esm2022/app/eo-framework/process-form/process-form.component.mjs +3 -3
  226. package/esm2022/app/eo-framework/process-form/process-form.module.mjs +4 -4
  227. package/esm2022/app/eo-framework/quick-search/quick-search/quick-search.component.mjs +3 -3
  228. package/esm2022/app/eo-framework/quick-search/quick-search.module.mjs +4 -4
  229. package/esm2022/app/eo-framework/recyclebin-details/recyclebin-details.component.mjs +3 -3
  230. package/esm2022/app/eo-framework/result-list/result-list.component.mjs +10 -5
  231. package/esm2022/app/eo-framework/result-list/result-list.module.mjs +4 -4
  232. package/esm2022/app/eo-framework/settings/change-password/change-password-form/change-password-form.component.mjs +3 -3
  233. package/esm2022/app/eo-framework/settings/permissions/permissions.component.mjs +3 -3
  234. package/esm2022/app/eo-framework/settings/settings.module.mjs +4 -4
  235. package/esm2022/app/eo-framework/shortcuts/global-shortcuts/global-shortcuts-section/global-shortcuts-section.component.mjs +3 -3
  236. package/esm2022/app/eo-framework/shortcuts/global-shortcuts/global-shortcuts.component.mjs +3 -3
  237. package/esm2022/app/eo-framework/shortcuts/shortcuts.directive.mjs +3 -3
  238. package/esm2022/app/eo-framework/shortcuts/shortcuts.module.mjs +4 -4
  239. package/esm2022/app/eo-framework/shortcuts/shortcuts.service.mjs +3 -3
  240. package/esm2022/app/eo-framework/stored-query/stored-query/stored-query.component.mjs +3 -3
  241. package/esm2022/app/eo-framework/stored-query/stored-query-details/dynamic-property-switch/dynamic-property-switch.component.mjs +3 -3
  242. package/esm2022/app/eo-framework/stored-query/stored-query-details/stored-query-details.component.mjs +3 -3
  243. package/esm2022/app/eo-framework/stored-query/stored-query.module.mjs +4 -4
  244. package/esm2022/app/eo-framework/tree/tree-node/tree-node.component.mjs +3 -3
  245. package/esm2022/app/eo-framework/tree/tree.component.mjs +3 -3
  246. package/esm2022/app/eo-framework/tree/tree.module.mjs +4 -4
  247. package/esm2022/app/eo-framework/ui/clipboard/clipboard.component.mjs +3 -3
  248. package/esm2022/app/eo-framework/ui/eo-dialog/eo-dialog.component.mjs +3 -3
  249. package/esm2022/app/eo-framework/ui/eo-icon/eo-icon.component.mjs +3 -3
  250. package/esm2022/app/eo-framework/ui/error-message/error-message.component.mjs +3 -3
  251. package/esm2022/app/eo-framework/ui/indexdata-summary/indexdata-summary-entry/indexdata-summary-entry.component.mjs +4 -4
  252. package/esm2022/app/eo-framework/ui/indexdata-summary/indexdata-summary.component.mjs +141 -8
  253. package/esm2022/app/eo-framework/ui/indexdata-summary/indexdata-summary.interface.mjs +2 -0
  254. package/esm2022/app/eo-framework/ui/loading-spinner/loading-spinner.component.mjs +3 -3
  255. package/esm2022/app/eo-framework/ui/outside-click/outside-click.directive.mjs +3 -3
  256. package/esm2022/app/eo-framework/ui/overlay/overlay.component.mjs +3 -3
  257. package/esm2022/app/eo-framework/ui/query-scope-select/query-scope-select.component.mjs +3 -3
  258. package/esm2022/app/eo-framework/ui/router-link/router-link.directive.mjs +3 -3
  259. package/esm2022/app/eo-framework/ui/rtl-aware/rtl-aware.directive.mjs +3 -3
  260. package/esm2022/app/eo-framework/ui/signature-tab/signature-tab.component.mjs +3 -3
  261. package/esm2022/app/eo-framework/ui/ui.module.mjs +17 -28
  262. package/esm2022/app/eo-framework/ui/user-avatar/user-avatar.component.mjs +3 -3
  263. package/esm2022/app/eo-framework/upload-overlay/upload-overlay-guard.service.mjs +3 -3
  264. package/esm2022/app/eo-framework/upload-overlay/upload-overlay.component.mjs +3 -3
  265. package/esm2022/app/eo-framework/util/directive/prevent-double-click.directive.mjs +3 -3
  266. package/esm2022/app/eo-framework/util/directive/trap-focus.directive.mjs +3 -3
  267. package/esm2022/app/eo-framework/util/services/utilities.service.mjs +3 -3
  268. package/esm2022/app/eo-framework/util/sortable/order-by.pipe.mjs +3 -3
  269. package/esm2022/app/eo-framework/util/util.module.mjs +4 -4
  270. package/esm2022/app/eo-framework-core/agent/agent.service.mjs +4 -4
  271. package/esm2022/app/eo-framework-core/api/grid.service.mjs +6 -6
  272. package/esm2022/app/eo-framework-core/api/plugins.service.mjs +3 -3
  273. package/esm2022/app/eo-framework-core/empty-state/empty-state.service.mjs +3 -3
  274. package/esm2022/app/eo-framework-core/eo-framework-core.module.mjs +13 -19
  275. package/esm2022/app/eo-framework-core/error-handler/error-handler.service.mjs +4 -4
  276. package/esm2022/app/eo-framework-core/layout/layout.service.mjs +3 -3
  277. package/esm2022/app/eo-framework-core/location/location.service.mjs +3 -3
  278. package/esm2022/app/eo-framework-core/pending-changes/pending-changes-guard.service.mjs +3 -3
  279. package/esm2022/app/eo-framework-core/pending-changes/pending-changes.service.mjs +3 -3
  280. package/esm2022/app/eo-framework-core/pipes/filesize.pipe.mjs +3 -3
  281. package/esm2022/app/eo-framework-core/pipes/keys.pipe.mjs +3 -3
  282. package/esm2022/app/eo-framework-core/pipes/locale-date.pipe.mjs +3 -3
  283. package/esm2022/app/eo-framework-core/pipes/locale-number.pipe.mjs +12 -12
  284. package/esm2022/app/eo-framework-core/pipes/pipes.module.mjs +4 -4
  285. package/esm2022/app/eo-framework-core/pipes/safe-html.pipe.mjs +3 -3
  286. package/esm2022/app/eo-framework-core/references/reference.service.mjs +3 -3
  287. package/esm2022/app/eo-framework-core/route-guards/auth/auth-guard.service.mjs +3 -3
  288. package/esm2022/app/eo-framework-core/route-guards/capabilities/capabilities-guard.service.mjs +3 -3
  289. package/esm2022/app/eo-framework-core/search/app-search.service.mjs +32 -7
  290. package/esm2022/app/eo-framework-core/selection/selection.service.mjs +3 -3
  291. package/esm2022/app/eo-framework-core/title/page-title.service.mjs +3 -3
  292. package/fesm2022/eo-sdk-client.mjs +1183 -1621
  293. package/fesm2022/eo-sdk-client.mjs.map +1 -1
  294. package/misc/scripts/copy-client-assets.js +1 -1
  295. package/package.json +17 -17
  296. package/proxy.config.js +13 -0
  297. package/scss/_migrationTemp.scss +1 -0
  298. package/styles.css +1 -0
  299. package/app/eo-framework/grid/row-grouping/batchRemover.d.ts +0 -13
  300. package/app/eo-framework/grid/row-grouping/batchRemover.d.ts.map +0 -1
  301. package/app/eo-framework/grid/row-grouping/group-stage.d.ts +0 -45
  302. package/app/eo-framework/grid/row-grouping/group-stage.d.ts.map +0 -1
  303. package/app/eo-framework/grid/row-grouping/row-grouping.module.d.ts +0 -8
  304. package/app/eo-framework/grid/row-grouping/row-grouping.module.d.ts.map +0 -1
  305. package/esm2022/app/eo-framework/grid/row-grouping/batchRemover.mjs +0 -50
  306. package/esm2022/app/eo-framework/grid/row-grouping/group-stage.mjs +0 -623
  307. package/esm2022/app/eo-framework/grid/row-grouping/row-grouping.module.mjs +0 -8
  308. package/proxy.config.json +0 -97
@@ -1,623 +0,0 @@
1
- import { __decorate } from "tslib";
2
- import { _, Autowired, Bean, BeanStub, RowNode } from "@ag-grid-community/core";
3
- import { BatchRemover } from "./batchRemover";
4
- let GroupStage = class GroupStage extends BeanStub {
5
- execute(params) {
6
- const details = this.createGroupingDetails(params);
7
- if (details.transactions) {
8
- this.handleTransaction(details);
9
- }
10
- else {
11
- const afterColsChanged = params.afterColumnsChanged === true;
12
- this.shotgunResetEverything(details, afterColsChanged);
13
- }
14
- if (!details.usingTreeData) {
15
- // we don't do group sorting for tree data
16
- this.positionLeafsAndGroups(params.changedPath);
17
- this.orderGroups(details);
18
- }
19
- this.selectableService.updateSelectableAfterGrouping();
20
- }
21
- positionLeafsAndGroups(changedPath) {
22
- changedPath.forEachChangedNodeDepthFirst(group => {
23
- if (group.childrenAfterGroup) {
24
- const leafNodes = [];
25
- const groupNodes = [];
26
- let unbalancedNode;
27
- group.childrenAfterGroup.forEach(row => {
28
- if (!row.childrenAfterGroup?.length) {
29
- leafNodes.push(row);
30
- }
31
- else {
32
- if (row.key === '' && !unbalancedNode) {
33
- unbalancedNode = row;
34
- }
35
- else {
36
- groupNodes.push(row);
37
- }
38
- }
39
- });
40
- if (unbalancedNode) {
41
- groupNodes.push(unbalancedNode);
42
- }
43
- group.childrenAfterGroup = [...leafNodes, ...groupNodes];
44
- }
45
- }, false);
46
- }
47
- createGroupingDetails(params) {
48
- const { rowNode, changedPath, rowNodeTransactions, rowNodeOrder } = params;
49
- const usingTreeData = this.gos.get('treeData');
50
- const groupedCols = usingTreeData ? null : this.columnModel.getRowGroupColumns();
51
- const details = {
52
- // someone complained that the parent attribute was causing some change detection
53
- // to break in an angular add-on. Taking the parent out breaks a cyclic dependency, hence this flag got introduced.
54
- includeParents: !this.gos.get('suppressParentsInRowNodes'),
55
- expandByDefault: this.gos.get('groupDefaultExpanded'),
56
- groupedCols: groupedCols,
57
- rootNode: rowNode,
58
- pivotMode: this.columnModel.isPivotMode(),
59
- groupedColCount: usingTreeData || !groupedCols ? 0 : groupedCols.length,
60
- rowNodeOrder: rowNodeOrder,
61
- transactions: rowNodeTransactions,
62
- // if no transaction, then it's shotgun, changed path would be 'not active' at this point anyway
63
- changedPath: changedPath,
64
- groupAllowUnbalanced: this.gos.get('groupAllowUnbalanced'),
65
- isGroupOpenByDefault: this.gos.getCallback('isGroupOpenByDefault'),
66
- initialGroupOrderComparator: this.gos.getCallback('initialGroupOrderComparator'),
67
- usingTreeData: usingTreeData,
68
- suppressGroupMaintainValueType: this.gos.get('suppressGroupMaintainValueType'),
69
- getDataPath: usingTreeData ? this.gos.get('getDataPath') : undefined,
70
- keyCreators: groupedCols?.map(column => column.getColDef().keyCreator) ?? []
71
- };
72
- return details;
73
- }
74
- handleTransaction(details) {
75
- details.transactions.forEach(tran => {
76
- // we don't allow batch remover for tree data as tree data uses Filler Nodes,
77
- // and creating/deleting filler nodes needs to be done alongside the node deleting
78
- // and moving. if we want to Batch Remover working with tree data then would need
79
- // to consider how Filler Nodes would be impacted (it's possible that it can be easily
80
- // modified to work, however for now I don't have the brain energy to work it all out).
81
- const batchRemover = !details.usingTreeData ? new BatchRemover() : undefined;
82
- // the order here of [add, remove, update] needs to be the same as in ClientSideNodeManager,
83
- // as the order is important when a record with the same id is added and removed in the same
84
- // transaction.
85
- if (_.existsAndNotEmpty(tran.remove)) {
86
- this.removeNodes(tran.remove, details, batchRemover);
87
- }
88
- if (_.existsAndNotEmpty(tran.update)) {
89
- this.moveNodesInWrongPath(tran.update, details, batchRemover);
90
- }
91
- if (_.existsAndNotEmpty(tran.add)) {
92
- this.insertNodes(tran.add, details, false);
93
- }
94
- // must flush here, and not allow another transaction to be applied,
95
- // as each transaction must finish leaving the data in a consistent state.
96
- if (batchRemover) {
97
- const parentsWithChildrenRemoved = batchRemover.getAllParents().slice();
98
- batchRemover.flush();
99
- this.removeEmptyGroups(parentsWithChildrenRemoved, details);
100
- }
101
- });
102
- if (details.rowNodeOrder) {
103
- this.sortChildren(details);
104
- }
105
- }
106
- // this is used when doing delta updates, eg Redux, keeps nodes in right order
107
- sortChildren(details) {
108
- details.changedPath.forEachChangedNodeDepthFirst(node => {
109
- if (!node.childrenAfterGroup) {
110
- return;
111
- }
112
- const didSort = _.sortRowNodesByOrder(node.childrenAfterGroup, details.rowNodeOrder);
113
- if (didSort) {
114
- details.changedPath.addParentNode(node);
115
- }
116
- }, false, true);
117
- }
118
- orderGroups(details) {
119
- const comparator = details.initialGroupOrderComparator;
120
- if (_.exists(comparator)) {
121
- recursiveSort(details.rootNode);
122
- }
123
- function recursiveSort(rowNode) {
124
- const doSort = _.exists(rowNode.childrenAfterGroup) &&
125
- // we only want to sort groups, so we do not sort leafs (a leaf group has leafs as children)
126
- !rowNode.leafGroup;
127
- if (doSort) {
128
- rowNode.childrenAfterGroup.sort((nodeA, nodeB) => comparator({ nodeA, nodeB }));
129
- rowNode.childrenAfterGroup.forEach((childNode) => recursiveSort(childNode));
130
- }
131
- }
132
- }
133
- getExistingPathForNode(node, details) {
134
- const res = [];
135
- // when doing tree data, the node is part of the path,
136
- // but when doing grid grouping, the node is not part of the path so we start with the parent.
137
- let pointer = details.usingTreeData ? node : node.parent;
138
- while (pointer && pointer !== details.rootNode) {
139
- res.push({
140
- key: pointer.key,
141
- rowGroupColumn: pointer.rowGroupColumn,
142
- field: pointer.field
143
- });
144
- pointer = pointer.parent;
145
- }
146
- res.reverse();
147
- return res;
148
- }
149
- moveNodesInWrongPath(childNodes, details, batchRemover) {
150
- childNodes.forEach(childNode => {
151
- // we add node, even if parent has not changed, as the data could have
152
- // changed, hence aggregations will be wrong
153
- if (details.changedPath.isActive()) {
154
- details.changedPath.addParentNode(childNode.parent);
155
- }
156
- const infoToKeyMapper = (item) => item.key;
157
- const oldPath = this.getExistingPathForNode(childNode, details).map(infoToKeyMapper);
158
- const newPath = this.getGroupInfo(childNode, details).map(infoToKeyMapper);
159
- const nodeInCorrectPath = _.areEqual(oldPath, newPath);
160
- if (!nodeInCorrectPath) {
161
- this.moveNode(childNode, details, batchRemover);
162
- }
163
- });
164
- }
165
- moveNode(childNode, details, batchRemover) {
166
- this.removeNodesInStages([childNode], details, batchRemover);
167
- this.insertOneNode(childNode, details, true, batchRemover);
168
- // hack - if we didn't do this, then renaming a tree item (ie changing rowNode.key) wouldn't get
169
- // refreshed into the gui.
170
- // this is needed to kick off the event that rowComp listens to for refresh. this in turn
171
- // then will get each cell in the row to refresh - which is what we need as we don't know which
172
- // columns will be displaying the rowNode.key info.
173
- childNode.setData(childNode.data);
174
- // we add both old and new parents to changed path, as both will need to be refreshed.
175
- // we already added the old parent (in calling method), so just add the new parent here
176
- if (details.changedPath.isActive()) {
177
- const newParent = childNode.parent;
178
- details.changedPath.addParentNode(newParent);
179
- }
180
- }
181
- removeNodes(leafRowNodes, details, batchRemover) {
182
- this.removeNodesInStages(leafRowNodes, details, batchRemover);
183
- if (details.changedPath.isActive()) {
184
- leafRowNodes.forEach(rowNode => details.changedPath.addParentNode(rowNode.parent));
185
- }
186
- }
187
- removeNodesInStages(leafRowNodes, details, batchRemover) {
188
- this.removeNodesFromParents(leafRowNodes, details, batchRemover);
189
- if (details.usingTreeData) {
190
- this.postRemoveCreateFillerNodes(leafRowNodes, details);
191
- // When not TreeData, then removeEmptyGroups is called just before the BatchRemover is flushed.
192
- // However for TreeData, there is no BatchRemover, so we have to call removeEmptyGroups here.
193
- const nodeParents = leafRowNodes.map(n => n.parent);
194
- this.removeEmptyGroups(nodeParents, details);
195
- }
196
- }
197
- forEachParentGroup(details, group, callback) {
198
- let pointer = group;
199
- while (pointer && pointer !== details.rootNode) {
200
- callback(pointer);
201
- pointer = pointer.parent;
202
- }
203
- }
204
- removeNodesFromParents(nodesToRemove, details, provided) {
205
- // this method can be called with BatchRemover as optional. if it is missed, we created a local version
206
- // and flush it at the end. if one is provided, we add to the provided one and it gets flushed elsewhere.
207
- const batchRemoverIsLocal = provided == null;
208
- const batchRemoverToUse = provided ? provided : new BatchRemover();
209
- nodesToRemove.forEach(nodeToRemove => {
210
- this.removeFromParent(nodeToRemove, batchRemoverToUse);
211
- // remove from allLeafChildren. we clear down all parents EXCEPT the Root Node, as
212
- // the ClientSideNodeManager is responsible for the Root Node.
213
- this.forEachParentGroup(details, nodeToRemove.parent, parentNode => {
214
- batchRemoverToUse.removeFromAllLeafChildren(parentNode, nodeToRemove);
215
- });
216
- });
217
- if (batchRemoverIsLocal) {
218
- batchRemoverToUse.flush();
219
- }
220
- }
221
- postRemoveCreateFillerNodes(nodesToRemove, details) {
222
- nodesToRemove.forEach(nodeToRemove => {
223
- // if not group, and children are present, need to move children to a group.
224
- // otherwise if no children, we can just remove without replacing.
225
- const replaceWithGroup = nodeToRemove.hasChildren();
226
- if (replaceWithGroup) {
227
- const oldPath = this.getExistingPathForNode(nodeToRemove, details);
228
- // because we just removed the userGroup, this will always return new support group
229
- const newGroupNode = this.findParentForNode(nodeToRemove, oldPath, details);
230
- // these properties are the ones that will be incorrect in the newly created group,
231
- // so copy them from the old childNode
232
- newGroupNode.expanded = nodeToRemove.expanded;
233
- newGroupNode.allLeafChildren = nodeToRemove.allLeafChildren;
234
- newGroupNode.childrenAfterGroup = nodeToRemove.childrenAfterGroup;
235
- newGroupNode.childrenMapped = nodeToRemove.childrenMapped;
236
- newGroupNode.updateHasChildren();
237
- newGroupNode.childrenAfterGroup.forEach(rowNode => rowNode.parent = newGroupNode);
238
- }
239
- });
240
- }
241
- removeEmptyGroups(possibleEmptyGroups, details) {
242
- // we do this multiple times, as when we remove groups, that means the parent of just removed
243
- // group can then be empty. to get around this, if we remove, then we check everything again for
244
- // newly emptied groups. the max number of times this will execute is the depth of the group tree.
245
- let checkAgain = true;
246
- const groupShouldBeRemoved = (rowNode) => {
247
- // because of the while loop below, it's possible we already moved the node,
248
- // so double check before trying to remove again.
249
- const mapKey = this.getChildrenMappedKey(rowNode.key, rowNode.rowGroupColumn);
250
- const parentRowNode = rowNode.parent;
251
- const groupAlreadyRemoved = (parentRowNode && parentRowNode.childrenMapped) ?
252
- !parentRowNode.childrenMapped[mapKey] : true;
253
- if (groupAlreadyRemoved) {
254
- // if not linked, then group was already removed
255
- return false;
256
- }
257
- // if still not removed, then we remove if this group is empty
258
- return !!rowNode.isEmptyRowGroupNode();
259
- };
260
- while (checkAgain) {
261
- checkAgain = false;
262
- const batchRemover = new BatchRemover();
263
- possibleEmptyGroups.forEach(possibleEmptyGroup => {
264
- // remove empty groups
265
- this.forEachParentGroup(details, possibleEmptyGroup, rowNode => {
266
- if (groupShouldBeRemoved(rowNode)) {
267
- checkAgain = true;
268
- this.removeFromParent(rowNode, batchRemover);
269
- // we remove selection on filler nodes here, as the selection would not be removed
270
- // from the RowNodeManager, as filler nodes don't exist on the RowNodeManager
271
- rowNode.setSelectedParams({ newValue: false, source: 'rowGroupChanged' });
272
- }
273
- });
274
- });
275
- batchRemover.flush();
276
- }
277
- }
278
- // removes the node from the parent by:
279
- // a) removing from childrenAfterGroup (using batchRemover if present, otherwise immediately)
280
- // b) removing from childrenMapped (immediately)
281
- // c) setRowTop(null) - as the rowRenderer uses this to know the RowNode is no longer needed
282
- // d) setRowIndex(null) - as the rowNode will no longer be displayed.
283
- removeFromParent(child, batchRemover) {
284
- if (child.parent) {
285
- if (batchRemover) {
286
- batchRemover.removeFromChildrenAfterGroup(child.parent, child);
287
- }
288
- else {
289
- _.removeFromArray(child.parent.childrenAfterGroup, child);
290
- child.parent.updateHasChildren();
291
- }
292
- }
293
- const mapKey = this.getChildrenMappedKey(child.key, child.rowGroupColumn);
294
- if (child.parent && child.parent.childrenMapped) {
295
- child.parent.childrenMapped[mapKey] = undefined;
296
- }
297
- // this is important for transition, see rowComp removeFirstPassFuncs. when doing animation and
298
- // remove, if rowTop is still present, the rowComp thinks it's just moved position.
299
- child.setRowTop(null);
300
- child.setRowIndex(null);
301
- }
302
- addToParent(child, parent) {
303
- const mapKey = this.getChildrenMappedKey(child.key, child.rowGroupColumn);
304
- if (parent) {
305
- const children = parent.childrenMapped != null;
306
- if (children) {
307
- parent.childrenMapped[mapKey] = child;
308
- }
309
- parent.childrenAfterGroup.push(child);
310
- parent.updateHasChildren();
311
- }
312
- }
313
- areGroupColsEqual(d1, d2) {
314
- if (d1 == null || d2 == null || d1.pivotMode !== d2.pivotMode) {
315
- return false;
316
- }
317
- return _.areEqual(d1.groupedCols, d2.groupedCols) && _.areEqual(d1.keyCreators, d2.keyCreators);
318
- }
319
- checkAllGroupDataAfterColsChanged(details) {
320
- const recurse = (rowNodes) => {
321
- if (!rowNodes) {
322
- return;
323
- }
324
- rowNodes.forEach(rowNode => {
325
- const isLeafNode = !details.usingTreeData && !rowNode.group;
326
- if (isLeafNode) {
327
- return;
328
- }
329
- const groupInfo = {
330
- field: rowNode.field,
331
- key: rowNode.key,
332
- rowGroupColumn: rowNode.rowGroupColumn,
333
- leafNode: rowNode.allLeafChildren[0],
334
- };
335
- this.setGroupData(rowNode, groupInfo, details);
336
- recurse(rowNode.childrenAfterGroup);
337
- });
338
- };
339
- recurse(details.rootNode.childrenAfterGroup);
340
- }
341
- shotgunResetEverything(details, afterColumnsChanged) {
342
- if (this.noChangeInGroupingColumns(details, afterColumnsChanged)) {
343
- return;
344
- }
345
- // groups are about to get disposed, so need to deselect any that are selected
346
- this.selectionService.filterFromSelection((node) => node && !node.group);
347
- const { rootNode, groupedCols } = details;
348
- // because we are not creating the root node each time, we have the logic
349
- // here to change leafGroup once.
350
- // we set .leafGroup to false for tree data, as .leafGroup is only used when pivoting, and pivoting
351
- // isn't allowed with treeData, so the grid never actually use .leafGroup when doing treeData.
352
- rootNode.leafGroup = details.usingTreeData ? false : groupedCols.length === 0;
353
- // we are doing everything from scratch, so reset childrenAfterGroup and childrenMapped from the rootNode
354
- rootNode.childrenAfterGroup = [];
355
- rootNode.childrenMapped = {};
356
- rootNode.updateHasChildren();
357
- const sibling = rootNode.sibling;
358
- if (sibling) {
359
- sibling.childrenAfterGroup = rootNode.childrenAfterGroup;
360
- sibling.childrenMapped = rootNode.childrenMapped;
361
- }
362
- this.insertNodes(rootNode.allLeafChildren, details, false);
363
- }
364
- noChangeInGroupingColumns(details, afterColumnsChanged) {
365
- let noFurtherProcessingNeeded = false;
366
- const groupDisplayColumns = this.columnModel.getGroupDisplayColumns();
367
- const newGroupDisplayColIds = groupDisplayColumns ?
368
- groupDisplayColumns.map(c => c.getId()).join('-') : '';
369
- if (afterColumnsChanged) {
370
- // we only need to redo grouping if doing normal grouping (ie not tree data)
371
- // and the group cols have changed.
372
- noFurtherProcessingNeeded = details.usingTreeData || this.areGroupColsEqual(details, this.oldGroupingDetails);
373
- // if the group display cols have changed, then we need to update rowNode.groupData
374
- // (regardless of tree data or row grouping)
375
- if (this.oldGroupDisplayColIds !== newGroupDisplayColIds) {
376
- this.checkAllGroupDataAfterColsChanged(details);
377
- }
378
- }
379
- this.oldGroupingDetails = details;
380
- this.oldGroupDisplayColIds = newGroupDisplayColIds;
381
- return noFurtherProcessingNeeded;
382
- }
383
- insertNodes(newRowNodes, details, isMove) {
384
- newRowNodes.forEach(rowNode => {
385
- this.insertOneNode(rowNode, details, isMove);
386
- if (details.changedPath.isActive()) {
387
- details.changedPath.addParentNode(rowNode.parent);
388
- }
389
- });
390
- }
391
- insertOneNode(childNode, details, isMove, batchRemover) {
392
- const path = this.getGroupInfo(childNode, details);
393
- const parentGroup = this.findParentForNode(childNode, path, details, batchRemover);
394
- if (!parentGroup.group) {
395
- console.warn(`AG Grid: duplicate group keys for row data, keys should be unique`, [parentGroup.data, childNode.data]);
396
- }
397
- if (details.usingTreeData) {
398
- this.swapGroupWithUserNode(parentGroup, childNode, isMove);
399
- }
400
- else {
401
- childNode.parent = parentGroup;
402
- childNode.level = path.length;
403
- parentGroup.childrenAfterGroup.push(childNode);
404
- parentGroup.updateHasChildren();
405
- }
406
- }
407
- findParentForNode(childNode, path, details, batchRemover) {
408
- let nextNode = details.rootNode;
409
- path.forEach((groupInfo, level) => {
410
- nextNode = this.getOrCreateNextNode(nextNode, groupInfo, level, details);
411
- // node gets added to all group nodes.
412
- // note: we do not add to rootNode here, as the rootNode is the master list of rowNodes
413
- if (!batchRemover?.isRemoveFromAllLeafChildren(nextNode, childNode)) {
414
- nextNode.allLeafChildren.push(childNode);
415
- }
416
- else {
417
- // if this node is about to be removed, prevent that
418
- batchRemover?.preventRemoveFromAllLeafChildren(nextNode, childNode);
419
- }
420
- });
421
- return nextNode;
422
- }
423
- swapGroupWithUserNode(fillerGroup, userGroup, isMove) {
424
- userGroup.parent = fillerGroup.parent;
425
- userGroup.key = fillerGroup.key;
426
- userGroup.field = fillerGroup.field;
427
- userGroup.groupData = fillerGroup.groupData;
428
- userGroup.level = fillerGroup.level;
429
- // AG-3441 - preserve the existing expanded status of the node if we're moving it, so that
430
- // you can drag a sub tree from one parent to another without changing its expansion
431
- if (!isMove) {
432
- userGroup.expanded = fillerGroup.expanded;
433
- }
434
- // we set .leafGroup to false for tree data, as .leafGroup is only used when pivoting, and pivoting
435
- // isn't allowed with treeData, so the grid never actually use .leafGroup when doing treeData.
436
- userGroup.leafGroup = fillerGroup.leafGroup;
437
- // always null for userGroups, as row grouping is not allowed when doing tree data
438
- userGroup.rowGroupIndex = fillerGroup.rowGroupIndex;
439
- userGroup.allLeafChildren = fillerGroup.allLeafChildren;
440
- userGroup.childrenAfterGroup = fillerGroup.childrenAfterGroup;
441
- userGroup.childrenMapped = fillerGroup.childrenMapped;
442
- userGroup.sibling = fillerGroup.sibling;
443
- userGroup.updateHasChildren();
444
- this.removeFromParent(fillerGroup);
445
- userGroup.childrenAfterGroup.forEach((rowNode) => rowNode.parent = userGroup);
446
- this.addToParent(userGroup, fillerGroup.parent);
447
- }
448
- getOrCreateNextNode(parentGroup, groupInfo, level, details) {
449
- const key = this.getChildrenMappedKey(groupInfo.key, groupInfo.rowGroupColumn);
450
- let nextNode = parentGroup.childrenMapped ? parentGroup.childrenMapped[key] : undefined;
451
- if (!nextNode) {
452
- nextNode = this.createGroup(groupInfo, parentGroup, level, details);
453
- // attach the new group to the parent
454
- this.addToParent(nextNode, parentGroup);
455
- }
456
- return nextNode;
457
- }
458
- createGroup(groupInfo, parent, level, details) {
459
- const groupNode = new RowNode(this.beans);
460
- groupNode.group = true;
461
- groupNode.field = groupInfo.field;
462
- groupNode.rowGroupColumn = groupInfo.rowGroupColumn;
463
- this.setGroupData(groupNode, groupInfo, details);
464
- groupNode.key = groupInfo.key;
465
- groupNode.id = this.createGroupId(groupNode, parent, details.usingTreeData, level);
466
- groupNode.level = level;
467
- groupNode.leafGroup = details.usingTreeData ? false : level === (details.groupedColCount - 1);
468
- groupNode.allLeafChildren = [];
469
- // why is this done here? we are not updating the children count as we go,
470
- // i suspect this is updated in the filter stage
471
- groupNode.setAllChildrenCount(0);
472
- groupNode.rowGroupIndex = details.usingTreeData ? null : level;
473
- groupNode.childrenAfterGroup = [];
474
- groupNode.childrenMapped = {};
475
- groupNode.updateHasChildren();
476
- groupNode.parent = details.includeParents ? parent : null;
477
- this.setExpandedInitialValue(details, groupNode);
478
- return groupNode;
479
- }
480
- createGroupId(node, parent, usingTreeData, level) {
481
- let createGroupId;
482
- if (usingTreeData) {
483
- createGroupId = (node, parent, level) => {
484
- if (level < 0) {
485
- return null;
486
- } // root node
487
- const parentId = parent ? createGroupId(parent, parent.parent, level - 1) : null;
488
- return `${parentId == null ? '' : parentId + '-'}${level}-${node.key}`;
489
- };
490
- }
491
- else {
492
- createGroupId = (node, parent) => {
493
- if (!node.rowGroupColumn) {
494
- return null;
495
- } // root node
496
- const parentId = parent ? createGroupId(parent, parent.parent, 0) : null;
497
- return `${parentId == null ? '' : parentId + '-'}${node.rowGroupColumn.getColId()}-${node.key}`;
498
- };
499
- }
500
- // we put 'row-group-' before the group id, so it doesn't clash with standard row id's. we also use 't-' and 'b-'
501
- // for top pinned and bottom pinned rows.
502
- return RowNode.ID_PREFIX_ROW_GROUP + createGroupId(node, parent, level);
503
- }
504
- setGroupData(groupNode, groupInfo, details) {
505
- groupNode.groupData = {};
506
- const groupDisplayCols = this.columnModel.getGroupDisplayColumns();
507
- groupDisplayCols.forEach(col => {
508
- // newGroup.rowGroupColumn=null when working off GroupInfo, and we always display the group in the group column
509
- // if rowGroupColumn is present, then it's grid row grouping and we only include if configuration says so
510
- const isTreeData = details.usingTreeData;
511
- if (isTreeData) {
512
- groupNode.groupData[col.getColId()] = groupInfo.key;
513
- return;
514
- }
515
- const groupColumn = groupNode.rowGroupColumn;
516
- const isRowGroupDisplayed = groupColumn !== null && col.isRowGroupDisplayed(groupColumn.getId());
517
- if (isRowGroupDisplayed) {
518
- if (details.suppressGroupMaintainValueType) {
519
- groupNode.groupData[col.getColId()] = groupInfo.key;
520
- }
521
- else {
522
- // if maintain group value type, get the value from any leaf node.
523
- groupNode.groupData[col.getColId()] = this.valueService.getValue(groupColumn, groupInfo.leafNode);
524
- }
525
- }
526
- });
527
- }
528
- getChildrenMappedKey(key, rowGroupColumn) {
529
- if (rowGroupColumn) {
530
- // grouping by columns
531
- return rowGroupColumn.getId() + '-' + key;
532
- }
533
- // tree data - we don't have rowGroupColumns
534
- return key;
535
- }
536
- setExpandedInitialValue(details, groupNode) {
537
- // if pivoting the leaf group is never expanded as we do not show leaf rows
538
- if (details.pivotMode && groupNode.leafGroup) {
539
- groupNode.expanded = false;
540
- return;
541
- }
542
- // use callback if exists
543
- const userCallback = details.isGroupOpenByDefault;
544
- if (userCallback) {
545
- const params = {
546
- rowNode: groupNode,
547
- field: groupNode.field,
548
- key: groupNode.key,
549
- level: groupNode.level,
550
- rowGroupColumn: groupNode.rowGroupColumn
551
- };
552
- groupNode.expanded = userCallback(params) == true;
553
- return;
554
- }
555
- // use expandByDefault if exists
556
- const { expandByDefault } = details;
557
- if (details.expandByDefault === -1) {
558
- groupNode.expanded = true;
559
- return;
560
- }
561
- // otherwise
562
- groupNode.expanded = groupNode.level < expandByDefault;
563
- }
564
- getGroupInfo(rowNode, details) {
565
- if (details.usingTreeData) {
566
- return this.getGroupInfoFromCallback(rowNode, details);
567
- }
568
- return this.getGroupInfoFromGroupColumns(rowNode, details);
569
- }
570
- getGroupInfoFromCallback(rowNode, details) {
571
- const keys = details.getDataPath ? details.getDataPath(rowNode.data) : null;
572
- if (keys === null || keys === undefined || keys.length === 0) {
573
- _.warnOnce(`getDataPath() should not return an empty path for data ${rowNode.data}`);
574
- }
575
- const groupInfoMapper = (key) => ({ key, field: null, rowGroupColumn: null });
576
- return keys ? keys.map(groupInfoMapper) : [];
577
- }
578
- getGroupInfoFromGroupColumns(rowNode, details) {
579
- const res = [];
580
- details.groupedCols.forEach(groupCol => {
581
- let key = this.valueService.getKeyForNode(groupCol, rowNode);
582
- let keyExists = key !== null && key !== undefined && key !== '';
583
- // unbalanced tree and pivot mode don't work together - not because of the grid, it doesn't make
584
- // mathematical sense as you are building up a cube. so if pivot mode, we put in a blank key where missing.
585
- // this keeps the tree balanced and hence can be represented as a group.
586
- const createGroupForEmpty = details.pivotMode || !details.groupAllowUnbalanced;
587
- if (createGroupForEmpty && !keyExists) {
588
- key = '';
589
- keyExists = true;
590
- }
591
- if (keyExists) {
592
- const item = {
593
- key: key,
594
- field: groupCol.getColDef().field,
595
- rowGroupColumn: groupCol,
596
- leafNode: rowNode,
597
- };
598
- res.push(item);
599
- }
600
- });
601
- return res;
602
- }
603
- };
604
- __decorate([
605
- Autowired('columnModel')
606
- ], GroupStage.prototype, "columnModel", void 0);
607
- __decorate([
608
- Autowired('selectableService')
609
- ], GroupStage.prototype, "selectableService", void 0);
610
- __decorate([
611
- Autowired('valueService')
612
- ], GroupStage.prototype, "valueService", void 0);
613
- __decorate([
614
- Autowired('beans')
615
- ], GroupStage.prototype, "beans", void 0);
616
- __decorate([
617
- Autowired('selectionService')
618
- ], GroupStage.prototype, "selectionService", void 0);
619
- GroupStage = __decorate([
620
- Bean('groupStage')
621
- ], GroupStage);
622
- export { GroupStage };
623
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"group-stage.js","sourceRoot":"","sources":["../../../../../../../../src/app/eo-framework/grid/row-grouping/group-stage.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    _,\n    Autowired,\n    Bean,\n    BeanStub,\n    ChangedPath,\n    Column,\n    ColumnModel,\n    GetDataPath,\n    IRowNodeStage,\n    IsGroupOpenByDefaultParams,\n    RowNode,\n    RowNodeTransaction,\n    SelectableService,\n    StageExecuteParams,\n    ValueService,\n    Beans,\n    ISelectionService,\n    WithoutGridCommon,\n    InitialGroupOrderComparatorParams,\n    GridOptions,\n    KeyCreatorParams\n} from \"@ag-grid-community/core\";\nimport { BatchRemover } from \"./batchRemover\";\n\ninterface GroupInfo {\n    key: string; // e.g. 'Ireland'\n    field: string | null; // e.g. 'country'\n    rowGroupColumn: Column | null;\n    leafNode?: RowNode;\n}\n\ninterface GroupingDetails {\n    pivotMode: boolean;\n    includeParents: boolean;\n    expandByDefault: number;\n    changedPath: ChangedPath;\n    rootNode: RowNode;\n    groupedCols: Column[];\n    groupedColCount: number;\n    transactions: RowNodeTransaction[];\n    rowNodeOrder: { [id: string]: number; };\n    \n    groupAllowUnbalanced: boolean;\n    isGroupOpenByDefault: (params: WithoutGridCommon<IsGroupOpenByDefaultParams>) => boolean;\n    initialGroupOrderComparator: (params: WithoutGridCommon<InitialGroupOrderComparatorParams>) => number;\n    \n    usingTreeData: boolean;\n    suppressGroupMaintainValueType: boolean;\n    getDataPath: GetDataPath | undefined;\n    keyCreators: (((params: KeyCreatorParams) => string) | undefined)[];\n}\n\n@Bean('groupStage')\nexport class GroupStage extends BeanStub implements IRowNodeStage {\n\n    @Autowired('columnModel') private columnModel: ColumnModel;\n    @Autowired('selectableService') private selectableService: SelectableService;\n    @Autowired('valueService') private valueService: ValueService;\n    @Autowired('beans') private beans: Beans;\n    @Autowired('selectionService') private selectionService: ISelectionService;\n\n    // when grouping, these items are of note:\n    // rowNode.parent: RowNode: set to the parent\n    // rowNode.childrenAfterGroup: RowNode[] = the direct children of this group\n    // rowNode.childrenMapped: string=>RowNode = children mapped by group key (when groups) or an empty map if leaf group (this is then used by pivot)\n    // for leaf groups, rowNode.childrenAfterGroup = rowNode.allLeafChildren;\n\n    private oldGroupingDetails: GroupingDetails;\n    private oldGroupDisplayColIds: string;\n\n    public execute(params: StageExecuteParams): void {\n\n        const details = this.createGroupingDetails(params);\n\n        if (details.transactions) {\n            this.handleTransaction(details);\n        } else {\n            const afterColsChanged = params.afterColumnsChanged === true;\n            this.shotgunResetEverything(details, afterColsChanged);\n        }\n\n        if (!details.usingTreeData) {\n            // we don't do group sorting for tree data\n            this.positionLeafsAndGroups(params.changedPath!);\n            this.orderGroups(details);\n        }\n\n        this.selectableService.updateSelectableAfterGrouping();\n    }\n\n    private positionLeafsAndGroups(changedPath: ChangedPath) {\n        changedPath.forEachChangedNodeDepthFirst(group => {\n            if (group.childrenAfterGroup) {\n                const leafNodes: RowNode[] = [];\n                const groupNodes: RowNode[] = [];\n                let unbalancedNode: RowNode | undefined;\n\n                group.childrenAfterGroup.forEach(row => {\n                    if (!row.childrenAfterGroup?.length) {\n                        leafNodes.push(row);\n                    } else {\n                        if (row.key === '' && !unbalancedNode) {\n                            unbalancedNode = row;\n                        } else {\n                            groupNodes.push(row);\n                        }\n                    }\n                });\n\n                if (unbalancedNode) {\n                    groupNodes.push(unbalancedNode);\n                }\n                \n                group.childrenAfterGroup = [...leafNodes, ...groupNodes];\n            }\n        }, false);\n    }\n\n    private createGroupingDetails(params: StageExecuteParams): GroupingDetails {\n        const { rowNode, changedPath, rowNodeTransactions, rowNodeOrder } = params;\n\n        const usingTreeData = this.gos.get('treeData');\n\n        const groupedCols = usingTreeData ? null : this.columnModel.getRowGroupColumns();\n\n        const details: GroupingDetails = {\n            // someone complained that the parent attribute was causing some change detection\n            // to break in an angular add-on.  Taking the parent out breaks a cyclic dependency, hence this flag got introduced.\n            includeParents: !this.gos.get('suppressParentsInRowNodes'),\n            expandByDefault: this.gos.get('groupDefaultExpanded'),\n            groupedCols: groupedCols!,\n            rootNode: rowNode,\n            pivotMode: this.columnModel.isPivotMode(),\n            groupedColCount: usingTreeData || !groupedCols ? 0 : groupedCols.length,\n            rowNodeOrder: rowNodeOrder!,\n            transactions: rowNodeTransactions!,\n            // if no transaction, then it's shotgun, changed path would be 'not active' at this point anyway\n            changedPath: changedPath!,\n            groupAllowUnbalanced:  this.gos.get('groupAllowUnbalanced'),\n            isGroupOpenByDefault: this.gos.getCallback('isGroupOpenByDefault') as any,\n            initialGroupOrderComparator: this.gos.getCallback('initialGroupOrderComparator') as any,\n            usingTreeData: usingTreeData,\n            suppressGroupMaintainValueType: this.gos.get('suppressGroupMaintainValueType'),\n            getDataPath: usingTreeData ? this.gos.get('getDataPath') : undefined,\n            keyCreators: groupedCols?.map(column => column.getColDef().keyCreator) ?? []\n        };\n\n        return details;\n    }\n\n    private handleTransaction(details: GroupingDetails): void {\n\n        details.transactions.forEach(tran => {\n            // we don't allow batch remover for tree data as tree data uses Filler Nodes,\n            // and creating/deleting filler nodes needs to be done alongside the node deleting\n            // and moving. if we want to Batch Remover working with tree data then would need\n            // to consider how Filler Nodes would be impacted (it's possible that it can be easily\n            // modified to work, however for now I don't have the brain energy to work it all out).\n            const batchRemover = !details.usingTreeData ? new BatchRemover() : undefined;\n\n            // the order here of [add, remove, update] needs to be the same as in ClientSideNodeManager,\n            // as the order is important when a record with the same id is added and removed in the same\n            // transaction.\n            if (_.existsAndNotEmpty(tran.remove)) {\n                this.removeNodes(tran.remove as RowNode[], details, batchRemover);\n            }\n            if (_.existsAndNotEmpty(tran.update)) {\n                this.moveNodesInWrongPath(tran.update as RowNode[], details, batchRemover);\n            }\n            if (_.existsAndNotEmpty(tran.add)) {\n                this.insertNodes(tran.add as RowNode[], details, false);\n            }\n            // must flush here, and not allow another transaction to be applied,\n            // as each transaction must finish leaving the data in a consistent state.\n            if (batchRemover) {\n                const parentsWithChildrenRemoved = batchRemover.getAllParents().slice();\n                batchRemover.flush();\n                this.removeEmptyGroups(parentsWithChildrenRemoved, details);\n            }\n        });\n\n        if (details.rowNodeOrder) {\n            this.sortChildren(details);\n        }\n    }\n\n    // this is used when doing delta updates, eg Redux, keeps nodes in right order\n    private sortChildren(details: GroupingDetails): void {\n        details.changedPath.forEachChangedNodeDepthFirst(node => {\n            if (!node.childrenAfterGroup) {\n                return;\n            }\n\n            const didSort = _.sortRowNodesByOrder(node.childrenAfterGroup!, details.rowNodeOrder);\n            if (didSort) {\n                details.changedPath.addParentNode(node);\n            }\n        }, false, true);\n    }\n\n    private orderGroups(details: GroupingDetails): void {\n        const comparator = details.initialGroupOrderComparator;\n        if (_.exists(comparator)) { recursiveSort(details.rootNode); }\n\n        function recursiveSort(rowNode: RowNode): void {\n            const doSort = _.exists(rowNode.childrenAfterGroup) &&\n                // we only want to sort groups, so we do not sort leafs (a leaf group has leafs as children)\n                !rowNode.leafGroup;\n\n            if (doSort) {\n                rowNode.childrenAfterGroup!.sort((nodeA, nodeB) => comparator!({ nodeA, nodeB }));\n                rowNode.childrenAfterGroup!.forEach((childNode: RowNode) => recursiveSort(childNode));\n            }\n        }\n    }\n\n    private getExistingPathForNode(node: RowNode, details: GroupingDetails): GroupInfo[] {\n        const res: GroupInfo[] = [];\n\n        // when doing tree data, the node is part of the path,\n        // but when doing grid grouping, the node is not part of the path so we start with the parent.\n        let pointer = details.usingTreeData ? node : node.parent;\n        while (pointer && pointer !== details.rootNode) {\n            res.push({\n                key: pointer.key!,\n                rowGroupColumn: pointer.rowGroupColumn,\n                field: pointer.field\n            });\n            pointer = pointer.parent;\n        }\n        res.reverse();\n        return res;\n    }\n\n    private moveNodesInWrongPath(childNodes: RowNode[], details: GroupingDetails, batchRemover: BatchRemover | undefined): void {\n        childNodes.forEach(childNode => {\n\n            // we add node, even if parent has not changed, as the data could have\n            // changed, hence aggregations will be wrong\n            if (details.changedPath.isActive()) {\n                details.changedPath.addParentNode(childNode.parent);\n            }\n\n            const infoToKeyMapper = (item: GroupInfo) => item.key;\n            const oldPath: string[] = this.getExistingPathForNode(childNode, details).map(infoToKeyMapper);\n            const newPath: string[] = this.getGroupInfo(childNode, details).map(infoToKeyMapper);\n\n            const nodeInCorrectPath = _.areEqual(oldPath, newPath);\n\n            if (!nodeInCorrectPath) {\n                this.moveNode(childNode, details, batchRemover);\n            }\n        });\n    }\n\n    private moveNode(childNode: RowNode, details: GroupingDetails, batchRemover: BatchRemover | undefined): void {\n\n        this.removeNodesInStages([childNode], details, batchRemover);\n        this.insertOneNode(childNode, details, true, batchRemover);\n\n        // hack - if we didn't do this, then renaming a tree item (ie changing rowNode.key) wouldn't get\n        // refreshed into the gui.\n        // this is needed to kick off the event that rowComp listens to for refresh. this in turn\n        // then will get each cell in the row to refresh - which is what we need as we don't know which\n        // columns will be displaying the rowNode.key info.\n        childNode.setData(childNode.data);\n\n        // we add both old and new parents to changed path, as both will need to be refreshed.\n        // we already added the old parent (in calling method), so just add the new parent here\n        if (details.changedPath.isActive()) {\n            const newParent = childNode.parent;\n            details.changedPath.addParentNode(newParent);\n        }\n    }\n\n    private removeNodes(leafRowNodes: RowNode[], details: GroupingDetails, batchRemover: BatchRemover | undefined): void {\n        this.removeNodesInStages(leafRowNodes, details, batchRemover);\n        if (details.changedPath.isActive()) {\n            leafRowNodes.forEach(rowNode => details.changedPath.addParentNode(rowNode.parent));\n        }\n    }\n\n    private removeNodesInStages(leafRowNodes: RowNode[], details: GroupingDetails, batchRemover: BatchRemover | undefined): void {\n        this.removeNodesFromParents(leafRowNodes, details, batchRemover);\n        if (details.usingTreeData) {\n            this.postRemoveCreateFillerNodes(leafRowNodes, details);\n\n            // When not TreeData, then removeEmptyGroups is called just before the BatchRemover is flushed.\n            // However for TreeData, there is no BatchRemover, so we have to call removeEmptyGroups here.\n            const nodeParents = leafRowNodes.map(n => n.parent!);\n            this.removeEmptyGroups(nodeParents, details);\n        }\n    }\n\n    private forEachParentGroup(details: GroupingDetails, group: RowNode, callback: (parent: RowNode) => void): void {\n        let pointer: RowNode | null = group;\n        while (pointer && pointer !== details.rootNode) {\n            callback(pointer);\n            pointer = pointer.parent;\n        }\n    }\n\n    private removeNodesFromParents(nodesToRemove: RowNode[], details: GroupingDetails, provided: BatchRemover | undefined): void {\n        // this method can be called with BatchRemover as optional. if it is missed, we created a local version\n        // and flush it at the end. if one is provided, we add to the provided one and it gets flushed elsewhere.\n        const batchRemoverIsLocal = provided == null;\n        const batchRemoverToUse = provided ? provided : new BatchRemover();\n\n        nodesToRemove.forEach(nodeToRemove => {\n            this.removeFromParent(nodeToRemove, batchRemoverToUse);\n\n            // remove from allLeafChildren. we clear down all parents EXCEPT the Root Node, as\n            // the ClientSideNodeManager is responsible for the Root Node.\n            this.forEachParentGroup(details, nodeToRemove.parent!, parentNode => {\n                batchRemoverToUse.removeFromAllLeafChildren(parentNode, nodeToRemove);\n            });\n        });\n\n        if (batchRemoverIsLocal) {\n            batchRemoverToUse.flush();\n        }\n    }\n\n    private postRemoveCreateFillerNodes(nodesToRemove: RowNode[], details: GroupingDetails): void {\n        nodesToRemove.forEach(nodeToRemove => {\n\n            // if not group, and children are present, need to move children to a group.\n            // otherwise if no children, we can just remove without replacing.\n            const replaceWithGroup = nodeToRemove.hasChildren();\n            if (replaceWithGroup) {\n                const oldPath = this.getExistingPathForNode(nodeToRemove, details);\n                // because we just removed the userGroup, this will always return new support group\n                const newGroupNode = this.findParentForNode(nodeToRemove, oldPath, details);\n\n                // these properties are the ones that will be incorrect in the newly created group,\n                // so copy them from the old childNode\n                newGroupNode.expanded = nodeToRemove.expanded;\n                newGroupNode.allLeafChildren = nodeToRemove.allLeafChildren;\n                newGroupNode.childrenAfterGroup = nodeToRemove.childrenAfterGroup;\n                newGroupNode.childrenMapped = nodeToRemove.childrenMapped;\n                newGroupNode.updateHasChildren();\n\n                newGroupNode.childrenAfterGroup!.forEach(rowNode => rowNode.parent = newGroupNode);\n            }\n\n        });\n    }\n\n    private removeEmptyGroups(possibleEmptyGroups: RowNode[], details: GroupingDetails): void {\n        // we do this multiple times, as when we remove groups, that means the parent of just removed\n        // group can then be empty. to get around this, if we remove, then we check everything again for\n        // newly emptied groups. the max number of times this will execute is the depth of the group tree.\n        let checkAgain = true;\n\n        const groupShouldBeRemoved = (rowNode: RowNode): boolean => {\n\n            // because of the while loop below, it's possible we already moved the node,\n            // so double check before trying to remove again.\n            const mapKey = this.getChildrenMappedKey(rowNode.key!, rowNode.rowGroupColumn);\n            const parentRowNode = rowNode.parent;\n            const groupAlreadyRemoved = (parentRowNode && parentRowNode.childrenMapped) ?\n                !parentRowNode.childrenMapped[mapKey] : true;\n\n            if (groupAlreadyRemoved) {\n                // if not linked, then group was already removed\n                return false;\n            }\n            // if still not removed, then we remove if this group is empty\n            return !!rowNode.isEmptyRowGroupNode();\n        };\n\n        while (checkAgain) {\n            checkAgain = false;\n            const batchRemover: BatchRemover = new BatchRemover();\n            possibleEmptyGroups.forEach(possibleEmptyGroup => {\n                // remove empty groups\n                this.forEachParentGroup(details, possibleEmptyGroup, rowNode => {\n                    if (groupShouldBeRemoved(rowNode)) {\n                        checkAgain = true;\n                        this.removeFromParent(rowNode, batchRemover);\n                        // we remove selection on filler nodes here, as the selection would not be removed\n                        // from the RowNodeManager, as filler nodes don't exist on the RowNodeManager\n                        rowNode.setSelectedParams({ newValue: false, source: 'rowGroupChanged' });\n                    }\n                });\n            });\n            batchRemover.flush();\n        }\n    }\n\n    // removes the node from the parent by:\n    // a) removing from childrenAfterGroup (using batchRemover if present, otherwise immediately)\n    // b) removing from childrenMapped (immediately)\n    // c) setRowTop(null) - as the rowRenderer uses this to know the RowNode is no longer needed\n    // d) setRowIndex(null) - as the rowNode will no longer be displayed.\n    private removeFromParent(child: RowNode, batchRemover?: BatchRemover) {\n        if (child.parent) {\n            if (batchRemover) {\n                batchRemover.removeFromChildrenAfterGroup(child.parent, child);\n            } else {\n                _.removeFromArray(child.parent.childrenAfterGroup!, child);\n                child.parent.updateHasChildren();\n            }\n        }\n        const mapKey = this.getChildrenMappedKey(child.key!, child.rowGroupColumn);\n        if (child.parent && child.parent.childrenMapped) {\n            child.parent.childrenMapped[mapKey] = undefined;\n        }\n        // this is important for transition, see rowComp removeFirstPassFuncs. when doing animation and\n        // remove, if rowTop is still present, the rowComp thinks it's just moved position.\n        child.setRowTop(null);\n        child.setRowIndex(null);\n    }\n\n    private addToParent(child: RowNode, parent: RowNode | null) {\n        const mapKey = this.getChildrenMappedKey(child.key!, child.rowGroupColumn);\n        if (parent) {\n            const children = parent.childrenMapped != null;\n            if (children) {\n                parent.childrenMapped![mapKey] = child;\n            }\n            parent.childrenAfterGroup!.push(child);\n            parent.updateHasChildren();\n        }\n    }\n\n    private areGroupColsEqual(d1: GroupingDetails, d2: GroupingDetails): boolean {\n        if (d1 == null || d2 == null || d1.pivotMode !== d2.pivotMode) { return false; }\n\n        return _.areEqual(d1.groupedCols, d2.groupedCols) && _.areEqual(d1.keyCreators, d2.keyCreators);\n    }\n\n    private checkAllGroupDataAfterColsChanged(details: GroupingDetails): void {\n\n        const recurse = (rowNodes: RowNode[] | null) => {\n            if (!rowNodes) { return; }\n            rowNodes.forEach(rowNode => {\n                const isLeafNode = !details.usingTreeData && !rowNode.group;\n                if (isLeafNode) { return; }\n                const groupInfo: GroupInfo = {\n                    field: rowNode.field,\n                    key: rowNode.key!,\n                    rowGroupColumn: rowNode.rowGroupColumn,\n                    leafNode: rowNode.allLeafChildren[0],\n                };\n                this.setGroupData(rowNode, groupInfo, details);\n                recurse(rowNode.childrenAfterGroup);\n            });\n        };\n\n        recurse(details.rootNode.childrenAfterGroup);\n    }\n\n    private shotgunResetEverything(details: GroupingDetails, afterColumnsChanged: boolean): void {\n\n        if (this.noChangeInGroupingColumns(details, afterColumnsChanged)) {\n            return;\n        }\n\n        // groups are about to get disposed, so need to deselect any that are selected\n        this.selectionService.filterFromSelection((node: RowNode) => node && !node.group);\n\n        const { rootNode, groupedCols } = details;\n        // because we are not creating the root node each time, we have the logic\n        // here to change leafGroup once.\n        // we set .leafGroup to false for tree data, as .leafGroup is only used when pivoting, and pivoting\n        // isn't allowed with treeData, so the grid never actually use .leafGroup when doing treeData.\n        rootNode.leafGroup = details.usingTreeData ? false : groupedCols.length === 0;\n\n        // we are doing everything from scratch, so reset childrenAfterGroup and childrenMapped from the rootNode\n        rootNode.childrenAfterGroup = [];\n        rootNode.childrenMapped = {};\n        rootNode.updateHasChildren();\n\n        const sibling = rootNode.sibling;\n        if (sibling) {\n            sibling.childrenAfterGroup = rootNode.childrenAfterGroup;\n            sibling.childrenMapped = rootNode.childrenMapped;\n        }\n\n        this.insertNodes(rootNode.allLeafChildren, details, false);\n    }\n\n    private noChangeInGroupingColumns(details: GroupingDetails, afterColumnsChanged: boolean): boolean {\n        let noFurtherProcessingNeeded = false;\n\n        const groupDisplayColumns = this.columnModel.getGroupDisplayColumns();\n        const newGroupDisplayColIds = groupDisplayColumns ?\n            groupDisplayColumns.map(c => c.getId()).join('-') : '';\n\n        if (afterColumnsChanged) {\n            // we only need to redo grouping if doing normal grouping (ie not tree data)\n            // and the group cols have changed.\n            noFurtherProcessingNeeded = details.usingTreeData || this.areGroupColsEqual(details, this.oldGroupingDetails);\n\n            // if the group display cols have changed, then we need to update rowNode.groupData\n            // (regardless of tree data or row grouping)\n            if (this.oldGroupDisplayColIds !== newGroupDisplayColIds) {\n                this.checkAllGroupDataAfterColsChanged(details);\n            }\n        }\n\n        this.oldGroupingDetails = details;\n        this.oldGroupDisplayColIds = newGroupDisplayColIds;\n\n        return noFurtherProcessingNeeded;\n    }\n\n    private insertNodes(newRowNodes: RowNode[], details: GroupingDetails, isMove: boolean): void {\n        newRowNodes.forEach(rowNode => {\n            this.insertOneNode(rowNode, details, isMove);\n            if (details.changedPath.isActive()) {\n                details.changedPath.addParentNode(rowNode.parent);\n            }\n        });\n    }\n\n    private insertOneNode(childNode: RowNode, details: GroupingDetails, isMove: boolean, batchRemover?: BatchRemover): void {\n\n        const path: GroupInfo[] = this.getGroupInfo(childNode, details);\n\n        const parentGroup = this.findParentForNode(childNode, path, details, batchRemover);\n        if (!parentGroup.group) {\n            console.warn(`AG Grid: duplicate group keys for row data, keys should be unique`,\n                [parentGroup.data, childNode.data]);\n        }\n\n        if (details.usingTreeData) {\n            this.swapGroupWithUserNode(parentGroup, childNode, isMove);\n        } else {\n            childNode.parent = parentGroup;\n            childNode.level = path.length;\n            parentGroup.childrenAfterGroup!.push(childNode);\n            parentGroup.updateHasChildren();\n        }\n    }\n\n    private findParentForNode(childNode: RowNode, path: GroupInfo[], details: GroupingDetails, batchRemover?: BatchRemover): RowNode {\n        let nextNode: RowNode = details.rootNode;\n\n        path.forEach((groupInfo, level) => {\n            nextNode = this.getOrCreateNextNode(nextNode, groupInfo, level, details);\n            // node gets added to all group nodes.\n            // note: we do not add to rootNode here, as the rootNode is the master list of rowNodes\n\n            if (!batchRemover?.isRemoveFromAllLeafChildren(nextNode, childNode)) {\n                nextNode.allLeafChildren.push(childNode);\n            } else {\n                // if this node is about to be removed, prevent that\n                batchRemover?.preventRemoveFromAllLeafChildren(nextNode, childNode);\n            }\n        });\n\n        return nextNode;\n    }\n\n    private swapGroupWithUserNode(fillerGroup: RowNode, userGroup: RowNode, isMove: boolean) {\n        userGroup.parent = fillerGroup.parent;\n        userGroup.key = fillerGroup.key;\n        userGroup.field = fillerGroup.field;\n        userGroup.groupData = fillerGroup.groupData;\n        userGroup.level = fillerGroup.level;\n        // AG-3441 - preserve the existing expanded status of the node if we're moving it, so that\n        // you can drag a sub tree from one parent to another without changing its expansion\n        if (!isMove) {\n            userGroup.expanded = fillerGroup.expanded;\n        }\n\n        // we set .leafGroup to false for tree data, as .leafGroup is only used when pivoting, and pivoting\n        // isn't allowed with treeData, so the grid never actually use .leafGroup when doing treeData.\n        userGroup.leafGroup = fillerGroup.leafGroup;\n\n        // always null for userGroups, as row grouping is not allowed when doing tree data\n        userGroup.rowGroupIndex = fillerGroup.rowGroupIndex;\n\n        userGroup.allLeafChildren = fillerGroup.allLeafChildren;\n        userGroup.childrenAfterGroup = fillerGroup.childrenAfterGroup;\n        userGroup.childrenMapped = fillerGroup.childrenMapped;\n        userGroup.sibling = fillerGroup.sibling;\n        userGroup.updateHasChildren();\n\n        this.removeFromParent(fillerGroup);\n        userGroup.childrenAfterGroup!.forEach((rowNode: RowNode) => rowNode.parent = userGroup);\n        this.addToParent(userGroup, fillerGroup.parent);\n    }\n\n    private getOrCreateNextNode(parentGroup: RowNode, groupInfo: GroupInfo, level: number,\n        details: GroupingDetails): RowNode {\n\n        const key = this.getChildrenMappedKey(groupInfo.key, groupInfo.rowGroupColumn);\n        let nextNode = parentGroup.childrenMapped ? parentGroup.childrenMapped[key] : undefined;\n\n        if (!nextNode) {\n            nextNode = this.createGroup(groupInfo, parentGroup, level, details);\n            // attach the new group to the parent\n            this.addToParent(nextNode, parentGroup);\n        }\n\n        return nextNode;\n    }\n\n    private createGroup(groupInfo: GroupInfo, parent: RowNode, level: number, details: GroupingDetails): RowNode {\n        const groupNode = new RowNode(this.beans);\n\n        groupNode.group = true;\n        groupNode.field = groupInfo.field;\n        groupNode.rowGroupColumn = groupInfo.rowGroupColumn;\n\n        this.setGroupData(groupNode, groupInfo, details);\n\n        groupNode.key = groupInfo.key;\n        groupNode.id = this.createGroupId(groupNode, parent, details.usingTreeData, level);\n\n        groupNode.level = level;\n        groupNode.leafGroup = details.usingTreeData ? false : level === (details.groupedColCount - 1);\n\n        groupNode.allLeafChildren = [];\n\n        // why is this done here? we are not updating the children count as we go,\n        // i suspect this is updated in the filter stage\n        groupNode.setAllChildrenCount(0);\n\n        groupNode.rowGroupIndex = details.usingTreeData ? null : level;\n\n        groupNode.childrenAfterGroup = [];\n        groupNode.childrenMapped = {};\n        groupNode.updateHasChildren();\n\n        groupNode.parent = details.includeParents ? parent : null;\n\n        this.setExpandedInitialValue(details, groupNode);\n\n        return groupNode;\n    }\n\n    private createGroupId(node: RowNode, parent: RowNode, usingTreeData: boolean, level: number): string {\n        let createGroupId: (node: RowNode, parent: RowNode | null, level: number) => string | null;\n        if (usingTreeData) {\n            createGroupId = (node, parent, level) => {\n                if (level < 0) { return null; } // root node\n                const parentId = parent ? createGroupId(parent, parent.parent, level - 1) : null;\n                return `${parentId == null ? '' : parentId + '-'}${level}-${node.key}`;\n            };\n        } else {\n            createGroupId = (node, parent) => {\n                if (!node.rowGroupColumn) { return null; } // root node\n                const parentId = parent ? createGroupId(parent, parent.parent, 0) : null;\n                return `${parentId == null ? '' : parentId + '-'}${node.rowGroupColumn.getColId()}-${node.key}`;\n            };\n        }\n\n        // we put 'row-group-' before the group id, so it doesn't clash with standard row id's. we also use 't-' and 'b-'\n        // for top pinned and bottom pinned rows.\n        return RowNode.ID_PREFIX_ROW_GROUP + createGroupId(node, parent, level);\n    }\n\n    private setGroupData(groupNode: RowNode, groupInfo: GroupInfo, details: GroupingDetails): void {\n        groupNode.groupData = {};\n        const groupDisplayCols: Column[] = this.columnModel.getGroupDisplayColumns();\n        groupDisplayCols.forEach(col => {\n            // newGroup.rowGroupColumn=null when working off GroupInfo, and we always display the group in the group column\n            // if rowGroupColumn is present, then it's grid row grouping and we only include if configuration says so\n            const isTreeData = details.usingTreeData;\n            if (isTreeData) {\n                groupNode.groupData![col.getColId()] = groupInfo.key;\n                return;\n            }\n\n            const groupColumn = groupNode.rowGroupColumn;\n            const isRowGroupDisplayed = groupColumn !== null && col.isRowGroupDisplayed(groupColumn.getId());\n            if (isRowGroupDisplayed) {\n                if (details.suppressGroupMaintainValueType) {\n                    groupNode.groupData![col.getColId()] = groupInfo.key;\n                } else {\n                    // if maintain group value type, get the value from any leaf node.\n                    groupNode.groupData![col.getColId()] = this.valueService.getValue(groupColumn, groupInfo.leafNode);\n                }\n            }\n        });\n    }\n\n    private getChildrenMappedKey(key: string, rowGroupColumn: Column | null): string {\n        if (rowGroupColumn) {\n            // grouping by columns\n            return rowGroupColumn.getId() + '-' + key;\n        }\n        // tree data - we don't have rowGroupColumns\n        return key;\n    }\n\n    private setExpandedInitialValue(details: GroupingDetails, groupNode: RowNode): void {\n        // if pivoting the leaf group is never expanded as we do not show leaf rows\n        if (details.pivotMode && groupNode.leafGroup) {\n            groupNode.expanded = false;\n            return;\n        }\n\n        // use callback if exists\n        const userCallback = details.isGroupOpenByDefault;\n        if (userCallback) {\n            const params: WithoutGridCommon<IsGroupOpenByDefaultParams> = {\n                rowNode: groupNode,\n                field: groupNode.field!,\n                key: groupNode.key!,\n                level: groupNode.level,\n                rowGroupColumn: groupNode.rowGroupColumn!\n            };\n            groupNode.expanded = userCallback(params) == true;\n            return;\n        }\n\n        // use expandByDefault if exists\n        const { expandByDefault } = details;\n        if (details.expandByDefault === -1) {\n            groupNode.expanded = true;\n            return;\n        }\n\n        // otherwise\n        groupNode.expanded = groupNode.level < expandByDefault;\n    }\n\n    private getGroupInfo(rowNode: RowNode, details: GroupingDetails): GroupInfo[] {\n        if (details.usingTreeData) {\n            return this.getGroupInfoFromCallback(rowNode, details);\n        }\n        return this.getGroupInfoFromGroupColumns(rowNode, details);\n    }\n\n    private getGroupInfoFromCallback(rowNode: RowNode, details: GroupingDetails): GroupInfo[] {        \n        const keys: string[] | null = details.getDataPath ? details.getDataPath(rowNode.data) : null;\n\n        if (keys === null || keys === undefined || keys.length === 0) {\n            _.warnOnce(`getDataPath() should not return an empty path for data ${rowNode.data}`);\n        }\n        const groupInfoMapper = (key: string | null) => ({ key, field: null, rowGroupColumn: null }) as GroupInfo;\n        return keys ? keys.map(groupInfoMapper) : [];\n    }\n\n    private getGroupInfoFromGroupColumns(rowNode: RowNode, details: GroupingDetails) {\n        const res: GroupInfo[] = [];\n        details.groupedCols.forEach(groupCol => {\n            let key: string = this.valueService.getKeyForNode(groupCol, rowNode);\n            let keyExists = key !== null && key !== undefined && key !== '';\n\n            // unbalanced tree and pivot mode don't work together - not because of the grid, it doesn't make\n            // mathematical sense as you are building up a cube. so if pivot mode, we put in a blank key where missing.\n            // this keeps the tree balanced and hence can be represented as a group.\n            const createGroupForEmpty = details.pivotMode || !details.groupAllowUnbalanced;\n            if (createGroupForEmpty && !keyExists) {\n                key = '';\n                keyExists = true;\n            }\n\n            if (keyExists) {\n                const item = {\n                    key: key,\n                    field: groupCol.getColDef().field,\n                    rowGroupColumn: groupCol,\n                    leafNode: rowNode,\n                } as GroupInfo;\n                res.push(item);\n            }\n        });\n        return res;\n    }\n}"]}