cps-ui-kit 0.165.0 → 17.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (166) hide show
  1. package/esm2022/lib/components/cps-autocomplete/cps-autocomplete.component.mjs +824 -0
  2. package/esm2022/lib/components/cps-button/cps-button.component.mjs +190 -0
  3. package/esm2022/lib/components/cps-button-toggle/cps-button-toggle.component.mjs +235 -0
  4. package/esm2022/lib/components/cps-checkbox/cps-checkbox.component.mjs +149 -0
  5. package/esm2022/lib/components/cps-chip/cps-chip.component.mjs +94 -0
  6. package/esm2022/lib/components/cps-datepicker/cps-datepicker.component.mjs +382 -0
  7. package/esm2022/lib/components/cps-expansion-panel/cps-expansion-panel.component.mjs +209 -0
  8. package/esm2022/lib/components/cps-file-upload/cps-file-upload.component.mjs +138 -0
  9. package/esm2022/lib/components/cps-icon/cps-icon.component.mjs +193 -0
  10. package/esm2022/lib/components/cps-info-circle/cps-info-circle.component.mjs +61 -0
  11. package/esm2022/lib/components/cps-input/cps-input.component.mjs +386 -0
  12. package/{esm2020 → esm2022}/lib/components/cps-loader/cps-loader.component.mjs +5 -5
  13. package/esm2022/lib/components/cps-menu/cps-menu.component.mjs +552 -0
  14. package/esm2022/lib/components/cps-paginator/cps-paginator.component.mjs +114 -0
  15. package/esm2022/lib/components/cps-paginator/pipes/cps-paginate.pipe.mjs +30 -0
  16. package/{esm2020 → esm2022}/lib/components/cps-progress-circular/cps-progress-circular.component.mjs +4 -4
  17. package/{esm2020 → esm2022}/lib/components/cps-progress-linear/cps-progress-linear.component.mjs +4 -4
  18. package/{esm2020 → esm2022}/lib/components/cps-radio-group/cps-radio/cps-radio.component.mjs +7 -7
  19. package/esm2022/lib/components/cps-radio-group/cps-radio-button/cps-radio-button.component.mjs +55 -0
  20. package/esm2022/lib/components/cps-radio-group/cps-radio-group.component.mjs +158 -0
  21. package/esm2022/lib/components/cps-select/cps-select.component.mjs +615 -0
  22. package/esm2022/lib/components/cps-sidebar-menu/cps-sidebar-menu.component.mjs +110 -0
  23. package/{esm2020 → esm2022}/lib/components/cps-tab-group/cps-tab/cps-tab.component.mjs +4 -4
  24. package/esm2022/lib/components/cps-tab-group/cps-tab-group.component.mjs +303 -0
  25. package/esm2022/lib/components/cps-table/components/internal/cps-sort-icon/cps-sort-icon.component.mjs +79 -0
  26. package/esm2022/lib/components/cps-table/components/internal/table-column-filter/table-column-filter.component.mjs +408 -0
  27. package/esm2022/lib/components/cps-table/components/internal/table-column-filter-constraint/table-column-filter-constraint.component.mjs +149 -0
  28. package/esm2022/lib/components/cps-table/components/internal/table-row-menu/table-row-menu.component.mjs +88 -0
  29. package/esm2022/lib/components/cps-table/cps-table.component.mjs +941 -0
  30. package/esm2022/lib/components/cps-table/directives/cps-table-column-filter.directive.mjs +181 -0
  31. package/{esm2020 → esm2022}/lib/components/cps-table/directives/cps-table-column-sortable.directive.mjs +5 -5
  32. package/{esm2020 → esm2022}/lib/components/cps-table/directives/cps-table-header-selectable.directive.mjs +5 -5
  33. package/{esm2020 → esm2022}/lib/components/cps-table/directives/cps-table-row-selectable.directive.mjs +5 -5
  34. package/esm2022/lib/components/cps-table/directives/internal/table-unsort.directive.mjs +220 -0
  35. package/esm2022/lib/components/cps-tag/cps-tag.component.mjs +136 -0
  36. package/esm2022/lib/components/cps-textarea/cps-textarea.component.mjs +291 -0
  37. package/esm2022/lib/components/cps-timepicker/cps-timepicker.component.mjs +351 -0
  38. package/esm2022/lib/components/cps-tree-autocomplete/cps-tree-autocomplete.component.mjs +251 -0
  39. package/esm2022/lib/components/cps-tree-select/cps-tree-select.component.mjs +87 -0
  40. package/esm2022/lib/components/cps-tree-table/cps-tree-table.component.mjs +1196 -0
  41. package/{esm2020 → esm2022}/lib/components/cps-tree-table/directives/cps-tree-table-column-filter.directive.mjs +5 -5
  42. package/{esm2020 → esm2022}/lib/components/cps-tree-table/directives/cps-tree-table-column-sortable.directive.mjs +5 -5
  43. package/{esm2020 → esm2022}/lib/components/cps-tree-table/directives/cps-tree-table-header-selectable.directive.mjs +5 -5
  44. package/{esm2020 → esm2022}/lib/components/cps-tree-table/directives/cps-tree-table-row-selectable.directive.mjs +5 -5
  45. package/esm2022/lib/components/cps-tree-table/directives/cps-tree-table-row-toggler.directive.mjs +43 -0
  46. package/esm2022/lib/components/cps-tree-table/directives/internal/tree-table-unsort.directive.mjs +354 -0
  47. package/esm2022/lib/components/internal/cps-base-tree-dropdown/cps-base-tree-dropdown.component.mjs +619 -0
  48. package/esm2022/lib/directives/cps-tooltip/cps-tooltip.directive.mjs +257 -0
  49. package/{esm2020 → esm2022}/lib/pipes/internal/check-option-selected.pipe.mjs +4 -4
  50. package/esm2022/lib/pipes/internal/combine-labels.pipe.mjs +25 -0
  51. package/{esm2020 → esm2022}/lib/pipes/internal/label-by-value.pipe.mjs +4 -4
  52. package/esm2022/lib/services/cps-dialog/cps-dialog.service.mjs +99 -0
  53. package/{esm2020 → esm2022}/lib/services/cps-dialog/internal/components/cps-confirmation/cps-confirmation.component.mjs +5 -5
  54. package/esm2022/lib/services/cps-dialog/internal/components/cps-dialog/cps-dialog.component.mjs +470 -0
  55. package/{esm2020 → esm2022}/lib/services/cps-dialog/internal/directives/cps-dialog-content.directive.mjs +5 -5
  56. package/esm2022/lib/services/cps-dialog/utils/cps-dialog-config.mjs +3 -0
  57. package/esm2022/lib/services/cps-notification/cps-notification.service.mjs +126 -0
  58. package/esm2022/lib/services/cps-notification/internal/components/cps-notification-container/cps-notification-container.component.mjs +91 -0
  59. package/{esm2020 → esm2022}/lib/services/cps-notification/internal/components/cps-toast/cps-toast.component.mjs +23 -23
  60. package/esm2022/lib/utils/colors-utils.mjs +57 -0
  61. package/esm2022/lib/utils/internal/size-utils.mjs +24 -0
  62. package/{esm2020 → esm2022}/public-api.mjs +2 -2
  63. package/{fesm2020 → fesm2022}/cps-ui-kit.mjs +481 -391
  64. package/fesm2022/cps-ui-kit.mjs.map +1 -0
  65. package/lib/components/cps-autocomplete/cps-autocomplete.component.d.ts +2 -2
  66. package/lib/components/cps-button/cps-button.component.d.ts +1 -1
  67. package/lib/components/cps-button-toggle/cps-button-toggle.component.d.ts +2 -2
  68. package/lib/components/cps-checkbox/cps-checkbox.component.d.ts +2 -2
  69. package/lib/components/cps-chip/cps-chip.component.d.ts +1 -1
  70. package/lib/components/cps-datepicker/cps-datepicker.component.d.ts +2 -2
  71. package/lib/components/cps-expansion-panel/cps-expansion-panel.component.d.ts +1 -1
  72. package/lib/components/cps-file-upload/cps-file-upload.component.d.ts +1 -1
  73. package/lib/components/cps-icon/cps-icon.component.d.ts +1 -1
  74. package/lib/components/cps-info-circle/cps-info-circle.component.d.ts +2 -2
  75. package/lib/components/cps-input/cps-input.component.d.ts +2 -2
  76. package/lib/components/cps-loader/cps-loader.component.d.ts +1 -1
  77. package/lib/components/cps-menu/cps-menu.component.d.ts +1 -1
  78. package/lib/components/cps-paginator/cps-paginator.component.d.ts +1 -1
  79. package/lib/components/cps-progress-circular/cps-progress-circular.component.d.ts +1 -1
  80. package/lib/components/cps-progress-linear/cps-progress-linear.component.d.ts +1 -1
  81. package/lib/components/cps-radio-group/cps-radio/cps-radio.component.d.ts +1 -1
  82. package/lib/components/cps-radio-group/cps-radio-button/cps-radio-button.component.d.ts +1 -1
  83. package/lib/components/cps-radio-group/cps-radio-group.component.d.ts +2 -2
  84. package/lib/components/cps-select/cps-select.component.d.ts +2 -2
  85. package/lib/components/cps-sidebar-menu/cps-sidebar-menu.component.d.ts +1 -1
  86. package/lib/components/cps-tab-group/cps-tab/cps-tab.component.d.ts +1 -1
  87. package/lib/components/cps-tab-group/cps-tab-group.component.d.ts +1 -1
  88. package/lib/components/cps-table/components/internal/cps-sort-icon/cps-sort-icon.component.d.ts +1 -1
  89. package/lib/components/cps-table/components/internal/table-column-filter/table-column-filter.component.d.ts +1 -1
  90. package/lib/components/cps-table/components/internal/table-column-filter-constraint/table-column-filter-constraint.component.d.ts +1 -1
  91. package/lib/components/cps-table/components/internal/table-row-menu/table-row-menu.component.d.ts +1 -1
  92. package/lib/components/cps-table/cps-table.component.d.ts +1 -1
  93. package/lib/components/cps-table/directives/cps-table-column-filter.directive.d.ts +1 -1
  94. package/lib/components/cps-table/directives/cps-table-column-sortable.directive.d.ts +1 -1
  95. package/lib/components/cps-table/directives/cps-table-row-selectable.directive.d.ts +1 -1
  96. package/lib/components/cps-tag/cps-tag.component.d.ts +1 -1
  97. package/lib/components/cps-textarea/cps-textarea.component.d.ts +2 -2
  98. package/lib/components/cps-timepicker/cps-timepicker.component.d.ts +2 -2
  99. package/lib/components/cps-tree-autocomplete/cps-tree-autocomplete.component.d.ts +1 -1
  100. package/lib/components/cps-tree-select/cps-tree-select.component.d.ts +1 -1
  101. package/lib/components/cps-tree-table/cps-tree-table.component.d.ts +4 -4
  102. package/lib/components/cps-tree-table/directives/cps-tree-table-column-filter.directive.d.ts +1 -1
  103. package/lib/components/cps-tree-table/directives/cps-tree-table-column-sortable.directive.d.ts +1 -1
  104. package/lib/components/cps-tree-table/directives/cps-tree-table-row-selectable.directive.d.ts +1 -1
  105. package/lib/components/cps-tree-table/directives/cps-tree-table-row-toggler.directive.d.ts +1 -1
  106. package/lib/components/internal/cps-base-tree-dropdown/cps-base-tree-dropdown.component.d.ts +2 -2
  107. package/lib/directives/{cps-tooltip.directive.d.ts → cps-tooltip/cps-tooltip.directive.d.ts} +2 -2
  108. package/lib/services/cps-dialog/cps-dialog.service.d.ts +13 -0
  109. package/lib/services/cps-dialog/utils/cps-dialog-config.d.ts +1 -1
  110. package/lib/services/cps-notification/cps-notification.service.d.ts +32 -0
  111. package/lib/services/cps-notification/internal/components/cps-notification-container/cps-notification-container.component.d.ts +1 -1
  112. package/lib/services/cps-notification/internal/components/cps-toast/cps-toast.component.d.ts +1 -1
  113. package/package.json +12 -18
  114. package/public-api.d.ts +1 -1
  115. package/esm2020/lib/components/cps-autocomplete/cps-autocomplete.component.mjs +0 -824
  116. package/esm2020/lib/components/cps-button/cps-button.component.mjs +0 -190
  117. package/esm2020/lib/components/cps-button-toggle/cps-button-toggle.component.mjs +0 -235
  118. package/esm2020/lib/components/cps-checkbox/cps-checkbox.component.mjs +0 -149
  119. package/esm2020/lib/components/cps-chip/cps-chip.component.mjs +0 -94
  120. package/esm2020/lib/components/cps-datepicker/cps-datepicker.component.mjs +0 -382
  121. package/esm2020/lib/components/cps-expansion-panel/cps-expansion-panel.component.mjs +0 -209
  122. package/esm2020/lib/components/cps-file-upload/cps-file-upload.component.mjs +0 -138
  123. package/esm2020/lib/components/cps-icon/cps-icon.component.mjs +0 -193
  124. package/esm2020/lib/components/cps-info-circle/cps-info-circle.component.mjs +0 -61
  125. package/esm2020/lib/components/cps-input/cps-input.component.mjs +0 -386
  126. package/esm2020/lib/components/cps-menu/cps-menu.component.mjs +0 -552
  127. package/esm2020/lib/components/cps-paginator/cps-paginator.component.mjs +0 -113
  128. package/esm2020/lib/components/cps-paginator/pipes/cps-paginate.pipe.mjs +0 -30
  129. package/esm2020/lib/components/cps-radio-group/cps-radio-button/cps-radio-button.component.mjs +0 -55
  130. package/esm2020/lib/components/cps-radio-group/cps-radio-group.component.mjs +0 -158
  131. package/esm2020/lib/components/cps-select/cps-select.component.mjs +0 -615
  132. package/esm2020/lib/components/cps-sidebar-menu/cps-sidebar-menu.component.mjs +0 -110
  133. package/esm2020/lib/components/cps-tab-group/cps-tab-group.component.mjs +0 -299
  134. package/esm2020/lib/components/cps-table/components/internal/cps-sort-icon/cps-sort-icon.component.mjs +0 -79
  135. package/esm2020/lib/components/cps-table/components/internal/table-column-filter/table-column-filter.component.mjs +0 -408
  136. package/esm2020/lib/components/cps-table/components/internal/table-column-filter-constraint/table-column-filter-constraint.component.mjs +0 -148
  137. package/esm2020/lib/components/cps-table/components/internal/table-row-menu/table-row-menu.component.mjs +0 -88
  138. package/esm2020/lib/components/cps-table/cps-table.component.mjs +0 -940
  139. package/esm2020/lib/components/cps-table/directives/cps-table-column-filter.directive.mjs +0 -181
  140. package/esm2020/lib/components/cps-table/directives/internal/table-unsort.directive.mjs +0 -210
  141. package/esm2020/lib/components/cps-tag/cps-tag.component.mjs +0 -136
  142. package/esm2020/lib/components/cps-textarea/cps-textarea.component.mjs +0 -291
  143. package/esm2020/lib/components/cps-timepicker/cps-timepicker.component.mjs +0 -351
  144. package/esm2020/lib/components/cps-tree-autocomplete/cps-tree-autocomplete.component.mjs +0 -250
  145. package/esm2020/lib/components/cps-tree-select/cps-tree-select.component.mjs +0 -87
  146. package/esm2020/lib/components/cps-tree-table/cps-tree-table.component.mjs +0 -1192
  147. package/esm2020/lib/components/cps-tree-table/directives/cps-tree-table-row-toggler.directive.mjs +0 -43
  148. package/esm2020/lib/components/cps-tree-table/directives/internal/tree-table-unsort.directive.mjs +0 -334
  149. package/esm2020/lib/components/internal/cps-base-tree-dropdown/cps-base-tree-dropdown.component.mjs +0 -616
  150. package/esm2020/lib/directives/cps-tooltip.directive.mjs +0 -257
  151. package/esm2020/lib/pipes/internal/combine-labels.pipe.mjs +0 -25
  152. package/esm2020/lib/services/cps-dialog/cps-dialog.service.mjs +0 -86
  153. package/esm2020/lib/services/cps-dialog/internal/components/cps-dialog/cps-dialog.component.mjs +0 -470
  154. package/esm2020/lib/services/cps-dialog/utils/cps-dialog-config.mjs +0 -3
  155. package/esm2020/lib/services/cps-notification/cps-notification.service.mjs +0 -94
  156. package/esm2020/lib/services/cps-notification/internal/components/cps-notification-container/cps-notification-container.component.mjs +0 -91
  157. package/esm2020/lib/utils/colors-utils.mjs +0 -57
  158. package/esm2020/lib/utils/internal/size-utils.mjs +0 -24
  159. package/fesm2015/cps-ui-kit.mjs +0 -12086
  160. package/fesm2015/cps-ui-kit.mjs.map +0 -1
  161. package/fesm2020/cps-ui-kit.mjs.map +0 -1
  162. /package/{esm2020 → esm2022}/cps-ui-kit.mjs +0 -0
  163. /package/{esm2020 → esm2022}/lib/components/cps-table/cps-column-filter-types.mjs +0 -0
  164. /package/{esm2020 → esm2022}/lib/services/cps-dialog/utils/cps-dialog-ref.mjs +0 -0
  165. /package/{esm2020 → esm2022}/lib/services/cps-notification/utils/cps-notification-config.mjs +0 -0
  166. /package/{esm2020 → esm2022}/lib/services/cps-notification/utils/internal/cps-notification-data.mjs +0 -0
