@eui/components 17.0.0-next.20 → 17.0.0-next.21

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 (258) hide show
  1. package/docs/classes/EuiTreeHelper.html +85 -0
  2. package/docs/classes/EuiTreePagination.html +514 -0
  3. package/docs/components/ChartComponent.html +1 -1
  4. package/docs/components/CollapsedBreadcrumbComponent.html +1 -1
  5. package/docs/components/EclMessageWcComponent.html +1 -1
  6. package/docs/components/EuiAccessibleButtonIconComponent.html +1 -1
  7. package/docs/components/EuiAlertComponent.html +96 -609
  8. package/docs/components/EuiAppBreadcrumbComponent.html +1 -1
  9. package/docs/components/EuiAppComponent.html +1 -1
  10. package/docs/components/EuiAppFooterComponent.html +1 -1
  11. package/docs/components/EuiAppHeaderComponent.html +1 -1
  12. package/docs/components/EuiAppSidebarBodyComponent.html +1 -1
  13. package/docs/components/EuiAppSidebarComponent.html +1 -1
  14. package/docs/components/EuiAppSidebarDrawerComponent.html +1 -1
  15. package/docs/components/EuiAppSidebarFooterComponent.html +1 -1
  16. package/docs/components/EuiAppSidebarHeaderComponent.html +1 -1
  17. package/docs/components/EuiAppSidebarHeaderUserProfileComponent.html +1 -1
  18. package/docs/components/EuiAppSidebarMenuComponent.html +1 -1
  19. package/docs/components/EuiAppToolbarComponent.html +1 -1
  20. package/docs/components/EuiAppTopMessageComponent.html +1 -1
  21. package/docs/components/EuiAutocompleteAsyncTestComponent.html +1 -1
  22. package/docs/components/EuiAutocompleteChipsAsyncTestComponent.html +1 -1
  23. package/docs/components/EuiAutocompleteChipsTestComponent.html +1 -1
  24. package/docs/components/EuiAutocompleteComponent.html +1 -1
  25. package/docs/components/EuiAutocompleteTestComponent.html +1 -1
  26. package/docs/components/EuiAvatarBadgeComponent.html +1 -1
  27. package/docs/components/EuiAvatarComponent.html +1 -1
  28. package/docs/components/EuiAvatarIconComponent.html +1 -1
  29. package/docs/components/EuiAvatarImageComponent.html +1 -1
  30. package/docs/components/EuiAvatarListComponent.html +1 -1
  31. package/docs/components/EuiAvatarTextComponent.html +1 -1
  32. package/docs/components/EuiBadgeComponent.html +1 -1
  33. package/docs/components/EuiBlockContentComponent.html +1 -1
  34. package/docs/components/EuiBlockDocumentComponent.html +1 -1
  35. package/docs/components/EuiBreadcrumbComponent.html +1 -1
  36. package/docs/components/EuiBreadcrumbItemComponent.html +1 -1
  37. package/docs/components/EuiButtonComponent.html +1 -1
  38. package/docs/components/EuiButtonGroupComponent.html +1 -1
  39. package/docs/components/EuiButtonsComponent.html +1 -1
  40. package/docs/components/EuiCardComponent.html +1 -1
  41. package/docs/components/EuiCardContentComponent.html +1 -1
  42. package/docs/components/EuiCardFooterActionButtonsComponent.html +1 -1
  43. package/docs/components/EuiCardFooterActionIconsComponent.html +1 -1
  44. package/docs/components/EuiCardFooterComponent.html +1 -1
  45. package/docs/components/EuiCardFooterMenuContentComponent.html +1 -1
  46. package/docs/components/EuiCardHeaderBodyComponent.html +1 -1
  47. package/docs/components/EuiCardHeaderComponent.html +1 -1
  48. package/docs/components/EuiCardHeaderLeftContentComponent.html +1 -1
  49. package/docs/components/EuiCardHeaderRightContentComponent.html +1 -1
  50. package/docs/components/EuiCardHeaderSubtitleComponent.html +1 -1
  51. package/docs/components/EuiCardHeaderTitleComponent.html +1 -1
  52. package/docs/components/EuiCardMediaComponent.html +1 -1
  53. package/docs/components/EuiChipComponent.html +1 -1
  54. package/docs/components/EuiChipListComponent.html +1 -1
  55. package/docs/components/EuiCommonHeaderComponent.html +1 -1
  56. package/docs/components/EuiDashboardButtonComponent.html +1 -1
  57. package/docs/components/EuiDashboardCardComponent.html +1 -1
  58. package/docs/components/EuiDateRangeSelectorComponent.html +70 -2
  59. package/docs/components/EuiDatepickerComponent.html +1 -1
  60. package/docs/components/EuiDialogComponent.html +1 -1
  61. package/docs/components/EuiDialogContainerComponent.html +1 -1
  62. package/docs/components/EuiDimmerComponent.html +1 -1
  63. package/docs/components/EuiDisableContentComponent.html +1 -1
  64. package/docs/components/EuiDiscussionThreadComponent.html +1 -1
  65. package/docs/components/EuiDiscussionThreadItemComponent.html +1 -1
  66. package/docs/components/EuiDropdownComponent.html +1 -1
  67. package/docs/components/EuiDropdownItemComponent.html +1 -1
  68. package/docs/components/EuiEclBannerComponent.html +1 -1
  69. package/docs/components/EuiEclButtonComponent.html +1 -1
  70. package/docs/components/EuiEclCarouselComponent.html +1 -1
  71. package/docs/components/EuiEclCarouselItemComponent.html +1 -1
  72. package/docs/components/EuiEclIconComponent.html +1 -1
  73. package/docs/components/EuiEclMessageComponent.html +1 -1
  74. package/docs/components/EuiEditorComponent.html +1 -1
  75. package/docs/components/EuiEditorCountersComponent.html +1 -1
  76. package/docs/components/EuiEditorHtmlViewComponent.html +1 -1
  77. package/docs/components/EuiEditorImageDialogComponent.html +1 -1
  78. package/docs/components/EuiEditorJsonViewComponent.html +1 -1
  79. package/docs/components/EuiExpandContentComponent.html +1 -1
  80. package/docs/components/EuiFeedbackMessageComponent.html +1 -1
  81. package/docs/components/EuiFieldsetComponent.html +1 -1
  82. package/docs/components/EuiFilePreviewComponent.html +1 -1
  83. package/docs/components/EuiFileUploadComponent.html +1 -2
  84. package/docs/components/EuiFileUploadProgressComponent.html +1 -1
  85. package/docs/components/EuiFooterComponent.html +1 -1
  86. package/docs/components/EuiGrowlComponent.html +1 -1
  87. package/docs/components/EuiHeaderAppComponent.html +1 -1
  88. package/docs/components/EuiHeaderAppNameComponent.html +1 -1
  89. package/docs/components/EuiHeaderAppNameLogoComponent.html +1 -1
  90. package/docs/components/EuiHeaderAppSubtitleComponent.html +1 -1
  91. package/docs/components/EuiHeaderComponent.html +1 -1
  92. package/docs/components/EuiHeaderEnvironmentComponent.html +1 -1
  93. package/docs/components/EuiHeaderLogoComponent.html +1 -1
  94. package/docs/components/EuiHeaderUserProfileComponent.html +1 -1
  95. package/docs/components/EuiIconColorComponent.html +1 -1
  96. package/docs/components/EuiIconComponent.html +1 -1
  97. package/docs/components/EuiIconSvgComponent.html +1 -1
  98. package/docs/components/EuiIconToggleComponent.html +1 -1
  99. package/docs/components/EuiInputCheckboxComponent.html +1 -1
  100. package/docs/components/EuiInputGroupComponent.html +1 -1
  101. package/docs/components/EuiInputNumberComponent.html +14 -2
  102. package/docs/components/EuiInputRadioComponent.html +1 -1
  103. package/docs/components/EuiInputTextComponent.html +1 -1
  104. package/docs/components/EuiLabelComponent.html +1 -1
  105. package/docs/components/EuiLanguageSelectorComponent.html +1 -1
  106. package/docs/components/EuiListComponent.html +1 -1
  107. package/docs/components/EuiListItemComponent.html +1 -1
  108. package/docs/components/EuiMenuComponent.html +1 -1
  109. package/docs/components/EuiMenuItemComponent.html +1 -1
  110. package/docs/components/EuiMessageBoxComponent.html +1 -1
  111. package/docs/components/EuiModalSelectorComponent.html +1 -1
  112. package/docs/components/EuiNotificationItemComponent.html +1 -1
  113. package/docs/components/EuiNotificationItemV2Component.html +1 -1
  114. package/docs/components/EuiNotificationsComponent.html +1 -1
  115. package/docs/components/EuiNotificationsV2Component.html +1 -1
  116. package/docs/components/EuiOverlayBodyComponent.html +1 -1
  117. package/docs/components/EuiOverlayComponent.html +1 -1
  118. package/docs/components/EuiOverlayFooterComponent.html +1 -1
  119. package/docs/components/EuiOverlayHeaderComponent.html +1 -1
  120. package/docs/components/EuiOverlayHeaderTitleComponent.html +1 -1
  121. package/docs/components/EuiPageBreadcrumbComponent.html +1 -1
  122. package/docs/components/EuiPageColumnComponent.html +1 -1
  123. package/docs/components/EuiPageColumnsComponent.html +1 -1
  124. package/docs/components/EuiPageComponent.html +1 -1
  125. package/docs/components/EuiPageContentComponent.html +1 -1
  126. package/docs/components/EuiPageFooterComponent.html +1 -1
  127. package/docs/components/EuiPageHeaderComponent.html +1 -1
  128. package/docs/components/EuiPageHeroHeaderComponent.html +1 -1
  129. package/docs/components/EuiPageTopContentComponent.html +1 -1
  130. package/docs/components/EuiPaginatorComponent.html +1 -1
  131. package/docs/components/EuiPopoverComponent.html +1 -1
  132. package/docs/components/EuiProgressBarComponent.html +1 -1
  133. package/docs/components/EuiProgressCircleComponent.html +1 -1
  134. package/docs/components/EuiResizableComponent.html +1 -1
  135. package/docs/components/EuiSearchComponent.html +1 -1
  136. package/docs/components/EuiSelectComponent.html +1 -1
  137. package/docs/components/EuiSidebarMenuComponent.html +1 -1
  138. package/docs/components/EuiSidebarToggleComponent.html +1 -1
  139. package/docs/components/EuiSlideToggleComponent.html +1 -1
  140. package/docs/components/EuiSlideToggleTestComponent.html +1 -1
  141. package/docs/components/EuiTabComponent.html +1 -1
  142. package/docs/components/EuiTabContentComponent.html +1 -1
  143. package/docs/components/EuiTabLabelComponent.html +1 -1
  144. package/docs/components/EuiTableComponent.html +1 -1
  145. package/docs/components/EuiTableExpandableRowComponent.html +1 -1
  146. package/docs/components/EuiTableFilterComponent.html +1 -1
  147. package/docs/components/EuiTableSelectableHeaderComponent.html +2 -2
  148. package/docs/components/EuiTableSelectableRowComponent.html +1 -1
  149. package/docs/components/EuiTableSortableColComponent.html +1 -1
  150. package/docs/components/EuiTabsComponent.html +1 -1
  151. package/docs/components/EuiTextareaComponent.html +1 -1
  152. package/docs/components/EuiTimebarComponent.html +1 -1
  153. package/docs/components/EuiTimelineComponent.html +1 -1
  154. package/docs/components/EuiTimelineItemComponent.html +1 -1
  155. package/docs/components/EuiTimepickerComponent.html +1 -1
  156. package/docs/components/EuiToolbarAppComponent.html +1 -1
  157. package/docs/components/EuiToolbarCenterComponent.html +1 -1
  158. package/docs/components/EuiToolbarComponent.html +1 -1
  159. package/docs/components/EuiToolbarEnvironmentComponent.html +1 -1
  160. package/docs/components/EuiToolbarItemComponent.html +1 -1
  161. package/docs/components/EuiToolbarItemNotificationsComponent.html +1 -1
  162. package/docs/components/EuiToolbarItemSearchComponent.html +1 -1
  163. package/docs/components/EuiToolbarItemUserProfileComponent.html +1 -1
  164. package/docs/components/EuiToolbarItemsComponent.html +1 -1
  165. package/docs/components/EuiToolbarLogoComponent.html +1 -1
  166. package/docs/components/EuiToolbarMenuComponent.html +1 -1
  167. package/docs/components/EuiTooltipContainerComponent.html +1 -1
  168. package/docs/components/EuiTreeComponent.html +527 -55
  169. package/docs/components/EuiTreeListComponent.html +1 -1
  170. package/docs/components/EuiTreeListItemComponent.html +1 -1
  171. package/docs/components/EuiTreeListItemContentComponent.html +1 -1
  172. package/docs/components/EuiTreeListToolbarComponent.html +1 -1
  173. package/docs/components/EuiUserProfileCardComponent.html +1 -1
  174. package/docs/components/EuiUserProfileComponent.html +1 -1
  175. package/docs/components/EuiUserProfileMenuComponent.html +1 -1
  176. package/docs/components/EuiUserProfileMenuItemComponent.html +1 -1
  177. package/docs/components/EuiUxTreeComponent.html +1 -1
  178. package/docs/components/EuiUxTreeNodeComponent.html +1 -1
  179. package/docs/components/EuiUxTreeToolbarComponent.html +1 -1
  180. package/docs/components/EuiWizardComponent.html +1 -1
  181. package/docs/components/EuiWizardStepComponent.html +1 -1
  182. package/docs/components/QuillEditorComponent.html +1 -1
  183. package/docs/dependencies.html +2 -2
  184. package/docs/directives/EuiAlertTitleDirective.html +284 -0
  185. package/docs/index.html +3 -3
  186. package/docs/interfaces/MultiSelectionLogic.html +259 -0
  187. package/docs/interfaces/SelectConfigModel.html +52 -0
  188. package/docs/interfaces/SingleSelectionLogic.html +214 -0
  189. package/docs/js/menu-wc.js +29 -6
  190. package/docs/js/menu-wc_es5.js +1 -1
  191. package/docs/js/search/search_index.js +2 -2
  192. package/docs/miscellaneous/typealiases.html +2 -2
  193. package/docs/modules/EuiAlertModule.html +9 -0
  194. package/esm2022/eui-alert/eui-alert.component.mjs +80 -35
  195. package/esm2022/eui-card/eui-card.component.mjs +2 -2
  196. package/esm2022/eui-date-range-selector/eui-date-range-selector.component.mjs +13 -3
  197. package/esm2022/eui-dialog/container/eui-dialog-container.component.mjs +2 -2
  198. package/esm2022/eui-dialog/eui-dialog.component.mjs +2 -2
  199. package/esm2022/eui-dropdown/dropdown-item/eui-dropdown-item.component.mjs +2 -2
  200. package/esm2022/eui-dropdown/eui-dropdown.component.mjs +2 -2
  201. package/esm2022/eui-file-upload/eui-file-upload.component.mjs +8 -7
  202. package/esm2022/eui-file-upload/file-preview/file-preview.component.mjs +2 -2
  203. package/esm2022/eui-growl/eui-growl.component.mjs +2 -2
  204. package/esm2022/eui-input-number/eui-input-number.component.mjs +17 -9
  205. package/esm2022/eui-overlay/components/eui-overlay-body/eui-overlay-body.component.mjs +2 -2
  206. package/esm2022/eui-overlay/components/eui-overlay-footer/eui-overlay-footer.component.mjs +2 -2
  207. package/esm2022/eui-overlay/components/eui-overlay-header/eui-overlay-header.component.mjs +2 -2
  208. package/esm2022/eui-overlay/eui-overlay.component.mjs +2 -2
  209. package/esm2022/eui-page/eui-page.component.mjs +2 -2
  210. package/esm2022/eui-select/eui-select.component.mjs +2 -2
  211. package/esm2022/eui-sidebar-menu/eui-sidebar-menu.component.mjs +2 -2
  212. package/esm2022/eui-table/eui-table.component.mjs +2 -2
  213. package/esm2022/eui-table/selectable-header/eui-table-selectable-header.component.mjs +3 -3
  214. package/esm2022/eui-tabs/eui-tab/eui-tab.component.mjs +2 -2
  215. package/esm2022/eui-tabs/eui-tabs.component.mjs +2 -2
  216. package/esm2022/eui-textarea/eui-textarea.component.mjs +2 -2
  217. package/esm2022/eui-tree/eui-tree-helper.mjs +8 -1
  218. package/esm2022/eui-tree/eui-tree.component.mjs +450 -184
  219. package/esm2022/eui-tree/eui-tree.model.mjs +41 -1
  220. package/esm2022/layout/eui-app/eui-app-sidebar/sidebar.component.mjs +2 -2
  221. package/eui-alert/eui-alert.component.d.ts +23 -11
  222. package/eui-alert/eui-alert.component.d.ts.map +1 -1
  223. package/eui-date-range-selector/eui-date-range-selector.component.d.ts +2 -0
  224. package/eui-date-range-selector/eui-date-range-selector.component.d.ts.map +1 -1
  225. package/eui-file-upload/eui-file-upload.component.d.ts +2 -3
  226. package/eui-file-upload/eui-file-upload.component.d.ts.map +1 -1
  227. package/eui-input-number/eui-input-number.component.d.ts +3 -2
  228. package/eui-input-number/eui-input-number.component.d.ts.map +1 -1
  229. package/eui-tree/eui-tree-helper.d.ts +1 -0
  230. package/eui-tree/eui-tree-helper.d.ts.map +1 -1
  231. package/eui-tree/eui-tree.component.d.ts +46 -19
  232. package/eui-tree/eui-tree.component.d.ts.map +1 -1
  233. package/eui-tree/eui-tree.model.d.ts +41 -7
  234. package/eui-tree/eui-tree.model.d.ts.map +1 -1
  235. package/fesm2022/eui-components-eui-alert.mjs +80 -35
  236. package/fesm2022/eui-components-eui-alert.mjs.map +1 -1
  237. package/fesm2022/eui-components-eui-card.mjs +2 -2
  238. package/fesm2022/eui-components-eui-date-range-selector.mjs +12 -2
  239. package/fesm2022/eui-components-eui-date-range-selector.mjs.map +1 -1
  240. package/fesm2022/eui-components-eui-dialog.mjs +4 -4
  241. package/fesm2022/eui-components-eui-dropdown.mjs +4 -4
  242. package/fesm2022/eui-components-eui-file-upload.mjs +8 -7
  243. package/fesm2022/eui-components-eui-file-upload.mjs.map +1 -1
  244. package/fesm2022/eui-components-eui-growl.mjs +2 -2
  245. package/fesm2022/eui-components-eui-input-number.mjs +16 -8
  246. package/fesm2022/eui-components-eui-input-number.mjs.map +1 -1
  247. package/fesm2022/eui-components-eui-overlay.mjs +8 -8
  248. package/fesm2022/eui-components-eui-page.mjs +2 -2
  249. package/fesm2022/eui-components-eui-select.mjs +2 -2
  250. package/fesm2022/eui-components-eui-sidebar-menu.mjs +2 -2
  251. package/fesm2022/eui-components-eui-table.mjs +4 -4
  252. package/fesm2022/eui-components-eui-table.mjs.map +1 -1
  253. package/fesm2022/eui-components-eui-tabs.mjs +4 -4
  254. package/fesm2022/eui-components-eui-textarea.mjs +2 -2
  255. package/fesm2022/eui-components-eui-tree.mjs +533 -221
  256. package/fesm2022/eui-components-eui-tree.mjs.map +1 -1
  257. package/fesm2022/eui-components-layout.mjs +2 -2
  258. package/package.json +7 -7
@@ -1,6 +1,7 @@
1
- import { Component, Input, NgModule, ChangeDetectionStrategy, EventEmitter, Output, ViewEncapsulation, HostBinding, } from '@angular/core';
1
+ import { Component, Input, NgModule, ChangeDetectionStrategy, EventEmitter, Output, ViewEncapsulation, HostBinding, ViewChild, } from '@angular/core';
2
2
  import { CommonModule } from '@angular/common';
3
3
  import { RouterModule } from '@angular/router';
4
+ import { EuiTreePagination, } from './eui-tree.model';
4
5
  import { FormsModule } from '@angular/forms';
5
6
  import { EuiInputCheckboxModule } from '@eui/components/eui-input-checkbox';
6
7
  import { EuiButtonModule } from '@eui/components/eui-button';
@@ -13,36 +14,26 @@ import { NestedTreeControl, CdkTreeModule } from '@angular/cdk/tree';
13
14
  import { ArrayDataSource, SelectionModel } from '@angular/cdk/collections';
14
15
  import { coerceBooleanProperty } from '@angular/cdk/coercion';
15
16
  import { TranslateModule } from '@ngx-translate/core';
17
+ import { ScrollingModule, CdkScrollable } from '@angular/cdk/scrolling';
18
+ import { debounceTime } from 'rxjs';
16
19
  import * as i0 from "@angular/core";
17
- import * as i1 from "@angular/common";
18
- import * as i2 from "@angular/router";
19
- import * as i3 from "@eui/components/eui-input-checkbox";
20
- import * as i4 from "@angular/cdk/tree";
21
- import * as i5 from "@eui/components/eui-button";
22
- import * as i6 from "@eui/components/eui-icon";
23
- import * as i7 from "@eui/components/eui-label";
24
- import * as i8 from "@eui/components/eui-badge";
25
- import * as i9 from "@eui/components/eui-chip";
26
- import * as i10 from "@eui/components/eui-dropdown";
27
- import * as i11 from "@ngx-translate/core";
20
+ import * as i1 from "@angular/cdk/scrolling";
21
+ import * as i2 from "@angular/common";
22
+ import * as i3 from "@angular/router";
23
+ import * as i4 from "@eui/components/eui-input-checkbox";
24
+ import * as i5 from "@angular/cdk/tree";
25
+ import * as i6 from "@eui/components/eui-button";
26
+ import * as i7 from "@eui/components/eui-icon";
27
+ import * as i8 from "@eui/components/eui-label";
28
+ import * as i9 from "@eui/components/eui-badge";
29
+ import * as i10 from "@eui/components/eui-chip";
30
+ import * as i11 from "@eui/components/eui-dropdown";
31
+ import * as i12 from "@ngx-translate/core";
28
32
  export class EuiTreeComponent {
29
33
  get cssClasses() {
30
34
  return this.getCssClasses();
31
35
  }
32
36
  // @ViewChild('treeComponentInstance') public treeComponentInstance: any;
33
- // @ViewChild('treeComponentInstance') public treeComponentInstance: any;
34
- get showUnderlinedLinks() {
35
- return this._showUnderlinedLinks;
36
- }
37
- set showUnderlinedLinks(value) {
38
- this._showUnderlinedLinks = coerceBooleanProperty(value);
39
- }
40
- get showLines() {
41
- return this._showLines;
42
- }
43
- set showLines(value) {
44
- this._showLines = coerceBooleanProperty(value);
45
- }
46
37
  get isClickTogglingNode() {
47
38
  return this._isClickTogglingNode;
48
39
  }
@@ -55,6 +46,12 @@ export class EuiTreeComponent {
55
46
  set isMultiselect(value) {
56
47
  this._isMultiselect = coerceBooleanProperty(value);
57
48
  }
49
+ get isSingleSelect() {
50
+ return this._isSingleSelect;
51
+ }
52
+ set isSingleSelect(value) {
53
+ this._isSingleSelect = coerceBooleanProperty(value);
54
+ }
58
55
  get isRecursiveSelection() {
59
56
  return this._isRecursiveSelection;
60
57
  }
@@ -67,14 +64,33 @@ export class EuiTreeComponent {
67
64
  set isRecursiveParentSelection(value) {
68
65
  this._isRecursiveParentSelection = coerceBooleanProperty(value);
69
66
  }
67
+ get showUnderlinedLinks() {
68
+ return this._showUnderlinedLinks;
69
+ }
70
+ set showUnderlinedLinks(value) {
71
+ this._showUnderlinedLinks = coerceBooleanProperty(value);
72
+ }
73
+ get showLines() {
74
+ return this._showLines;
75
+ }
76
+ set showLines(value) {
77
+ this._showLines = coerceBooleanProperty(value);
78
+ }
70
79
  get autoTranslate() {
71
80
  return this._autoTranslate;
72
81
  }
73
82
  set autoTranslate(value) {
74
83
  this._autoTranslate = coerceBooleanProperty(value);
75
84
  }
76
- constructor(changeDetectorRef) {
85
+ get highlightPath() {
86
+ return this._highlightPath;
87
+ }
88
+ set highlightPath(value) {
89
+ this._highlightPath = coerceBooleanProperty(value);
90
+ }
91
+ constructor(changeDetectorRef, scrollDispatcher) {
77
92
  this.changeDetectorRef = changeDetectorRef;
93
+ this.scrollDispatcher = scrollDispatcher;
78
94
  this.e2eAttr = 'eui-tree';
79
95
  this.expandedSvgIconClass = 'eui-chevron-forward:eui';
80
96
  this.collapsedSvgIconClass = 'eui-chevron-down:eui';
@@ -84,17 +100,20 @@ export class EuiTreeComponent {
84
100
  this.uid = Math.floor(Math.random() * 1000000000).toString();
85
101
  this._isClickTogglingNode = false;
86
102
  this._isMultiselect = false;
103
+ this._isSingleSelect = false;
87
104
  this._isRecursiveSelection = false;
88
105
  this._isRecursiveParentSelection = true;
89
- this._autoTranslate = true;
106
+ this._showUnderlinedLinks = false;
90
107
  this._showLines = false;
91
- this.hasChild = (_, item) => !!item?.children && item?.children?.length > 0;
108
+ this._autoTranslate = true;
109
+ this._highlightPath = false;
110
+ this.hasChild = (_, item) => !!item?.children && item?.children?.length >= 0;
92
111
  }
93
112
  ngOnInit() {
94
113
  this.initTree();
95
114
  }
96
115
  ngOnChanges(changes) {
97
- if (changes['nodes'].currentValue !== changes['nodes'].previousValue) {
116
+ if (changes['nodes']?.currentValue !== changes['nodes']?.previousValue) {
98
117
  this.renderTree = false;
99
118
  this.initTree();
100
119
  }
@@ -103,14 +122,25 @@ export class EuiTreeComponent {
103
122
  if (this.selectionModelSubs) {
104
123
  this.selectionModelSubs.unsubscribe();
105
124
  }
125
+ if (this.scrollDispatcherSubs) {
126
+ this.scrollDispatcherSubs.unsubscribe();
127
+ }
106
128
  }
107
129
  getSelection() {
108
130
  return this._selection;
109
131
  }
132
+ getProcessedNodes() {
133
+ return this.processedNodes;
134
+ }
135
+ // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html
136
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
137
+ trackBy(index, item) {
138
+ return item.path;
139
+ }
110
140
  // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html
111
141
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
112
- trackBy(index, el) {
113
- return el.parent;
142
+ trackByControl(item) {
143
+ return item;
114
144
  }
115
145
  getTreeItem(path) {
116
146
  const indexArr = this.resolvePath(path);
@@ -143,102 +173,154 @@ export class EuiTreeComponent {
143
173
  this.changeDetectorRef.markForCheck();
144
174
  }
145
175
  filterTerm(filterInput) {
146
- if (filterInput && filterInput !== '') {
176
+ if (filterInput !== '' && filterInput !== null && typeof filterInput !== 'undefined') {
177
+ this.treeDataRunTime = this.filterTreeData(structuredClone(this.treeDataRunTimeBackup), 'label', filterInput);
178
+ this.treeDataRunTime = this.applyRunTimeLastItems(this.treeDataRunTime);
179
+ this.cdkArrayDataSource = new ArrayDataSource(this.treeDataRunTime);
180
+ this.cdkTreeControl = new NestedTreeControl((node) => node?.children, { trackBy: this.trackByControl });
181
+ this.cdkTreeControl.dataNodes = this.treeDataRunTime;
147
182
  this.renderTree = false;
148
183
  this.changeDetectorRef.detectChanges();
149
- setTimeout(() => {
150
- this.treeDataRunTime = this.filterTreeData(structuredClone(this.treeDataRunTimeBackup), 'label', filterInput);
151
- this.cdkArrayDataSource = new ArrayDataSource(this.treeDataRunTime);
152
- this.cdkTreeControl = new NestedTreeControl((node) => node?.children);
153
- this.cdkTreeControl.dataNodes = this.treeDataRunTime;
154
- this.renderTree = true;
155
- this.changeDetectorRef.detectChanges();
156
- this.expandAll();
157
- });
184
+ this.renderTree = true;
185
+ this.changeDetectorRef.detectChanges();
186
+ this.expandAll();
158
187
  }
159
188
  else {
189
+ this.treeDataRunTime = structuredClone(this.treeDataRunTimeBackup);
190
+ this.cdkArrayDataSource = new ArrayDataSource(this.treeDataRunTime);
191
+ this.cdkTreeControl = new NestedTreeControl((node) => node?.children, { trackBy: this.trackByControl });
192
+ this.cdkTreeControl.dataNodes = this.treeDataRunTime;
160
193
  this.renderTree = false;
161
194
  this.changeDetectorRef.detectChanges();
162
- setTimeout(() => {
163
- this.treeDataRunTime = structuredClone(this.treeDataRunTimeBackup);
164
- this.cdkArrayDataSource = new ArrayDataSource(this.treeDataRunTime);
165
- this.cdkTreeControl = new NestedTreeControl((node) => node?.children);
166
- this.cdkTreeControl.dataNodes = this.treeDataRunTime;
167
- this.renderTree = true;
168
- this.changeDetectorRef.detectChanges();
169
- this.expandAll();
170
- });
195
+ this.renderTree = true;
196
+ this.changeDetectorRef.detectChanges();
197
+ this.expandAll();
171
198
  }
172
199
  }
173
200
  setAllSelection(isChecked) {
174
- this.setIsCheckedForAll(this.processedNodes, isChecked, this.treeDataRunTime);
201
+ this.setIsCheckedForAll(this.treeDataRunTime, isChecked);
175
202
  this.changeDetectorRef.markForCheck();
176
203
  }
177
- onNodeClick(treeItem) {
178
- this.nodeClick.emit(this.getTreeItem(treeItem?.path));
204
+ updateTreeItem(treeItem, path) {
205
+ this.setTreeData(path, this.processInputs([treeItem])[0]);
206
+ const pathArr = path.split('.');
207
+ const index = parseInt(pathArr.pop(), 10);
208
+ const treeItemRuntime = this.calculateRunTimeState(treeItem, index, pathArr.join('.'));
209
+ this.setTreeDataRunTime(path, treeItemRuntime);
210
+ // itemRecursiveSelectionState
211
+ const itemRecursiveSelectionState = this.calculateItemSelectionRecursiveState(treeItem);
212
+ this.setRunTimeSelectionRecursiveStateTree(path, itemRecursiveSelectionState);
213
+ this.syncStateChangesAtPath(path);
214
+ // Rendering
215
+ this.changeDetectorRef.detectChanges();
216
+ this.treeComponentInstance.renderNodeChanges([]);
217
+ this.treeComponentInstance.renderNodeChanges(this.treeDataRunTime);
218
+ if (this.cdkTreeControl.isExpanded(treeItemRuntime) && !treeItem.node.isExpanded) {
219
+ this.cdkTreeControl.toggle(treeItemRuntime);
220
+ }
221
+ else if (!this.cdkTreeControl.isExpanded(treeItemRuntime) && treeItem.node.isExpanded) {
222
+ this.cdkTreeControl.expand(treeItemRuntime);
223
+ }
224
+ this.changeDetectorRef.detectChanges();
225
+ }
226
+ onNodeClick(treeRunTimeItem) {
227
+ this.nodeClick.emit(this.getTreeItem(treeRunTimeItem?.path));
179
228
  if (this.isClickTogglingNode) {
180
- this.cdkTreeControl.toggle(treeItem);
181
- this.onNodeToggle(treeItem);
229
+ this.cdkTreeControl.toggle(treeRunTimeItem);
230
+ this.onNodeToggle(treeRunTimeItem);
182
231
  }
183
232
  }
184
- onNodeToggle(treeItem) {
185
- this.nodeToggle.emit(this.getTreeItem(treeItem?.path));
233
+ onNodeToggle(treeRunTimeItem) {
234
+ this.getTreeItem(treeRunTimeItem?.path).node.isExpanded = this.cdkTreeControl.isExpanded(treeRunTimeItem);
235
+ this.nodeToggle.emit(this.getTreeItem(treeRunTimeItem?.path));
186
236
  }
187
237
  // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html
188
238
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
189
239
  nodeSelected(evt, path) {
190
240
  const item = this.getTreeItem(path);
191
- const treeItemModel = this.getRunTimeTreeItem(path);
241
+ const runTimeTreeItem = this.getRunTimeBackupTreeItem(path);
242
+ const renderedRunTimeTreeItem = this.getRunTimeTreeItem(path);
192
243
  const node = item.node;
193
- const children = item.children;
194
- const pathArr = path.split('.');
195
- const hasParent = pathArr.length > 1;
196
- // Sets the hasParent If there is a parent, and removes the last element form pathArr.
197
- if (hasParent) {
198
- pathArr.pop();
199
- }
200
- // Silently sets the isSelected.
201
- node.isSelected = evt.target.checked;
202
- // Sets isSelected change on the control.
203
- if (node.isSelected) {
204
- this.selectTreeItem(treeItemModel);
244
+ // console.log(path,item,runTimeTreeItem, renderedRunTimeTreeItem);
245
+ if (!node?.selectConfig?.singleSelect) {
246
+ node.isSelected = evt.target.checked;
247
+ node.isIndeterminate = false;
248
+ // If the node is recursive it sets every children with the change.
249
+ if (renderedRunTimeTreeItem?.children && renderedRunTimeTreeItem?.children?.length > 0) {
250
+ if (node?.selectConfig?.recursive) {
251
+ // console.log(renderedRunTimeTreeItem);
252
+ this.setIsCheckedForAll(renderedRunTimeTreeItem?.children, evt.target.checked);
253
+ }
254
+ }
255
+ this.setRunTimeSelectionRecursiveStateTree(path, this.calculateItemSelectionRecursiveState(structuredClone(this.getTreeItem(path))));
256
+ if (renderedRunTimeTreeItem?.children && renderedRunTimeTreeItem?.children?.length > 0) {
257
+ if (node?.selectConfig?.recursive) {
258
+ // this.setIsCheckedForAll(renderedRunTimeTreeItem?.children, evt.target.checked);
259
+ this.runStateChangesForAll(renderedRunTimeTreeItem?.children);
260
+ }
261
+ this.treeComponentInstance?.renderNodeChanges([]);
262
+ this.treeComponentInstance?.renderNodeChanges(this.treeDataRunTime);
263
+ }
264
+ this.syncStateChangesAtPath(path);
265
+ if (this.getTreeItem(path).node.isSelected) {
266
+ this.selectTreeItem(runTimeTreeItem);
267
+ }
268
+ else {
269
+ this.deselectTreeItem(runTimeTreeItem);
270
+ }
271
+ const nodePathsSeq = this.getParentPaths(path);
272
+ if (nodePathsSeq.length > 0) {
273
+ nodePathsSeq.forEach((nodePath) => {
274
+ const treeItem = this.getTreeItem(nodePath);
275
+ const childStates = this.getRunTimeSelectionRecursiveState(nodePath).children.map((_) => _.selectionRecursiveState);
276
+ this.updateRunTimeSelectionRecursiveState(nodePath, this.decideSelectionRecursiveState(childStates, treeItem.node?.isSelected, treeItem.node?.selectConfig?.recursive, treeItem.node?.selectConfig?.noAutoSelectParent));
277
+ this.syncStateChangesAtPath(nodePath);
278
+ });
279
+ this.changeDetectorRef.detectChanges();
280
+ }
281
+ else {
282
+ this.changeDetectorRef.detectChanges();
283
+ }
205
284
  }
206
285
  else {
207
- this.deselectTreeItem(treeItemModel);
208
- }
209
- node.isIndeterminate = false;
210
- // If the node is recursive it sets every children with the change.
211
- if (children && children.length > 0) {
212
- if (node?.selectConfig?.recursive) {
213
- this.setIsCheckedForAll(children, evt.target.checked, treeItemModel?.children);
286
+ const prevItem = this.selectionModel.selected[0];
287
+ if (evt.target.checked) {
288
+ if (prevItem) {
289
+ this.getTreeItem(prevItem.path).node.isSelected = false;
290
+ this.selectionModel.deselect(prevItem);
291
+ }
292
+ item.node.isSelected = true;
293
+ this.selectionModel.select(runTimeTreeItem);
294
+ }
295
+ else {
296
+ item.node.isSelected = false;
297
+ this.selectionModel.deselect(runTimeTreeItem);
298
+ }
299
+ if (this.highlightPath) {
300
+ if (evt.target.checked && prevItem) {
301
+ const prevItemNodePathsSeq = this.getParentPaths(prevItem.path);
302
+ if (prevItemNodePathsSeq.length > 0) {
303
+ prevItemNodePathsSeq.forEach((nodePath) => {
304
+ this.updateRunTimeSelectionRecursiveState(nodePath, 'allNotSelected');
305
+ this.syncStateChangesAtPath(nodePath);
306
+ });
307
+ }
308
+ }
309
+ const nodePathsSeq = this.getParentPaths(path);
310
+ if (nodePathsSeq?.length > 0) {
311
+ nodePathsSeq.forEach((nodePath) => {
312
+ this.updateRunTimeSelectionRecursiveState(nodePath, evt.target.checked ? 'indeterminate' : 'allNotSelected');
313
+ this.syncStateChangesAtPath(nodePath);
314
+ });
315
+ this.changeDetectorRef.detectChanges();
316
+ }
214
317
  }
215
- }
216
- // Calculates to the node and its children node state
217
- this.setRunTimeSelectionRecursiveStateTree(path, this.calculateItemSelectionRecursiveState(structuredClone(this.getTreeItem(path))));
218
- // It is here for the filter edge case.
219
- this.syncStateChangesAtPath(path);
220
- if (hasParent) {
221
- // Calculates parent path
222
- const parentPath = pathArr.join('.');
223
- // Creating node index sequence f.e If path is '1.2' it will be [1,2]
224
- const nodeIndexSeq = parentPath.split('.').map((indexStr) => parseInt(indexStr, 10));
225
- // Calculating the node paths array to be re-calculated from bottom to top
226
- const nodePathsSeq = [];
227
- nodeIndexSeq.forEach((nodeIndex, index) => {
228
- nodePathsSeq[index] = nodeIndexSeq.slice(0, index + 1).join('.');
229
- });
230
- nodePathsSeq.reverse();
231
- nodePathsSeq.forEach((nodePath) => {
232
- this.updateRunTimeSelectionRecursiveState(nodePath, this.decideSelectionRecursiveState(this.getRunTimeSelectionRecursiveState(nodePath)));
233
- this.syncStateChangesAtPath(nodePath);
234
- });
235
- this.changeDetectorRef.detectChanges();
236
318
  }
237
319
  }
238
320
  // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html
239
321
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
240
- onSelectFn(path, treeItemModel) {
241
- if (treeItemModel?.node?.selectable) {
322
+ onSelectFn(path) {
323
+ if (this.getTreeItem(path)?.node?.selectable) {
242
324
  const nodeSelected = this.nodeSelected.bind(this);
243
325
  // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html
244
326
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
@@ -250,23 +332,54 @@ export class EuiTreeComponent {
250
332
  console.warn('treeItemModel.node.selectable is false, you can not implement onSelect');
251
333
  };
252
334
  }
335
+ getRunTimeSelectionRecursiveState(path) {
336
+ const indexArr = this.resolvePath(path);
337
+ let nodeArr = this.runTimeSelectionRecursiveState;
338
+ let node;
339
+ indexArr?.forEach((pathIndex, index) => {
340
+ if (index < indexArr.length - 1) {
341
+ nodeArr = nodeArr[pathIndex]?.children;
342
+ }
343
+ else {
344
+ node = nodeArr[pathIndex];
345
+ }
346
+ });
347
+ return node;
348
+ }
253
349
  initTree() {
254
350
  if (this.nodes) {
255
351
  this._isMultiLevel = this.checkIfMultiLevel(this.nodes);
256
352
  this.processedNodes = this.processInputs(structuredClone(this.nodes));
257
- this.createTreeDataRuntime(this.processedNodes);
258
- this.cdkArrayDataSource = new ArrayDataSource(this.treeDataRunTime);
353
+ this.treeDataRunTime = this.createTreeDataRuntime(this.processedNodes);
354
+ this.treeDataRunTime = this.applyRunTimeLastItems(this.treeDataRunTime);
355
+ this.runTimeSelectionRecursiveState = this.createRunTimeSelectionRecursiveState(this.processedNodes);
259
356
  this.treeDataRunTimeBackup = structuredClone(this.treeDataRunTime);
260
- this.cdkTreeControl = new NestedTreeControl((node) => node?.children);
261
- this.cdkTreeControl.dataNodes = this.treeDataRunTime;
357
+ // console.log(this.processedNodes,this.treeDataRunTime);
358
+ if (this.treeDataRunTimeBackup.length > 800) {
359
+ this.treePagination = new EuiTreePagination(this.treeDataRunTimeBackup, 1, 2, 400);
360
+ const paginatedData = this.treePagination.getViewData().data;
361
+ this.cdkArrayDataSource = new ArrayDataSource(paginatedData);
362
+ this.cdkTreeControl = new NestedTreeControl((node) => node?.children, {
363
+ trackBy: this.trackByControl,
364
+ });
365
+ this.cdkTreeControl.dataNodes = paginatedData;
366
+ this.runScrollListener();
367
+ }
368
+ else {
369
+ this.cdkArrayDataSource = new ArrayDataSource(this.treeDataRunTime);
370
+ this.cdkTreeControl = new NestedTreeControl((node) => node?.children, {
371
+ trackBy: this.trackByControl,
372
+ });
373
+ this.cdkTreeControl.dataNodes = this.treeDataRunTime;
374
+ }
262
375
  this.renderInitialExpand(this.treeDataRunTime);
263
376
  this.selectionModel = new SelectionModel(true, this.getInitialSelection(this.treeDataRunTime), true, (a, b) => a?.path === b?.path);
264
- this._selection = [...this.selectionModel.selected]?.map((item) => this.getTreeItem(item.path));
377
+ this._selection = [...this.selectionModel.selected]?.map((item) => this.getTreeItem(item?.path));
265
378
  this.renderTree = true;
266
379
  if (this.selectionModelSubs) {
267
380
  this.selectionModelSubs.unsubscribe();
268
381
  }
269
- this.selectionModelSubs = this.selectionModel.changed.subscribe((sc) => {
382
+ this.selectionModelSubs = this.selectionModel.changed.pipe(debounceTime(1)).subscribe((sc) => {
270
383
  const selectionChange = {
271
384
  added: sc.added.map((_) => this.getTreeItem(_.path)),
272
385
  removed: sc.removed.map((_) => this.getTreeItem(_.path)),
@@ -282,10 +395,13 @@ export class EuiTreeComponent {
282
395
  if (this.isMultiselect) {
283
396
  treeData = this.overrideTreeDataModelForSelection(treeData, this.isRecursiveSelection, !this.isRecursiveParentSelection);
284
397
  }
398
+ if (this.isSingleSelect) {
399
+ treeData = this.overrideTreeDataModelForSelection(treeData, false, false, true);
400
+ }
285
401
  return treeData;
286
402
  }
287
- overrideTreeDataModelForSelection(nodeArr, isRecursive, noAutoSelectParent) {
288
- return nodeArr?.map((item) => {
403
+ overrideTreeDataModelForSelection(nodeArr, isRecursive, noAutoSelectParent, singleSelect) {
404
+ return nodeArr?.map((item, index) => {
289
405
  if (item?.children && item.children.length > 0) {
290
406
  return {
291
407
  ...item,
@@ -302,9 +418,12 @@ export class EuiTreeComponent {
302
418
  noAutoSelectParent: typeof item?.node?.selectConfig?.noAutoSelectParent === 'undefined'
303
419
  ? noAutoSelectParent
304
420
  : item?.node?.selectConfig?.noAutoSelectParent,
421
+ singleSelect: typeof item?.node?.selectConfig?.singleSelect === 'undefined'
422
+ ? singleSelect
423
+ : item?.node?.selectConfig?.singleSelect,
305
424
  },
306
425
  },
307
- children: this.overrideTreeDataModelForSelection(item.children, isRecursive, noAutoSelectParent),
426
+ children: this.overrideTreeDataModelForSelection(item.children, isRecursive, noAutoSelectParent, singleSelect),
308
427
  };
309
428
  }
310
429
  else {
@@ -313,11 +432,67 @@ export class EuiTreeComponent {
313
432
  node: {
314
433
  ...item.node,
315
434
  selectable: typeof item?.node?.selectable === 'undefined' ? true : item?.node?.selectable,
435
+ selectConfig: {
436
+ ...item.node?.selectConfig,
437
+ singleSelect: typeof item?.node?.selectConfig?.singleSelect === 'undefined'
438
+ ? singleSelect
439
+ : item?.node?.selectConfig?.singleSelect,
440
+ },
316
441
  },
317
442
  };
318
443
  }
319
444
  });
320
445
  }
446
+ runScrollListener() {
447
+ this.scrollDispatcherSubs = this.scrollDispatcher.scrolled().subscribe((scrollable) => {
448
+ if (scrollable && this.checkIfCurrentScrollable(scrollable)) {
449
+ const isAtBottom = scrollable?.getElementRef().nativeElement.scrollTop + scrollable?.getElementRef().nativeElement.clientHeight >=
450
+ scrollable?.getElementRef().nativeElement.scrollHeight;
451
+ const isAtTop = scrollable?.getElementRef().nativeElement.scrollTop === 0;
452
+ // console.log('Element:', this.cdkScrollableRef.getElementRef());
453
+ if (isAtBottom && !this.treePagination.isAtMax()) {
454
+ if (this.nodes.length > 0) {
455
+ this.treeDataRunTime = this.treePagination.paginateNext().data;
456
+ this.treeDataRunTime = this.applyRunTimeLastItems(this.treeDataRunTime);
457
+ this.cdkArrayDataSource = new ArrayDataSource(this.treeDataRunTime);
458
+ this.cdkTreeControl = new NestedTreeControl((node) => node?.children, {
459
+ trackBy: this.trackByControl,
460
+ });
461
+ this.cdkTreeControl.dataNodes = this.treeDataRunTime;
462
+ this.renderTree = false;
463
+ this.changeDetectorRef.detectChanges();
464
+ this.renderTree = true;
465
+ this.changeDetectorRef.detectChanges();
466
+ this.expandAll();
467
+ const totalHeight = scrollable.measureScrollOffset('bottom') + scrollable.measureScrollOffset('top');
468
+ const viewportHeight = scrollable.getElementRef().nativeElement.clientHeight;
469
+ const positionToScroll = totalHeight - viewportHeight;
470
+ scrollable.scrollTo({ top: positionToScroll / 2 });
471
+ }
472
+ }
473
+ else if (isAtTop && this.treePagination.getCurrentStartPage() > 1) {
474
+ if (this.nodes.length > 0) {
475
+ this.treeDataRunTime = this.treePagination.paginatePrev().data;
476
+ this.treeDataRunTime = this.applyRunTimeLastItems(this.treeDataRunTime);
477
+ this.cdkArrayDataSource = new ArrayDataSource(this.treeDataRunTime);
478
+ this.cdkTreeControl = new NestedTreeControl((node) => node?.children, {
479
+ trackBy: this.trackByControl,
480
+ });
481
+ this.cdkTreeControl.dataNodes = this.treeDataRunTime;
482
+ this.renderTree = false;
483
+ this.changeDetectorRef.detectChanges();
484
+ this.renderTree = true;
485
+ this.changeDetectorRef.detectChanges();
486
+ this.expandAll();
487
+ const totalHeight = scrollable.measureScrollOffset('bottom') + scrollable.measureScrollOffset('top');
488
+ const viewportHeight = scrollable.getElementRef().nativeElement.clientHeight;
489
+ const positionToScroll = totalHeight - viewportHeight;
490
+ scrollable.scrollTo({ top: positionToScroll / 2 + viewportHeight });
491
+ }
492
+ }
493
+ }
494
+ });
495
+ }
321
496
  getSelectionIndexOfItem(runTimeTreeItem) {
322
497
  return this.selectionModel.selected.findIndex((i) => i?.path === runTimeTreeItem?.path);
323
498
  }
@@ -335,54 +510,65 @@ export class EuiTreeComponent {
335
510
  this.selectionModel.setSelection(...newSelection);
336
511
  }
337
512
  }
338
- // Creates treeDataRunTime & runTimeSelectionRecursiveState for separate the logic.
339
513
  createTreeDataRuntime(nodes) {
340
- this.treeDataRunTime = structuredClone(nodes)?.map((item, index) => {
341
- return this.calculateRunTimeState({ ...item }, index);
514
+ return structuredClone(nodes)?.map((item, index) => {
515
+ return this.calculateRunTimeState(item, index);
516
+ });
517
+ }
518
+ applyRunTimeLastItems(items) {
519
+ return items?.map((item, index) => {
520
+ if (item?.children) {
521
+ return {
522
+ ...item,
523
+ last: items.length === index + 1 ? true : undefined,
524
+ children: item.children?.length > 0 ? this.applyRunTimeLastItems(item.children) : item?.children,
525
+ };
526
+ }
527
+ else {
528
+ return {
529
+ ...item,
530
+ last: items.length === index + 1 ? true : undefined,
531
+ };
532
+ }
342
533
  });
343
- this.runTimeSelectionRecursiveState = structuredClone(nodes)?.map((item) => this.calculateItemSelectionRecursiveState({ ...item }));
534
+ }
535
+ createRunTimeSelectionRecursiveState(nodes) {
536
+ return structuredClone(nodes)?.map((item) => this.calculateItemSelectionRecursiveState({ ...item }));
344
537
  }
345
538
  // Creating run time state which includes children selection state for selection tree.
346
- calculateItemSelectionRecursiveState(treeItem) {
539
+ calculateItemSelectionRecursiveState(treeItem, isSelected) {
540
+ const childrenSelectionRecursive = [];
347
541
  if (treeItem.children && treeItem.children.length > 0) {
348
542
  treeItem.children.forEach((child, index) => {
349
- treeItem.children[index] = this.calculateItemSelectionRecursiveState(child);
543
+ childrenSelectionRecursive[index] = this.calculateItemSelectionRecursiveState(child);
350
544
  });
351
545
  }
352
- const itemState = this.decideSelectionRecursiveState(treeItem);
546
+ const childStates = childrenSelectionRecursive.map((_) => _.selectionRecursiveState);
547
+ const itemState = this.decideSelectionRecursiveState(childStates, isSelected || treeItem.node.isSelected, treeItem.node?.selectConfig?.recursive, treeItem.node?.selectConfig?.noAutoSelectParent);
353
548
  return {
354
- ...treeItem,
355
549
  selectionRecursiveState: itemState,
550
+ children: childrenSelectionRecursive,
356
551
  };
357
552
  }
358
- decideSelectionRecursiveState(treeItem) {
359
- // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html
360
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
361
- const runTimeItems = treeItem.children || [];
362
- const childStates = runTimeItems?.map((item) => item.selectionRecursiveState);
553
+ decideSelectionRecursiveState(childStates = [], isSelected, recursive, noAutoSelectParent) {
363
554
  let itemState = 'indeterminate';
364
- if (treeItem.node.isSelected && childStates.every((state) => state === 'allSelected')) {
555
+ if (isSelected && childStates.every((state) => state === 'allSelected')) {
365
556
  itemState = 'allSelected';
366
557
  }
367
- else if (!treeItem.node.isSelected && childStates.every((state) => state === 'allNotSelected')) {
558
+ else if (!isSelected && childStates.every((state) => state === 'allNotSelected')) {
368
559
  itemState = 'allNotSelected';
369
560
  }
370
- else if (treeItem.node?.selectConfig?.recursive &&
371
- childStates.every((state) => state === 'allSelected') &&
372
- !treeItem.node.isSelected &&
373
- !treeItem?.node?.selectConfig?.noAutoSelectParent) {
561
+ else if (recursive && childStates.every((state) => state === 'allSelected') && !isSelected && !noAutoSelectParent) {
374
562
  itemState = 'allSelected';
375
563
  }
376
- else if (treeItem.node?.selectConfig?.recursive &&
377
- childStates.every((state) => state === 'allNotSelected') &&
378
- treeItem.node.isSelected) {
564
+ else if (recursive && childStates.every((state) => state === 'allNotSelected') && isSelected) {
379
565
  itemState = 'allNotSelected';
380
566
  }
381
567
  return itemState;
382
568
  }
383
569
  syncStateChangesAtPath(nodePath) {
384
570
  const treeItem = this.getTreeItem(nodePath);
385
- const runTimeTreeItem = this.getRunTimeTreeItem(nodePath);
571
+ const runTimeTreeItem = this.getRunTimeBackupTreeItem(nodePath);
386
572
  const runTimeSelectionRecursiveItem = this.getRunTimeSelectionRecursiveState(nodePath);
387
573
  if (treeItem?.node?.selectable && treeItem.node?.selectConfig?.recursive) {
388
574
  if (!treeItem.node?.selectConfig?.noAutoSelectParent) {
@@ -401,27 +587,37 @@ export class EuiTreeComponent {
401
587
  };
402
588
  }
403
589
  // console.log(treeItem, treeItem.node.treeContentBlock.label, 'isSelected:' + treeItem.node.isSelected, 'isIndeterminate:' + treeItem.node.isIndeterminate);
404
- if (treeItem.node.isSelected === true) {
590
+ if (treeItem.node.isSelected === true && !this.selectionModel.isSelected(runTimeTreeItem)) {
405
591
  this.selectTreeItem(runTimeTreeItem);
406
592
  }
407
- else {
593
+ else if (treeItem.node.isSelected === false && this.selectionModel.isSelected(runTimeTreeItem)) {
408
594
  this.deselectTreeItem(runTimeTreeItem);
409
595
  }
410
596
  }
411
597
  }
412
- getRunTimeSelectionRecursiveState(path) {
598
+ setTreeData(path, item) {
413
599
  const indexArr = this.resolvePath(path);
414
- let nodeArr = this.runTimeSelectionRecursiveState;
415
- let node;
600
+ let itemArr = this.processedNodes;
416
601
  indexArr.forEach((pathIndex, index) => {
417
602
  if (index < indexArr.length - 1) {
418
- nodeArr = nodeArr[pathIndex]?.children;
603
+ itemArr = itemArr[pathIndex]?.children;
419
604
  }
420
605
  else {
421
- node = nodeArr[pathIndex];
606
+ itemArr[pathIndex] = item;
607
+ }
608
+ });
609
+ }
610
+ setTreeDataRunTime(path, item) {
611
+ const indexArr = this.resolvePath(path);
612
+ let itemArr = this.treeDataRunTime;
613
+ indexArr.forEach((pathIndex, index) => {
614
+ if (index < indexArr.length - 1) {
615
+ itemArr = itemArr[pathIndex]?.children;
616
+ }
617
+ else {
618
+ itemArr[pathIndex] = item;
422
619
  }
423
620
  });
424
- return node;
425
621
  }
426
622
  setRunTimeSelectionRecursiveStateTree(path, item) {
427
623
  const indexArr = this.resolvePath(path);
@@ -450,53 +646,90 @@ export class EuiTreeComponent {
450
646
  }
451
647
  });
452
648
  }
453
- setIsCheckedForAll(nodeArr, isChecked, runTimeTreeData) {
454
- nodeArr.forEach((item, index) => {
455
- if (runTimeTreeData[index] && nodeArr[index]?.node?.selectable) {
456
- nodeArr[index] = {
457
- ...item,
458
- node: {
459
- ...item.node,
460
- isSelected: isChecked,
461
- isIndeterminate: false,
462
- },
463
- };
649
+ setIsCheckedForAll(nodeArr, isChecked) {
650
+ nodeArr.forEach((runTimeItem, index) => {
651
+ const treeItem = this.getTreeItem(runTimeItem.path);
652
+ const node = treeItem.node;
653
+ if (node?.selectable) {
654
+ node.isSelected = isChecked;
655
+ node.isIndeterminate = false;
464
656
  if (isChecked) {
465
- this.selectTreeItem(runTimeTreeData[index]);
657
+ this.selectTreeItem(runTimeItem);
466
658
  }
467
659
  else {
468
- this.deselectTreeItem(runTimeTreeData[index]);
660
+ this.deselectTreeItem(runTimeItem);
469
661
  }
470
662
  }
471
- if (runTimeTreeData[index]?.children?.length > 0 && nodeArr[index].children && nodeArr[index].children.length > 0) {
472
- this.setIsCheckedForAll(nodeArr[index].children, isChecked, runTimeTreeData[index].children);
663
+ if (runTimeItem?.children?.length > 0 && runTimeItem?.children && runTimeItem?.children.length > 0) {
664
+ this.setIsCheckedForAll(nodeArr[index].children, isChecked);
665
+ }
666
+ });
667
+ }
668
+ runStateChangesForAll(nodeArr) {
669
+ nodeArr.forEach((runTimeItem, index) => {
670
+ if (runTimeItem?.children?.length > 0 && runTimeItem?.children && runTimeItem?.children.length > 0) {
671
+ this.syncSelectionAtPath(runTimeItem);
672
+ this.runStateChangesForAll(nodeArr[index].children);
473
673
  }
474
674
  });
475
675
  }
676
+ syncSelectionAtPath(runTimeTreeItem) {
677
+ // It is here for the filter edge case.
678
+ this.syncStateChangesAtPath(runTimeTreeItem.path);
679
+ // Sets isSelected change on the control.
680
+ if (this.getTreeItem(runTimeTreeItem.path).node.isSelected) {
681
+ this.selectTreeItem(runTimeTreeItem);
682
+ }
683
+ else {
684
+ this.deselectTreeItem(runTimeTreeItem);
685
+ }
686
+ }
476
687
  resolvePath(path) {
477
688
  return path?.split('.').map((index) => parseInt(index, 10));
478
689
  }
690
+ getParentPaths(path) {
691
+ const pathArr = path.split('.');
692
+ const hasParent = pathArr.length > 1;
693
+ // Sets the hasParent If there is a parent, and removes the last element form pathArr.
694
+ if (hasParent) {
695
+ pathArr.pop();
696
+ // Calculates parent path
697
+ const parentPath = pathArr.join('.');
698
+ // Creating node index sequence f.e If path is '1.2' it will be [1,2]
699
+ const nodeIndexSeq = parentPath.split('.').map((indexStr) => parseInt(indexStr, 10));
700
+ // Calculating the node paths array to be re-calculated from bottom to top
701
+ const nodePathsSeq = [];
702
+ nodeIndexSeq.forEach((nodeIndex, index) => {
703
+ nodePathsSeq[index] = nodeIndexSeq.slice(0, index + 1).join('.');
704
+ });
705
+ return nodePathsSeq.reverse();
706
+ }
707
+ else {
708
+ return [];
709
+ }
710
+ }
479
711
  calculateRunTimeState(treeItem, index, parentPath) {
480
- treeItem.path = parentPath ? parentPath + '.' + index : index.toString();
481
- treeItem.index = index;
482
- if (treeItem.children && treeItem.children.length > 0) {
712
+ const runTimeTreeItem = {
713
+ path: parentPath ? parentPath + '.' + index : index.toString(),
714
+ index,
715
+ };
716
+ if (treeItem.children && treeItem.children.length >= 0) {
717
+ runTimeTreeItem.children = [];
483
718
  treeItem.children.forEach((child, treeItemIndex) => {
484
- treeItem.children[treeItemIndex] = this.calculateRunTimeState(child, treeItemIndex, treeItem.path);
719
+ runTimeTreeItem.children[treeItemIndex] = this.calculateRunTimeState(child, treeItemIndex, runTimeTreeItem.path);
485
720
  });
486
721
  }
487
- return treeItem;
722
+ return runTimeTreeItem;
488
723
  }
489
- filterTreeData(treeData, key = 'label', filterStr) {
490
- return treeData.filter((treeItem) => {
491
- if (treeItem?.children?.length > 0) {
492
- treeItem.children = this.filterTreeData([...treeItem.children], key, filterStr);
493
- treeItem.children = treeItem.children.length > 0 ? treeItem.children : undefined;
494
- }
495
- if (this.normalizedStr(treeItem.node.treeContentBlock.label).includes(this.normalizedStr(filterStr))) {
724
+ filterTreeData(runTimeTreeData, key = 'label', filterStr) {
725
+ return runTimeTreeData.filter((runTimeItem) => {
726
+ if (this.normalizedStr(this.getTreeItem(runTimeItem.path).node.treeContentBlock.label).includes(this.normalizedStr(filterStr))) {
496
727
  return true;
497
728
  }
498
- else if (treeItem?.children?.length > 0) {
499
- return treeItem?.children?.length > 0;
729
+ else if (runTimeItem?.children?.length > 0) {
730
+ runTimeItem.children = this.filterTreeData(structuredClone(runTimeItem.children), key, filterStr);
731
+ runTimeItem.children = runTimeItem.children.length > 0 ? runTimeItem.children : undefined;
732
+ return runTimeItem?.children?.length > 0;
500
733
  }
501
734
  else {
502
735
  return false;
@@ -516,7 +749,7 @@ export class EuiTreeComponent {
516
749
  }
517
750
  scanSelection(nodes, selection) {
518
751
  nodes.forEach((item) => {
519
- if (item.node?.selectable && item.node.isSelected) {
752
+ if (this.getTreeItem(item.path).node?.selectable && this.getTreeItem(item.path).node.isSelected) {
520
753
  selection.push(item);
521
754
  }
522
755
  if (item?.children?.length > 0) {
@@ -526,7 +759,7 @@ export class EuiTreeComponent {
526
759
  }
527
760
  renderInitialExpand(nodes) {
528
761
  nodes.forEach((item) => {
529
- if (item?.node?.isExpanded) {
762
+ if (this.getTreeItem(item.path).node.isExpanded) {
530
763
  this.expandAt(item.path);
531
764
  }
532
765
  if (item?.children?.length > 0) {
@@ -535,8 +768,25 @@ export class EuiTreeComponent {
535
768
  });
536
769
  }
537
770
  getRunTimeTreeItem(path) {
771
+ return this.findRunTimeTreeItem(this.treeDataRunTime, path);
772
+ }
773
+ findRunTimeTreeItem(treeDataRunTime, path) {
774
+ for (const runTimeItem of treeDataRunTime) {
775
+ if (runTimeItem.path === path) {
776
+ return runTimeItem;
777
+ }
778
+ else if (runTimeItem?.children?.length > 0) {
779
+ const found = this.findRunTimeTreeItem(runTimeItem.children, path);
780
+ if (found) {
781
+ return found;
782
+ }
783
+ }
784
+ }
785
+ return null;
786
+ }
787
+ getRunTimeBackupTreeItem(path) {
538
788
  const indexArr = this.resolvePath(path);
539
- let nodeArr = this.treeDataRunTime;
789
+ let nodeArr = this.treeDataRunTimeBackup;
540
790
  let node;
541
791
  if (nodeArr && Array.isArray(nodeArr)) {
542
792
  indexArr?.forEach((pathIndex, index) => {
@@ -558,19 +808,22 @@ export class EuiTreeComponent {
558
808
  checkIfMultiLevel(tree) {
559
809
  let isMultiLevel = false;
560
810
  tree.forEach((item) => {
561
- if (item?.children?.length > 0) {
811
+ if (item?.children?.length >= 0) {
562
812
  isMultiLevel = true;
563
813
  }
564
814
  });
565
815
  return isMultiLevel;
566
816
  }
567
- /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.0-rc.1", ngImport: i0, type: EuiTreeComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
568
- /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.0-rc.1", type: EuiTreeComponent, selector: "eui-tree", inputs: { e2eAttr: "e2eAttr", nodes: "nodes", nodeTemplateRef: "nodeTemplateRef", nodeContentMetadataTemplateRef: "nodeContentMetadataTemplateRef", rightContextMenuTemplateRef: "rightContextMenuTemplateRef", expandedIconClass: "expandedIconClass", collapsedIconClass: "collapsedIconClass", expandedSvgIconClass: "expandedSvgIconClass", collapsedSvgIconClass: "collapsedSvgIconClass", showUnderlinedLinks: "showUnderlinedLinks", showLines: "showLines", isClickTogglingNode: "isClickTogglingNode", isMultiselect: "isMultiselect", isRecursiveSelection: "isRecursiveSelection", isRecursiveParentSelection: "isRecursiveParentSelection", autoTranslate: "autoTranslate" }, outputs: { selectionChange: "selectionChange", nodeClick: "nodeClick", nodeToggle: "nodeToggle" }, host: { properties: { "class": "this.cssClasses", "attr.data-e2e": "this.e2eAttr" } }, usesOnChanges: true, ngImport: i0, template: "<ul class=\"eui-tree__wrapper\">\n <cdk-tree [dataSource]=\"cdkArrayDataSource\" [treeControl]=\"cdkTreeControl\" [trackBy]=\"trackBy\" *ngIf=\"renderTree\" class=\"eui-cdk-tree\">\n <!-- There are two states of generic cdk-nested-tree-node declarations.\n First one is without child. No sub rendering.\n -->\n <cdk-nested-tree-node *cdkTreeNodeDef=\"let treeItemModel\" class=\"eui-cdk-nested-tree-node\">\n <li\n class=\"eui-tree-node\"\n *ngIf=\"treeItemModel\"\n title=\"{{\n getTreeItem(treeItemModel?.path)?.node?.treeContentBlock?.tooltipLabel ||\n getTreeItem(treeItemModel?.path)?.node?.treeContentBlock?.label\n }}\">\n <div class=\"eui-tree-node-wrapper\" (click)=\"onNodeClick(treeItemModel)\"\n [class.eui-tree-node-wrapper--last]=\"false\"\n [class.eui-tree-node-wrapper--show-lines]=\"showLines\">\n <div class=\"eui-tree-node-wrapper__container\">\n <!--\n Renders node in default or provided template's context.\n Generates onSelect with onSelectFn for developers to send the events from their custom check events.\n Provides id to be used on generic template\n -->\n <ng-container\n [ngTemplateOutlet]=\"nodeTemplateRef || nodeTemplateDefault\"\n [ngTemplateOutletContext]=\"{\n $implicit: getTreeItem(treeItemModel?.path)?.node,\n onSelect: onSelectFn(treeItemModel.path, treeItemModel),\n id: uid + treeItemModel.path\n }\">\n </ng-container>\n </div>\n </div>\n </li>\n </cdk-nested-tree-node>\n <!-- This is the tree node template for expandable nodes -->\n <cdk-nested-tree-node\n *cdkTreeNodeDef=\"let treeItemModel; when: hasChild\"\n class=\"eui-cdk-nested-tree-node eui-cdk-nested-tree-node--with-child\">\n <li\n class=\"eui-tree-node\"\n *ngIf=\"treeItemModel\"\n title=\"{{\n getTreeItem(treeItemModel?.path)?.node?.treeContentBlock?.tooltipLabel ||\n getTreeItem(treeItemModel?.path)?.node?.treeContentBlock?.label\n }}\">\n <div class=\"eui-tree-node-wrapper\"\n [class.eui-tree-node-wrapper--last]=\"false\"\n [class.eui-tree-node-wrapper--show-lines]=\"showLines\">\n <!--Here wraps the node, and listen for node clicks.-->\n <div (click)=\"onNodeClick(treeItemModel)\" class=\"eui-tree-node-wrapper__container\">\n <!-- Expand/collapse action button -->\n <button\n euiButton\n euiIconButton\n euiBasicButton\n euiRounded\n euiSizeS\n type=\"button\"\n [attr.aria-label]=\"'Toggle ' + treeItemModel?.node?.treeContentBlock?.label\"\n (click)=\"onNodeToggle(treeItemModel)\"\n cdkTreeNodeToggle\n class=\"eui-tree-node__button\">\n <span\n euiIcon\n *ngIf=\"!cdkTreeControl.isExpanded(treeItemModel) && collapsedIconClass\"\n [iconClass]=\"collapsedIconClass\"></span>\n <span\n euiIcon\n *ngIf=\"cdkTreeControl.isExpanded(treeItemModel) && expandedIconClass\"\n [iconClass]=\"expandedIconClass\"></span>\n <eui-icon-svg\n *ngIf=\"!cdkTreeControl.isExpanded(treeItemModel) && !collapsedIconClass\"\n [icon]=\"expandedSvgIconClass\"></eui-icon-svg>\n <eui-icon-svg\n *ngIf=\"cdkTreeControl.isExpanded(treeItemModel) && !expandedIconClass\"\n [icon]=\"collapsedSvgIconClass\"></eui-icon-svg>\n </button>\n <!--\n Renders node in default or provided template's context.\n Generates onSelect with onSelectFn for developers to send the events from their custom check events.\n Provides id to be used on generic template\n -->\n <ng-container\n [ngTemplateOutlet]=\"nodeTemplateRef || nodeTemplateDefault\"\n [ngTemplateOutletContext]=\"{\n $implicit: getTreeItem(treeItemModel?.path)?.node,\n onSelect: onSelectFn(treeItemModel?.path, treeItemModel),\n id: uid + treeItemModel.path\n }\">\n </ng-container>\n </div>\n </div>\n <!--uses cdkTreeNodeOutlet to render children nodes, CdkTreeControl is used to control isExpanded state.-->\n <ul class=\"eui-tree-node\" *ngIf=\"cdkTreeControl.isExpanded(treeItemModel)\">\n <ng-container cdkTreeNodeOutlet></ng-container>\n </ul>\n </li>\n </cdk-nested-tree-node>\n </cdk-tree>\n</ul>\n\n<ng-template #nodeTemplateDefault let-node let-onSelect=\"onSelect\" let-id=\"id\">\n <ng-container *ngIf=\"node\">\n <div class=\"eui-tree-node-wrapper__container-left\" [class.eui-tree-node-wrapper__container-left--selected]=\"node?.isSelected\">\n <!--input checkbox area-->\n <input\n euiInputCheckBox\n *ngIf=\"node && node.selectable\"\n type=\"checkbox\"\n id=\"{{ id }}\"\n [checked]=\"!!node?.isSelected\"\n [indeterminate]=\"!!node?.isIndeterminate\"\n (change)=\"onSelect($event)\"\n class=\"eui-u-mr-m\" />\n\n <!--icon area-->\n <ng-container *ngIf=\"node?.treeContentBlock?.iconClass\">\n <eui-icon\n [euiVariant]=\"node?.treeContentBlock?.iconTypeClass || 'primary'\"\n iconClass=\"{{ node?.treeContentBlock?.iconClass }}\"\n euiSizeS\n class=\"eui-u-mr-xs\">\n </eui-icon>\n </ng-container>\n <ng-container *ngIf=\"node?.treeContentBlock?.iconSvgName\">\n <eui-icon-svg\n icon=\"{{ node?.treeContentBlock?.iconSvgName }}\"\n fillColor=\"{{ node?.treeContentBlock?.iconTypeClass || 'grey-100' }}\"\n size=\"s\"\n class=\"eui-u-mr-xs\">\n </eui-icon-svg>\n </ng-container>\n\n <!--chips area-->\n <ng-container *ngIf=\"node?.treeContentBlock?.chips\">\n <eui-chip\n *ngFor=\"let chip of node.treeContentBlock.chips\"\n euiSizeXS\n [euiVariant]=\"chip.typeClass || 'secondary'\"\n [euiOutline]=\"chip.isOutline\"\n class=\"eui-chip--rounded eui-u-mb-none eui-u-mr-xs\">\n <span euiLabel>{{ chip.label }}</span>\n </eui-chip>\n </ng-container>\n\n <!--badge (typeLabel & typeClass) area-->\n <ng-container *ngIf=\"node?.treeContentBlock?.typeLabel\" [ngSwitch]=\"node?.treeContentBlock?.typeClass\">\n <eui-badge euiSizeM [euiVariant]=\"node?.treeContentBlock?.typeClass || 'primary'\" class=\"eui-u-flex-no-shrink eui-u-mr-xs\">\n {{ node?.treeContentBlock?.typeLabel }}\n </eui-badge>\n </ng-container>\n </div>\n\n <!--label area-->\n <div class=\"eui-tree-node-wrapper__container-middle\">\n <label\n *ngIf=\"!node?.treeContentBlock?.url && !node?.treeContentBlock?.urlExternal\"\n euiLabel\n for=\"{{ id }}\"\n class=\"eui-u-text-truncate eui-u-p-2xs\"\n [class.eui-label--selected]=\"node?.isSelected\"\n [class.eui-u-cursor-pointer]=\"node?.selectable\">\n {{ autoTranslate ? (node?.treeContentBlock?.label | translate) : node?.treeContentBlock?.label }}\n </label>\n <label *ngIf=\"node?.treeContentBlock?.url\" euiLabel for=\"{{ id }}\" class=\"eui-u-text-truncate eui-u-p-2xs\">\n <a class=\"eui-u-text-link\" [class.eui-u-text-link-standalone]=\"!showUnderlinedLinks\" [routerLink]=\"node?.treeContentBlock?.url\">\n {{ autoTranslate ? (node?.treeContentBlock?.label | translate) : node?.treeContentBlock?.label }}\n </a>\n </label>\n <label *ngIf=\"node?.treeContentBlock?.urlExternal\" euiLabel for=\"{{ id }}\" class=\"eui-u-text-truncate eui-u-p-2xs\">\n <a\n class=\"eui-u-text-link-external\"\n [class.eui-u-text-link-external-standalone]=\"!showUnderlinedLinks\"\n href=\"{{ node?.treeContentBlock?.urlExternal }}\"\n target=\"{{ node?.treeContentBlock?.urlExternalTarget || 'blank' }}\">\n {{ autoTranslate ? (node?.treeContentBlock?.label | translate) : node?.treeContentBlock?.label }}\n </a>\n </label>\n </div>\n\n <div *ngIf=\"node?.treeContentBlock?.rightContent\" class=\"eui-tree-node-wrapper__container-right\">\n <!--badges area-->\n <ng-container *ngFor=\"let badge of node.treeContentBlock.rightContent?.badges\">\n <eui-badge euiSizeM euiOutline [euiVariant]=\"badge.typeClass || 'secondary'\" class=\"eui-u-ml-xs\">\n <span euiLabel>{{ badge.label }}</span>\n </eui-badge>\n </ng-container>\n\n <!--chips area-->\n <ng-container *ngFor=\"let chip of node.treeContentBlock.rightContent?.chips\">\n <eui-chip\n euiSizeXS\n [euiVariant]=\"chip.typeClass || 'secondary'\"\n [euiOutline]=\"chip.isOutline\"\n class=\"eui-chip--rounded eui-u-mb-none eui-u-ml-xs\">\n <span euiLabel>{{ chip.label }}</span>\n </eui-chip>\n </ng-container>\n\n <!--Context menu-->\n <ng-container *ngIf=\"node.treeContentBlock.rightContent?.contextMenuMetaData && rightContextMenuTemplateRef\">\n <eui-dropdown class=\"eui-u-ml-xs\">\n <button euiButton euiSizeS euiRounded euiIconButton euiBasicButton euiSecondary [attr.aria-label]=\"'Options menu'\">\n <eui-icon-svg icon=\"eui-ellipsis-vertical\"></eui-icon-svg>\n </button>\n <eui-dropdown-content>\n <ng-template\n [ngTemplateOutlet]=\"rightContextMenuTemplateRef\"\n [ngTemplateOutletContext]=\"{\n $implicit: node?.treeContentBlock?.rightContent?.contextMenuMetaData,\n metadata: node?.treeContentBlock?.rightContent?.contextMenuMetaData\n }\">\n </ng-template>\n </eui-dropdown-content>\n </eui-dropdown>\n </ng-container>\n </div>\n\n <!--metadata, uses the help of ng template to generate dynamic expand variable without handling state -->\n <ng-container\n *ngIf=\"node.treeContentBlock?.metadata && nodeContentMetadataTemplateRef\"\n [ngTemplateOutlet]=\"nodeContentMetadataContainer\"\n [ngTemplateOutletContext]=\"{\n $implicit: { expanded: false }\n }\">\n </ng-container>\n <ng-template #nodeContentMetadataContainer let-metaDataContainer>\n <button\n euiButton\n euiBasicButton\n euiIconButton\n euiRounded\n euiSizeS\n type=\"button\"\n (click)=\"metaDataContainer.expanded = !metaDataContainer.expanded\">\n <eui-icon-svg [icon]=\"metaDataContainer.expanded ? 'eui-chevron-down' : 'eui-chevron-forward'\"></eui-icon-svg>\n </button>\n <div *ngIf=\"metaDataContainer.expanded\" class=\"eui-tree-node__metacontent\">\n <!--passing metadata of the node content to provided template-ref:nodeContentMetadataTemplateRef-->\n <ng-template\n [ngTemplateOutlet]=\"nodeContentMetadataTemplateRef\"\n [ngTemplateOutletContext]=\"{\n $implicit: node?.treeContentBlock?.metadata,\n metadata: node?.treeContentBlock?.metadata\n }\">\n </ng-template>\n </div>\n </ng-template>\n </ng-container>\n</ng-template>\n", styles: [".eui-tree{display:flex;overflow-x:hidden;overflow-y:auto;position:relative;width:100%}.eui-tree::-webkit-scrollbar{display:inherit;height:6px;width:6px;background-color:var(--eui-base-color-grey-5)}.eui-tree::-webkit-scrollbar-thumb{background-color:var(--eui-base-color-grey-20);border-radius:5rem}.eui-tree::-webkit-scrollbar-thumb:hover{background-color:var(--eui-base-color-grey-35)}.eui-tree::-webkit-scrollbar-track{background-color:var(--eui-base-color-grey-5);border-radius:0}.eui-tree .eui-tree__wrapper{display:flex;list-style:none;margin:0;padding:var(--eui-base-spacing-2xs);position:relative;width:100%}.eui-tree .eui-tree__wrapper .eui-cdk-tree{display:flex;flex-direction:column;width:100%}.eui-tree .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node{display:flex;width:auto}.eui-tree .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node:not(.eui-cdk-nested-tree-node--with-child){padding-inline-start:var(--eui-base-spacing-xl)}.eui-tree .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node:not(.eui-cdk-nested-tree-node--with-child) .eui-tree-node-wrapper.eui-tree-node-wrapper--show-lines:before{position:relative;left:calc(-1 * var(--eui-base-spacing-l) + var(--eui-base-spacing-2xs));display:inline-flex;border-left:1px solid var(--eui-base-color-grey-25);content:\"\";height:100%}.eui-tree .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node:not(.eui-cdk-nested-tree-node--with-child) .eui-tree-node-wrapper.eui-tree-node-wrapper--show-lines.eui-tree-node-wrapper--last:before{align-self:flex-start;display:inline-flex;height:50%;position:relative}.eui-tree .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node:not(.eui-cdk-nested-tree-node--with-child) .eui-tree-node-wrapper.eui-tree-node-wrapper--show-lines .eui-tree-node-wrapper__container:before{position:relative;left:0;display:inline-flex;width:var(--eui-base-spacing-l);border-bottom:1px solid var(--eui-base-color-grey-25);border-left:1px solid var(--eui-base-color-grey-25);content:\"\";margin-left:calc(-1 * var(--eui-base-spacing-l) + var(--eui-base-spacing-2xs))}.eui-tree .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node--with-child{display:flex;width:100%}.eui-tree .eui-tree__wrapper .eui-tree-node{display:flex;flex-direction:column;width:100%}.eui-tree .eui-tree__wrapper .eui-tree-node__metacontent{display:flex}.eui-tree .eui-tree__wrapper .eui-tree-node__button{margin-left:calc(-1 * var(--eui-base-spacing-2xs));margin-right:var(--eui-base-spacing-2xs)}.eui-tree .eui-tree__wrapper ul.eui-tree-node{padding-inline-start:var(--eui-base-spacing-l)}.eui-tree .eui-tree__wrapper .eui-tree-node-wrapper{align-items:center;display:flex;min-height:var(--eui-base-spacing-xl);width:100%}.eui-tree .eui-tree__wrapper .eui-tree-node-wrapper:hover{background-color:var(--eui-base-color-grey-5)}.eui-tree .eui-tree__wrapper .eui-tree-node-wrapper__container{align-items:center;display:flex;width:100%}.eui-tree .eui-tree__wrapper .eui-tree-node-wrapper__container-left{align-items:center;display:flex;justify-content:flex-start}.eui-tree .eui-tree__wrapper .eui-tree-node-wrapper__container-middle{align-items:center;display:flex;justify-content:flex-start;overflow:hidden;width:100%}.eui-tree .eui-tree__wrapper .eui-tree-node-wrapper__container-right{align-items:center;display:flex;justify-content:flex-end;margin-left:auto}.eui-tree:not(.eui-tree--with-children) .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node{padding-inline-start:2px}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: i3.EuiInputCheckboxComponent, selector: "input[euiInputCheckBox]", inputs: ["indeterminate", "isInvalid", "styleClass", "checked", "id"], outputs: ["indeterminateChange"] }, { kind: "directive", type: i4.CdkNestedTreeNode, selector: "cdk-nested-tree-node", inputs: ["role", "disabled", "tabIndex"], exportAs: ["cdkNestedTreeNode"] }, { kind: "directive", type: i4.CdkTreeNodeDef, selector: "[cdkTreeNodeDef]", inputs: ["cdkTreeNodeDefWhen"] }, { kind: "directive", type: i4.CdkTreeNodeToggle, selector: "[cdkTreeNodeToggle]", inputs: ["cdkTreeNodeToggleRecursive"] }, { kind: "component", type: i4.CdkTree, selector: "cdk-tree", inputs: ["dataSource", "treeControl", "trackBy"], exportAs: ["cdkTree"] }, { kind: "directive", type: i4.CdkTreeNodeOutlet, selector: "[cdkTreeNodeOutlet]" }, { kind: "component", type: i5.EuiButtonComponent, selector: "button[euiButton], a[euiButton]", inputs: ["e2eAttr", "id", "euiBasicButton", "euiButtonCall", "euiBlockButton", "isLoading", "euiIconButton", "euiLineWrap"], outputs: ["buttonClick"] }, { kind: "component", type: i6.EuiIconComponent, selector: "div[euiIcon], span[euiIcon], i[euiIcon], eui-icon", inputs: ["aria-label", "iconClass", "isLoading"] }, { kind: "component", type: i6.EuiIconSvgComponent, selector: "eui-icon-svg, span[euiIconSvg], i[euiIconSvg]", inputs: ["icon", "size", "fillColor", "set", "ariaLabelledby", "role", "style", "iconUrl", "transform", "aria-label", "ariaHidden", "focusable", "isLoading"] }, { kind: "component", type: i7.EuiLabelComponent, selector: "label[euiLabel], span[euiLabel], div[euiLabel], a[euiLabel], eui-label, label[euiSublabel], span[euiSublabel], div[euiSublabel], a[euiSublabel], eui-sublabel", inputs: ["euiRequired", "euiReadonly", "euiSublabel"] }, { kind: "component", type: i8.EuiBadgeComponent, selector: "div[euiBadge], span[euiBadge], eui-badge", inputs: ["aria-label"] }, { kind: "component", type: i9.EuiChipComponent, selector: "eui-chip, span[euiChip], li[euiChip]", inputs: ["euiInternalId", "tooltipMessage", "id", "data", "isChipRemovable", "isSquared"], outputs: ["remove"] }, { kind: "component", type: i10.EuiDropdownComponent, selector: "eui-dropdown", inputs: ["e2eAttr", "tabIndex", "width", "position", "isDropDownRightAligned", "isClosedOnClickInside", "isLabelUpdatedFromSelectedItem", "isExpandOnHover", "hasTabNavigation"] }, { kind: "directive", type: i10.EuiDropdownContentDirective, selector: "eui-dropdown-content" }, { kind: "pipe", type: i11.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
817
+ checkIfCurrentScrollable(scrolled) {
818
+ return scrolled.getElementRef().nativeElement === this.cdkScrollableRef.getElementRef().nativeElement;
819
+ }
820
+ /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.0-rc.1", ngImport: i0, type: EuiTreeComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.ScrollDispatcher }], target: i0.ɵɵFactoryTarget.Component }); }
821
+ /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.0-rc.1", type: EuiTreeComponent, selector: "eui-tree", inputs: { e2eAttr: "e2eAttr", nodes: "nodes", nodeTemplateRef: "nodeTemplateRef", nodeContentMetadataTemplateRef: "nodeContentMetadataTemplateRef", rightContextMenuTemplateRef: "rightContextMenuTemplateRef", expandedIconClass: "expandedIconClass", collapsedIconClass: "collapsedIconClass", expandedSvgIconClass: "expandedSvgIconClass", collapsedSvgIconClass: "collapsedSvgIconClass", isClickTogglingNode: "isClickTogglingNode", isMultiselect: "isMultiselect", isSingleSelect: "isSingleSelect", isRecursiveSelection: "isRecursiveSelection", isRecursiveParentSelection: "isRecursiveParentSelection", showUnderlinedLinks: "showUnderlinedLinks", showLines: "showLines", autoTranslate: "autoTranslate", highlightPath: "highlightPath" }, outputs: { selectionChange: "selectionChange", nodeClick: "nodeClick", nodeToggle: "nodeToggle" }, host: { properties: { "class": "this.cssClasses", "attr.data-e2e": "this.e2eAttr" } }, viewQueries: [{ propertyName: "cdkScrollableRef", first: true, predicate: ["cdkScrollableRef"], descendants: true, read: CdkScrollable }, { propertyName: "treeComponentInstance", first: true, predicate: ["treeComponentInstance"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<ul class=\"eui-tree__wrapper\" cdkScrollable #cdkScrollableRef style=\"overflow: auto; max-height: 400px\">\n <cdk-tree\n #treeComponentInstance\n [dataSource]=\"cdkArrayDataSource\"\n [treeControl]=\"cdkTreeControl\"\n [trackBy]=\"trackBy\"\n *ngIf=\"renderTree\"\n class=\"eui-cdk-tree\">\n <!-- There are two states of generic cdk-nested-tree-node declarations.\n First one is without child. No sub rendering.\n -->\n <cdk-nested-tree-node *cdkTreeNodeDef=\"let treeRunTimeItemModel\" class=\"eui-cdk-nested-tree-node\">\n <li\n class=\"eui-tree-node\"\n *ngIf=\"treeRunTimeItemModel\"\n title=\"{{\n getTreeItem(treeRunTimeItemModel?.path)?.node?.treeContentBlock?.tooltipLabel ||\n getTreeItem(treeRunTimeItemModel?.path)?.node?.treeContentBlock?.label\n }}\">\n <div\n class=\"eui-tree-node-wrapper\"\n (click)=\"onNodeClick(treeRunTimeItemModel)\"\n [class.eui-tree-node-wrapper--last]=\"treeRunTimeItemModel.last\"\n [class.eui-tree-node-wrapper--show-lines]=\"showLines && _isMultiLevel\">\n <div class=\"eui-tree-node-wrapper__container\">\n <!--\n Renders node in default or provided template's context.\n Generates onSelect with onSelectFn for developers to send the events from their custom check events.\n Provides id to be used on generic template\n -->\n <ng-container\n [ngTemplateOutlet]=\"nodeTemplateRef || nodeTemplateDefault\"\n [ngTemplateOutletContext]=\"{\n $implicit: getTreeItem(treeRunTimeItemModel?.path)?.node,\n onSelect: onSelectFn(treeRunTimeItemModel.path),\n id: uid + treeRunTimeItemModel.path\n }\">\n </ng-container>\n </div>\n </div>\n </li>\n </cdk-nested-tree-node>\n <!-- This is the tree node template for expandable nodes -->\n <cdk-nested-tree-node\n *cdkTreeNodeDef=\"let treeRunTimeItemModel; when: hasChild\"\n class=\"eui-cdk-nested-tree-node eui-cdk-nested-tree-node--with-child\">\n <li\n class=\"eui-tree-node\"\n *ngIf=\"treeRunTimeItemModel\"\n title=\"{{\n getTreeItem(treeRunTimeItemModel?.path)?.node?.treeContentBlock?.tooltipLabel ||\n getTreeItem(treeRunTimeItemModel?.path)?.node?.treeContentBlock?.label\n }}\">\n <div\n class=\"eui-tree-node-wrapper\"\n [class.eui-tree-node-wrapper--last]=\"treeRunTimeItemModel.last\"\n [class.eui-tree-node-wrapper--show-lines]=\"showLines\">\n <!--Here wraps the node, and listen for node clicks.-->\n <div (click)=\"onNodeClick(treeRunTimeItemModel)\" class=\"eui-tree-node-wrapper__container\">\n <!-- Expand/collapse action button -->\n <button\n euiButton\n euiIconButton\n euiBasicButton\n euiRounded\n euiSizeS\n type=\"button\"\n [attr.aria-label]=\"'Toggle ' + getTreeItem(treeRunTimeItemModel?.path)?.node?.treeContentBlock?.label\"\n (click)=\"onNodeToggle(treeRunTimeItemModel)\"\n cdkTreeNodeToggle\n class=\"eui-tree-node__button\">\n <span\n euiIcon\n *ngIf=\"!cdkTreeControl.isExpanded(treeRunTimeItemModel) && collapsedIconClass\"\n [iconClass]=\"collapsedIconClass\"></span>\n <span\n euiIcon\n *ngIf=\"cdkTreeControl.isExpanded(treeRunTimeItemModel) && expandedIconClass\"\n [iconClass]=\"expandedIconClass\"></span>\n <eui-icon-svg\n *ngIf=\"!cdkTreeControl.isExpanded(treeRunTimeItemModel) && !collapsedIconClass\"\n [icon]=\"expandedSvgIconClass\"></eui-icon-svg>\n <eui-icon-svg\n *ngIf=\"cdkTreeControl.isExpanded(treeRunTimeItemModel) && !expandedIconClass\"\n [icon]=\"collapsedSvgIconClass\"></eui-icon-svg>\n </button>\n <!--\n Renders node in default or provided template's context.\n Generates onSelect with onSelectFn for developers to send the events from their custom check events.\n Provides id to be used on generic template\n -->\n <ng-container\n [ngTemplateOutlet]=\"nodeTemplateRef || nodeTemplateDefault\"\n [ngTemplateOutletContext]=\"{\n $implicit: getTreeItem(treeRunTimeItemModel.path)?.node,\n onSelect: onSelectFn(treeRunTimeItemModel.path),\n id: uid + treeRunTimeItemModel.path,\n path: treeRunTimeItemModel.path\n }\">\n </ng-container>\n </div>\n </div>\n <!--uses cdkTreeNodeOutlet to render children nodes, CdkTreeControl is used to control isExpanded state.-->\n <ul class=\"eui-tree-node\" *ngIf=\"cdkTreeControl.isExpanded(treeRunTimeItemModel)\">\n <ng-container cdkTreeNodeOutlet></ng-container>\n </ul>\n </li>\n </cdk-nested-tree-node>\n </cdk-tree>\n</ul>\n\n<ng-template #nodeTemplateDefault let-node let-onSelect=\"onSelect\" let-id=\"id\" let-path=\"path\">\n <ng-container *ngIf=\"node\">\n <div class=\"eui-tree-node-wrapper__container-left\" [class.eui-tree-node-wrapper__container-left--selected]=\"node?.isSelected\">\n <!--input checkbox area-->\n <input\n euiInputCheckBox\n *ngIf=\"node && node.selectable\"\n type=\"checkbox\"\n id=\"{{ id }}\"\n [checked]=\"!!node?.isSelected\"\n [indeterminate]=\"!!node?.isIndeterminate\"\n (change)=\"onSelect($event)\"\n class=\"eui-u-mr-m\" />\n\n <!--icon area-->\n <ng-container *ngIf=\"node?.treeContentBlock?.iconClass\">\n <eui-icon\n [euiVariant]=\"node?.treeContentBlock?.iconTypeClass || 'primary'\"\n iconClass=\"{{ node?.treeContentBlock?.iconClass }}\"\n euiSizeS\n class=\"eui-u-mr-xs\">\n </eui-icon>\n </ng-container>\n <ng-container *ngIf=\"node?.treeContentBlock?.iconSvgName\">\n <eui-icon-svg\n icon=\"{{ node?.treeContentBlock?.iconSvgName }}\"\n fillColor=\"{{ node?.treeContentBlock?.iconTypeClass || 'grey-100' }}\"\n size=\"s\"\n class=\"eui-u-mr-xs\">\n </eui-icon-svg>\n </ng-container>\n\n <!--chips area-->\n <ng-container *ngIf=\"node?.treeContentBlock?.chips\">\n <eui-chip\n *ngFor=\"let chip of node.treeContentBlock.chips\"\n euiSizeXS\n [euiVariant]=\"chip.typeClass || 'secondary'\"\n [euiOutline]=\"chip.isOutline\"\n class=\"eui-chip--rounded eui-u-mb-none eui-u-mr-xs\">\n <span euiLabel>{{ chip.label }}</span>\n </eui-chip>\n </ng-container>\n\n <!--badge (typeLabel & typeClass) area-->\n <ng-container *ngIf=\"node?.treeContentBlock?.typeLabel\" [ngSwitch]=\"node?.treeContentBlock?.typeClass\">\n <eui-badge euiSizeM [euiVariant]=\"node?.treeContentBlock?.typeClass || 'primary'\" class=\"eui-u-flex-no-shrink eui-u-mr-xs\">\n {{ node?.treeContentBlock?.typeLabel }}\n </eui-badge>\n </ng-container>\n </div>\n\n <!--label area-->\n <div class=\"eui-tree-node-wrapper__container-middle\">\n <label\n *ngIf=\"!node?.treeContentBlock?.url && !node?.treeContentBlock?.urlExternal\"\n euiLabel\n for=\"{{ id }}\"\n class=\"eui-u-text-truncate eui-u-p-2xs\"\n [class.eui-label--selected]=\"\n highlightPath\n ? getRunTimeSelectionRecursiveState(path)?.selectionRecursiveState === 'indeterminate' || node?.isSelected\n : node?.isSelected\n \"\n [class.eui-u-cursor-pointer]=\"node?.selectable\">\n {{ autoTranslate ? (node?.treeContentBlock?.label | translate) : node?.treeContentBlock?.label }}\n </label>\n <label *ngIf=\"node?.treeContentBlock?.url\" euiLabel for=\"{{ id }}\" class=\"eui-u-text-truncate eui-u-p-2xs\">\n <a\n class=\"eui-u-text-link\"\n [class.eui-u-text-link-standalone]=\"!showUnderlinedLinks\"\n [routerLink]=\"node?.treeContentBlock?.url\">\n {{ autoTranslate ? (node?.treeContentBlock?.label | translate) : node?.treeContentBlock?.label }}\n </a>\n </label>\n <label *ngIf=\"node?.treeContentBlock?.urlExternal\" euiLabel for=\"{{ id }}\" class=\"eui-u-text-truncate eui-u-p-2xs\">\n <a\n class=\"eui-u-text-link-external\"\n [class.eui-u-text-link-external-standalone]=\"!showUnderlinedLinks\"\n href=\"{{ node?.treeContentBlock?.urlExternal }}\"\n target=\"{{ node?.treeContentBlock?.urlExternalTarget || 'blank' }}\">\n {{ autoTranslate ? (node?.treeContentBlock?.label | translate) : node?.treeContentBlock?.label }}\n </a>\n </label>\n </div>\n\n <div *ngIf=\"node?.treeContentBlock?.rightContent\" class=\"eui-tree-node-wrapper__container-right\">\n <!--badges area-->\n <ng-container *ngFor=\"let badge of node.treeContentBlock.rightContent?.badges\">\n <eui-badge euiSizeM euiOutline [euiVariant]=\"badge.typeClass || 'secondary'\" class=\"eui-u-ml-xs\">\n <span euiLabel>{{ badge.label }}</span>\n </eui-badge>\n </ng-container>\n\n <!--chips area-->\n <ng-container *ngFor=\"let chip of node.treeContentBlock.rightContent?.chips\">\n <eui-chip\n euiSizeXS\n [euiVariant]=\"chip.typeClass || 'secondary'\"\n [euiOutline]=\"chip.isOutline\"\n class=\"eui-chip--rounded eui-u-mb-none eui-u-ml-xs\">\n <span euiLabel>{{ chip.label }}</span>\n </eui-chip>\n </ng-container>\n\n <!--Context menu-->\n <ng-container *ngIf=\"node.treeContentBlock.rightContent?.contextMenuMetaData && rightContextMenuTemplateRef\">\n <eui-dropdown class=\"eui-u-ml-xs\">\n <button euiButton euiSizeS euiRounded euiIconButton euiBasicButton euiSecondary [attr.aria-label]=\"'Options menu'\">\n <eui-icon-svg icon=\"eui-ellipsis-vertical\"></eui-icon-svg>\n </button>\n <eui-dropdown-content>\n <ng-template\n [ngTemplateOutlet]=\"rightContextMenuTemplateRef\"\n [ngTemplateOutletContext]=\"{\n $implicit: node?.treeContentBlock?.rightContent?.contextMenuMetaData,\n metadata: node?.treeContentBlock?.rightContent?.contextMenuMetaData\n }\">\n </ng-template>\n </eui-dropdown-content>\n </eui-dropdown>\n </ng-container>\n </div>\n\n <!--metadata, uses the help of ng template to generate dynamic expand variable without handling state -->\n <ng-container\n *ngIf=\"node.treeContentBlock?.metadata && nodeContentMetadataTemplateRef\"\n [ngTemplateOutlet]=\"nodeContentMetadataContainer\"\n [ngTemplateOutletContext]=\"{\n $implicit: { expanded: false }\n }\">\n </ng-container>\n <ng-template #nodeContentMetadataContainer let-metaDataContainer>\n <button\n euiButton\n euiBasicButton\n euiIconButton\n euiRounded\n euiSizeS\n type=\"button\"\n aria-label=\"expand collapse tree item\"\n (click)=\"metaDataContainer.expanded = !metaDataContainer.expanded\">\n <eui-icon-svg [icon]=\"metaDataContainer.expanded ? 'eui-chevron-down' : 'eui-chevron-forward'\"></eui-icon-svg>\n </button>\n <div *ngIf=\"metaDataContainer.expanded\" class=\"eui-tree-node__metacontent\">\n <!--passing metadata of the node content to provided template-ref:nodeContentMetadataTemplateRef-->\n <ng-template\n [ngTemplateOutlet]=\"nodeContentMetadataTemplateRef\"\n [ngTemplateOutletContext]=\"{\n $implicit: node?.treeContentBlock?.metadata,\n metadata: node?.treeContentBlock?.metadata\n }\">\n </ng-template>\n </div>\n </ng-template>\n </ng-container>\n</ng-template>\n", styles: [".eui-tree{display:flex;overflow-x:hidden;overflow-y:auto;position:relative;width:100%}.eui-tree::-webkit-scrollbar{display:inherit;height:6px;width:6px;background-color:var(--eui-base-color-grey-5)}.eui-tree::-webkit-scrollbar-thumb{background-color:var(--eui-base-color-grey-20);border-radius:5rem}.eui-tree::-webkit-scrollbar-thumb:hover{background-color:var(--eui-base-color-grey-50)}.eui-tree::-webkit-scrollbar-track{background-color:var(--eui-base-color-grey-5);border-radius:0}.eui-tree .eui-tree__wrapper{display:flex;list-style:none;margin:0;padding:var(--eui-base-spacing-2xs);position:relative;width:100%}.eui-tree .eui-tree__wrapper .eui-cdk-tree{display:flex;flex-direction:column;width:100%}.eui-tree .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node{display:flex;width:auto}.eui-tree .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node:not(.eui-cdk-nested-tree-node--with-child){padding-inline-start:var(--eui-base-spacing-xl)}.eui-tree .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node:not(.eui-cdk-nested-tree-node--with-child) .eui-tree-node-wrapper.eui-tree-node-wrapper--show-lines:before{position:relative;left:calc(-1 * var(--eui-base-spacing-l) + var(--eui-base-spacing-2xs));display:inline-flex;border-left:1px solid var(--eui-base-color-grey-25);content:\"\";height:100%}.eui-tree .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node:not(.eui-cdk-nested-tree-node--with-child) .eui-tree-node-wrapper.eui-tree-node-wrapper--show-lines.eui-tree-node-wrapper--last:before{align-self:flex-start;display:inline-flex;height:50%;position:relative}.eui-tree .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node:not(.eui-cdk-nested-tree-node--with-child) .eui-tree-node-wrapper.eui-tree-node-wrapper--show-lines .eui-tree-node-wrapper__container:before{position:relative;left:0;display:inline-flex;width:var(--eui-base-spacing-l);border-bottom:1px solid var(--eui-base-color-grey-25);border-left:1px solid var(--eui-base-color-grey-25);content:\"\";margin-left:calc(-1 * var(--eui-base-spacing-l) + var(--eui-base-spacing-2xs))}.eui-tree .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node--with-child{display:flex;width:100%}.eui-tree .eui-tree__wrapper .eui-tree-node{display:flex;flex-direction:column;width:100%}.eui-tree .eui-tree__wrapper .eui-tree-node__metacontent{display:flex}.eui-tree .eui-tree__wrapper .eui-tree-node__button{margin-left:calc(-1 * var(--eui-base-spacing-2xs));margin-right:var(--eui-base-spacing-2xs)}.eui-tree .eui-tree__wrapper ul.eui-tree-node{padding-inline-start:var(--eui-base-spacing-l)}.eui-tree .eui-tree__wrapper .eui-tree-node-wrapper{align-items:center;display:flex;min-height:var(--eui-base-spacing-xl);width:100%}.eui-tree .eui-tree__wrapper .eui-tree-node-wrapper:hover{background-color:var(--eui-base-color-grey-5)}.eui-tree .eui-tree__wrapper .eui-tree-node-wrapper__container{align-items:center;display:flex;width:100%}.eui-tree .eui-tree__wrapper .eui-tree-node-wrapper__container-left{align-items:center;display:flex;justify-content:flex-start}.eui-tree .eui-tree__wrapper .eui-tree-node-wrapper__container-middle{align-items:center;display:flex;justify-content:flex-start;overflow:hidden;width:100%}.eui-tree .eui-tree__wrapper .eui-tree-node-wrapper__container-right{align-items:center;display:flex;justify-content:flex-end;margin-left:auto}.eui-tree:not(.eui-tree--with-children) .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node{padding-inline-start:2px}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: i4.EuiInputCheckboxComponent, selector: "input[euiInputCheckBox]", inputs: ["indeterminate", "isInvalid", "styleClass", "checked", "id"], outputs: ["indeterminateChange"] }, { kind: "directive", type: i5.CdkNestedTreeNode, selector: "cdk-nested-tree-node", inputs: ["role", "disabled", "tabIndex"], exportAs: ["cdkNestedTreeNode"] }, { kind: "directive", type: i5.CdkTreeNodeDef, selector: "[cdkTreeNodeDef]", inputs: ["cdkTreeNodeDefWhen"] }, { kind: "directive", type: i5.CdkTreeNodeToggle, selector: "[cdkTreeNodeToggle]", inputs: ["cdkTreeNodeToggleRecursive"] }, { kind: "component", type: i5.CdkTree, selector: "cdk-tree", inputs: ["dataSource", "treeControl", "trackBy"], exportAs: ["cdkTree"] }, { kind: "directive", type: i5.CdkTreeNodeOutlet, selector: "[cdkTreeNodeOutlet]" }, { kind: "component", type: i6.EuiButtonComponent, selector: "button[euiButton], a[euiButton]", inputs: ["e2eAttr", "id", "euiBasicButton", "euiButtonCall", "euiBlockButton", "isLoading", "euiIconButton", "euiLineWrap"], outputs: ["buttonClick"] }, { kind: "component", type: i7.EuiIconComponent, selector: "div[euiIcon], span[euiIcon], i[euiIcon], eui-icon", inputs: ["aria-label", "iconClass", "isLoading"] }, { kind: "component", type: i7.EuiIconSvgComponent, selector: "eui-icon-svg, span[euiIconSvg], i[euiIconSvg]", inputs: ["icon", "size", "fillColor", "set", "ariaLabelledby", "role", "style", "iconUrl", "transform", "aria-label", "ariaHidden", "focusable", "isLoading"] }, { kind: "component", type: i8.EuiLabelComponent, selector: "label[euiLabel], span[euiLabel], div[euiLabel], a[euiLabel], eui-label, label[euiSublabel], span[euiSublabel], div[euiSublabel], a[euiSublabel], eui-sublabel", inputs: ["euiRequired", "euiReadonly", "euiSublabel"] }, { kind: "component", type: i9.EuiBadgeComponent, selector: "div[euiBadge], span[euiBadge], eui-badge", inputs: ["aria-label"] }, { kind: "component", type: i10.EuiChipComponent, selector: "eui-chip, span[euiChip], li[euiChip]", inputs: ["euiInternalId", "tooltipMessage", "id", "data", "isChipRemovable", "isSquared"], outputs: ["remove"] }, { kind: "component", type: i11.EuiDropdownComponent, selector: "eui-dropdown", inputs: ["e2eAttr", "tabIndex", "width", "position", "isDropDownRightAligned", "isClosedOnClickInside", "isLabelUpdatedFromSelectedItem", "isExpandOnHover", "hasTabNavigation"] }, { kind: "directive", type: i11.EuiDropdownContentDirective, selector: "eui-dropdown-content" }, { kind: "directive", type: i1.CdkScrollable, selector: "[cdk-scrollable], [cdkScrollable]" }, { kind: "pipe", type: i12.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
569
822
  }
570
823
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-rc.1", ngImport: i0, type: EuiTreeComponent, decorators: [{
571
824
  type: Component,
572
- args: [{ selector: 'eui-tree', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<ul class=\"eui-tree__wrapper\">\n <cdk-tree [dataSource]=\"cdkArrayDataSource\" [treeControl]=\"cdkTreeControl\" [trackBy]=\"trackBy\" *ngIf=\"renderTree\" class=\"eui-cdk-tree\">\n <!-- There are two states of generic cdk-nested-tree-node declarations.\n First one is without child. No sub rendering.\n -->\n <cdk-nested-tree-node *cdkTreeNodeDef=\"let treeItemModel\" class=\"eui-cdk-nested-tree-node\">\n <li\n class=\"eui-tree-node\"\n *ngIf=\"treeItemModel\"\n title=\"{{\n getTreeItem(treeItemModel?.path)?.node?.treeContentBlock?.tooltipLabel ||\n getTreeItem(treeItemModel?.path)?.node?.treeContentBlock?.label\n }}\">\n <div class=\"eui-tree-node-wrapper\" (click)=\"onNodeClick(treeItemModel)\"\n [class.eui-tree-node-wrapper--last]=\"false\"\n [class.eui-tree-node-wrapper--show-lines]=\"showLines\">\n <div class=\"eui-tree-node-wrapper__container\">\n <!--\n Renders node in default or provided template's context.\n Generates onSelect with onSelectFn for developers to send the events from their custom check events.\n Provides id to be used on generic template\n -->\n <ng-container\n [ngTemplateOutlet]=\"nodeTemplateRef || nodeTemplateDefault\"\n [ngTemplateOutletContext]=\"{\n $implicit: getTreeItem(treeItemModel?.path)?.node,\n onSelect: onSelectFn(treeItemModel.path, treeItemModel),\n id: uid + treeItemModel.path\n }\">\n </ng-container>\n </div>\n </div>\n </li>\n </cdk-nested-tree-node>\n <!-- This is the tree node template for expandable nodes -->\n <cdk-nested-tree-node\n *cdkTreeNodeDef=\"let treeItemModel; when: hasChild\"\n class=\"eui-cdk-nested-tree-node eui-cdk-nested-tree-node--with-child\">\n <li\n class=\"eui-tree-node\"\n *ngIf=\"treeItemModel\"\n title=\"{{\n getTreeItem(treeItemModel?.path)?.node?.treeContentBlock?.tooltipLabel ||\n getTreeItem(treeItemModel?.path)?.node?.treeContentBlock?.label\n }}\">\n <div class=\"eui-tree-node-wrapper\"\n [class.eui-tree-node-wrapper--last]=\"false\"\n [class.eui-tree-node-wrapper--show-lines]=\"showLines\">\n <!--Here wraps the node, and listen for node clicks.-->\n <div (click)=\"onNodeClick(treeItemModel)\" class=\"eui-tree-node-wrapper__container\">\n <!-- Expand/collapse action button -->\n <button\n euiButton\n euiIconButton\n euiBasicButton\n euiRounded\n euiSizeS\n type=\"button\"\n [attr.aria-label]=\"'Toggle ' + treeItemModel?.node?.treeContentBlock?.label\"\n (click)=\"onNodeToggle(treeItemModel)\"\n cdkTreeNodeToggle\n class=\"eui-tree-node__button\">\n <span\n euiIcon\n *ngIf=\"!cdkTreeControl.isExpanded(treeItemModel) && collapsedIconClass\"\n [iconClass]=\"collapsedIconClass\"></span>\n <span\n euiIcon\n *ngIf=\"cdkTreeControl.isExpanded(treeItemModel) && expandedIconClass\"\n [iconClass]=\"expandedIconClass\"></span>\n <eui-icon-svg\n *ngIf=\"!cdkTreeControl.isExpanded(treeItemModel) && !collapsedIconClass\"\n [icon]=\"expandedSvgIconClass\"></eui-icon-svg>\n <eui-icon-svg\n *ngIf=\"cdkTreeControl.isExpanded(treeItemModel) && !expandedIconClass\"\n [icon]=\"collapsedSvgIconClass\"></eui-icon-svg>\n </button>\n <!--\n Renders node in default or provided template's context.\n Generates onSelect with onSelectFn for developers to send the events from their custom check events.\n Provides id to be used on generic template\n -->\n <ng-container\n [ngTemplateOutlet]=\"nodeTemplateRef || nodeTemplateDefault\"\n [ngTemplateOutletContext]=\"{\n $implicit: getTreeItem(treeItemModel?.path)?.node,\n onSelect: onSelectFn(treeItemModel?.path, treeItemModel),\n id: uid + treeItemModel.path\n }\">\n </ng-container>\n </div>\n </div>\n <!--uses cdkTreeNodeOutlet to render children nodes, CdkTreeControl is used to control isExpanded state.-->\n <ul class=\"eui-tree-node\" *ngIf=\"cdkTreeControl.isExpanded(treeItemModel)\">\n <ng-container cdkTreeNodeOutlet></ng-container>\n </ul>\n </li>\n </cdk-nested-tree-node>\n </cdk-tree>\n</ul>\n\n<ng-template #nodeTemplateDefault let-node let-onSelect=\"onSelect\" let-id=\"id\">\n <ng-container *ngIf=\"node\">\n <div class=\"eui-tree-node-wrapper__container-left\" [class.eui-tree-node-wrapper__container-left--selected]=\"node?.isSelected\">\n <!--input checkbox area-->\n <input\n euiInputCheckBox\n *ngIf=\"node && node.selectable\"\n type=\"checkbox\"\n id=\"{{ id }}\"\n [checked]=\"!!node?.isSelected\"\n [indeterminate]=\"!!node?.isIndeterminate\"\n (change)=\"onSelect($event)\"\n class=\"eui-u-mr-m\" />\n\n <!--icon area-->\n <ng-container *ngIf=\"node?.treeContentBlock?.iconClass\">\n <eui-icon\n [euiVariant]=\"node?.treeContentBlock?.iconTypeClass || 'primary'\"\n iconClass=\"{{ node?.treeContentBlock?.iconClass }}\"\n euiSizeS\n class=\"eui-u-mr-xs\">\n </eui-icon>\n </ng-container>\n <ng-container *ngIf=\"node?.treeContentBlock?.iconSvgName\">\n <eui-icon-svg\n icon=\"{{ node?.treeContentBlock?.iconSvgName }}\"\n fillColor=\"{{ node?.treeContentBlock?.iconTypeClass || 'grey-100' }}\"\n size=\"s\"\n class=\"eui-u-mr-xs\">\n </eui-icon-svg>\n </ng-container>\n\n <!--chips area-->\n <ng-container *ngIf=\"node?.treeContentBlock?.chips\">\n <eui-chip\n *ngFor=\"let chip of node.treeContentBlock.chips\"\n euiSizeXS\n [euiVariant]=\"chip.typeClass || 'secondary'\"\n [euiOutline]=\"chip.isOutline\"\n class=\"eui-chip--rounded eui-u-mb-none eui-u-mr-xs\">\n <span euiLabel>{{ chip.label }}</span>\n </eui-chip>\n </ng-container>\n\n <!--badge (typeLabel & typeClass) area-->\n <ng-container *ngIf=\"node?.treeContentBlock?.typeLabel\" [ngSwitch]=\"node?.treeContentBlock?.typeClass\">\n <eui-badge euiSizeM [euiVariant]=\"node?.treeContentBlock?.typeClass || 'primary'\" class=\"eui-u-flex-no-shrink eui-u-mr-xs\">\n {{ node?.treeContentBlock?.typeLabel }}\n </eui-badge>\n </ng-container>\n </div>\n\n <!--label area-->\n <div class=\"eui-tree-node-wrapper__container-middle\">\n <label\n *ngIf=\"!node?.treeContentBlock?.url && !node?.treeContentBlock?.urlExternal\"\n euiLabel\n for=\"{{ id }}\"\n class=\"eui-u-text-truncate eui-u-p-2xs\"\n [class.eui-label--selected]=\"node?.isSelected\"\n [class.eui-u-cursor-pointer]=\"node?.selectable\">\n {{ autoTranslate ? (node?.treeContentBlock?.label | translate) : node?.treeContentBlock?.label }}\n </label>\n <label *ngIf=\"node?.treeContentBlock?.url\" euiLabel for=\"{{ id }}\" class=\"eui-u-text-truncate eui-u-p-2xs\">\n <a class=\"eui-u-text-link\" [class.eui-u-text-link-standalone]=\"!showUnderlinedLinks\" [routerLink]=\"node?.treeContentBlock?.url\">\n {{ autoTranslate ? (node?.treeContentBlock?.label | translate) : node?.treeContentBlock?.label }}\n </a>\n </label>\n <label *ngIf=\"node?.treeContentBlock?.urlExternal\" euiLabel for=\"{{ id }}\" class=\"eui-u-text-truncate eui-u-p-2xs\">\n <a\n class=\"eui-u-text-link-external\"\n [class.eui-u-text-link-external-standalone]=\"!showUnderlinedLinks\"\n href=\"{{ node?.treeContentBlock?.urlExternal }}\"\n target=\"{{ node?.treeContentBlock?.urlExternalTarget || 'blank' }}\">\n {{ autoTranslate ? (node?.treeContentBlock?.label | translate) : node?.treeContentBlock?.label }}\n </a>\n </label>\n </div>\n\n <div *ngIf=\"node?.treeContentBlock?.rightContent\" class=\"eui-tree-node-wrapper__container-right\">\n <!--badges area-->\n <ng-container *ngFor=\"let badge of node.treeContentBlock.rightContent?.badges\">\n <eui-badge euiSizeM euiOutline [euiVariant]=\"badge.typeClass || 'secondary'\" class=\"eui-u-ml-xs\">\n <span euiLabel>{{ badge.label }}</span>\n </eui-badge>\n </ng-container>\n\n <!--chips area-->\n <ng-container *ngFor=\"let chip of node.treeContentBlock.rightContent?.chips\">\n <eui-chip\n euiSizeXS\n [euiVariant]=\"chip.typeClass || 'secondary'\"\n [euiOutline]=\"chip.isOutline\"\n class=\"eui-chip--rounded eui-u-mb-none eui-u-ml-xs\">\n <span euiLabel>{{ chip.label }}</span>\n </eui-chip>\n </ng-container>\n\n <!--Context menu-->\n <ng-container *ngIf=\"node.treeContentBlock.rightContent?.contextMenuMetaData && rightContextMenuTemplateRef\">\n <eui-dropdown class=\"eui-u-ml-xs\">\n <button euiButton euiSizeS euiRounded euiIconButton euiBasicButton euiSecondary [attr.aria-label]=\"'Options menu'\">\n <eui-icon-svg icon=\"eui-ellipsis-vertical\"></eui-icon-svg>\n </button>\n <eui-dropdown-content>\n <ng-template\n [ngTemplateOutlet]=\"rightContextMenuTemplateRef\"\n [ngTemplateOutletContext]=\"{\n $implicit: node?.treeContentBlock?.rightContent?.contextMenuMetaData,\n metadata: node?.treeContentBlock?.rightContent?.contextMenuMetaData\n }\">\n </ng-template>\n </eui-dropdown-content>\n </eui-dropdown>\n </ng-container>\n </div>\n\n <!--metadata, uses the help of ng template to generate dynamic expand variable without handling state -->\n <ng-container\n *ngIf=\"node.treeContentBlock?.metadata && nodeContentMetadataTemplateRef\"\n [ngTemplateOutlet]=\"nodeContentMetadataContainer\"\n [ngTemplateOutletContext]=\"{\n $implicit: { expanded: false }\n }\">\n </ng-container>\n <ng-template #nodeContentMetadataContainer let-metaDataContainer>\n <button\n euiButton\n euiBasicButton\n euiIconButton\n euiRounded\n euiSizeS\n type=\"button\"\n (click)=\"metaDataContainer.expanded = !metaDataContainer.expanded\">\n <eui-icon-svg [icon]=\"metaDataContainer.expanded ? 'eui-chevron-down' : 'eui-chevron-forward'\"></eui-icon-svg>\n </button>\n <div *ngIf=\"metaDataContainer.expanded\" class=\"eui-tree-node__metacontent\">\n <!--passing metadata of the node content to provided template-ref:nodeContentMetadataTemplateRef-->\n <ng-template\n [ngTemplateOutlet]=\"nodeContentMetadataTemplateRef\"\n [ngTemplateOutletContext]=\"{\n $implicit: node?.treeContentBlock?.metadata,\n metadata: node?.treeContentBlock?.metadata\n }\">\n </ng-template>\n </div>\n </ng-template>\n </ng-container>\n</ng-template>\n", styles: [".eui-tree{display:flex;overflow-x:hidden;overflow-y:auto;position:relative;width:100%}.eui-tree::-webkit-scrollbar{display:inherit;height:6px;width:6px;background-color:var(--eui-base-color-grey-5)}.eui-tree::-webkit-scrollbar-thumb{background-color:var(--eui-base-color-grey-20);border-radius:5rem}.eui-tree::-webkit-scrollbar-thumb:hover{background-color:var(--eui-base-color-grey-35)}.eui-tree::-webkit-scrollbar-track{background-color:var(--eui-base-color-grey-5);border-radius:0}.eui-tree .eui-tree__wrapper{display:flex;list-style:none;margin:0;padding:var(--eui-base-spacing-2xs);position:relative;width:100%}.eui-tree .eui-tree__wrapper .eui-cdk-tree{display:flex;flex-direction:column;width:100%}.eui-tree .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node{display:flex;width:auto}.eui-tree .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node:not(.eui-cdk-nested-tree-node--with-child){padding-inline-start:var(--eui-base-spacing-xl)}.eui-tree .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node:not(.eui-cdk-nested-tree-node--with-child) .eui-tree-node-wrapper.eui-tree-node-wrapper--show-lines:before{position:relative;left:calc(-1 * var(--eui-base-spacing-l) + var(--eui-base-spacing-2xs));display:inline-flex;border-left:1px solid var(--eui-base-color-grey-25);content:\"\";height:100%}.eui-tree .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node:not(.eui-cdk-nested-tree-node--with-child) .eui-tree-node-wrapper.eui-tree-node-wrapper--show-lines.eui-tree-node-wrapper--last:before{align-self:flex-start;display:inline-flex;height:50%;position:relative}.eui-tree .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node:not(.eui-cdk-nested-tree-node--with-child) .eui-tree-node-wrapper.eui-tree-node-wrapper--show-lines .eui-tree-node-wrapper__container:before{position:relative;left:0;display:inline-flex;width:var(--eui-base-spacing-l);border-bottom:1px solid var(--eui-base-color-grey-25);border-left:1px solid var(--eui-base-color-grey-25);content:\"\";margin-left:calc(-1 * var(--eui-base-spacing-l) + var(--eui-base-spacing-2xs))}.eui-tree .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node--with-child{display:flex;width:100%}.eui-tree .eui-tree__wrapper .eui-tree-node{display:flex;flex-direction:column;width:100%}.eui-tree .eui-tree__wrapper .eui-tree-node__metacontent{display:flex}.eui-tree .eui-tree__wrapper .eui-tree-node__button{margin-left:calc(-1 * var(--eui-base-spacing-2xs));margin-right:var(--eui-base-spacing-2xs)}.eui-tree .eui-tree__wrapper ul.eui-tree-node{padding-inline-start:var(--eui-base-spacing-l)}.eui-tree .eui-tree__wrapper .eui-tree-node-wrapper{align-items:center;display:flex;min-height:var(--eui-base-spacing-xl);width:100%}.eui-tree .eui-tree__wrapper .eui-tree-node-wrapper:hover{background-color:var(--eui-base-color-grey-5)}.eui-tree .eui-tree__wrapper .eui-tree-node-wrapper__container{align-items:center;display:flex;width:100%}.eui-tree .eui-tree__wrapper .eui-tree-node-wrapper__container-left{align-items:center;display:flex;justify-content:flex-start}.eui-tree .eui-tree__wrapper .eui-tree-node-wrapper__container-middle{align-items:center;display:flex;justify-content:flex-start;overflow:hidden;width:100%}.eui-tree .eui-tree__wrapper .eui-tree-node-wrapper__container-right{align-items:center;display:flex;justify-content:flex-end;margin-left:auto}.eui-tree:not(.eui-tree--with-children) .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node{padding-inline-start:2px}\n"] }]
573
- }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { cssClasses: [{
825
+ args: [{ selector: 'eui-tree', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<ul class=\"eui-tree__wrapper\" cdkScrollable #cdkScrollableRef style=\"overflow: auto; max-height: 400px\">\n <cdk-tree\n #treeComponentInstance\n [dataSource]=\"cdkArrayDataSource\"\n [treeControl]=\"cdkTreeControl\"\n [trackBy]=\"trackBy\"\n *ngIf=\"renderTree\"\n class=\"eui-cdk-tree\">\n <!-- There are two states of generic cdk-nested-tree-node declarations.\n First one is without child. No sub rendering.\n -->\n <cdk-nested-tree-node *cdkTreeNodeDef=\"let treeRunTimeItemModel\" class=\"eui-cdk-nested-tree-node\">\n <li\n class=\"eui-tree-node\"\n *ngIf=\"treeRunTimeItemModel\"\n title=\"{{\n getTreeItem(treeRunTimeItemModel?.path)?.node?.treeContentBlock?.tooltipLabel ||\n getTreeItem(treeRunTimeItemModel?.path)?.node?.treeContentBlock?.label\n }}\">\n <div\n class=\"eui-tree-node-wrapper\"\n (click)=\"onNodeClick(treeRunTimeItemModel)\"\n [class.eui-tree-node-wrapper--last]=\"treeRunTimeItemModel.last\"\n [class.eui-tree-node-wrapper--show-lines]=\"showLines && _isMultiLevel\">\n <div class=\"eui-tree-node-wrapper__container\">\n <!--\n Renders node in default or provided template's context.\n Generates onSelect with onSelectFn for developers to send the events from their custom check events.\n Provides id to be used on generic template\n -->\n <ng-container\n [ngTemplateOutlet]=\"nodeTemplateRef || nodeTemplateDefault\"\n [ngTemplateOutletContext]=\"{\n $implicit: getTreeItem(treeRunTimeItemModel?.path)?.node,\n onSelect: onSelectFn(treeRunTimeItemModel.path),\n id: uid + treeRunTimeItemModel.path\n }\">\n </ng-container>\n </div>\n </div>\n </li>\n </cdk-nested-tree-node>\n <!-- This is the tree node template for expandable nodes -->\n <cdk-nested-tree-node\n *cdkTreeNodeDef=\"let treeRunTimeItemModel; when: hasChild\"\n class=\"eui-cdk-nested-tree-node eui-cdk-nested-tree-node--with-child\">\n <li\n class=\"eui-tree-node\"\n *ngIf=\"treeRunTimeItemModel\"\n title=\"{{\n getTreeItem(treeRunTimeItemModel?.path)?.node?.treeContentBlock?.tooltipLabel ||\n getTreeItem(treeRunTimeItemModel?.path)?.node?.treeContentBlock?.label\n }}\">\n <div\n class=\"eui-tree-node-wrapper\"\n [class.eui-tree-node-wrapper--last]=\"treeRunTimeItemModel.last\"\n [class.eui-tree-node-wrapper--show-lines]=\"showLines\">\n <!--Here wraps the node, and listen for node clicks.-->\n <div (click)=\"onNodeClick(treeRunTimeItemModel)\" class=\"eui-tree-node-wrapper__container\">\n <!-- Expand/collapse action button -->\n <button\n euiButton\n euiIconButton\n euiBasicButton\n euiRounded\n euiSizeS\n type=\"button\"\n [attr.aria-label]=\"'Toggle ' + getTreeItem(treeRunTimeItemModel?.path)?.node?.treeContentBlock?.label\"\n (click)=\"onNodeToggle(treeRunTimeItemModel)\"\n cdkTreeNodeToggle\n class=\"eui-tree-node__button\">\n <span\n euiIcon\n *ngIf=\"!cdkTreeControl.isExpanded(treeRunTimeItemModel) && collapsedIconClass\"\n [iconClass]=\"collapsedIconClass\"></span>\n <span\n euiIcon\n *ngIf=\"cdkTreeControl.isExpanded(treeRunTimeItemModel) && expandedIconClass\"\n [iconClass]=\"expandedIconClass\"></span>\n <eui-icon-svg\n *ngIf=\"!cdkTreeControl.isExpanded(treeRunTimeItemModel) && !collapsedIconClass\"\n [icon]=\"expandedSvgIconClass\"></eui-icon-svg>\n <eui-icon-svg\n *ngIf=\"cdkTreeControl.isExpanded(treeRunTimeItemModel) && !expandedIconClass\"\n [icon]=\"collapsedSvgIconClass\"></eui-icon-svg>\n </button>\n <!--\n Renders node in default or provided template's context.\n Generates onSelect with onSelectFn for developers to send the events from their custom check events.\n Provides id to be used on generic template\n -->\n <ng-container\n [ngTemplateOutlet]=\"nodeTemplateRef || nodeTemplateDefault\"\n [ngTemplateOutletContext]=\"{\n $implicit: getTreeItem(treeRunTimeItemModel.path)?.node,\n onSelect: onSelectFn(treeRunTimeItemModel.path),\n id: uid + treeRunTimeItemModel.path,\n path: treeRunTimeItemModel.path\n }\">\n </ng-container>\n </div>\n </div>\n <!--uses cdkTreeNodeOutlet to render children nodes, CdkTreeControl is used to control isExpanded state.-->\n <ul class=\"eui-tree-node\" *ngIf=\"cdkTreeControl.isExpanded(treeRunTimeItemModel)\">\n <ng-container cdkTreeNodeOutlet></ng-container>\n </ul>\n </li>\n </cdk-nested-tree-node>\n </cdk-tree>\n</ul>\n\n<ng-template #nodeTemplateDefault let-node let-onSelect=\"onSelect\" let-id=\"id\" let-path=\"path\">\n <ng-container *ngIf=\"node\">\n <div class=\"eui-tree-node-wrapper__container-left\" [class.eui-tree-node-wrapper__container-left--selected]=\"node?.isSelected\">\n <!--input checkbox area-->\n <input\n euiInputCheckBox\n *ngIf=\"node && node.selectable\"\n type=\"checkbox\"\n id=\"{{ id }}\"\n [checked]=\"!!node?.isSelected\"\n [indeterminate]=\"!!node?.isIndeterminate\"\n (change)=\"onSelect($event)\"\n class=\"eui-u-mr-m\" />\n\n <!--icon area-->\n <ng-container *ngIf=\"node?.treeContentBlock?.iconClass\">\n <eui-icon\n [euiVariant]=\"node?.treeContentBlock?.iconTypeClass || 'primary'\"\n iconClass=\"{{ node?.treeContentBlock?.iconClass }}\"\n euiSizeS\n class=\"eui-u-mr-xs\">\n </eui-icon>\n </ng-container>\n <ng-container *ngIf=\"node?.treeContentBlock?.iconSvgName\">\n <eui-icon-svg\n icon=\"{{ node?.treeContentBlock?.iconSvgName }}\"\n fillColor=\"{{ node?.treeContentBlock?.iconTypeClass || 'grey-100' }}\"\n size=\"s\"\n class=\"eui-u-mr-xs\">\n </eui-icon-svg>\n </ng-container>\n\n <!--chips area-->\n <ng-container *ngIf=\"node?.treeContentBlock?.chips\">\n <eui-chip\n *ngFor=\"let chip of node.treeContentBlock.chips\"\n euiSizeXS\n [euiVariant]=\"chip.typeClass || 'secondary'\"\n [euiOutline]=\"chip.isOutline\"\n class=\"eui-chip--rounded eui-u-mb-none eui-u-mr-xs\">\n <span euiLabel>{{ chip.label }}</span>\n </eui-chip>\n </ng-container>\n\n <!--badge (typeLabel & typeClass) area-->\n <ng-container *ngIf=\"node?.treeContentBlock?.typeLabel\" [ngSwitch]=\"node?.treeContentBlock?.typeClass\">\n <eui-badge euiSizeM [euiVariant]=\"node?.treeContentBlock?.typeClass || 'primary'\" class=\"eui-u-flex-no-shrink eui-u-mr-xs\">\n {{ node?.treeContentBlock?.typeLabel }}\n </eui-badge>\n </ng-container>\n </div>\n\n <!--label area-->\n <div class=\"eui-tree-node-wrapper__container-middle\">\n <label\n *ngIf=\"!node?.treeContentBlock?.url && !node?.treeContentBlock?.urlExternal\"\n euiLabel\n for=\"{{ id }}\"\n class=\"eui-u-text-truncate eui-u-p-2xs\"\n [class.eui-label--selected]=\"\n highlightPath\n ? getRunTimeSelectionRecursiveState(path)?.selectionRecursiveState === 'indeterminate' || node?.isSelected\n : node?.isSelected\n \"\n [class.eui-u-cursor-pointer]=\"node?.selectable\">\n {{ autoTranslate ? (node?.treeContentBlock?.label | translate) : node?.treeContentBlock?.label }}\n </label>\n <label *ngIf=\"node?.treeContentBlock?.url\" euiLabel for=\"{{ id }}\" class=\"eui-u-text-truncate eui-u-p-2xs\">\n <a\n class=\"eui-u-text-link\"\n [class.eui-u-text-link-standalone]=\"!showUnderlinedLinks\"\n [routerLink]=\"node?.treeContentBlock?.url\">\n {{ autoTranslate ? (node?.treeContentBlock?.label | translate) : node?.treeContentBlock?.label }}\n </a>\n </label>\n <label *ngIf=\"node?.treeContentBlock?.urlExternal\" euiLabel for=\"{{ id }}\" class=\"eui-u-text-truncate eui-u-p-2xs\">\n <a\n class=\"eui-u-text-link-external\"\n [class.eui-u-text-link-external-standalone]=\"!showUnderlinedLinks\"\n href=\"{{ node?.treeContentBlock?.urlExternal }}\"\n target=\"{{ node?.treeContentBlock?.urlExternalTarget || 'blank' }}\">\n {{ autoTranslate ? (node?.treeContentBlock?.label | translate) : node?.treeContentBlock?.label }}\n </a>\n </label>\n </div>\n\n <div *ngIf=\"node?.treeContentBlock?.rightContent\" class=\"eui-tree-node-wrapper__container-right\">\n <!--badges area-->\n <ng-container *ngFor=\"let badge of node.treeContentBlock.rightContent?.badges\">\n <eui-badge euiSizeM euiOutline [euiVariant]=\"badge.typeClass || 'secondary'\" class=\"eui-u-ml-xs\">\n <span euiLabel>{{ badge.label }}</span>\n </eui-badge>\n </ng-container>\n\n <!--chips area-->\n <ng-container *ngFor=\"let chip of node.treeContentBlock.rightContent?.chips\">\n <eui-chip\n euiSizeXS\n [euiVariant]=\"chip.typeClass || 'secondary'\"\n [euiOutline]=\"chip.isOutline\"\n class=\"eui-chip--rounded eui-u-mb-none eui-u-ml-xs\">\n <span euiLabel>{{ chip.label }}</span>\n </eui-chip>\n </ng-container>\n\n <!--Context menu-->\n <ng-container *ngIf=\"node.treeContentBlock.rightContent?.contextMenuMetaData && rightContextMenuTemplateRef\">\n <eui-dropdown class=\"eui-u-ml-xs\">\n <button euiButton euiSizeS euiRounded euiIconButton euiBasicButton euiSecondary [attr.aria-label]=\"'Options menu'\">\n <eui-icon-svg icon=\"eui-ellipsis-vertical\"></eui-icon-svg>\n </button>\n <eui-dropdown-content>\n <ng-template\n [ngTemplateOutlet]=\"rightContextMenuTemplateRef\"\n [ngTemplateOutletContext]=\"{\n $implicit: node?.treeContentBlock?.rightContent?.contextMenuMetaData,\n metadata: node?.treeContentBlock?.rightContent?.contextMenuMetaData\n }\">\n </ng-template>\n </eui-dropdown-content>\n </eui-dropdown>\n </ng-container>\n </div>\n\n <!--metadata, uses the help of ng template to generate dynamic expand variable without handling state -->\n <ng-container\n *ngIf=\"node.treeContentBlock?.metadata && nodeContentMetadataTemplateRef\"\n [ngTemplateOutlet]=\"nodeContentMetadataContainer\"\n [ngTemplateOutletContext]=\"{\n $implicit: { expanded: false }\n }\">\n </ng-container>\n <ng-template #nodeContentMetadataContainer let-metaDataContainer>\n <button\n euiButton\n euiBasicButton\n euiIconButton\n euiRounded\n euiSizeS\n type=\"button\"\n aria-label=\"expand collapse tree item\"\n (click)=\"metaDataContainer.expanded = !metaDataContainer.expanded\">\n <eui-icon-svg [icon]=\"metaDataContainer.expanded ? 'eui-chevron-down' : 'eui-chevron-forward'\"></eui-icon-svg>\n </button>\n <div *ngIf=\"metaDataContainer.expanded\" class=\"eui-tree-node__metacontent\">\n <!--passing metadata of the node content to provided template-ref:nodeContentMetadataTemplateRef-->\n <ng-template\n [ngTemplateOutlet]=\"nodeContentMetadataTemplateRef\"\n [ngTemplateOutletContext]=\"{\n $implicit: node?.treeContentBlock?.metadata,\n metadata: node?.treeContentBlock?.metadata\n }\">\n </ng-template>\n </div>\n </ng-template>\n </ng-container>\n</ng-template>\n", styles: [".eui-tree{display:flex;overflow-x:hidden;overflow-y:auto;position:relative;width:100%}.eui-tree::-webkit-scrollbar{display:inherit;height:6px;width:6px;background-color:var(--eui-base-color-grey-5)}.eui-tree::-webkit-scrollbar-thumb{background-color:var(--eui-base-color-grey-20);border-radius:5rem}.eui-tree::-webkit-scrollbar-thumb:hover{background-color:var(--eui-base-color-grey-50)}.eui-tree::-webkit-scrollbar-track{background-color:var(--eui-base-color-grey-5);border-radius:0}.eui-tree .eui-tree__wrapper{display:flex;list-style:none;margin:0;padding:var(--eui-base-spacing-2xs);position:relative;width:100%}.eui-tree .eui-tree__wrapper .eui-cdk-tree{display:flex;flex-direction:column;width:100%}.eui-tree .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node{display:flex;width:auto}.eui-tree .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node:not(.eui-cdk-nested-tree-node--with-child){padding-inline-start:var(--eui-base-spacing-xl)}.eui-tree .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node:not(.eui-cdk-nested-tree-node--with-child) .eui-tree-node-wrapper.eui-tree-node-wrapper--show-lines:before{position:relative;left:calc(-1 * var(--eui-base-spacing-l) + var(--eui-base-spacing-2xs));display:inline-flex;border-left:1px solid var(--eui-base-color-grey-25);content:\"\";height:100%}.eui-tree .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node:not(.eui-cdk-nested-tree-node--with-child) .eui-tree-node-wrapper.eui-tree-node-wrapper--show-lines.eui-tree-node-wrapper--last:before{align-self:flex-start;display:inline-flex;height:50%;position:relative}.eui-tree .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node:not(.eui-cdk-nested-tree-node--with-child) .eui-tree-node-wrapper.eui-tree-node-wrapper--show-lines .eui-tree-node-wrapper__container:before{position:relative;left:0;display:inline-flex;width:var(--eui-base-spacing-l);border-bottom:1px solid var(--eui-base-color-grey-25);border-left:1px solid var(--eui-base-color-grey-25);content:\"\";margin-left:calc(-1 * var(--eui-base-spacing-l) + var(--eui-base-spacing-2xs))}.eui-tree .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node--with-child{display:flex;width:100%}.eui-tree .eui-tree__wrapper .eui-tree-node{display:flex;flex-direction:column;width:100%}.eui-tree .eui-tree__wrapper .eui-tree-node__metacontent{display:flex}.eui-tree .eui-tree__wrapper .eui-tree-node__button{margin-left:calc(-1 * var(--eui-base-spacing-2xs));margin-right:var(--eui-base-spacing-2xs)}.eui-tree .eui-tree__wrapper ul.eui-tree-node{padding-inline-start:var(--eui-base-spacing-l)}.eui-tree .eui-tree__wrapper .eui-tree-node-wrapper{align-items:center;display:flex;min-height:var(--eui-base-spacing-xl);width:100%}.eui-tree .eui-tree__wrapper .eui-tree-node-wrapper:hover{background-color:var(--eui-base-color-grey-5)}.eui-tree .eui-tree__wrapper .eui-tree-node-wrapper__container{align-items:center;display:flex;width:100%}.eui-tree .eui-tree__wrapper .eui-tree-node-wrapper__container-left{align-items:center;display:flex;justify-content:flex-start}.eui-tree .eui-tree__wrapper .eui-tree-node-wrapper__container-middle{align-items:center;display:flex;justify-content:flex-start;overflow:hidden;width:100%}.eui-tree .eui-tree__wrapper .eui-tree-node-wrapper__container-right{align-items:center;display:flex;justify-content:flex-end;margin-left:auto}.eui-tree:not(.eui-tree--with-children) .eui-tree__wrapper .eui-cdk-tree .eui-cdk-nested-tree-node{padding-inline-start:2px}\n"] }]
826
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.ScrollDispatcher }], propDecorators: { cssClasses: [{
574
827
  type: HostBinding,
575
828
  args: ['class']
576
829
  }], e2eAttr: [{
@@ -594,20 +847,30 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-rc.1", ng
594
847
  type: Input
595
848
  }], collapsedSvgIconClass: [{
596
849
  type: Input
597
- }], showUnderlinedLinks: [{
598
- type: Input
599
- }], showLines: [{
600
- type: Input
850
+ }], cdkScrollableRef: [{
851
+ type: ViewChild,
852
+ args: ['cdkScrollableRef', { read: CdkScrollable }]
853
+ }], treeComponentInstance: [{
854
+ type: ViewChild,
855
+ args: ['treeComponentInstance']
601
856
  }], isClickTogglingNode: [{
602
857
  type: Input
603
858
  }], isMultiselect: [{
604
859
  type: Input
860
+ }], isSingleSelect: [{
861
+ type: Input
605
862
  }], isRecursiveSelection: [{
606
863
  type: Input
607
864
  }], isRecursiveParentSelection: [{
608
865
  type: Input
866
+ }], showUnderlinedLinks: [{
867
+ type: Input
868
+ }], showLines: [{
869
+ type: Input
609
870
  }], autoTranslate: [{
610
871
  type: Input
872
+ }], highlightPath: [{
873
+ type: Input
611
874
  }], selectionChange: [{
612
875
  type: Output
613
876
  }], nodeClick: [{
@@ -628,7 +891,8 @@ export class EuiTreeModule {
628
891
  EuiLabelModule,
629
892
  EuiBadgeModule,
630
893
  EuiChipModule,
631
- EuiDropdownModule], exports: [EuiTreeComponent] }); }
894
+ EuiDropdownModule,
895
+ ScrollingModule], exports: [EuiTreeComponent] }); }
632
896
  /** @nocollapse */ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.0.0-rc.1", ngImport: i0, type: EuiTreeModule, imports: [CommonModule,
633
897
  RouterModule,
634
898
  FormsModule,
@@ -640,7 +904,8 @@ export class EuiTreeModule {
640
904
  EuiLabelModule,
641
905
  EuiBadgeModule,
642
906
  EuiChipModule,
643
- EuiDropdownModule] }); }
907
+ EuiDropdownModule,
908
+ ScrollingModule] }); }
644
909
  }
645
910
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-rc.1", ngImport: i0, type: EuiTreeModule, decorators: [{
646
911
  type: NgModule,
@@ -658,9 +923,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0-rc.1", ng
658
923
  EuiBadgeModule,
659
924
  EuiChipModule,
660
925
  EuiDropdownModule,
926
+ ScrollingModule,
661
927
  ],
662
928
  declarations: [EuiTreeComponent],
663
929
  exports: [EuiTreeComponent],
664
930
  }]
665
931
  }] });
666
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-tree.component.js","sourceRoot":"","sources":["../../../eui-tree/eui-tree.component.ts","../../../eui-tree/eui-tree.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    Input,\n    NgModule,\n    ChangeDetectionStrategy,\n    EventEmitter,\n    Output,\n    ViewEncapsulation,\n    TemplateRef,\n    ChangeDetectorRef,\n    SimpleChanges,\n    OnInit,\n    OnChanges,\n    HostBinding,\n    OnDestroy,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { RouterModule } from '@angular/router';\nimport {\n    SelectionRecursiveState,\n    TreeDataModel,\n    TreeItemModel,\n    TreeDataRunTimeModel,\n    TreeItemRunTimeModel,\n    TreeItemSelectionRecursiveModel,\n    EuiTreeSelectionChanges,\n} from './eui-tree.model';\nimport { FormsModule } from '@angular/forms';\nimport { EuiInputCheckboxModule } from '@eui/components/eui-input-checkbox';\nimport { EuiButtonModule } from '@eui/components/eui-button';\nimport { EuiIconModule } from '@eui/components/eui-icon';\nimport { EuiLabelModule } from '@eui/components/eui-label';\nimport { EuiBadgeModule } from '@eui/components/eui-badge';\nimport { EuiChipModule } from '@eui/components/eui-chip';\nimport { EuiDropdownModule } from '@eui/components/eui-dropdown';\nimport { NestedTreeControl, CdkTreeModule } from '@angular/cdk/tree';\nimport { ArrayDataSource, SelectionModel } from '@angular/cdk/collections';\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { TranslateModule } from '@ngx-translate/core';\n\n@Component({\n    selector: 'eui-tree',\n    templateUrl: './eui-tree.component.html',\n    styleUrls: ['./styles/_index.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuiTreeComponent implements OnInit, OnChanges, OnDestroy {\n    @HostBinding('class')\n    public get cssClasses(): string {\n        return this.getCssClasses();\n    }\n    @HostBinding('attr.data-e2e') @Input() e2eAttr = 'eui-tree';\n    @Input() nodes: TreeDataModel;\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    @Input() nodeTemplateRef: TemplateRef<any>;\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    @Input() nodeContentMetadataTemplateRef: TemplateRef<any>;\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    @Input() rightContextMenuTemplateRef: TemplateRef<any>;\n    @Input() expandedIconClass: string;\n    @Input() collapsedIconClass: string;\n    @Input() expandedSvgIconClass = 'eui-chevron-forward:eui';\n    @Input() collapsedSvgIconClass = 'eui-chevron-down:eui';\n\n    // @ViewChild('treeComponentInstance') public treeComponentInstance: any;\n    // @ViewChild('treeComponentInstance') public treeComponentInstance: any;\n    @Input()\n    get showUnderlinedLinks(): boolean {\n        return this._showUnderlinedLinks;\n    }\n\n    set showUnderlinedLinks(value: BooleanInput) {\n        this._showUnderlinedLinks = coerceBooleanProperty(value);\n    }\n\n    @Input()\n    get showLines(): boolean {\n        return this._showLines;\n    }\n\n    set showLines(value: BooleanInput) {\n        this._showLines = coerceBooleanProperty(value);\n    }\n\n    @Input()\n    get isClickTogglingNode(): boolean {\n        return this._isClickTogglingNode;\n    }\n\n    set isClickTogglingNode(value: BooleanInput) {\n        this._isClickTogglingNode = coerceBooleanProperty(value);\n    }\n\n    @Input()\n    get isMultiselect(): boolean {\n        return this._isMultiselect;\n    }\n\n    set isMultiselect(value: BooleanInput) {\n        this._isMultiselect = coerceBooleanProperty(value);\n    }\n\n    @Input()\n    get isRecursiveSelection(): boolean {\n        return this._isRecursiveSelection;\n    }\n\n    set isRecursiveSelection(value: BooleanInput) {\n        this._isRecursiveSelection = coerceBooleanProperty(value);\n    }\n\n    @Input()\n    get isRecursiveParentSelection(): boolean {\n        return this._isRecursiveParentSelection;\n    }\n\n    set isRecursiveParentSelection(value: BooleanInput) {\n        this._isRecursiveParentSelection = coerceBooleanProperty(value);\n    }\n\n    @Input()\n    get autoTranslate(): boolean {\n        return this._autoTranslate;\n    }\n\n    set autoTranslate(value: BooleanInput) {\n        this._autoTranslate = coerceBooleanProperty(value);\n    }\n\n    @Output() selectionChange = new EventEmitter<EuiTreeSelectionChanges>();\n    @Output() nodeClick = new EventEmitter<TreeItemModel>();\n    @Output() nodeToggle = new EventEmitter<TreeItemModel>();\n    cdkArrayDataSource: ArrayDataSource<TreeItemModel>;\n    cdkTreeControl: NestedTreeControl<TreeItemModel>;\n    renderTree: boolean;\n    public uid: string = Math.floor(Math.random() * 1000000000).toString();\n    private processedNodes: TreeDataModel;\n    private treeDataRunTime: TreeDataRunTimeModel;\n    private treeDataRunTimeBackup: TreeDataRunTimeModel;\n    private runTimeSelectionRecursiveState: Array<TreeItemSelectionRecursiveModel>;\n    private selectionModel: SelectionModel<TreeItemRunTimeModel>;\n    private _isClickTogglingNode = false;\n    private _isMultiselect = false;\n    private _isRecursiveSelection = false;\n    private _isRecursiveParentSelection = true;\n    private _autoTranslate = true;\n    private selectionModelSubs;\n    private _selection;\n    private _isMultiLevel;\n    private _showUnderlinedLinks;\n    private _showLines = false;\n\n    constructor(private changeDetectorRef: ChangeDetectorRef) {}\n\n    ngOnInit(): void {\n        this.initTree();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes['nodes'].currentValue !== changes['nodes'].previousValue) {\n            this.renderTree = false;\n            this.initTree();\n        }\n    }\n\n    ngOnDestroy(): void {\n        if (this.selectionModelSubs) {\n            this.selectionModelSubs.unsubscribe();\n        }\n    }\n\n    getSelection(): TreeDataModel {\n        return this._selection;\n    }\n\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    trackBy(index: number, el: any): any {\n        return el.parent;\n    }\n\n    getTreeItem(path: string): TreeItemModel {\n        const indexArr: Array<number> = this.resolvePath(path);\n        let nodeArr = this.processedNodes;\n        let node;\n        if (nodeArr && Array.isArray(nodeArr)) {\n            indexArr?.forEach((pathIndex: number, index) => {\n                if (index < indexArr.length - 1) {\n                    nodeArr = nodeArr && nodeArr[pathIndex]?.children;\n                } else {\n                    node = nodeArr[pathIndex];\n                }\n            });\n        }\n        return node;\n    }\n\n    expandAll(): void {\n        this.cdkTreeControl.expandAll();\n        this.changeDetectorRef.markForCheck();\n    }\n\n    expandAt(path: string): void {\n        this.cdkTreeControl.expandDescendants(this.getRunTimeTreeItem(path[0]));\n        this.cdkTreeControl.toggleDescendants(this.getRunTimeTreeItem(path));\n        this.cdkTreeControl.expand(this.getRunTimeTreeItem(path));\n        this.changeDetectorRef.markForCheck();\n    }\n\n    collapseAll(): void {\n        this.cdkTreeControl.collapseAll();\n        this.changeDetectorRef.markForCheck();\n    }\n\n    filterTerm(filterInput: string): void {\n        if (filterInput && filterInput !== '') {\n            this.renderTree = false;\n            this.changeDetectorRef.detectChanges();\n            setTimeout(() => {\n                this.treeDataRunTime = this.filterTreeData(structuredClone(this.treeDataRunTimeBackup), 'label', filterInput);\n                this.cdkArrayDataSource = new ArrayDataSource(this.treeDataRunTime);\n                this.cdkTreeControl = new NestedTreeControl<TreeItemRunTimeModel>((node) => node?.children);\n                this.cdkTreeControl.dataNodes = this.treeDataRunTime;\n                this.renderTree = true;\n                this.changeDetectorRef.detectChanges();\n                this.expandAll();\n            });\n        } else {\n            this.renderTree = false;\n            this.changeDetectorRef.detectChanges();\n            setTimeout(() => {\n                this.treeDataRunTime = structuredClone(this.treeDataRunTimeBackup);\n                this.cdkArrayDataSource = new ArrayDataSource(this.treeDataRunTime);\n                this.cdkTreeControl = new NestedTreeControl<TreeItemRunTimeModel>((node) => node?.children);\n                this.cdkTreeControl.dataNodes = this.treeDataRunTime;\n                this.renderTree = true;\n                this.changeDetectorRef.detectChanges();\n                this.expandAll();\n            });\n        }\n    }\n\n    setAllSelection(isChecked: boolean): void {\n        this.setIsCheckedForAll(this.processedNodes, isChecked, this.treeDataRunTime);\n        this.changeDetectorRef.markForCheck();\n    }\n\n    onNodeClick(treeItem: TreeItemRunTimeModel): void {\n        this.nodeClick.emit(this.getTreeItem(treeItem?.path));\n        if (this.isClickTogglingNode) {\n            this.cdkTreeControl.toggle(treeItem);\n            this.onNodeToggle(treeItem);\n        }\n    }\n\n    onNodeToggle(treeItem: TreeItemRunTimeModel): void {\n        this.nodeToggle.emit(this.getTreeItem(treeItem?.path));\n    }\n\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    nodeSelected(evt: any, path: string): void {\n        const item = this.getTreeItem(path);\n        const treeItemModel = this.getRunTimeTreeItem(path);\n        const node = item.node;\n        const children = item.children;\n        const pathArr = path.split('.');\n        const hasParent = pathArr.length > 1;\n        // Sets the hasParent If there is a parent, and removes the last element form pathArr.\n        if (hasParent) {\n            pathArr.pop();\n        }\n        // Silently sets the isSelected.\n        node.isSelected = evt.target.checked;\n        // Sets isSelected change on the control.\n        if (node.isSelected) {\n            this.selectTreeItem(treeItemModel);\n        } else {\n            this.deselectTreeItem(treeItemModel);\n        }\n        node.isIndeterminate = false;\n        // If the node is recursive it sets every children with the change.\n        if (children && children.length > 0) {\n            if (node?.selectConfig?.recursive) {\n                this.setIsCheckedForAll(children, evt.target.checked, treeItemModel?.children);\n            }\n        }\n        // Calculates to the node and its children node state\n        this.setRunTimeSelectionRecursiveStateTree(\n            path,\n            this.calculateItemSelectionRecursiveState(structuredClone(this.getTreeItem(path))),\n        );\n        // It is here for the filter edge case.\n        this.syncStateChangesAtPath(path);\n\n        if (hasParent) {\n            // Calculates parent path\n            const parentPath = pathArr.join('.');\n            // Creating node index sequence f.e If path is '1.2' it will be [1,2]\n            const nodeIndexSeq = parentPath.split('.').map((indexStr) => parseInt(indexStr, 10));\n            // Calculating the node paths array to be re-calculated from bottom to top\n            const nodePathsSeq = [];\n            nodeIndexSeq.forEach((nodeIndex, index) => {\n                nodePathsSeq[index] = nodeIndexSeq.slice(0, index + 1).join('.');\n            });\n            nodePathsSeq.reverse();\n            nodePathsSeq.forEach((nodePath: string) => {\n                this.updateRunTimeSelectionRecursiveState(\n                    nodePath,\n                    this.decideSelectionRecursiveState(this.getRunTimeSelectionRecursiveState(nodePath)),\n                );\n                this.syncStateChangesAtPath(nodePath);\n            });\n            this.changeDetectorRef.detectChanges();\n        }\n    }\n\n    hasChild = (_: number, item: TreeItemRunTimeModel): boolean => !!item?.children && item?.children?.length > 0;\n\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    onSelectFn(path: string, treeItemModel: TreeItemRunTimeModel): (evt: any) => void {\n        if (treeItemModel?.node?.selectable) {\n            const nodeSelected = this.nodeSelected.bind(this);\n            // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n            // eslint-disable-next-line @typescript-eslint/no-explicit-any\n            return (evt: any) => nodeSelected(evt, path);\n        }\n        // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        return (evt: any) => {\n            console.warn('treeItemModel.node.selectable is false, you can not implement onSelect');\n        };\n    }\n\n    private initTree(): void {\n        if (this.nodes) {\n            this._isMultiLevel = this.checkIfMultiLevel(this.nodes);\n            this.processedNodes = this.processInputs(structuredClone(this.nodes));\n            this.createTreeDataRuntime(this.processedNodes);\n            this.cdkArrayDataSource = new ArrayDataSource(this.treeDataRunTime);\n            this.treeDataRunTimeBackup = structuredClone(this.treeDataRunTime);\n            this.cdkTreeControl = new NestedTreeControl<TreeItemRunTimeModel>((node) => node?.children);\n            this.cdkTreeControl.dataNodes = this.treeDataRunTime;\n            this.renderInitialExpand(this.treeDataRunTime);\n            this.selectionModel = new SelectionModel<TreeItemRunTimeModel>(\n                true,\n                this.getInitialSelection(this.treeDataRunTime),\n                true,\n                (a, b) => a?.path === b?.path,\n            );\n            this._selection = [...this.selectionModel.selected]?.map((item) => this.getTreeItem(item.path));\n            this.renderTree = true;\n            if (this.selectionModelSubs) {\n                this.selectionModelSubs.unsubscribe();\n            }\n            this.selectionModelSubs = this.selectionModel.changed.subscribe((sc) => {\n                const selectionChange = {\n                    added: sc.added.map((_) => this.getTreeItem(_.path)),\n                    removed: sc.removed.map((_) => this.getTreeItem(_.path)),\n                    selection: [...this.selectionModel.selected].map((item) => this.getTreeItem(item.path)),\n                };\n                this._selection = selectionChange.selection;\n                this.selectionChange.emit(selectionChange);\n            });\n            this.changeDetectorRef.markForCheck();\n        }\n    }\n\n    private processInputs(treeData: TreeDataModel): TreeDataModel {\n        if (this.isMultiselect) {\n            treeData = this.overrideTreeDataModelForSelection(treeData, this.isRecursiveSelection, !this.isRecursiveParentSelection);\n        }\n        return treeData;\n    }\n\n    private overrideTreeDataModelForSelection(nodeArr: TreeDataModel, isRecursive: boolean, noAutoSelectParent: boolean): TreeDataModel {\n        return nodeArr?.map((item: TreeItemModel) => {\n            if (item?.children && item.children.length > 0) {\n                return {\n                    ...item,\n                    node: {\n                        ...item.node,\n                        selectable: typeof item?.node?.selectable === 'undefined' ? true : item?.node?.selectable,\n                        // isSelected: false,\n                        // isIndeterminate: false,\n                        selectConfig: {\n                            ...item.node.selectConfig,\n                            recursive:\n                                typeof item?.node?.selectConfig?.recursive === 'undefined'\n                                    ? !!isRecursive\n                                    : item?.node?.selectConfig?.recursive,\n                            noAutoSelectParent:\n                                typeof item?.node?.selectConfig?.noAutoSelectParent === 'undefined'\n                                    ? noAutoSelectParent\n                                    : item?.node?.selectConfig?.noAutoSelectParent,\n                        },\n                    },\n                    children: this.overrideTreeDataModelForSelection(item.children, isRecursive, noAutoSelectParent),\n                };\n            } else {\n                return {\n                    ...item,\n                    node: {\n                        ...item.node,\n                        selectable: typeof item?.node?.selectable === 'undefined' ? true : item?.node?.selectable,\n                    },\n                };\n            }\n        });\n    }\n\n    private getSelectionIndexOfItem(runTimeTreeItem: TreeItemRunTimeModel): number {\n        return this.selectionModel.selected.findIndex((i) => i?.path === runTimeTreeItem?.path);\n    }\n\n    private selectTreeItem(runTimeTreeItem: TreeItemRunTimeModel): void {\n        const indexOfItem = this.getSelectionIndexOfItem(runTimeTreeItem);\n        if (indexOfItem === -1) {\n            this.selectionModel.select(runTimeTreeItem);\n        }\n    }\n\n    private deselectTreeItem(runTimeTreeItem: TreeItemRunTimeModel): void {\n        const indexOfItem = this.getSelectionIndexOfItem(runTimeTreeItem);\n        if (indexOfItem > -1) {\n            const newSelection = [...this.selectionModel.selected];\n            newSelection.splice(indexOfItem, 1);\n            this.selectionModel.setSelection(...newSelection);\n        }\n    }\n\n    // Creates treeDataRunTime & runTimeSelectionRecursiveState for separate the logic.\n    private createTreeDataRuntime(nodes: TreeDataModel): void {\n        this.treeDataRunTime = structuredClone(nodes)?.map((item, index) => {\n            return this.calculateRunTimeState({ ...item }, index);\n        });\n        this.runTimeSelectionRecursiveState = structuredClone(nodes)?.map((item) => this.calculateItemSelectionRecursiveState({ ...item }));\n    }\n\n    // Creating run time state which includes children selection state for selection tree.\n    private calculateItemSelectionRecursiveState(treeItem: TreeItemModel): TreeItemSelectionRecursiveModel {\n        if (treeItem.children && treeItem.children.length > 0) {\n            treeItem.children.forEach((child, index) => {\n                treeItem.children[index] = this.calculateItemSelectionRecursiveState(child);\n            });\n        }\n\n        const itemState: SelectionRecursiveState = this.decideSelectionRecursiveState(treeItem);\n\n        return {\n            ...treeItem,\n            selectionRecursiveState: itemState,\n        };\n    }\n\n    private decideSelectionRecursiveState(treeItem: TreeItemSelectionRecursiveModel): SelectionRecursiveState {\n        // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        const runTimeItems = treeItem.children || ([] as any);\n        const childStates = runTimeItems?.map((item) => item.selectionRecursiveState);\n        let itemState: SelectionRecursiveState = 'indeterminate';\n        if (treeItem.node.isSelected && childStates.every((state) => state === 'allSelected')) {\n            itemState = 'allSelected';\n        } else if (!treeItem.node.isSelected && childStates.every((state) => state === 'allNotSelected')) {\n            itemState = 'allNotSelected';\n        } else if (\n            treeItem.node?.selectConfig?.recursive &&\n            childStates.every((state) => state === 'allSelected') &&\n            !treeItem.node.isSelected &&\n            !treeItem?.node?.selectConfig?.noAutoSelectParent\n        ) {\n            itemState = 'allSelected';\n        } else if (\n            treeItem.node?.selectConfig?.recursive &&\n            childStates.every((state) => state === 'allNotSelected') &&\n            treeItem.node.isSelected\n        ) {\n            itemState = 'allNotSelected';\n        }\n        return itemState;\n    }\n\n    private syncStateChangesAtPath(nodePath): void {\n        const treeItem = this.getTreeItem(nodePath);\n        const runTimeTreeItem = this.getRunTimeTreeItem(nodePath);\n        const runTimeSelectionRecursiveItem = this.getRunTimeSelectionRecursiveState(nodePath);\n        if (treeItem?.node?.selectable && treeItem.node?.selectConfig?.recursive) {\n            if (!treeItem.node?.selectConfig?.noAutoSelectParent) {\n                treeItem.node = {\n                    ...treeItem.node,\n                    isSelected: runTimeSelectionRecursiveItem.selectionRecursiveState === 'allSelected',\n                    isIndeterminate: runTimeSelectionRecursiveItem.selectionRecursiveState === 'indeterminate',\n                };\n            } else {\n                treeItem.node = {\n                    ...treeItem.node,\n                    isSelected: treeItem.node.isSelected && runTimeSelectionRecursiveItem.selectionRecursiveState === 'allSelected',\n                    isIndeterminate:\n                        runTimeSelectionRecursiveItem.selectionRecursiveState === 'indeterminate' ||\n                        (!treeItem.node.isSelected && runTimeSelectionRecursiveItem.selectionRecursiveState === 'allSelected'),\n                };\n            }\n            // console.log(treeItem, treeItem.node.treeContentBlock.label, 'isSelected:' + treeItem.node.isSelected, 'isIndeterminate:' + treeItem.node.isIndeterminate);\n            if (treeItem.node.isSelected === true) {\n                this.selectTreeItem(runTimeTreeItem);\n            } else {\n                this.deselectTreeItem(runTimeTreeItem);\n            }\n        }\n    }\n\n    private getRunTimeSelectionRecursiveState(path: string): TreeItemSelectionRecursiveModel {\n        const indexArr: Array<number> = this.resolvePath(path);\n        let nodeArr = this.runTimeSelectionRecursiveState;\n        let node;\n        indexArr.forEach((pathIndex: number, index) => {\n            if (index < indexArr.length - 1) {\n                nodeArr = nodeArr[pathIndex]?.children;\n            } else {\n                node = nodeArr[pathIndex];\n            }\n        });\n        return node;\n    }\n\n    private setRunTimeSelectionRecursiveStateTree(path: string, item: TreeItemSelectionRecursiveModel): void {\n        const indexArr: Array<number> = this.resolvePath(path);\n        let itemArr = this.runTimeSelectionRecursiveState;\n        indexArr.forEach((pathIndex: number, index) => {\n            if (index < indexArr.length - 1) {\n                itemArr = itemArr[pathIndex]?.children;\n            } else {\n                itemArr[pathIndex] = item;\n            }\n        });\n    }\n\n    private updateRunTimeSelectionRecursiveState(path: string, selectionRecursiveState: SelectionRecursiveState): void {\n        const indexArr: Array<number> = this.resolvePath(path);\n        let itemArr = this.runTimeSelectionRecursiveState;\n        indexArr.forEach((pathIndex: number, index) => {\n            if (index < indexArr.length - 1) {\n                itemArr = itemArr[pathIndex]?.children;\n            } else {\n                itemArr[pathIndex] = {\n                    ...itemArr[pathIndex],\n                    selectionRecursiveState,\n                };\n            }\n        });\n    }\n\n    private setIsCheckedForAll(nodeArr: TreeDataModel, isChecked: boolean, runTimeTreeData: TreeDataRunTimeModel): void {\n        nodeArr.forEach((item: TreeItemModel, index: number) => {\n            if (runTimeTreeData[index] && nodeArr[index]?.node?.selectable) {\n                nodeArr[index] = {\n                    ...item,\n                    node: {\n                        ...item.node,\n                        isSelected: isChecked,\n                        isIndeterminate: false,\n                    },\n                };\n                if (isChecked) {\n                    this.selectTreeItem(runTimeTreeData[index]);\n                } else {\n                    this.deselectTreeItem(runTimeTreeData[index]);\n                }\n            }\n            if (runTimeTreeData[index]?.children?.length > 0 && nodeArr[index].children && nodeArr[index].children.length > 0) {\n                this.setIsCheckedForAll(nodeArr[index].children, isChecked, runTimeTreeData[index].children);\n            }\n        });\n    }\n\n    private resolvePath(path: string): Array<number> {\n        return path?.split('.').map((index: string) => parseInt(index, 10));\n    }\n\n    private calculateRunTimeState(treeItem: TreeItemRunTimeModel, index: number, parentPath?: string): TreeItemRunTimeModel {\n        treeItem.path = parentPath ? parentPath + '.' + index : index.toString();\n        treeItem.index = index;\n        if (treeItem.children && treeItem.children.length > 0) {\n            treeItem.children.forEach((child, treeItemIndex) => {\n                treeItem.children[treeItemIndex] = this.calculateRunTimeState(child, treeItemIndex, treeItem.path);\n            });\n        }\n        return treeItem;\n    }\n\n    private filterTreeData(treeData: TreeDataModel, key = 'label', filterStr: string): TreeItemModel[] {\n        return treeData.filter((treeItem: TreeItemModel): boolean => {\n            if (treeItem?.children?.length > 0) {\n                treeItem.children = this.filterTreeData([...treeItem.children], key, filterStr);\n                treeItem.children = treeItem.children.length > 0 ? treeItem.children : undefined;\n            }\n            if (this.normalizedStr(treeItem.node.treeContentBlock.label).includes(this.normalizedStr(filterStr))) {\n                return true;\n            } else if (treeItem?.children?.length > 0) {\n                return treeItem?.children?.length > 0;\n            } else {\n                return false;\n            }\n        });\n    }\n\n    private normalizedStr(str: string): string {\n        return str\n            .toLowerCase()\n            .normalize('NFD')\n            .replace(/[\\u0300-\\u036f]/g, '');\n    }\n\n    private getInitialSelection(nodes: TreeDataRunTimeModel): Array<TreeItemRunTimeModel> {\n        const selection: Array<TreeItemRunTimeModel> = [];\n        this.scanSelection(nodes, selection);\n        return selection;\n    }\n\n    private scanSelection(nodes: TreeDataRunTimeModel, selection: Array<TreeItemRunTimeModel>): void {\n        nodes.forEach((item: TreeItemRunTimeModel) => {\n            if (item.node?.selectable && item.node.isSelected) {\n                selection.push(item);\n            }\n            if (item?.children?.length > 0) {\n                this.scanSelection(item.children, selection);\n            }\n        });\n    }\n\n    private renderInitialExpand(nodes: TreeDataRunTimeModel): void {\n        nodes.forEach((item: TreeItemRunTimeModel) => {\n            if (item?.node?.isExpanded) {\n                this.expandAt(item.path);\n            }\n            if (item?.children?.length > 0) {\n                this.renderInitialExpand(item.children);\n            }\n        });\n    }\n\n    private getRunTimeTreeItem(path: string): TreeItemRunTimeModel {\n        const indexArr: Array<number> = this.resolvePath(path);\n        let nodeArr = this.treeDataRunTime;\n        let node;\n        if (nodeArr && Array.isArray(nodeArr)) {\n            indexArr?.forEach((pathIndex: number, index) => {\n                if (index < indexArr.length - 1) {\n                    nodeArr = nodeArr && nodeArr[pathIndex]?.children;\n                } else {\n                    node = nodeArr[pathIndex];\n                }\n            });\n        }\n        return node;\n    }\n\n    private getCssClasses(): string {\n        return ['eui-tree', this.isMultiselect ? 'eui-tree--multiselect' : '', this._isMultiLevel ? 'eui-tree--with-children' : '']\n            .join(' ')\n            .trim();\n    }\n\n    private checkIfMultiLevel(tree: TreeDataModel): boolean {\n        let isMultiLevel = false;\n        tree.forEach((item: TreeItemModel) => {\n            if (item?.children?.length > 0) {\n                isMultiLevel = true;\n            }\n        });\n        return isMultiLevel;\n    }\n}\n\n@NgModule({\n    imports: [\n        CommonModule,\n        RouterModule,\n        FormsModule,\n        TranslateModule,\n        EuiInputCheckboxModule,\n        CdkTreeModule,\n        EuiButtonModule,\n        EuiIconModule,\n        EuiLabelModule,\n        EuiBadgeModule,\n        EuiChipModule,\n        EuiDropdownModule,\n    ],\n    declarations: [EuiTreeComponent],\n    exports: [EuiTreeComponent],\n})\nexport class EuiTreeModule {}\n","<ul class=\"eui-tree__wrapper\">\n    <cdk-tree [dataSource]=\"cdkArrayDataSource\" [treeControl]=\"cdkTreeControl\" [trackBy]=\"trackBy\" *ngIf=\"renderTree\" class=\"eui-cdk-tree\">\n        <!-- There are two states of generic cdk-nested-tree-node declarations.\n        First one is without child. No sub rendering.\n        -->\n        <cdk-nested-tree-node *cdkTreeNodeDef=\"let treeItemModel\" class=\"eui-cdk-nested-tree-node\">\n            <li\n                class=\"eui-tree-node\"\n                *ngIf=\"treeItemModel\"\n                title=\"{{\n                    getTreeItem(treeItemModel?.path)?.node?.treeContentBlock?.tooltipLabel ||\n                        getTreeItem(treeItemModel?.path)?.node?.treeContentBlock?.label\n                }}\">\n                <div class=\"eui-tree-node-wrapper\" (click)=\"onNodeClick(treeItemModel)\"\n                     [class.eui-tree-node-wrapper--last]=\"false\"\n                     [class.eui-tree-node-wrapper--show-lines]=\"showLines\">\n                    <div class=\"eui-tree-node-wrapper__container\">\n                        <!--\n                        Renders node in default or provided template's context.\n                        Generates onSelect with onSelectFn for developers to send the events from their custom check events.\n                        Provides id to be used on generic template\n                        -->\n                        <ng-container\n                            [ngTemplateOutlet]=\"nodeTemplateRef || nodeTemplateDefault\"\n                            [ngTemplateOutletContext]=\"{\n                                $implicit: getTreeItem(treeItemModel?.path)?.node,\n                                onSelect: onSelectFn(treeItemModel.path, treeItemModel),\n                                id: uid + treeItemModel.path\n                            }\">\n                        </ng-container>\n                    </div>\n                </div>\n            </li>\n        </cdk-nested-tree-node>\n        <!-- This is the tree node template for expandable nodes -->\n        <cdk-nested-tree-node\n            *cdkTreeNodeDef=\"let treeItemModel; when: hasChild\"\n            class=\"eui-cdk-nested-tree-node eui-cdk-nested-tree-node--with-child\">\n            <li\n                class=\"eui-tree-node\"\n                *ngIf=\"treeItemModel\"\n                title=\"{{\n                    getTreeItem(treeItemModel?.path)?.node?.treeContentBlock?.tooltipLabel ||\n                        getTreeItem(treeItemModel?.path)?.node?.treeContentBlock?.label\n                }}\">\n                <div class=\"eui-tree-node-wrapper\"\n                     [class.eui-tree-node-wrapper--last]=\"false\"\n                     [class.eui-tree-node-wrapper--show-lines]=\"showLines\">\n                    <!--Here wraps the node, and listen for node clicks.-->\n                    <div (click)=\"onNodeClick(treeItemModel)\" class=\"eui-tree-node-wrapper__container\">\n                        <!-- Expand/collapse action button -->\n                        <button\n                            euiButton\n                            euiIconButton\n                            euiBasicButton\n                            euiRounded\n                            euiSizeS\n                            type=\"button\"\n                            [attr.aria-label]=\"'Toggle ' + treeItemModel?.node?.treeContentBlock?.label\"\n                            (click)=\"onNodeToggle(treeItemModel)\"\n                            cdkTreeNodeToggle\n                            class=\"eui-tree-node__button\">\n                            <span\n                                euiIcon\n                                *ngIf=\"!cdkTreeControl.isExpanded(treeItemModel) && collapsedIconClass\"\n                                [iconClass]=\"collapsedIconClass\"></span>\n                            <span\n                                euiIcon\n                                *ngIf=\"cdkTreeControl.isExpanded(treeItemModel) && expandedIconClass\"\n                                [iconClass]=\"expandedIconClass\"></span>\n                            <eui-icon-svg\n                                *ngIf=\"!cdkTreeControl.isExpanded(treeItemModel) && !collapsedIconClass\"\n                                [icon]=\"expandedSvgIconClass\"></eui-icon-svg>\n                            <eui-icon-svg\n                                *ngIf=\"cdkTreeControl.isExpanded(treeItemModel) && !expandedIconClass\"\n                                [icon]=\"collapsedSvgIconClass\"></eui-icon-svg>\n                        </button>\n                        <!--\n                        Renders node in default or provided template's context.\n                        Generates onSelect with onSelectFn for developers to send the events from their custom check events.\n                        Provides id to be used on generic template\n                        -->\n                        <ng-container\n                            [ngTemplateOutlet]=\"nodeTemplateRef || nodeTemplateDefault\"\n                            [ngTemplateOutletContext]=\"{\n                                $implicit: getTreeItem(treeItemModel?.path)?.node,\n                                onSelect: onSelectFn(treeItemModel?.path, treeItemModel),\n                                id: uid + treeItemModel.path\n                            }\">\n                        </ng-container>\n                    </div>\n                </div>\n                <!--uses cdkTreeNodeOutlet to render children nodes, CdkTreeControl is used to control isExpanded state.-->\n                <ul class=\"eui-tree-node\" *ngIf=\"cdkTreeControl.isExpanded(treeItemModel)\">\n                    <ng-container cdkTreeNodeOutlet></ng-container>\n                </ul>\n            </li>\n        </cdk-nested-tree-node>\n    </cdk-tree>\n</ul>\n\n<ng-template #nodeTemplateDefault let-node let-onSelect=\"onSelect\" let-id=\"id\">\n    <ng-container *ngIf=\"node\">\n        <div class=\"eui-tree-node-wrapper__container-left\" [class.eui-tree-node-wrapper__container-left--selected]=\"node?.isSelected\">\n            <!--input checkbox area-->\n            <input\n                euiInputCheckBox\n                *ngIf=\"node && node.selectable\"\n                type=\"checkbox\"\n                id=\"{{ id }}\"\n                [checked]=\"!!node?.isSelected\"\n                [indeterminate]=\"!!node?.isIndeterminate\"\n                (change)=\"onSelect($event)\"\n                class=\"eui-u-mr-m\" />\n\n            <!--icon area-->\n            <ng-container *ngIf=\"node?.treeContentBlock?.iconClass\">\n                <eui-icon\n                    [euiVariant]=\"node?.treeContentBlock?.iconTypeClass || 'primary'\"\n                    iconClass=\"{{ node?.treeContentBlock?.iconClass }}\"\n                    euiSizeS\n                    class=\"eui-u-mr-xs\">\n                </eui-icon>\n            </ng-container>\n            <ng-container *ngIf=\"node?.treeContentBlock?.iconSvgName\">\n                <eui-icon-svg\n                    icon=\"{{ node?.treeContentBlock?.iconSvgName }}\"\n                    fillColor=\"{{ node?.treeContentBlock?.iconTypeClass || 'grey-100' }}\"\n                    size=\"s\"\n                    class=\"eui-u-mr-xs\">\n                </eui-icon-svg>\n            </ng-container>\n\n            <!--chips area-->\n            <ng-container *ngIf=\"node?.treeContentBlock?.chips\">\n                <eui-chip\n                    *ngFor=\"let chip of node.treeContentBlock.chips\"\n                    euiSizeXS\n                    [euiVariant]=\"chip.typeClass || 'secondary'\"\n                    [euiOutline]=\"chip.isOutline\"\n                    class=\"eui-chip--rounded eui-u-mb-none eui-u-mr-xs\">\n                    <span euiLabel>{{ chip.label }}</span>\n                </eui-chip>\n            </ng-container>\n\n            <!--badge (typeLabel & typeClass) area-->\n            <ng-container *ngIf=\"node?.treeContentBlock?.typeLabel\" [ngSwitch]=\"node?.treeContentBlock?.typeClass\">\n                <eui-badge euiSizeM [euiVariant]=\"node?.treeContentBlock?.typeClass || 'primary'\" class=\"eui-u-flex-no-shrink eui-u-mr-xs\">\n                    {{ node?.treeContentBlock?.typeLabel }}\n                </eui-badge>\n            </ng-container>\n        </div>\n\n        <!--label area-->\n        <div class=\"eui-tree-node-wrapper__container-middle\">\n            <label\n                *ngIf=\"!node?.treeContentBlock?.url && !node?.treeContentBlock?.urlExternal\"\n                euiLabel\n                for=\"{{ id }}\"\n                class=\"eui-u-text-truncate eui-u-p-2xs\"\n                [class.eui-label--selected]=\"node?.isSelected\"\n                [class.eui-u-cursor-pointer]=\"node?.selectable\">\n                {{ autoTranslate ? (node?.treeContentBlock?.label | translate) : node?.treeContentBlock?.label }}\n            </label>\n            <label *ngIf=\"node?.treeContentBlock?.url\" euiLabel for=\"{{ id }}\" class=\"eui-u-text-truncate eui-u-p-2xs\">\n                <a class=\"eui-u-text-link\" [class.eui-u-text-link-standalone]=\"!showUnderlinedLinks\" [routerLink]=\"node?.treeContentBlock?.url\">\n                    {{ autoTranslate ? (node?.treeContentBlock?.label | translate) : node?.treeContentBlock?.label }}\n                </a>\n            </label>\n            <label *ngIf=\"node?.treeContentBlock?.urlExternal\" euiLabel for=\"{{ id }}\" class=\"eui-u-text-truncate eui-u-p-2xs\">\n                <a\n                    class=\"eui-u-text-link-external\"\n                    [class.eui-u-text-link-external-standalone]=\"!showUnderlinedLinks\"\n                    href=\"{{ node?.treeContentBlock?.urlExternal }}\"\n                    target=\"{{ node?.treeContentBlock?.urlExternalTarget || 'blank' }}\">\n                    {{ autoTranslate ? (node?.treeContentBlock?.label | translate) : node?.treeContentBlock?.label }}\n                </a>\n            </label>\n        </div>\n\n        <div *ngIf=\"node?.treeContentBlock?.rightContent\" class=\"eui-tree-node-wrapper__container-right\">\n            <!--badges area-->\n            <ng-container *ngFor=\"let badge of node.treeContentBlock.rightContent?.badges\">\n                <eui-badge euiSizeM euiOutline [euiVariant]=\"badge.typeClass || 'secondary'\" class=\"eui-u-ml-xs\">\n                    <span euiLabel>{{ badge.label }}</span>\n                </eui-badge>\n            </ng-container>\n\n            <!--chips area-->\n            <ng-container *ngFor=\"let chip of node.treeContentBlock.rightContent?.chips\">\n                <eui-chip\n                    euiSizeXS\n                    [euiVariant]=\"chip.typeClass || 'secondary'\"\n                    [euiOutline]=\"chip.isOutline\"\n                    class=\"eui-chip--rounded eui-u-mb-none eui-u-ml-xs\">\n                    <span euiLabel>{{ chip.label }}</span>\n                </eui-chip>\n            </ng-container>\n\n            <!--Context menu-->\n            <ng-container *ngIf=\"node.treeContentBlock.rightContent?.contextMenuMetaData && rightContextMenuTemplateRef\">\n                <eui-dropdown class=\"eui-u-ml-xs\">\n                    <button euiButton euiSizeS euiRounded euiIconButton euiBasicButton euiSecondary [attr.aria-label]=\"'Options menu'\">\n                        <eui-icon-svg icon=\"eui-ellipsis-vertical\"></eui-icon-svg>\n                    </button>\n                    <eui-dropdown-content>\n                        <ng-template\n                            [ngTemplateOutlet]=\"rightContextMenuTemplateRef\"\n                            [ngTemplateOutletContext]=\"{\n                                $implicit: node?.treeContentBlock?.rightContent?.contextMenuMetaData,\n                                metadata: node?.treeContentBlock?.rightContent?.contextMenuMetaData\n                            }\">\n                        </ng-template>\n                    </eui-dropdown-content>\n                </eui-dropdown>\n            </ng-container>\n        </div>\n\n        <!--metadata, uses the help of ng template to generate dynamic expand variable without handling state -->\n        <ng-container\n            *ngIf=\"node.treeContentBlock?.metadata && nodeContentMetadataTemplateRef\"\n            [ngTemplateOutlet]=\"nodeContentMetadataContainer\"\n            [ngTemplateOutletContext]=\"{\n                $implicit: { expanded: false }\n            }\">\n        </ng-container>\n        <ng-template #nodeContentMetadataContainer let-metaDataContainer>\n            <button\n                euiButton\n                euiBasicButton\n                euiIconButton\n                euiRounded\n                euiSizeS\n                type=\"button\"\n                (click)=\"metaDataContainer.expanded = !metaDataContainer.expanded\">\n                <eui-icon-svg [icon]=\"metaDataContainer.expanded ? 'eui-chevron-down' : 'eui-chevron-forward'\"></eui-icon-svg>\n            </button>\n            <div *ngIf=\"metaDataContainer.expanded\" class=\"eui-tree-node__metacontent\">\n                <!--passing metadata of the node content to provided template-ref:nodeContentMetadataTemplateRef-->\n                <ng-template\n                    [ngTemplateOutlet]=\"nodeContentMetadataTemplateRef\"\n                    [ngTemplateOutletContext]=\"{\n                        $implicit: node?.treeContentBlock?.metadata,\n                        metadata: node?.treeContentBlock?.metadata\n                    }\">\n                </ng-template>\n            </div>\n        </ng-template>\n    </ng-container>\n</ng-template>\n"]}
932
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-tree.component.js","sourceRoot":"","sources":["../../../eui-tree/eui-tree.component.ts","../../../eui-tree/eui-tree.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    Input,\n    NgModule,\n    ChangeDetectionStrategy,\n    EventEmitter,\n    Output,\n    ViewEncapsulation,\n    TemplateRef,\n    ChangeDetectorRef,\n    SimpleChanges,\n    OnInit,\n    OnChanges,\n    HostBinding,\n    OnDestroy,\n    ViewChild,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { RouterModule } from '@angular/router';\nimport {\n    SelectionRecursiveState,\n    TreeDataModel,\n    TreeItemModel,\n    TreeDataRunTimeModel,\n    TreeItemRunTimeModel,\n    TreeItemSelectionRecursiveModel,\n    EuiTreeSelectionChanges,\n    EuiTreePagination,\n} from './eui-tree.model';\nimport { FormsModule } from '@angular/forms';\nimport { EuiInputCheckboxModule } from '@eui/components/eui-input-checkbox';\nimport { EuiButtonModule } from '@eui/components/eui-button';\nimport { EuiIconModule } from '@eui/components/eui-icon';\nimport { EuiLabelModule } from '@eui/components/eui-label';\nimport { EuiBadgeModule } from '@eui/components/eui-badge';\nimport { EuiChipModule } from '@eui/components/eui-chip';\nimport { EuiDropdownModule } from '@eui/components/eui-dropdown';\nimport { NestedTreeControl, CdkTreeModule, CdkTree } from '@angular/cdk/tree';\nimport { ArrayDataSource, SelectionModel } from '@angular/cdk/collections';\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { ScrollingModule, ScrollDispatcher, CdkScrollable } from '@angular/cdk/scrolling';\nimport { debounceTime } from 'rxjs';\n\n@Component({\n    selector: 'eui-tree',\n    templateUrl: './eui-tree.component.html',\n    styleUrls: ['./styles/_index.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuiTreeComponent implements OnInit, OnChanges, OnDestroy {\n    @HostBinding('class')\n    public get cssClasses(): string {\n        return this.getCssClasses();\n    }\n    @HostBinding('attr.data-e2e') @Input() e2eAttr = 'eui-tree';\n    @Input() nodes: TreeDataModel;\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    @Input() nodeTemplateRef: TemplateRef<any>;\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    @Input() nodeContentMetadataTemplateRef: TemplateRef<any>;\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    @Input() rightContextMenuTemplateRef: TemplateRef<any>;\n    @Input() expandedIconClass: string;\n    @Input() collapsedIconClass: string;\n    @Input() expandedSvgIconClass = 'eui-chevron-forward:eui';\n    @Input() collapsedSvgIconClass = 'eui-chevron-down:eui';\n\n    @ViewChild('cdkScrollableRef', { read: CdkScrollable }) cdkScrollableRef: CdkScrollable;\n    @ViewChild('treeComponentInstance') public treeComponentInstance: CdkTree<TreeItemRunTimeModel>;\n\n    // @ViewChild('treeComponentInstance') public treeComponentInstance: any;\n\n    @Input()\n    get isClickTogglingNode(): boolean {\n        return this._isClickTogglingNode;\n    }\n\n    set isClickTogglingNode(value: BooleanInput) {\n        this._isClickTogglingNode = coerceBooleanProperty(value);\n    }\n\n    @Input()\n    get isMultiselect(): boolean {\n        return this._isMultiselect;\n    }\n\n    set isMultiselect(value: BooleanInput) {\n        this._isMultiselect = coerceBooleanProperty(value);\n    }\n\n    @Input()\n    get isSingleSelect(): boolean {\n        return this._isSingleSelect;\n    }\n\n    set isSingleSelect(value: BooleanInput) {\n        this._isSingleSelect = coerceBooleanProperty(value);\n    }\n\n    @Input()\n    get isRecursiveSelection(): boolean {\n        return this._isRecursiveSelection;\n    }\n\n    set isRecursiveSelection(value: BooleanInput) {\n        this._isRecursiveSelection = coerceBooleanProperty(value);\n    }\n\n    @Input()\n    get isRecursiveParentSelection(): boolean {\n        return this._isRecursiveParentSelection;\n    }\n\n    set isRecursiveParentSelection(value: BooleanInput) {\n        this._isRecursiveParentSelection = coerceBooleanProperty(value);\n    }\n\n    @Input()\n    get showUnderlinedLinks(): boolean {\n        return this._showUnderlinedLinks;\n    }\n\n    set showUnderlinedLinks(value: BooleanInput) {\n        this._showUnderlinedLinks = coerceBooleanProperty(value);\n    }\n\n    @Input()\n    get showLines(): boolean {\n        return this._showLines;\n    }\n\n    set showLines(value: BooleanInput) {\n        this._showLines = coerceBooleanProperty(value);\n    }\n\n    @Input()\n    get autoTranslate(): boolean {\n        return this._autoTranslate;\n    }\n\n    set autoTranslate(value: BooleanInput) {\n        this._autoTranslate = coerceBooleanProperty(value);\n    }\n\n    @Input()\n    get highlightPath(): boolean {\n        return this._highlightPath;\n    }\n\n    set highlightPath(value: BooleanInput) {\n        this._highlightPath = coerceBooleanProperty(value);\n    }\n\n    @Output() selectionChange = new EventEmitter<EuiTreeSelectionChanges>();\n    @Output() nodeClick = new EventEmitter<TreeItemModel>();\n    @Output() nodeToggle = new EventEmitter<TreeItemModel>();\n    cdkArrayDataSource: ArrayDataSource<TreeItemRunTimeModel>;\n    cdkTreeControl: NestedTreeControl<TreeItemRunTimeModel>;\n    renderTree: boolean;\n    public uid: string = Math.floor(Math.random() * 1000000000).toString();\n    protected _isMultiLevel;\n    private processedNodes: TreeDataModel;\n    private treeDataRunTime: TreeDataRunTimeModel;\n    private treeDataRunTimeBackup: TreeDataRunTimeModel;\n    private runTimeSelectionRecursiveState: Array<TreeItemSelectionRecursiveModel>;\n    private selectionModel: SelectionModel<TreeItemRunTimeModel>;\n    private _isClickTogglingNode = false;\n    private _isMultiselect = false;\n    private _isSingleSelect = false;\n    private _isRecursiveSelection = false;\n    private _isRecursiveParentSelection = true;\n    private _showUnderlinedLinks = false;\n    private _showLines = false;\n    private _autoTranslate = true;\n    private _highlightPath = false;\n    private selectionModelSubs;\n    private scrollDispatcherSubs;\n    private _selection;\n    private treePagination: EuiTreePagination<TreeItemRunTimeModel>;\n\n    constructor(private changeDetectorRef: ChangeDetectorRef, private scrollDispatcher: ScrollDispatcher) {}\n\n    ngOnInit(): void {\n        this.initTree();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes['nodes']?.currentValue !== changes['nodes']?.previousValue) {\n            this.renderTree = false;\n            this.initTree();\n        }\n    }\n\n    ngOnDestroy(): void {\n        if (this.selectionModelSubs) {\n            this.selectionModelSubs.unsubscribe();\n        }\n        if (this.scrollDispatcherSubs) {\n            this.scrollDispatcherSubs.unsubscribe();\n        }\n    }\n\n    getSelection(): TreeDataModel {\n        return this._selection;\n    }\n\n    getProcessedNodes(): TreeDataModel {\n        return this.processedNodes;\n    }\n\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    trackBy(index: number, item: TreeItemRunTimeModel): any {\n        return item.path;\n    }\n\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    trackByControl(item: TreeItemRunTimeModel): any {\n        return item;\n    }\n\n    getTreeItem(path: string): TreeItemModel {\n        const indexArr: Array<number> = this.resolvePath(path);\n        let nodeArr = this.processedNodes;\n        let node;\n        if (nodeArr && Array.isArray(nodeArr)) {\n            indexArr?.forEach((pathIndex: number, index) => {\n                if (index < indexArr.length - 1) {\n                    nodeArr = nodeArr && nodeArr[pathIndex]?.children;\n                } else {\n                    node = nodeArr[pathIndex];\n                }\n            });\n        }\n        return node;\n    }\n\n    expandAll(): void {\n        this.cdkTreeControl.expandAll();\n        this.changeDetectorRef.markForCheck();\n    }\n\n    expandAt(path: string): void {\n        this.cdkTreeControl.expandDescendants(this.getRunTimeTreeItem(path[0]));\n        this.cdkTreeControl.toggleDescendants(this.getRunTimeTreeItem(path));\n        this.cdkTreeControl.expand(this.getRunTimeTreeItem(path));\n        this.changeDetectorRef.markForCheck();\n    }\n\n    collapseAll(): void {\n        this.cdkTreeControl.collapseAll();\n        this.changeDetectorRef.markForCheck();\n    }\n\n    filterTerm(filterInput: string): void {\n        if (filterInput !== '' && filterInput !== null && typeof filterInput !== 'undefined') {\n            this.treeDataRunTime = this.filterTreeData(structuredClone(this.treeDataRunTimeBackup), 'label', filterInput);\n            this.treeDataRunTime = this.applyRunTimeLastItems(this.treeDataRunTime);\n            this.cdkArrayDataSource = new ArrayDataSource(this.treeDataRunTime);\n            this.cdkTreeControl = new NestedTreeControl<TreeItemRunTimeModel>((node) => node?.children, { trackBy: this.trackByControl });\n            this.cdkTreeControl.dataNodes = this.treeDataRunTime;\n            this.renderTree = false;\n            this.changeDetectorRef.detectChanges();\n            this.renderTree = true;\n            this.changeDetectorRef.detectChanges();\n            this.expandAll();\n        } else {\n            this.treeDataRunTime = structuredClone(this.treeDataRunTimeBackup);\n            this.cdkArrayDataSource = new ArrayDataSource(this.treeDataRunTime);\n            this.cdkTreeControl = new NestedTreeControl<TreeItemRunTimeModel>((node) => node?.children, { trackBy: this.trackByControl });\n            this.cdkTreeControl.dataNodes = this.treeDataRunTime;\n            this.renderTree = false;\n            this.changeDetectorRef.detectChanges();\n            this.renderTree = true;\n            this.changeDetectorRef.detectChanges();\n            this.expandAll();\n        }\n    }\n\n    setAllSelection(isChecked: boolean): void {\n        this.setIsCheckedForAll(this.treeDataRunTime, isChecked);\n        this.changeDetectorRef.markForCheck();\n    }\n\n    updateTreeItem(treeItem: TreeItemModel, path: string): void {\n        this.setTreeData(path, this.processInputs([treeItem])[0]);\n        const pathArr = path.split('.');\n        const index = parseInt(pathArr.pop(), 10);\n        const treeItemRuntime = this.calculateRunTimeState(treeItem, index, pathArr.join('.'));\n        this.setTreeDataRunTime(path, treeItemRuntime);\n        // itemRecursiveSelectionState\n        const itemRecursiveSelectionState = this.calculateItemSelectionRecursiveState(treeItem);\n        this.setRunTimeSelectionRecursiveStateTree(path, itemRecursiveSelectionState);\n        this.syncStateChangesAtPath(path);\n        // Rendering\n        this.changeDetectorRef.detectChanges();\n        this.treeComponentInstance.renderNodeChanges([]);\n        this.treeComponentInstance.renderNodeChanges(this.treeDataRunTime);\n        if (this.cdkTreeControl.isExpanded(treeItemRuntime) && !treeItem.node.isExpanded) {\n            this.cdkTreeControl.toggle(treeItemRuntime);\n        } else if (!this.cdkTreeControl.isExpanded(treeItemRuntime) && treeItem.node.isExpanded) {\n            this.cdkTreeControl.expand(treeItemRuntime);\n        }\n        this.changeDetectorRef.detectChanges();\n    }\n\n    onNodeClick(treeRunTimeItem: TreeItemRunTimeModel): void {\n        this.nodeClick.emit(this.getTreeItem(treeRunTimeItem?.path));\n        if (this.isClickTogglingNode) {\n            this.cdkTreeControl.toggle(treeRunTimeItem);\n            this.onNodeToggle(treeRunTimeItem);\n        }\n    }\n\n    onNodeToggle(treeRunTimeItem: TreeItemRunTimeModel): void {\n        this.getTreeItem(treeRunTimeItem?.path).node.isExpanded = this.cdkTreeControl.isExpanded(treeRunTimeItem);\n        this.nodeToggle.emit(this.getTreeItem(treeRunTimeItem?.path));\n    }\n\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    nodeSelected(evt: any, path: string): void {\n        const item = this.getTreeItem(path);\n        const runTimeTreeItem = this.getRunTimeBackupTreeItem(path);\n        const renderedRunTimeTreeItem = this.getRunTimeTreeItem(path);\n        const node = item.node;\n        // console.log(path,item,runTimeTreeItem, renderedRunTimeTreeItem);\n        if (!node?.selectConfig?.singleSelect) {\n            node.isSelected = evt.target.checked;\n            node.isIndeterminate = false;\n            // If the node is recursive it sets every children with the change.\n            if (renderedRunTimeTreeItem?.children && renderedRunTimeTreeItem?.children?.length > 0) {\n                if (node?.selectConfig?.recursive) {\n                    // console.log(renderedRunTimeTreeItem);\n                    this.setIsCheckedForAll(renderedRunTimeTreeItem?.children, evt.target.checked);\n                }\n            }\n\n            this.setRunTimeSelectionRecursiveStateTree(\n                path,\n                this.calculateItemSelectionRecursiveState(structuredClone(this.getTreeItem(path))),\n            );\n            if (renderedRunTimeTreeItem?.children && renderedRunTimeTreeItem?.children?.length > 0) {\n                if (node?.selectConfig?.recursive) {\n                    // this.setIsCheckedForAll(renderedRunTimeTreeItem?.children, evt.target.checked);\n                    this.runStateChangesForAll(renderedRunTimeTreeItem?.children);\n                }\n                this.treeComponentInstance?.renderNodeChanges([]);\n                this.treeComponentInstance?.renderNodeChanges(this.treeDataRunTime);\n            }\n            this.syncStateChangesAtPath(path);\n            if (this.getTreeItem(path).node.isSelected) {\n                this.selectTreeItem(runTimeTreeItem);\n            } else {\n                this.deselectTreeItem(runTimeTreeItem);\n            }\n            const nodePathsSeq = this.getParentPaths(path);\n            if (nodePathsSeq.length > 0) {\n                nodePathsSeq.forEach((nodePath: string) => {\n                    const treeItem = this.getTreeItem(nodePath);\n                    const childStates = this.getRunTimeSelectionRecursiveState(nodePath).children.map((_) => _.selectionRecursiveState);\n                    this.updateRunTimeSelectionRecursiveState(\n                        nodePath,\n                        this.decideSelectionRecursiveState(\n                            childStates,\n                            treeItem.node?.isSelected,\n                            treeItem.node?.selectConfig?.recursive,\n                            treeItem.node?.selectConfig?.noAutoSelectParent,\n                        ),\n                    );\n                    this.syncStateChangesAtPath(nodePath);\n                });\n                this.changeDetectorRef.detectChanges();\n            } else {\n                this.changeDetectorRef.detectChanges();\n            }\n        } else {\n            const prevItem = this.selectionModel.selected[0];\n            if (evt.target.checked) {\n                if (prevItem) {\n                    this.getTreeItem(prevItem.path).node.isSelected = false;\n                    this.selectionModel.deselect(prevItem);\n                }\n                item.node.isSelected = true;\n                this.selectionModel.select(runTimeTreeItem);\n            } else {\n                item.node.isSelected = false;\n                this.selectionModel.deselect(runTimeTreeItem);\n            }\n            if (this.highlightPath) {\n                if (evt.target.checked && prevItem) {\n                    const prevItemNodePathsSeq = this.getParentPaths(prevItem.path);\n                    if (prevItemNodePathsSeq.length > 0) {\n                        prevItemNodePathsSeq.forEach((nodePath: string) => {\n                            this.updateRunTimeSelectionRecursiveState(nodePath, 'allNotSelected');\n                            this.syncStateChangesAtPath(nodePath);\n                        });\n                    }\n                }\n                const nodePathsSeq = this.getParentPaths(path);\n                if (nodePathsSeq?.length > 0) {\n                    nodePathsSeq.forEach((nodePath: string) => {\n                        this.updateRunTimeSelectionRecursiveState(nodePath, evt.target.checked ? 'indeterminate' : 'allNotSelected');\n                        this.syncStateChangesAtPath(nodePath);\n                    });\n                    this.changeDetectorRef.detectChanges();\n                }\n            }\n        }\n    }\n\n    hasChild = (_: number, item: TreeItemRunTimeModel): boolean => !!item?.children && item?.children?.length >= 0;\n\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    onSelectFn(path: string): (evt: any) => void {\n        if (this.getTreeItem(path)?.node?.selectable) {\n            const nodeSelected = this.nodeSelected.bind(this);\n            // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n            // eslint-disable-next-line @typescript-eslint/no-explicit-any\n            return (evt: any) => nodeSelected(evt, path);\n        }\n        // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        return (evt: any) => {\n            console.warn('treeItemModel.node.selectable is false, you can not implement onSelect');\n        };\n    }\n\n    getRunTimeSelectionRecursiveState(path: string): TreeItemSelectionRecursiveModel {\n        const indexArr: Array<number> = this.resolvePath(path);\n        let nodeArr = this.runTimeSelectionRecursiveState;\n        let node;\n        indexArr?.forEach((pathIndex: number, index) => {\n            if (index < indexArr.length - 1) {\n                nodeArr = nodeArr[pathIndex]?.children;\n            } else {\n                node = nodeArr[pathIndex];\n            }\n        });\n        return node;\n    }\n\n    private initTree(): void {\n        if (this.nodes) {\n            this._isMultiLevel = this.checkIfMultiLevel(this.nodes);\n            this.processedNodes = this.processInputs(structuredClone(this.nodes));\n            this.treeDataRunTime = this.createTreeDataRuntime(this.processedNodes);\n            this.treeDataRunTime = this.applyRunTimeLastItems(this.treeDataRunTime);\n            this.runTimeSelectionRecursiveState = this.createRunTimeSelectionRecursiveState(this.processedNodes);\n            this.treeDataRunTimeBackup = structuredClone(this.treeDataRunTime);\n            // console.log(this.processedNodes,this.treeDataRunTime);\n            if (this.treeDataRunTimeBackup.length > 800) {\n                this.treePagination = new EuiTreePagination<TreeItemRunTimeModel>(this.treeDataRunTimeBackup, 1, 2, 400);\n                const paginatedData = this.treePagination.getViewData().data;\n                this.cdkArrayDataSource = new ArrayDataSource<TreeItemRunTimeModel>(paginatedData);\n                this.cdkTreeControl = new NestedTreeControl<TreeItemRunTimeModel>((node) => node?.children, {\n                    trackBy: this.trackByControl,\n                });\n                this.cdkTreeControl.dataNodes = paginatedData;\n                this.runScrollListener();\n            } else {\n                this.cdkArrayDataSource = new ArrayDataSource<TreeItemRunTimeModel>(this.treeDataRunTime);\n                this.cdkTreeControl = new NestedTreeControl<TreeItemRunTimeModel>((node) => node?.children, {\n                    trackBy: this.trackByControl,\n                });\n                this.cdkTreeControl.dataNodes = this.treeDataRunTime;\n            }\n            this.renderInitialExpand(this.treeDataRunTime);\n            this.selectionModel = new SelectionModel<TreeItemRunTimeModel>(\n                true,\n                this.getInitialSelection(this.treeDataRunTime),\n                true,\n                (a, b) => a?.path === b?.path,\n            );\n            this._selection = [...this.selectionModel.selected]?.map((item) => this.getTreeItem(item?.path));\n            this.renderTree = true;\n            if (this.selectionModelSubs) {\n                this.selectionModelSubs.unsubscribe();\n            }\n            this.selectionModelSubs = this.selectionModel.changed.pipe(debounceTime(1)).subscribe((sc) => {\n                const selectionChange = {\n                    added: sc.added.map((_) => this.getTreeItem(_.path)),\n                    removed: sc.removed.map((_) => this.getTreeItem(_.path)),\n                    selection: [...this.selectionModel.selected].map((item) => this.getTreeItem(item.path)),\n                };\n                this._selection = selectionChange.selection;\n                this.selectionChange.emit(selectionChange);\n            });\n            this.changeDetectorRef.markForCheck();\n        }\n    }\n\n    private processInputs(treeData: TreeDataModel): TreeDataModel {\n        if (this.isMultiselect) {\n            treeData = this.overrideTreeDataModelForSelection(treeData, this.isRecursiveSelection, !this.isRecursiveParentSelection);\n        }\n        if (this.isSingleSelect) {\n            treeData = this.overrideTreeDataModelForSelection(treeData, false, false, true);\n        }\n        return treeData;\n    }\n\n    private overrideTreeDataModelForSelection(\n        nodeArr: TreeDataModel,\n        isRecursive: boolean,\n        noAutoSelectParent: boolean,\n        singleSelect?: boolean,\n    ): TreeDataModel {\n        return nodeArr?.map((item: TreeItemModel, index: number) => {\n            if (item?.children && item.children.length > 0) {\n                return {\n                    ...item,\n                    node: {\n                        ...item.node,\n                        selectable: typeof item?.node?.selectable === 'undefined' ? true : item?.node?.selectable,\n                        // isSelected: false,\n                        // isIndeterminate: false,\n                        selectConfig: {\n                            ...item.node.selectConfig,\n                            recursive:\n                                typeof item?.node?.selectConfig?.recursive === 'undefined'\n                                    ? !!isRecursive\n                                    : item?.node?.selectConfig?.recursive,\n                            noAutoSelectParent:\n                                typeof item?.node?.selectConfig?.noAutoSelectParent === 'undefined'\n                                    ? noAutoSelectParent\n                                    : item?.node?.selectConfig?.noAutoSelectParent,\n                            singleSelect:\n                                typeof item?.node?.selectConfig?.singleSelect === 'undefined'\n                                    ? singleSelect\n                                    : item?.node?.selectConfig?.singleSelect,\n                        },\n                    },\n                    children: this.overrideTreeDataModelForSelection(item.children, isRecursive, noAutoSelectParent, singleSelect),\n                };\n            } else {\n                return {\n                    ...item,\n                    node: {\n                        ...item.node,\n                        selectable: typeof item?.node?.selectable === 'undefined' ? true : item?.node?.selectable,\n                        selectConfig: {\n                            ...item.node?.selectConfig,\n                            singleSelect:\n                                typeof item?.node?.selectConfig?.singleSelect === 'undefined'\n                                    ? singleSelect\n                                    : item?.node?.selectConfig?.singleSelect,\n                        },\n                    },\n                };\n            }\n        });\n    }\n\n    private runScrollListener(): void {\n        this.scrollDispatcherSubs = this.scrollDispatcher.scrolled().subscribe((scrollable: CdkScrollable) => {\n            if (scrollable && this.checkIfCurrentScrollable(scrollable)) {\n                const isAtBottom =\n                    scrollable?.getElementRef().nativeElement.scrollTop + scrollable?.getElementRef().nativeElement.clientHeight >=\n                    scrollable?.getElementRef().nativeElement.scrollHeight;\n                const isAtTop = scrollable?.getElementRef().nativeElement.scrollTop === 0;\n                // console.log('Element:', this.cdkScrollableRef.getElementRef());\n                if (isAtBottom && !this.treePagination.isAtMax()) {\n                    if (this.nodes.length > 0) {\n                        this.treeDataRunTime = this.treePagination.paginateNext().data;\n                        this.treeDataRunTime = this.applyRunTimeLastItems(this.treeDataRunTime);\n                        this.cdkArrayDataSource = new ArrayDataSource(this.treeDataRunTime);\n                        this.cdkTreeControl = new NestedTreeControl<TreeItemRunTimeModel>((node) => node?.children, {\n                            trackBy: this.trackByControl,\n                        });\n                        this.cdkTreeControl.dataNodes = this.treeDataRunTime;\n                        this.renderTree = false;\n                        this.changeDetectorRef.detectChanges();\n                        this.renderTree = true;\n                        this.changeDetectorRef.detectChanges();\n                        this.expandAll();\n                        const totalHeight = scrollable.measureScrollOffset('bottom') + scrollable.measureScrollOffset('top');\n                        const viewportHeight = scrollable.getElementRef().nativeElement.clientHeight;\n                        const positionToScroll = totalHeight - viewportHeight;\n                        scrollable.scrollTo({ top: positionToScroll / 2 });\n                    }\n                } else if (isAtTop && this.treePagination.getCurrentStartPage() > 1) {\n                    if (this.nodes.length > 0) {\n                        this.treeDataRunTime = this.treePagination.paginatePrev().data;\n                        this.treeDataRunTime = this.applyRunTimeLastItems(this.treeDataRunTime);\n                        this.cdkArrayDataSource = new ArrayDataSource(this.treeDataRunTime);\n                        this.cdkTreeControl = new NestedTreeControl<TreeItemRunTimeModel>((node) => node?.children, {\n                            trackBy: this.trackByControl,\n                        });\n                        this.cdkTreeControl.dataNodes = this.treeDataRunTime;\n                        this.renderTree = false;\n                        this.changeDetectorRef.detectChanges();\n                        this.renderTree = true;\n                        this.changeDetectorRef.detectChanges();\n                        this.expandAll();\n                        const totalHeight = scrollable.measureScrollOffset('bottom') + scrollable.measureScrollOffset('top');\n                        const viewportHeight = scrollable.getElementRef().nativeElement.clientHeight;\n                        const positionToScroll = totalHeight - viewportHeight;\n                        scrollable.scrollTo({ top: positionToScroll / 2 + viewportHeight });\n                    }\n                }\n            }\n        });\n    }\n\n    private getSelectionIndexOfItem(runTimeTreeItem: TreeItemRunTimeModel): number {\n        return this.selectionModel.selected.findIndex((i) => i?.path === runTimeTreeItem?.path);\n    }\n\n    private selectTreeItem(runTimeTreeItem: TreeItemRunTimeModel): void {\n        const indexOfItem = this.getSelectionIndexOfItem(runTimeTreeItem);\n        if (indexOfItem === -1) {\n            this.selectionModel.select(runTimeTreeItem);\n        }\n    }\n\n    private deselectTreeItem(runTimeTreeItem: TreeItemRunTimeModel): void {\n        const indexOfItem = this.getSelectionIndexOfItem(runTimeTreeItem);\n        if (indexOfItem > -1) {\n            const newSelection = [...this.selectionModel.selected];\n            newSelection.splice(indexOfItem, 1);\n            this.selectionModel.setSelection(...newSelection);\n        }\n    }\n\n    private createTreeDataRuntime(nodes: TreeDataModel): TreeDataRunTimeModel {\n        return structuredClone(nodes)?.map((item, index) => {\n            return this.calculateRunTimeState(item, index);\n        });\n    }\n\n    private applyRunTimeLastItems(items: TreeDataRunTimeModel): TreeDataRunTimeModel {\n        return items?.map((item, index) => {\n            if (item?.children) {\n                return {\n                    ...item,\n                    last: items.length === index + 1 ? true : undefined,\n                    children: item.children?.length > 0 ? this.applyRunTimeLastItems(item.children) : item?.children,\n                };\n            } else {\n                return {\n                    ...item,\n                    last: items.length === index + 1 ? true : undefined,\n                };\n            }\n        });\n    }\n\n    private createRunTimeSelectionRecursiveState(nodes: TreeDataModel): Array<TreeItemSelectionRecursiveModel> {\n        return structuredClone(nodes)?.map((item) => this.calculateItemSelectionRecursiveState({ ...item }));\n    }\n\n    // Creating run time state which includes children selection state for selection tree.\n    private calculateItemSelectionRecursiveState(treeItem: TreeItemModel, isSelected?: boolean): TreeItemSelectionRecursiveModel {\n        const childrenSelectionRecursive: Array<TreeItemSelectionRecursiveModel> = [];\n        if (treeItem.children && treeItem.children.length > 0) {\n            treeItem.children.forEach((child, index) => {\n                childrenSelectionRecursive[index] = this.calculateItemSelectionRecursiveState(child);\n            });\n        }\n        const childStates = childrenSelectionRecursive.map((_) => _.selectionRecursiveState);\n        const itemState: SelectionRecursiveState = this.decideSelectionRecursiveState(\n            childStates,\n            isSelected || treeItem.node.isSelected,\n            treeItem.node?.selectConfig?.recursive,\n            treeItem.node?.selectConfig?.noAutoSelectParent,\n        );\n\n        return {\n            selectionRecursiveState: itemState,\n            children: childrenSelectionRecursive,\n        };\n    }\n\n    private decideSelectionRecursiveState(\n        childStates: Array<SelectionRecursiveState> = [],\n        isSelected: boolean,\n        recursive: boolean,\n        noAutoSelectParent: boolean,\n    ): SelectionRecursiveState {\n        let itemState: SelectionRecursiveState = 'indeterminate';\n        if (isSelected && childStates.every((state) => state === 'allSelected')) {\n            itemState = 'allSelected';\n        } else if (!isSelected && childStates.every((state) => state === 'allNotSelected')) {\n            itemState = 'allNotSelected';\n        } else if (recursive && childStates.every((state) => state === 'allSelected') && !isSelected && !noAutoSelectParent) {\n            itemState = 'allSelected';\n        } else if (recursive && childStates.every((state) => state === 'allNotSelected') && isSelected) {\n            itemState = 'allNotSelected';\n        }\n        return itemState;\n    }\n\n    private syncStateChangesAtPath(nodePath): void {\n        const treeItem = this.getTreeItem(nodePath);\n        const runTimeTreeItem = this.getRunTimeBackupTreeItem(nodePath);\n        const runTimeSelectionRecursiveItem = this.getRunTimeSelectionRecursiveState(nodePath);\n        if (treeItem?.node?.selectable && treeItem.node?.selectConfig?.recursive) {\n            if (!treeItem.node?.selectConfig?.noAutoSelectParent) {\n                treeItem.node = {\n                    ...treeItem.node,\n                    isSelected: runTimeSelectionRecursiveItem.selectionRecursiveState === 'allSelected',\n                    isIndeterminate: runTimeSelectionRecursiveItem.selectionRecursiveState === 'indeterminate',\n                };\n            } else {\n                treeItem.node = {\n                    ...treeItem.node,\n                    isSelected: treeItem.node.isSelected && runTimeSelectionRecursiveItem.selectionRecursiveState === 'allSelected',\n                    isIndeterminate:\n                        runTimeSelectionRecursiveItem.selectionRecursiveState === 'indeterminate' ||\n                        (!treeItem.node.isSelected && runTimeSelectionRecursiveItem.selectionRecursiveState === 'allSelected'),\n                };\n            }\n            // console.log(treeItem, treeItem.node.treeContentBlock.label, 'isSelected:' + treeItem.node.isSelected, 'isIndeterminate:' + treeItem.node.isIndeterminate);\n            if (treeItem.node.isSelected === true && !this.selectionModel.isSelected(runTimeTreeItem)) {\n                this.selectTreeItem(runTimeTreeItem);\n            } else if (treeItem.node.isSelected === false && this.selectionModel.isSelected(runTimeTreeItem)) {\n                this.deselectTreeItem(runTimeTreeItem);\n            }\n        }\n    }\n\n    private setTreeData(path: string, item: TreeItemModel): void {\n        const indexArr: Array<number> = this.resolvePath(path);\n        let itemArr = this.processedNodes;\n        indexArr.forEach((pathIndex: number, index) => {\n            if (index < indexArr.length - 1) {\n                itemArr = itemArr[pathIndex]?.children;\n            } else {\n                itemArr[pathIndex] = item;\n            }\n        });\n    }\n\n    private setTreeDataRunTime(path: string, item: TreeItemRunTimeModel): void {\n        const indexArr: Array<number> = this.resolvePath(path);\n        let itemArr = this.treeDataRunTime;\n        indexArr.forEach((pathIndex: number, index) => {\n            if (index < indexArr.length - 1) {\n                itemArr = itemArr[pathIndex]?.children;\n            } else {\n                itemArr[pathIndex] = item;\n            }\n        });\n    }\n\n    private setRunTimeSelectionRecursiveStateTree(path: string, item: TreeItemSelectionRecursiveModel): void {\n        const indexArr: Array<number> = this.resolvePath(path);\n        let itemArr = this.runTimeSelectionRecursiveState;\n        indexArr.forEach((pathIndex: number, index) => {\n            if (index < indexArr.length - 1) {\n                itemArr = itemArr[pathIndex]?.children;\n            } else {\n                itemArr[pathIndex] = item;\n            }\n        });\n    }\n\n    private updateRunTimeSelectionRecursiveState(path: string, selectionRecursiveState: SelectionRecursiveState): void {\n        const indexArr: Array<number> = this.resolvePath(path);\n        let itemArr = this.runTimeSelectionRecursiveState;\n        indexArr.forEach((pathIndex: number, index) => {\n            if (index < indexArr.length - 1) {\n                itemArr = itemArr[pathIndex]?.children;\n            } else {\n                itemArr[pathIndex] = {\n                    ...itemArr[pathIndex],\n                    selectionRecursiveState,\n                };\n            }\n        });\n    }\n\n    private setIsCheckedForAll(nodeArr: Array<TreeItemRunTimeModel>, isChecked: boolean): void {\n        nodeArr.forEach((runTimeItem: TreeItemRunTimeModel, index: number) => {\n            const treeItem = this.getTreeItem(runTimeItem.path);\n            const node = treeItem.node;\n            if (node?.selectable) {\n                node.isSelected = isChecked;\n                node.isIndeterminate = false;\n                if (isChecked) {\n                    this.selectTreeItem(runTimeItem);\n                } else {\n                    this.deselectTreeItem(runTimeItem);\n                }\n            }\n            if (runTimeItem?.children?.length > 0 && runTimeItem?.children && runTimeItem?.children.length > 0) {\n                this.setIsCheckedForAll(nodeArr[index].children, isChecked);\n            }\n        });\n    }\n\n    private runStateChangesForAll(nodeArr: Array<TreeItemRunTimeModel>): void {\n        nodeArr.forEach((runTimeItem: TreeItemRunTimeModel, index: number) => {\n            if (runTimeItem?.children?.length > 0 && runTimeItem?.children && runTimeItem?.children.length > 0) {\n                this.syncSelectionAtPath(runTimeItem);\n                this.runStateChangesForAll(nodeArr[index].children);\n            }\n        });\n    }\n\n    private syncSelectionAtPath(runTimeTreeItem: TreeItemRunTimeModel): void {\n        // It is here for the filter edge case.\n        this.syncStateChangesAtPath(runTimeTreeItem.path);\n        // Sets isSelected change on the control.\n        if (this.getTreeItem(runTimeTreeItem.path).node.isSelected) {\n            this.selectTreeItem(runTimeTreeItem);\n        } else {\n            this.deselectTreeItem(runTimeTreeItem);\n        }\n    }\n\n    private resolvePath(path: string): Array<number> {\n        return path?.split('.').map((index: string) => parseInt(index, 10));\n    }\n\n    private getParentPaths(path: string): Array<string> {\n        const pathArr = path.split('.');\n        const hasParent = pathArr.length > 1;\n        // Sets the hasParent If there is a parent, and removes the last element form pathArr.\n        if (hasParent) {\n            pathArr.pop();\n            // Calculates parent path\n            const parentPath = pathArr.join('.');\n            // Creating node index sequence f.e If path is '1.2' it will be [1,2]\n            const nodeIndexSeq = parentPath.split('.').map((indexStr) => parseInt(indexStr, 10));\n            // Calculating the node paths array to be re-calculated from bottom to top\n            const nodePathsSeq = [];\n            nodeIndexSeq.forEach((nodeIndex, index) => {\n                nodePathsSeq[index] = nodeIndexSeq.slice(0, index + 1).join('.');\n            });\n            return nodePathsSeq.reverse();\n        } else {\n            return [];\n        }\n    }\n\n    private calculateRunTimeState(treeItem: TreeItemModel, index: number, parentPath?: string): TreeItemRunTimeModel {\n        const runTimeTreeItem: TreeItemRunTimeModel = {\n            path: parentPath ? parentPath + '.' + index : index.toString(),\n            index,\n        };\n        if (treeItem.children && treeItem.children.length >= 0) {\n            runTimeTreeItem.children = [];\n            treeItem.children.forEach((child, treeItemIndex) => {\n                runTimeTreeItem.children[treeItemIndex] = this.calculateRunTimeState(child, treeItemIndex, runTimeTreeItem.path);\n            });\n        }\n        return runTimeTreeItem;\n    }\n\n    private filterTreeData(runTimeTreeData: TreeDataRunTimeModel, key = 'label', filterStr: string): TreeDataRunTimeModel {\n        return runTimeTreeData.filter((runTimeItem) => {\n            if (\n                this.normalizedStr(this.getTreeItem(runTimeItem.path).node.treeContentBlock.label).includes(this.normalizedStr(filterStr))\n            ) {\n                return true;\n            } else if (runTimeItem?.children?.length > 0) {\n                runTimeItem.children = this.filterTreeData(structuredClone(runTimeItem.children), key, filterStr);\n                runTimeItem.children = runTimeItem.children.length > 0 ? runTimeItem.children : undefined;\n                return runTimeItem?.children?.length > 0;\n            } else {\n                return false;\n            }\n        });\n    }\n\n    private normalizedStr(str: string): string {\n        return str\n            .toLowerCase()\n            .normalize('NFD')\n            .replace(/[\\u0300-\\u036f]/g, '');\n    }\n\n    private getInitialSelection(nodes: TreeDataRunTimeModel): Array<TreeItemRunTimeModel> {\n        const selection: Array<TreeItemRunTimeModel> = [];\n        this.scanSelection(nodes, selection);\n        return selection;\n    }\n\n    private scanSelection(nodes: TreeDataRunTimeModel, selection: Array<TreeItemRunTimeModel>): void {\n        nodes.forEach((item: TreeItemRunTimeModel) => {\n            if (this.getTreeItem(item.path).node?.selectable && this.getTreeItem(item.path).node.isSelected) {\n                selection.push(item);\n            }\n            if (item?.children?.length > 0) {\n                this.scanSelection(item.children, selection);\n            }\n        });\n    }\n\n    private renderInitialExpand(nodes: TreeDataRunTimeModel): void {\n        nodes.forEach((item: TreeItemRunTimeModel) => {\n            if (this.getTreeItem(item.path).node.isExpanded) {\n                this.expandAt(item.path);\n            }\n            if (item?.children?.length > 0) {\n                this.renderInitialExpand(item.children);\n            }\n        });\n    }\n\n    private getRunTimeTreeItem(path: string): TreeItemRunTimeModel {\n        return this.findRunTimeTreeItem(this.treeDataRunTime, path);\n    }\n\n    private findRunTimeTreeItem(treeDataRunTime: TreeDataRunTimeModel, path): TreeItemRunTimeModel {\n        for (const runTimeItem of treeDataRunTime) {\n            if (runTimeItem.path === path) {\n                return runTimeItem;\n            } else if (runTimeItem?.children?.length > 0) {\n                const found = this.findRunTimeTreeItem(runTimeItem.children, path);\n                if (found) {\n                    return found;\n                }\n            }\n        }\n        return null;\n    }\n\n    private getRunTimeBackupTreeItem(path: string): TreeItemRunTimeModel {\n        const indexArr: Array<number> = this.resolvePath(path);\n        let nodeArr = this.treeDataRunTimeBackup;\n        let node;\n        if (nodeArr && Array.isArray(nodeArr)) {\n            indexArr?.forEach((pathIndex: number, index) => {\n                if (index < indexArr.length - 1) {\n                    nodeArr = nodeArr && nodeArr[pathIndex]?.children;\n                } else {\n                    node = nodeArr[pathIndex];\n                }\n            });\n        }\n        return node;\n    }\n\n    private getCssClasses(): string {\n        return ['eui-tree', this.isMultiselect ? 'eui-tree--multiselect' : '', this._isMultiLevel ? 'eui-tree--with-children' : '']\n            .join(' ')\n            .trim();\n    }\n\n    private checkIfMultiLevel(tree: TreeDataModel): boolean {\n        let isMultiLevel = false;\n        tree.forEach((item: TreeItemModel) => {\n            if (item?.children?.length >= 0) {\n                isMultiLevel = true;\n            }\n        });\n        return isMultiLevel;\n    }\n\n    private checkIfCurrentScrollable(scrolled: CdkScrollable): boolean {\n        return scrolled.getElementRef().nativeElement === this.cdkScrollableRef.getElementRef().nativeElement;\n    }\n}\n\n@NgModule({\n    imports: [\n        CommonModule,\n        RouterModule,\n        FormsModule,\n        TranslateModule,\n        EuiInputCheckboxModule,\n        CdkTreeModule,\n        EuiButtonModule,\n        EuiIconModule,\n        EuiLabelModule,\n        EuiBadgeModule,\n        EuiChipModule,\n        EuiDropdownModule,\n        ScrollingModule,\n    ],\n    declarations: [EuiTreeComponent],\n    exports: [EuiTreeComponent],\n})\nexport class EuiTreeModule {}\n","<ul class=\"eui-tree__wrapper\" cdkScrollable #cdkScrollableRef style=\"overflow: auto; max-height: 400px\">\n    <cdk-tree\n        #treeComponentInstance\n        [dataSource]=\"cdkArrayDataSource\"\n        [treeControl]=\"cdkTreeControl\"\n        [trackBy]=\"trackBy\"\n        *ngIf=\"renderTree\"\n        class=\"eui-cdk-tree\">\n        <!-- There are two states of generic cdk-nested-tree-node declarations.\n        First one is without child. No sub rendering.\n        -->\n        <cdk-nested-tree-node *cdkTreeNodeDef=\"let treeRunTimeItemModel\" class=\"eui-cdk-nested-tree-node\">\n            <li\n                class=\"eui-tree-node\"\n                *ngIf=\"treeRunTimeItemModel\"\n                title=\"{{\n                    getTreeItem(treeRunTimeItemModel?.path)?.node?.treeContentBlock?.tooltipLabel ||\n                        getTreeItem(treeRunTimeItemModel?.path)?.node?.treeContentBlock?.label\n                }}\">\n                <div\n                    class=\"eui-tree-node-wrapper\"\n                    (click)=\"onNodeClick(treeRunTimeItemModel)\"\n                    [class.eui-tree-node-wrapper--last]=\"treeRunTimeItemModel.last\"\n                    [class.eui-tree-node-wrapper--show-lines]=\"showLines && _isMultiLevel\">\n                    <div class=\"eui-tree-node-wrapper__container\">\n                        <!--\n                        Renders node in default or provided template's context.\n                        Generates onSelect with onSelectFn for developers to send the events from their custom check events.\n                        Provides id to be used on generic template\n                        -->\n                        <ng-container\n                            [ngTemplateOutlet]=\"nodeTemplateRef || nodeTemplateDefault\"\n                            [ngTemplateOutletContext]=\"{\n                                $implicit: getTreeItem(treeRunTimeItemModel?.path)?.node,\n                                onSelect: onSelectFn(treeRunTimeItemModel.path),\n                                id: uid + treeRunTimeItemModel.path\n                            }\">\n                        </ng-container>\n                    </div>\n                </div>\n            </li>\n        </cdk-nested-tree-node>\n        <!-- This is the tree node template for expandable nodes -->\n        <cdk-nested-tree-node\n            *cdkTreeNodeDef=\"let treeRunTimeItemModel; when: hasChild\"\n            class=\"eui-cdk-nested-tree-node eui-cdk-nested-tree-node--with-child\">\n            <li\n                class=\"eui-tree-node\"\n                *ngIf=\"treeRunTimeItemModel\"\n                title=\"{{\n                    getTreeItem(treeRunTimeItemModel?.path)?.node?.treeContentBlock?.tooltipLabel ||\n                        getTreeItem(treeRunTimeItemModel?.path)?.node?.treeContentBlock?.label\n                }}\">\n                <div\n                    class=\"eui-tree-node-wrapper\"\n                    [class.eui-tree-node-wrapper--last]=\"treeRunTimeItemModel.last\"\n                    [class.eui-tree-node-wrapper--show-lines]=\"showLines\">\n                    <!--Here wraps the node, and listen for node clicks.-->\n                    <div (click)=\"onNodeClick(treeRunTimeItemModel)\" class=\"eui-tree-node-wrapper__container\">\n                        <!-- Expand/collapse action button -->\n                        <button\n                            euiButton\n                            euiIconButton\n                            euiBasicButton\n                            euiRounded\n                            euiSizeS\n                            type=\"button\"\n                            [attr.aria-label]=\"'Toggle ' + getTreeItem(treeRunTimeItemModel?.path)?.node?.treeContentBlock?.label\"\n                            (click)=\"onNodeToggle(treeRunTimeItemModel)\"\n                            cdkTreeNodeToggle\n                            class=\"eui-tree-node__button\">\n                            <span\n                                euiIcon\n                                *ngIf=\"!cdkTreeControl.isExpanded(treeRunTimeItemModel) && collapsedIconClass\"\n                                [iconClass]=\"collapsedIconClass\"></span>\n                            <span\n                                euiIcon\n                                *ngIf=\"cdkTreeControl.isExpanded(treeRunTimeItemModel) && expandedIconClass\"\n                                [iconClass]=\"expandedIconClass\"></span>\n                            <eui-icon-svg\n                                *ngIf=\"!cdkTreeControl.isExpanded(treeRunTimeItemModel) && !collapsedIconClass\"\n                                [icon]=\"expandedSvgIconClass\"></eui-icon-svg>\n                            <eui-icon-svg\n                                *ngIf=\"cdkTreeControl.isExpanded(treeRunTimeItemModel) && !expandedIconClass\"\n                                [icon]=\"collapsedSvgIconClass\"></eui-icon-svg>\n                        </button>\n                        <!--\n                        Renders node in default or provided template's context.\n                        Generates onSelect with onSelectFn for developers to send the events from their custom check events.\n                        Provides id to be used on generic template\n                        -->\n                        <ng-container\n                            [ngTemplateOutlet]=\"nodeTemplateRef || nodeTemplateDefault\"\n                            [ngTemplateOutletContext]=\"{\n                                $implicit: getTreeItem(treeRunTimeItemModel.path)?.node,\n                                onSelect: onSelectFn(treeRunTimeItemModel.path),\n                                id: uid + treeRunTimeItemModel.path,\n                                path: treeRunTimeItemModel.path\n                            }\">\n                        </ng-container>\n                    </div>\n                </div>\n                <!--uses cdkTreeNodeOutlet to render children nodes, CdkTreeControl is used to control isExpanded state.-->\n                <ul class=\"eui-tree-node\" *ngIf=\"cdkTreeControl.isExpanded(treeRunTimeItemModel)\">\n                    <ng-container cdkTreeNodeOutlet></ng-container>\n                </ul>\n            </li>\n        </cdk-nested-tree-node>\n    </cdk-tree>\n</ul>\n\n<ng-template #nodeTemplateDefault let-node let-onSelect=\"onSelect\" let-id=\"id\" let-path=\"path\">\n    <ng-container *ngIf=\"node\">\n        <div class=\"eui-tree-node-wrapper__container-left\" [class.eui-tree-node-wrapper__container-left--selected]=\"node?.isSelected\">\n            <!--input checkbox area-->\n            <input\n                euiInputCheckBox\n                *ngIf=\"node && node.selectable\"\n                type=\"checkbox\"\n                id=\"{{ id }}\"\n                [checked]=\"!!node?.isSelected\"\n                [indeterminate]=\"!!node?.isIndeterminate\"\n                (change)=\"onSelect($event)\"\n                class=\"eui-u-mr-m\" />\n\n            <!--icon area-->\n            <ng-container *ngIf=\"node?.treeContentBlock?.iconClass\">\n                <eui-icon\n                    [euiVariant]=\"node?.treeContentBlock?.iconTypeClass || 'primary'\"\n                    iconClass=\"{{ node?.treeContentBlock?.iconClass }}\"\n                    euiSizeS\n                    class=\"eui-u-mr-xs\">\n                </eui-icon>\n            </ng-container>\n            <ng-container *ngIf=\"node?.treeContentBlock?.iconSvgName\">\n                <eui-icon-svg\n                    icon=\"{{ node?.treeContentBlock?.iconSvgName }}\"\n                    fillColor=\"{{ node?.treeContentBlock?.iconTypeClass || 'grey-100' }}\"\n                    size=\"s\"\n                    class=\"eui-u-mr-xs\">\n                </eui-icon-svg>\n            </ng-container>\n\n            <!--chips area-->\n            <ng-container *ngIf=\"node?.treeContentBlock?.chips\">\n                <eui-chip\n                    *ngFor=\"let chip of node.treeContentBlock.chips\"\n                    euiSizeXS\n                    [euiVariant]=\"chip.typeClass || 'secondary'\"\n                    [euiOutline]=\"chip.isOutline\"\n                    class=\"eui-chip--rounded eui-u-mb-none eui-u-mr-xs\">\n                    <span euiLabel>{{ chip.label }}</span>\n                </eui-chip>\n            </ng-container>\n\n            <!--badge (typeLabel & typeClass) area-->\n            <ng-container *ngIf=\"node?.treeContentBlock?.typeLabel\" [ngSwitch]=\"node?.treeContentBlock?.typeClass\">\n                <eui-badge euiSizeM [euiVariant]=\"node?.treeContentBlock?.typeClass || 'primary'\" class=\"eui-u-flex-no-shrink eui-u-mr-xs\">\n                    {{ node?.treeContentBlock?.typeLabel }}\n                </eui-badge>\n            </ng-container>\n        </div>\n\n        <!--label area-->\n        <div class=\"eui-tree-node-wrapper__container-middle\">\n            <label\n                *ngIf=\"!node?.treeContentBlock?.url && !node?.treeContentBlock?.urlExternal\"\n                euiLabel\n                for=\"{{ id }}\"\n                class=\"eui-u-text-truncate eui-u-p-2xs\"\n                [class.eui-label--selected]=\"\n                    highlightPath\n                        ? getRunTimeSelectionRecursiveState(path)?.selectionRecursiveState === 'indeterminate' || node?.isSelected\n                        : node?.isSelected\n                \"\n                [class.eui-u-cursor-pointer]=\"node?.selectable\">\n                {{ autoTranslate ? (node?.treeContentBlock?.label | translate) : node?.treeContentBlock?.label }}\n            </label>\n            <label *ngIf=\"node?.treeContentBlock?.url\" euiLabel for=\"{{ id }}\" class=\"eui-u-text-truncate eui-u-p-2xs\">\n                <a\n                    class=\"eui-u-text-link\"\n                    [class.eui-u-text-link-standalone]=\"!showUnderlinedLinks\"\n                    [routerLink]=\"node?.treeContentBlock?.url\">\n                    {{ autoTranslate ? (node?.treeContentBlock?.label | translate) : node?.treeContentBlock?.label }}\n                </a>\n            </label>\n            <label *ngIf=\"node?.treeContentBlock?.urlExternal\" euiLabel for=\"{{ id }}\" class=\"eui-u-text-truncate eui-u-p-2xs\">\n                <a\n                    class=\"eui-u-text-link-external\"\n                    [class.eui-u-text-link-external-standalone]=\"!showUnderlinedLinks\"\n                    href=\"{{ node?.treeContentBlock?.urlExternal }}\"\n                    target=\"{{ node?.treeContentBlock?.urlExternalTarget || 'blank' }}\">\n                    {{ autoTranslate ? (node?.treeContentBlock?.label | translate) : node?.treeContentBlock?.label }}\n                </a>\n            </label>\n        </div>\n\n        <div *ngIf=\"node?.treeContentBlock?.rightContent\" class=\"eui-tree-node-wrapper__container-right\">\n            <!--badges area-->\n            <ng-container *ngFor=\"let badge of node.treeContentBlock.rightContent?.badges\">\n                <eui-badge euiSizeM euiOutline [euiVariant]=\"badge.typeClass || 'secondary'\" class=\"eui-u-ml-xs\">\n                    <span euiLabel>{{ badge.label }}</span>\n                </eui-badge>\n            </ng-container>\n\n            <!--chips area-->\n            <ng-container *ngFor=\"let chip of node.treeContentBlock.rightContent?.chips\">\n                <eui-chip\n                    euiSizeXS\n                    [euiVariant]=\"chip.typeClass || 'secondary'\"\n                    [euiOutline]=\"chip.isOutline\"\n                    class=\"eui-chip--rounded eui-u-mb-none eui-u-ml-xs\">\n                    <span euiLabel>{{ chip.label }}</span>\n                </eui-chip>\n            </ng-container>\n\n            <!--Context menu-->\n            <ng-container *ngIf=\"node.treeContentBlock.rightContent?.contextMenuMetaData && rightContextMenuTemplateRef\">\n                <eui-dropdown class=\"eui-u-ml-xs\">\n                    <button euiButton euiSizeS euiRounded euiIconButton euiBasicButton euiSecondary [attr.aria-label]=\"'Options menu'\">\n                        <eui-icon-svg icon=\"eui-ellipsis-vertical\"></eui-icon-svg>\n                    </button>\n                    <eui-dropdown-content>\n                        <ng-template\n                            [ngTemplateOutlet]=\"rightContextMenuTemplateRef\"\n                            [ngTemplateOutletContext]=\"{\n                                $implicit: node?.treeContentBlock?.rightContent?.contextMenuMetaData,\n                                metadata: node?.treeContentBlock?.rightContent?.contextMenuMetaData\n                            }\">\n                        </ng-template>\n                    </eui-dropdown-content>\n                </eui-dropdown>\n            </ng-container>\n        </div>\n\n        <!--metadata, uses the help of ng template to generate dynamic expand variable without handling state -->\n        <ng-container\n            *ngIf=\"node.treeContentBlock?.metadata && nodeContentMetadataTemplateRef\"\n            [ngTemplateOutlet]=\"nodeContentMetadataContainer\"\n            [ngTemplateOutletContext]=\"{\n                $implicit: { expanded: false }\n            }\">\n        </ng-container>\n        <ng-template #nodeContentMetadataContainer let-metaDataContainer>\n            <button\n                euiButton\n                euiBasicButton\n                euiIconButton\n                euiRounded\n                euiSizeS\n                type=\"button\"\n                aria-label=\"expand collapse tree item\"\n                (click)=\"metaDataContainer.expanded = !metaDataContainer.expanded\">\n                <eui-icon-svg [icon]=\"metaDataContainer.expanded ? 'eui-chevron-down' : 'eui-chevron-forward'\"></eui-icon-svg>\n            </button>\n            <div *ngIf=\"metaDataContainer.expanded\" class=\"eui-tree-node__metacontent\">\n                <!--passing metadata of the node content to provided template-ref:nodeContentMetadataTemplateRef-->\n                <ng-template\n                    [ngTemplateOutlet]=\"nodeContentMetadataTemplateRef\"\n                    [ngTemplateOutletContext]=\"{\n                        $implicit: node?.treeContentBlock?.metadata,\n                        metadata: node?.treeContentBlock?.metadata\n                    }\">\n                </ng-template>\n            </div>\n        </ng-template>\n    </ng-container>\n</ng-template>\n"]}