@@ -0,0 +1,619 @@
1
+ import { Component, EventEmitter, Input, Optional, Output, Self, ViewChild } from '@angular/core';
2
+ import { Subscription } from 'rxjs';
3
+ import { isEqual } from 'lodash-es';
4
+ import { convertSize } from '../../../utils/internal/size-utils';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/forms";
7
+ /**
8
+ * BaseTreeDropdownComponent is an internal base component to support hierarchical data dropdown.
9
+ * @group Components
10
+ */
11
+ export class CpsBaseTreeDropdownComponent {
12
+ /**
13
+ * An array of objects to display as the available options.
14
+ * @group Props
15
+ */
16
+ set options(options) {
17
+ if (options?.some((o) => o.inner)) {
18
+ this._options = options;
19
+ return;
20
+ }
21
+ this._options = this._toInnerOptions(options);
22
+ }
23
+ get options() {
24
+ return this._options;
25
+ }
26
+ set value(value) {
27
+ this._value = value;
28
+ this.onChange(value);
29
+ }
30
+ get value() {
31
+ return this._value;
32
+ }
33
+ constructor(control, cdRef) {
34
+ this.control = control;
35
+ this.cdRef = cdRef;
36
+ /**
37
+ * Label of the component.
38
+ * @group Props
39
+ */
40
+ this.label = '';
41
+ /**
42
+ * Bottom hint text.
43
+ * @group Props
44
+ */
45
+ this.hint = '';
46
+ /**
47
+ * Specifies if multiple values can be selected.
48
+ * @group Props
49
+ */
50
+ this.multiple = false;
51
+ /**
52
+ * Determines whether the component is disabled.
53
+ * @group Props
54
+ */
55
+ this.disabled = false;
56
+ /**
57
+ * Width of the component, of type number denoting pixels or string.
58
+ * @group Props
59
+ */
60
+ this.width = '100%';
61
+ /**
62
+ * When selecting an element, it will appear in a form of a chip.
63
+ * @group Props
64
+ */
65
+ this.chips = true;
66
+ /**
67
+ * Determines whether the chips can be directly removed.
68
+ * @group Props
69
+ */
70
+ this.closableChips = true;
71
+ /**
72
+ * When enabled, a clear icon is displayed to clear the value.
73
+ * @group Props
74
+ */
75
+ this.clearable = false;
76
+ /**
77
+ * Determines whether the dropdown should open on clear.
78
+ * @group Props
79
+ */
80
+ this.openOnClear = true;
81
+ /**
82
+ * Name of the label field of an option.
83
+ * @group Props
84
+ */
85
+ this.optionLabel = 'label';
86
+ /**
87
+ * Name of the info field of an option, shows the additional information text.
88
+ * @group Props
89
+ */
90
+ this.optionInfo = 'info';
91
+ /**
92
+ * Options for hiding details.
93
+ * @group Props
94
+ */
95
+ this.hideDetails = false;
96
+ /**
97
+ * Determines whether the component should have persistent clear icon.
98
+ * @group Props
99
+ */
100
+ this.persistentClear = false;
101
+ /**
102
+ * Icon before input value.
103
+ * @group Props
104
+ */
105
+ this.prefixIcon = '';
106
+ /**
107
+ * Size of icon before input value, of type number, string, 'fill', 'xsmall', 'small', 'normal' or 'large'.
108
+ * @group Props
109
+ */
110
+ this.prefixIconSize = '18px';
111
+ /**
112
+ * When enabled, a loading bar is displayed.
113
+ * @group Props
114
+ */
115
+ this.loading = false;
116
+ /**
117
+ * Determines whether only the elements within scrollable area should be added into the DOM.
118
+ * @group Props
119
+ */
120
+ this.virtualScroll = false;
121
+ /**
122
+ * Determines how many additional elements to add to the DOM outside of the view.
123
+ * @group Props
124
+ */
125
+ this.numToleratedItems = 10;
126
+ /**
127
+ * When it is not an empty string, an info icon is displayed to show text for more info.
128
+ * @group Props
129
+ */
130
+ this.infoTooltip = '';
131
+ /**
132
+ * Info tooltip class for styling.
133
+ * @group Props
134
+ */
135
+ this.infoTooltipClass = 'cps-tooltip-content';
136
+ /**
137
+ * Max width of infoTooltip of type number denoting pixels or string.
138
+ * @group Props
139
+ */
140
+ this.infoTooltipMaxWidth = '100%';
141
+ /**
142
+ * Determines whether the infoTooltip is persistent.
143
+ * @group Props
144
+ */
145
+ this.infoTooltipPersistent = false;
146
+ /**
147
+ * Position of infoTooltip, it can be 'top', 'bottom', 'left' or 'right'.
148
+ * @group Props
149
+ */
150
+ this.infoTooltipPosition = 'top';
151
+ /**
152
+ * When set, it expands all directiories initially.
153
+ * @group Props
154
+ */
155
+ this.initialExpandDirectories = false;
156
+ /**
157
+ * When set, it expands all options initially.
158
+ * @group Props
159
+ */
160
+ this.initialExpandAll = false;
161
+ /**
162
+ * Value of the component.
163
+ * @group Props
164
+ */
165
+ this._value = undefined;
166
+ /**
167
+ * Callback to invoke on value change.
168
+ * @param {any} any - value changed.
169
+ * @group Emits
170
+ */
171
+ this.valueChanged = new EventEmitter();
172
+ this._statusChangesSubscription = new Subscription();
173
+ this._options = [];
174
+ this.optionsMap = new Map();
175
+ this.originalOptionsMap = new Map();
176
+ this.virtualListHeight = 240;
177
+ this.virtualScrollItemSize = 40;
178
+ this.error = '';
179
+ this.cvtWidth = '';
180
+ this.isOpened = false;
181
+ this.optionFocused = false;
182
+ this.isAutocomplete = false;
183
+ this.boxWidth = 0;
184
+ // eslint-disable-next-line @typescript-eslint/no-empty-function
185
+ this.onChange = (event) => { };
186
+ // eslint-disable-next-line @typescript-eslint/no-empty-function
187
+ this.onTouched = () => { };
188
+ if (this.control) {
189
+ this.control.valueAccessor = this;
190
+ }
191
+ this.resizeObserver = new ResizeObserver((entries) => {
192
+ entries.forEach((entry) => {
193
+ if (entry?.target)
194
+ this.boxWidth = entry.target.offsetWidth;
195
+ });
196
+ });
197
+ }
198
+ ngOnInit() {
199
+ this.cvtWidth = convertSize(this.width);
200
+ if (!this._value) {
201
+ if (this.multiple) {
202
+ this._value = [];
203
+ this.treeSelection = [];
204
+ }
205
+ }
206
+ else {
207
+ this.treeSelection = this._valueToTreeSelection(this.value);
208
+ }
209
+ this._statusChangesSubscription = this.control?.statusChanges?.subscribe(() => {
210
+ this._checkErrors();
211
+ });
212
+ }
213
+ ngAfterViewInit() {
214
+ this._initContainerClickListener();
215
+ this.recalcVirtualListHeight();
216
+ this.resizeObserver.observe(this.boxEl.nativeElement);
217
+ this.cdRef.detectChanges();
218
+ }
219
+ ngOnDestroy() {
220
+ this._statusChangesSubscription?.unsubscribe();
221
+ this.treeContainerElement?.removeEventListener('click', this._handleOnContainerClick.bind(this));
222
+ this.resizeObserver?.disconnect();
223
+ }
224
+ _initContainerClickListener() {
225
+ this.treeContainerElement =
226
+ this.treeList?.el?.nativeElement?.querySelector('.p-tree-container');
227
+ if (this.treeContainerElement) {
228
+ this.treeContainerElement.addEventListener('click', this._handleOnContainerClick.bind(this));
229
+ }
230
+ }
231
+ _handleOnContainerClick(event) {
232
+ function getParentWithClass(element, className) {
233
+ let currentElement = element;
234
+ while (currentElement) {
235
+ if (currentElement.classList.contains(className)) {
236
+ return currentElement;
237
+ }
238
+ currentElement = currentElement.parentElement;
239
+ }
240
+ return null;
241
+ }
242
+ this.optionFocused = true;
243
+ const elem = event.target.classList.contains('p-treenode-content')
244
+ ? event.target
245
+ : getParentWithClass(event.target, 'p-treenode-content');
246
+ if (elem?.parentElement?.classList?.contains('cps-tree-node-fully-expandable')) {
247
+ this.onClickFullyExpandable(elem);
248
+ }
249
+ }
250
+ registerOnChange(fn) {
251
+ this.onChange = fn;
252
+ }
253
+ registerOnTouched(fn) {
254
+ this.onTouched = fn;
255
+ }
256
+ writeValue(value, internal = false) {
257
+ this.value = value;
258
+ if (!internal && value !== null) {
259
+ this.treeSelection = this._valueToTreeSelection(this.value);
260
+ }
261
+ }
262
+ updateValue(value) {
263
+ this.writeValue(value, true);
264
+ this.onChange(value);
265
+ this.valueChanged.emit(value);
266
+ }
267
+ onSelectNode() {
268
+ if (!this.multiple) {
269
+ this.toggleOptions(false);
270
+ }
271
+ }
272
+ onClickFullyExpandable(elem) {
273
+ const parent = elem.parentElement;
274
+ const key = this._getHTMLElementKey(parent);
275
+ if (!key)
276
+ return;
277
+ const treeNode = this.options.find((o) => o.key === key);
278
+ if (!treeNode)
279
+ return;
280
+ treeNode.expanded = !treeNode.expanded;
281
+ this.updateOptions();
282
+ setTimeout(() => {
283
+ this._nodeToggled(elem);
284
+ });
285
+ }
286
+ _getHTMLElementKey(elem) {
287
+ if (!elem?.classList)
288
+ return '';
289
+ const classList = [...elem.classList];
290
+ const key = classList.find((className) => {
291
+ return className.startsWith('key-');
292
+ });
293
+ if (!key)
294
+ return '';
295
+ return key.replace('key-', '');
296
+ }
297
+ treeSelectionChanged(selection) {
298
+ this.updateValue(this.treeSelectionToValue(selection));
299
+ }
300
+ recalcVirtualListHeight() {
301
+ if (!this.virtualScroll)
302
+ return;
303
+ const currentLen = this.treeList?.serializedValue?.length || 0;
304
+ this.virtualListHeight = Math.min(this.virtualScrollItemSize * currentLen, 240);
305
+ }
306
+ toggleOptions(show) {
307
+ if (this.disabled || this.isOpened === show)
308
+ return;
309
+ if (typeof show === 'boolean') {
310
+ if (show) {
311
+ this.optionsMenu.show({
312
+ target: this.boxEl.nativeElement
313
+ });
314
+ }
315
+ else {
316
+ this.optionsMenu.hide();
317
+ }
318
+ }
319
+ else {
320
+ this.optionsMenu.toggle({
321
+ target: this.boxEl.nativeElement
322
+ });
323
+ }
324
+ this.isOpened = this.optionsMenu.isVisible();
325
+ this.optionFocused = false;
326
+ if (this.isOpened && this.treeSelection) {
327
+ this._expandToNodes(this.multiple ? this.treeSelection : [this.treeSelection]);
328
+ this.updateOptions();
329
+ setTimeout(() => {
330
+ this.recalcVirtualListHeight();
331
+ const selected = this.treeContainerElement.querySelector('.p-highlight');
332
+ if (selected) {
333
+ selected.scrollIntoView({
334
+ behavior: 'instant',
335
+ block: 'nearest',
336
+ inline: 'center'
337
+ });
338
+ }
339
+ else if (this.virtualScroll && this.treeSelection) {
340
+ let key = '';
341
+ if (this.multiple) {
342
+ if (this.treeSelection.length > 0)
343
+ key = this.treeSelection[0].key;
344
+ }
345
+ else
346
+ key = this.treeSelection.key;
347
+ if (key) {
348
+ const idx = this.treeList?.serializedValue?.findIndex(
349
+ // Todo: Add explicit type
350
+ (v) => v.node.key === key) || -1;
351
+ if (idx >= 0)
352
+ this.treeList.scrollToVirtualIndex(idx);
353
+ }
354
+ }
355
+ });
356
+ }
357
+ }
358
+ remove(option) {
359
+ if (!this.multiple)
360
+ return;
361
+ this.treeSelection = this.treeSelection.filter((v) => !isEqual(v, option));
362
+ this.updateValue(this.treeSelectionToValue(this.treeSelection));
363
+ }
364
+ initArrowsNavigaton() {
365
+ if (!this.isOpened)
366
+ return;
367
+ if (!this.optionFocused) {
368
+ const firstElem = this.treeContainerElement?.querySelector('.p-treenode');
369
+ if (firstElem)
370
+ firstElem.focus();
371
+ this.optionFocused = true;
372
+ }
373
+ }
374
+ _nodeToggled(elem) {
375
+ this.recalcVirtualListHeight();
376
+ setTimeout(() => {
377
+ this.optionsMenu.align();
378
+ });
379
+ if (elem?.parentElement)
380
+ (elem?.parentElement).focus();
381
+ }
382
+ _nodeToggledWithChevron(elem) {
383
+ this._nodeToggled(elem);
384
+ // fix primeng tree event stop propagation
385
+ this.optionsMenu.selfClick = false;
386
+ }
387
+ onNodeExpand(event) {
388
+ this._nodeToggledWithChevron(event?.originalEvent?.currentTarget?.parentElement);
389
+ }
390
+ onNodeCollapse(event) {
391
+ this._nodeToggledWithChevron(event?.originalEvent?.currentTarget?.parentElement);
392
+ }
393
+ clear(event) {
394
+ event.stopPropagation();
395
+ if ((!this.multiple && this.treeSelection) ||
396
+ (this.multiple && this.treeSelection?.length > 0)) {
397
+ if (this.openOnClear) {
398
+ this.toggleOptions(true);
399
+ }
400
+ const val = this.multiple ? [] : undefined;
401
+ this.treeSelection = val;
402
+ this.updateValue(val);
403
+ }
404
+ this.optionFocused = false;
405
+ }
406
+ _checkErrors() {
407
+ const errors = this.control?.errors;
408
+ if (!this.control?.control?.touched || !errors) {
409
+ this.error = '';
410
+ return;
411
+ }
412
+ if ('required' in errors) {
413
+ this.error = 'Field is required';
414
+ return;
415
+ }
416
+ const errArr = Object.values(errors);
417
+ if (errArr.length < 1) {
418
+ this.error = '';
419
+ return;
420
+ }
421
+ const message = errArr.find((msg) => typeof msg === 'string');
422
+ this.error = message || 'Unknown error';
423
+ }
424
+ // eslint-disable-next-line @typescript-eslint/no-empty-function
425
+ setDisabledState(disabled) { }
426
+ onBlur() {
427
+ this.control?.control?.markAsTouched();
428
+ this._checkErrors();
429
+ }
430
+ focus() {
431
+ this.componentContainer?.nativeElement?.focus();
432
+ this.toggleOptions(true);
433
+ }
434
+ _expandToNodes(nodes) {
435
+ function getParentKey(key) {
436
+ const lastSeparatorIndex = key.lastIndexOf('-');
437
+ if (lastSeparatorIndex !== -1) {
438
+ return key.substring(0, lastSeparatorIndex);
439
+ }
440
+ return '';
441
+ }
442
+ nodes.forEach((node) => {
443
+ const parentNodeKey = getParentKey(node.key);
444
+ const parentNode = this.optionsMap.get(parentNodeKey) || null;
445
+ if (parentNode) {
446
+ parentNode.expanded = true;
447
+ this._expandToNodes([parentNode]);
448
+ }
449
+ });
450
+ }
451
+ _toInnerOptions(_options) {
452
+ const mapOption = (o, optionLabel, optionInfo, key, originalOptionsMap) => {
453
+ const inner = {
454
+ inner: true,
455
+ label: o[optionLabel],
456
+ info: o[optionInfo],
457
+ key,
458
+ styleClass: 'key-' + key
459
+ };
460
+ if (this.initialExpandAll) {
461
+ inner.expanded = true;
462
+ }
463
+ if (o.isDirectory) {
464
+ inner.type = 'directory';
465
+ inner.selectable = false;
466
+ inner.styleClass += ' cps-tree-node-fully-expandable';
467
+ if (this.initialExpandDirectories) {
468
+ inner.expanded = true;
469
+ }
470
+ }
471
+ if (o.children) {
472
+ inner.children = o.children.map((c, index) => {
473
+ return mapOption(c, optionLabel, optionInfo, key + '-' + index, originalOptionsMap);
474
+ });
475
+ }
476
+ originalOptionsMap.set(key, o);
477
+ return inner;
478
+ };
479
+ const res = _options.map((option, index) => {
480
+ return mapOption(option, this.optionLabel, this.optionInfo, '' + index, this.originalOptionsMap);
481
+ });
482
+ this.optionsMap = this._buildOptionsMap(res);
483
+ return res;
484
+ }
485
+ _buildOptionsMap(options) {
486
+ const nodeMap = new Map();
487
+ for (const option of options) {
488
+ nodeMap.set(option.key, option);
489
+ if (option.children) {
490
+ const childNodeMap = this._buildOptionsMap(option.children);
491
+ childNodeMap.forEach((value, key) => nodeMap.set(key, value));
492
+ }
493
+ }
494
+ return nodeMap;
495
+ }
496
+ treeSelectionToValue(selection) {
497
+ if (!selection)
498
+ return this.multiple ? [] : undefined;
499
+ if (this.multiple) {
500
+ return selection.map((s) => this.originalOptionsMap.get(s.key));
501
+ }
502
+ else {
503
+ return this.originalOptionsMap.get(selection.key);
504
+ }
505
+ }
506
+ _valueToTreeSelection(value) {
507
+ function getKey(v, map) {
508
+ for (const [key, val] of map.entries()) {
509
+ if (isEqual(v, val)) {
510
+ return key;
511
+ }
512
+ }
513
+ return '';
514
+ }
515
+ if (!value)
516
+ return this.multiple ? [] : undefined;
517
+ if (this.multiple) {
518
+ const res = [];
519
+ value.forEach((v) => {
520
+ const key = getKey(v, this.originalOptionsMap);
521
+ if (key)
522
+ res.push(this.optionsMap.get(key));
523
+ });
524
+ return res;
525
+ }
526
+ else {
527
+ const key = getKey(value, this.originalOptionsMap);
528
+ return key ? this.optionsMap.get(key) : undefined;
529
+ }
530
+ }
531
+ // this is a fix of primeng change detection bug when virtual scroller is enabled
532
+ updateOptions() {
533
+ if (!this.virtualScroll)
534
+ return;
535
+ this.options = [...this.options];
536
+ }
537
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsBaseTreeDropdownComponent, deps: [{ token: i1.NgControl, optional: true, self: true }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
538
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: CpsBaseTreeDropdownComponent, selector: "ng-component", inputs: { label: "label", hint: "hint", multiple: "multiple", disabled: "disabled", width: "width", chips: "chips", closableChips: "closableChips", clearable: "clearable", openOnClear: "openOnClear", optionLabel: "optionLabel", optionInfo: "optionInfo", hideDetails: "hideDetails", persistentClear: "persistentClear", prefixIcon: "prefixIcon", prefixIconSize: "prefixIconSize", loading: "loading", virtualScroll: "virtualScroll", numToleratedItems: "numToleratedItems", infoTooltip: "infoTooltip", infoTooltipClass: "infoTooltipClass", infoTooltipMaxWidth: "infoTooltipMaxWidth", infoTooltipPersistent: "infoTooltipPersistent", infoTooltipPosition: "infoTooltipPosition", initialExpandDirectories: "initialExpandDirectories", initialExpandAll: "initialExpandAll", options: "options", _value: ["value", "_value"] }, outputs: { valueChanged: "valueChanged" }, viewQueries: [{ propertyName: "componentContainer", first: true, predicate: ["componentContainer"], descendants: true }, { propertyName: "optionsMenu", first: true, predicate: ["optionsMenu"], descendants: true }, { propertyName: "treeList", first: true, predicate: ["treeList"], descendants: true }, { propertyName: "boxEl", first: true, predicate: ["boxEl"], descendants: true }], ngImport: i0, template: '', isInline: true }); }
539
+ }
540
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsBaseTreeDropdownComponent, decorators: [{
541
+ type: Component,
542
+ args: [{
543
+ template: ''
544
+ }]
545
+ }], ctorParameters: () => [{ type: i1.NgControl, decorators: [{
546
+ type: Self
547
+ }, {
548
+ type: Optional
549
+ }] }, { type: i0.ChangeDetectorRef }], propDecorators: { label: [{
550
+ type: Input
551
+ }], hint: [{
552
+ type: Input
553
+ }], multiple: [{
554
+ type: Input
555
+ }], disabled: [{
556
+ type: Input
557
+ }], width: [{
558
+ type: Input
559
+ }], chips: [{
560
+ type: Input
561
+ }], closableChips: [{
562
+ type: Input
563
+ }], clearable: [{
564
+ type: Input
565
+ }], openOnClear: [{
566
+ type: Input
567
+ }], optionLabel: [{
568
+ type: Input
569
+ }], optionInfo: [{
570
+ type: Input
571
+ }], hideDetails: [{
572
+ type: Input
573
+ }], persistentClear: [{
574
+ type: Input
575
+ }], prefixIcon: [{
576
+ type: Input
577
+ }], prefixIconSize: [{
578
+ type: Input
579
+ }], loading: [{
580
+ type: Input
581
+ }], virtualScroll: [{
582
+ type: Input
583
+ }], numToleratedItems: [{
584
+ type: Input
585
+ }], infoTooltip: [{
586
+ type: Input
587
+ }], infoTooltipClass: [{
588
+ type: Input
589
+ }], infoTooltipMaxWidth: [{
590
+ type: Input
591
+ }], infoTooltipPersistent: [{
592
+ type: Input
593
+ }], infoTooltipPosition: [{
594
+ type: Input
595
+ }], initialExpandDirectories: [{
596
+ type: Input
597
+ }], initialExpandAll: [{
598
+ type: Input
599
+ }], options: [{
600
+ type: Input
601
+ }], _value: [{
602
+ type: Input,
603
+ args: ['value']
604
+ }], valueChanged: [{
605
+ type: Output
606
+ }], componentContainer: [{
607
+ type: ViewChild,
608
+ args: ['componentContainer']
609
+ }], optionsMenu: [{
610
+ type: ViewChild,
611
+ args: ['optionsMenu']
612
+ }], treeList: [{
613
+ type: ViewChild,
614
+ args: ['treeList']
615
+ }], boxEl: [{
616
+ type: ViewChild,
617
+ args: ['boxEl']
618
+ }] } });
619
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-base-tree-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../projects/cps-ui-kit/src/lib/components/internal/cps-base-tree-dropdown/cps-base-tree-dropdown.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Self,\n  ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { TreeNode } from 'primeng/api';\nimport { Subscription } from 'rxjs';\nimport { Tree } from 'primeng/tree';\nimport { isEqual } from 'lodash-es';\nimport { IconType, iconSizeType } from '../../cps-icon/cps-icon.component';\nimport { convertSize } from '../../../utils/internal/size-utils';\nimport { CpsTooltipPosition } from '../../../directives/cps-tooltip/cps-tooltip.directive';\nimport { CpsMenuComponent } from '../../cps-menu/cps-menu.component';\n\n/**\n * BaseTreeDropdownComponent is an internal base component to support hierarchical data dropdown.\n * @group Components\n */\n@Component({\n  template: ''\n})\nexport class CpsBaseTreeDropdownComponent\n  implements ControlValueAccessor, OnInit, AfterViewInit, OnDestroy\n{\n  /**\n   * Label of the component.\n   * @group Props\n   */\n  @Input() label = '';\n\n  /**\n   * Bottom hint text.\n   * @group Props\n   */\n  @Input() hint = '';\n\n  /**\n   * Specifies if multiple values can be selected.\n   * @group Props\n   */\n  @Input() multiple = false;\n\n  /**\n   * Determines whether the component is disabled.\n   * @group Props\n   */\n  @Input() disabled = false;\n\n  /**\n   * Width of the component, of type number denoting pixels or string.\n   * @group Props\n   */\n  @Input() width: number | string = '100%';\n\n  /**\n   * When selecting an element, it will appear in a form of a chip.\n   * @group Props\n   */\n  @Input() chips = true;\n\n  /**\n   * Determines whether the chips can be directly removed.\n   * @group Props\n   */\n  @Input() closableChips = true;\n\n  /**\n   * When enabled, a clear icon is displayed to clear the value.\n   * @group Props\n   */\n  @Input() clearable = false;\n\n  /**\n   * Determines whether the dropdown should open on clear.\n   * @group Props\n   */\n  @Input() openOnClear = true;\n\n  /**\n   * Name of the label field of an option.\n   * @group Props\n   */\n  @Input() optionLabel = 'label';\n\n  /**\n   * Name of the info field of an option, shows the additional information text.\n   * @group Props\n   */\n  @Input() optionInfo = 'info';\n\n  /**\n   * Options for hiding details.\n   * @group Props\n   */\n  @Input() hideDetails = false;\n\n  /**\n   * Determines whether the component should have persistent clear icon.\n   * @group Props\n   */\n  @Input() persistentClear = false;\n\n  /**\n   * Icon before input value.\n   * @group Props\n   */\n  @Input() prefixIcon: IconType = '';\n\n  /**\n   * Size of icon before input value, of type number, string, 'fill', 'xsmall', 'small', 'normal' or 'large'.\n   * @group Props\n   */\n  @Input() prefixIconSize: iconSizeType = '18px';\n\n  /**\n   * When enabled, a loading bar is displayed.\n   * @group Props\n   */\n  @Input() loading = false;\n\n  /**\n   * Determines whether only the elements within scrollable area should be added into the DOM.\n   * @group Props\n   */\n  @Input() virtualScroll = false;\n\n  /**\n   * Determines how many additional elements to add to the DOM outside of the view.\n   * @group Props\n   */\n  @Input() numToleratedItems = 10;\n\n  /**\n   * When it is not an empty string, an info icon is displayed to show text for more info.\n   * @group Props\n   */\n  @Input() infoTooltip = '';\n\n  /**\n   * Info tooltip class for styling.\n   * @group Props\n   */\n  @Input() infoTooltipClass = 'cps-tooltip-content';\n\n  /**\n   * Max width of infoTooltip of type number denoting pixels or string.\n   * @group Props\n   */\n  @Input() infoTooltipMaxWidth: number | string = '100%';\n\n  /**\n   * Determines whether the infoTooltip is persistent.\n   * @group Props\n   */\n  @Input() infoTooltipPersistent = false;\n\n  /**\n   * Position of infoTooltip, it can be 'top', 'bottom', 'left' or 'right'.\n   * @group Props\n   */\n  @Input() infoTooltipPosition: CpsTooltipPosition = 'top';\n\n  /**\n   * When set, it expands all directiories initially.\n   * @group Props\n   */\n  @Input() initialExpandDirectories = false;\n\n  /**\n   * When set, it expands all options initially.\n   * @group Props\n   */\n  @Input() initialExpandAll = false;\n\n  /**\n   * An array of objects to display as the available options.\n   * @group Props\n   */\n  @Input() set options(options: any[]) {\n    if (options?.some((o) => o.inner)) {\n      this._options = options;\n      return;\n    }\n\n    this._options = this._toInnerOptions(options);\n  }\n\n  get options(): TreeNode[] {\n    return this._options;\n  }\n\n  /**\n   * Value of the component.\n   * @group Props\n   */\n  @Input('value') _value: any = undefined;\n\n  set value(value: any) {\n    this._value = value;\n    this.onChange(value);\n  }\n\n  get value(): any {\n    return this._value;\n  }\n\n  /**\n   * Callback to invoke on value change.\n   * @param {any} any - value changed.\n   * @group Emits\n   */\n  @Output() valueChanged = new EventEmitter<any>();\n\n  @ViewChild('componentContainer')\n  componentContainer!: ElementRef;\n\n  @ViewChild('optionsMenu')\n  optionsMenu!: CpsMenuComponent;\n\n  @ViewChild('treeList') treeList!: Tree;\n\n  @ViewChild('boxEl')\n  boxEl!: ElementRef;\n\n  private _statusChangesSubscription: Subscription = new Subscription();\n\n  _options: TreeNode[] = [];\n  optionsMap = new Map<string, TreeNode>();\n  originalOptionsMap = new Map<string, any>();\n\n  virtualListHeight = 240;\n  virtualScrollItemSize = 40;\n\n  error = '';\n  cvtWidth = '';\n  isOpened = false;\n  optionFocused = false;\n  isAutocomplete = false;\n\n  treeContainerElement!: HTMLElement;\n  treeSelection: any;\n\n  boxWidth = 0;\n  resizeObserver: ResizeObserver;\n\n  constructor(\n    @Self() @Optional() public control: NgControl,\n    public cdRef: ChangeDetectorRef\n  ) {\n    if (this.control) {\n      this.control.valueAccessor = this;\n    }\n    this.resizeObserver = new ResizeObserver((entries) => {\n      entries.forEach((entry) => {\n        if (entry?.target) this.boxWidth = (entry.target as any).offsetWidth;\n      });\n    });\n  }\n\n  ngOnInit() {\n    this.cvtWidth = convertSize(this.width);\n    if (!this._value) {\n      if (this.multiple) {\n        this._value = [];\n        this.treeSelection = [];\n      }\n    } else {\n      this.treeSelection = this._valueToTreeSelection(this.value);\n    }\n\n    this._statusChangesSubscription = this.control?.statusChanges?.subscribe(\n      () => {\n        this._checkErrors();\n      }\n    ) as Subscription;\n  }\n\n  ngAfterViewInit() {\n    this._initContainerClickListener();\n    this.recalcVirtualListHeight();\n    this.resizeObserver.observe(this.boxEl.nativeElement);\n    this.cdRef.detectChanges();\n  }\n\n  ngOnDestroy() {\n    this._statusChangesSubscription?.unsubscribe();\n\n    this.treeContainerElement?.removeEventListener(\n      'click',\n      this._handleOnContainerClick.bind(this)\n    );\n\n    this.resizeObserver?.disconnect();\n  }\n\n  private _initContainerClickListener() {\n    this.treeContainerElement =\n      this.treeList?.el?.nativeElement?.querySelector('.p-tree-container');\n    if (this.treeContainerElement) {\n      this.treeContainerElement.addEventListener(\n        'click',\n        this._handleOnContainerClick.bind(this)\n      );\n    }\n  }\n\n  private _handleOnContainerClick(event: any) {\n    function getParentWithClass(\n      element: HTMLElement | null,\n      className: string\n    ) {\n      let currentElement = element;\n      while (currentElement) {\n        if (currentElement.classList.contains(className)) {\n          return currentElement;\n        }\n        currentElement = currentElement.parentElement;\n      }\n      return null;\n    }\n\n    this.optionFocused = true;\n\n    const elem = event.target.classList.contains('p-treenode-content')\n      ? event.target\n      : getParentWithClass(event.target, 'p-treenode-content');\n\n    if (\n      elem?.parentElement?.classList?.contains('cps-tree-node-fully-expandable')\n    ) {\n      this.onClickFullyExpandable(elem);\n    }\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange = (event: any) => {};\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onTouched = () => {};\n\n  registerOnChange(fn: any) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any) {\n    this.onTouched = fn;\n  }\n\n  writeValue(value: any, internal = false) {\n    this.value = value;\n    if (!internal && value !== null) {\n      this.treeSelection = this._valueToTreeSelection(this.value);\n    }\n  }\n\n  updateValue(value: any): void {\n    this.writeValue(value, true);\n    this.onChange(value);\n    this.valueChanged.emit(value);\n  }\n\n  onSelectNode() {\n    if (!this.multiple) {\n      this.toggleOptions(false);\n    }\n  }\n\n  onClickFullyExpandable(elem: HTMLElement) {\n    const parent = elem.parentElement;\n    const key = this._getHTMLElementKey(parent);\n    if (!key) return;\n\n    const treeNode = this.options.find((o) => o.key === key);\n    if (!treeNode) return;\n\n    treeNode.expanded = !treeNode.expanded;\n    this.updateOptions();\n    setTimeout(() => {\n      this._nodeToggled(elem);\n    });\n  }\n\n  private _getHTMLElementKey(elem: any): string {\n    if (!elem?.classList) return '';\n    const classList = [...elem.classList];\n    const key = classList.find((className: string) => {\n      return className.startsWith('key-');\n    });\n    if (!key) return '';\n    return key.replace('key-', '');\n  }\n\n  treeSelectionChanged(selection: any) {\n    this.updateValue(this.treeSelectionToValue(selection));\n  }\n\n  recalcVirtualListHeight() {\n    if (!this.virtualScroll) return;\n    const currentLen = this.treeList?.serializedValue?.length || 0;\n    this.virtualListHeight = Math.min(\n      this.virtualScrollItemSize * currentLen,\n      240\n    );\n  }\n\n  toggleOptions(show?: boolean): void {\n    if (this.disabled || this.isOpened === show) return;\n\n    if (typeof show === 'boolean') {\n      if (show) {\n        this.optionsMenu.show({\n          target: this.boxEl.nativeElement\n        });\n      } else {\n        this.optionsMenu.hide();\n      }\n    } else {\n      this.optionsMenu.toggle({\n        target: this.boxEl.nativeElement\n      });\n    }\n\n    this.isOpened = this.optionsMenu.isVisible();\n\n    this.optionFocused = false;\n    if (this.isOpened && this.treeSelection) {\n      this._expandToNodes(\n        this.multiple ? this.treeSelection : [this.treeSelection]\n      );\n      this.updateOptions();\n      setTimeout(() => {\n        this.recalcVirtualListHeight();\n        const selected = this.treeContainerElement.querySelector(\n          '.p-highlight'\n        ) as any;\n        if (selected) {\n          selected.scrollIntoView({\n            behavior: 'instant',\n            block: 'nearest',\n            inline: 'center'\n          });\n        } else if (this.virtualScroll && this.treeSelection) {\n          let key = '';\n          if (this.multiple) {\n            if (this.treeSelection.length > 0) key = this.treeSelection[0].key;\n          } else key = this.treeSelection.key;\n          if (key) {\n            const idx =\n              this.treeList?.serializedValue?.findIndex(\n                // Todo: Add explicit type\n                (v: any) => v.node.key === key\n              ) || -1;\n            if (idx >= 0) this.treeList.scrollToVirtualIndex(idx);\n          }\n        }\n      });\n    }\n  }\n\n  remove(option: TreeNode): void {\n    if (!this.multiple) return;\n\n    this.treeSelection = this.treeSelection.filter(\n      (v: TreeNode) => !isEqual(v, option)\n    );\n    this.updateValue(this.treeSelectionToValue(this.treeSelection));\n  }\n\n  initArrowsNavigaton() {\n    if (!this.isOpened) return;\n\n    if (!this.optionFocused) {\n      const firstElem = this.treeContainerElement?.querySelector('.p-treenode');\n\n      if (firstElem) (firstElem as HTMLElement).focus();\n      this.optionFocused = true;\n    }\n  }\n\n  private _nodeToggled(elem: HTMLElement) {\n    this.recalcVirtualListHeight();\n    setTimeout(() => {\n      this.optionsMenu.align();\n    });\n\n    if (elem?.parentElement) (elem?.parentElement as HTMLElement).focus();\n  }\n\n  private _nodeToggledWithChevron(elem: HTMLElement) {\n    this._nodeToggled(elem);\n    // fix primeng tree event stop propagation\n    this.optionsMenu.selfClick = false;\n  }\n\n  onNodeExpand(event: any) {\n    this._nodeToggledWithChevron(\n      event?.originalEvent?.currentTarget?.parentElement\n    );\n  }\n\n  onNodeCollapse(event: any) {\n    this._nodeToggledWithChevron(\n      event?.originalEvent?.currentTarget?.parentElement\n    );\n  }\n\n  clear(event: any): void {\n    event.stopPropagation();\n\n    if (\n      (!this.multiple && this.treeSelection) ||\n      (this.multiple && this.treeSelection?.length > 0)\n    ) {\n      if (this.openOnClear) {\n        this.toggleOptions(true);\n      }\n      const val = this.multiple ? [] : undefined;\n      this.treeSelection = val;\n      this.updateValue(val);\n    }\n    this.optionFocused = false;\n  }\n\n  private _checkErrors(): void {\n    const errors = this.control?.errors;\n\n    if (!this.control?.control?.touched || !errors) {\n      this.error = '';\n      return;\n    }\n\n    if ('required' in errors) {\n      this.error = 'Field is required';\n      return;\n    }\n\n    const errArr = Object.values(errors);\n    if (errArr.length < 1) {\n      this.error = '';\n      return;\n    }\n    const message = errArr.find((msg) => typeof msg === 'string');\n\n    this.error = message || 'Unknown error';\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  setDisabledState(disabled: boolean) {}\n\n  onBlur() {\n    this.control?.control?.markAsTouched();\n    this._checkErrors();\n  }\n\n  focus() {\n    this.componentContainer?.nativeElement?.focus();\n    this.toggleOptions(true);\n  }\n\n  private _expandToNodes(nodes: any[]) {\n    function getParentKey(key: string): string {\n      const lastSeparatorIndex = key.lastIndexOf('-');\n      if (lastSeparatorIndex !== -1) {\n        return key.substring(0, lastSeparatorIndex);\n      }\n      return '';\n    }\n\n    nodes.forEach((node) => {\n      const parentNodeKey = getParentKey(node.key);\n      const parentNode = this.optionsMap.get(parentNodeKey) || null;\n\n      if (parentNode) {\n        parentNode.expanded = true;\n        this._expandToNodes([parentNode]);\n      }\n    });\n  }\n\n  private _toInnerOptions(_options: any[]): TreeNode[] {\n    const mapOption = (\n      o: any,\n      optionLabel: string,\n      optionInfo: string,\n      key: string,\n      originalOptionsMap: any\n    ) => {\n      const inner = {\n        inner: true,\n        label: o[optionLabel],\n        info: o[optionInfo],\n        key,\n        styleClass: 'key-' + key\n      } as TreeNode;\n\n      if (this.initialExpandAll) {\n        inner.expanded = true;\n      }\n\n      if (o.isDirectory) {\n        inner.type = 'directory';\n        inner.selectable = false;\n        inner.styleClass += ' cps-tree-node-fully-expandable';\n        if (this.initialExpandDirectories) {\n          inner.expanded = true;\n        }\n      }\n      if (o.children) {\n        inner.children = o.children.map((c: any, index: number) => {\n          return mapOption(\n            c,\n            optionLabel,\n            optionInfo,\n            key + '-' + index,\n            originalOptionsMap\n          );\n        });\n      }\n      originalOptionsMap.set(key, o);\n      return inner;\n    };\n\n    const res = _options.map((option, index) => {\n      return mapOption(\n        option,\n        this.optionLabel,\n        this.optionInfo,\n        '' + index,\n        this.originalOptionsMap\n      );\n    });\n\n    this.optionsMap = this._buildOptionsMap(res);\n\n    return res;\n  }\n\n  private _buildOptionsMap(options: any[]): Map<string, any> {\n    const nodeMap = new Map<string, any>();\n    for (const option of options) {\n      nodeMap.set(option.key, option);\n      if (option.children) {\n        const childNodeMap = this._buildOptionsMap(option.children);\n        childNodeMap.forEach((value, key) => nodeMap.set(key, value));\n      }\n    }\n    return nodeMap;\n  }\n\n  treeSelectionToValue(selection: any) {\n    if (!selection) return this.multiple ? [] : undefined;\n    if (this.multiple) {\n      return selection.map((s: any) => this.originalOptionsMap.get(s.key));\n    } else {\n      return this.originalOptionsMap.get(selection.key);\n    }\n  }\n\n  private _valueToTreeSelection(value: any) {\n    function getKey(v: any, map: Map<string, any>): string {\n      for (const [key, val] of map.entries()) {\n        if (isEqual(v, val)) {\n          return key;\n        }\n      }\n      return '';\n    }\n\n    if (!value) return this.multiple ? [] : undefined;\n\n    if (this.multiple) {\n      const res = [] as TreeNode[];\n      value.forEach((v: any) => {\n        const key = getKey(v, this.originalOptionsMap);\n        if (key) res.push(this.optionsMap.get(key) as TreeNode);\n      });\n      return res;\n    } else {\n      const key = getKey(value, this.originalOptionsMap);\n      return key ? this.optionsMap.get(key) : undefined;\n    }\n  }\n\n  // this is a fix of primeng change detection bug when virtual scroller is enabled\n  updateOptions() {\n    if (!this.virtualScroll) return;\n    this.options = [...this.options];\n  }\n}\n"]}