@progress-chef/platform-shared-components 0.0.154 → 0.0.156-rc.1

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 (135) hide show
  1. package/assets/icons/IconFont.css +6 -3
  2. package/assets/icons/IconFont.scss +6 -3
  3. package/assets/icons/IconFont.ttf +0 -0
  4. package/assets/icons/IconFont.woff +0 -0
  5. package/assets/icons/IconFont.woff2 +0 -0
  6. package/esm2022/lib/atoms/alert/alert.component.mjs +3 -3
  7. package/esm2022/lib/atoms/alert/alert.module.mjs +4 -4
  8. package/esm2022/lib/atoms/angular-popup/angular-popup.component.mjs +3 -3
  9. package/esm2022/lib/atoms/angular-popup/angular-popup.module.mjs +4 -4
  10. package/esm2022/lib/atoms/atoms.module.mjs +19 -5
  11. package/esm2022/lib/atoms/avatar/avatar.component.mjs +3 -3
  12. package/esm2022/lib/atoms/avatar/avatar.module.mjs +4 -4
  13. package/esm2022/lib/atoms/breadcrumb/breadcrumb.component.mjs +3 -3
  14. package/esm2022/lib/atoms/breadcrumb/breadcrumb.module.mjs +4 -4
  15. package/esm2022/lib/atoms/button/button.component.mjs +3 -3
  16. package/esm2022/lib/atoms/button/button.module.mjs +4 -4
  17. package/esm2022/lib/atoms/button-group/button-group.component.mjs +3 -3
  18. package/esm2022/lib/atoms/button-group/button-group.module.mjs +4 -4
  19. package/esm2022/lib/atoms/checkbox/checkbox.component.mjs +3 -3
  20. package/esm2022/lib/atoms/checkbox/checkbox.module.mjs +4 -4
  21. package/esm2022/lib/atoms/chip/chip.component.mjs +3 -3
  22. package/esm2022/lib/atoms/chip/chip.module.mjs +4 -4
  23. package/esm2022/lib/atoms/chip-list/chip-list.component.mjs +3 -3
  24. package/esm2022/lib/atoms/chip-list/chip-list.module.mjs +4 -4
  25. package/esm2022/lib/atoms/clipboard/clipboard.component.mjs +3 -3
  26. package/esm2022/lib/atoms/clipboard/clipboard.module.mjs +4 -4
  27. package/esm2022/lib/atoms/container/container.component.mjs +3 -3
  28. package/esm2022/lib/atoms/container/container.module.mjs +4 -4
  29. package/esm2022/lib/atoms/date-range/date-range.component.mjs +3 -3
  30. package/esm2022/lib/atoms/date-range/date-range.module.mjs +4 -4
  31. package/esm2022/lib/atoms/datepicker/datepicker.component.mjs +3 -3
  32. package/esm2022/lib/atoms/datepicker/datepicker.module.mjs +4 -4
  33. package/esm2022/lib/atoms/drag-and-drop/drag-and-drop.component.mjs +33 -5
  34. package/esm2022/lib/atoms/drag-and-drop/drag-and-drop.module.mjs +4 -4
  35. package/esm2022/lib/atoms/dropdown/dropdown.component.mjs +3 -3
  36. package/esm2022/lib/atoms/dropdown/dropdown.module.mjs +4 -4
  37. package/esm2022/lib/atoms/dropdown-button/dropdown-button.component.mjs +3 -3
  38. package/esm2022/lib/atoms/dropdown-button/dropdown-button.module.mjs +4 -4
  39. package/esm2022/lib/atoms/dropdown-tree/dropdowntree.component.mjs +3 -3
  40. package/esm2022/lib/atoms/dropdown-tree/dropdowntree.module.mjs +4 -4
  41. package/esm2022/lib/atoms/expansion-panel/expansion-panel.component.mjs +3 -3
  42. package/esm2022/lib/atoms/expansion-panel/expansion-panel.module.mjs +4 -4
  43. package/esm2022/lib/atoms/icon/icon.component.mjs +4 -4
  44. package/esm2022/lib/atoms/icon/icon.module.mjs +4 -4
  45. package/esm2022/lib/atoms/labels/label.component.mjs +3 -3
  46. package/esm2022/lib/atoms/labels/label.module.mjs +4 -4
  47. package/esm2022/lib/atoms/list-views/list-view.component.mjs +3 -3
  48. package/esm2022/lib/atoms/list-views/list-view.module.mjs +4 -4
  49. package/esm2022/lib/atoms/loader/loader.component.mjs +3 -3
  50. package/esm2022/lib/atoms/loader/loader.module.mjs +4 -4
  51. package/esm2022/lib/atoms/loading-spinner/loading-spinner.component.mjs +3 -3
  52. package/esm2022/lib/atoms/loading-spinner/loading-spinner.module.mjs +4 -4
  53. package/esm2022/lib/atoms/markdown-display/markdown-display.component.mjs +39 -0
  54. package/esm2022/lib/atoms/markdown-display/markdown-display.module.mjs +26 -0
  55. package/esm2022/lib/atoms/markdown-display/markdown-display.service.mjs +53 -0
  56. package/esm2022/lib/atoms/multi-select-dropdown/multi-select-dropdown.component.mjs +3 -3
  57. package/esm2022/lib/atoms/multi-select-dropdown/multi-select-dropdown.module.mjs +4 -4
  58. package/esm2022/lib/atoms/notification/notification.component.mjs +3 -3
  59. package/esm2022/lib/atoms/notification/notification.module.mjs +4 -4
  60. package/esm2022/lib/atoms/numeric-textbox/numeric-textbox.component.mjs +3 -3
  61. package/esm2022/lib/atoms/numeric-textbox/numeric-textbox.module.mjs +4 -4
  62. package/esm2022/lib/atoms/progress-bar/progress-bar.component.mjs +3 -3
  63. package/esm2022/lib/atoms/progress-bar/progress-bar.module.mjs +4 -4
  64. package/esm2022/lib/atoms/radio-button/radio-button.component.mjs +3 -3
  65. package/esm2022/lib/atoms/radio-button/radio-button.module.mjs +4 -4
  66. package/esm2022/lib/atoms/search-box/search-box.component.mjs +3 -3
  67. package/esm2022/lib/atoms/search-box/search-box.module.mjs +4 -4
  68. package/esm2022/lib/atoms/slider/slider.component.mjs +3 -3
  69. package/esm2022/lib/atoms/slider/slider.module.mjs +4 -4
  70. package/esm2022/lib/atoms/stepper/stepper.component.mjs +3 -3
  71. package/esm2022/lib/atoms/stepper/stepper.module.mjs +4 -4
  72. package/esm2022/lib/atoms/switch/switch.component.mjs +3 -3
  73. package/esm2022/lib/atoms/switch/switch.module.mjs +4 -4
  74. package/esm2022/lib/atoms/text-area/text-area.component.mjs +3 -3
  75. package/esm2022/lib/atoms/text-area/text-area.module.mjs +4 -4
  76. package/esm2022/lib/atoms/textbox/textbox.component.mjs +3 -3
  77. package/esm2022/lib/atoms/textbox/textbox.module.mjs +4 -4
  78. package/esm2022/lib/atoms/time-picker/time-picker.component.mjs +3 -3
  79. package/esm2022/lib/atoms/time-picker/time-picker.module.mjs +4 -4
  80. package/esm2022/lib/atoms/timescheduler/timescheduler.component.mjs +3 -3
  81. package/esm2022/lib/atoms/timescheduler/timescheduler.module.mjs +4 -4
  82. package/esm2022/lib/atoms/tooltip/tooltip.component.mjs +3 -3
  83. package/esm2022/lib/atoms/tooltip/tooltip.module.mjs +4 -4
  84. package/esm2022/lib/atoms/tree-list/tree-list.component.mjs +404 -0
  85. package/esm2022/lib/atoms/tree-list/tree-list.interfaces.mjs +2 -0
  86. package/esm2022/lib/atoms/tree-list/tree-list.module.mjs +44 -0
  87. package/esm2022/lib/atoms/tree-view/tree-view.component.mjs +521 -0
  88. package/esm2022/lib/atoms/tree-view/tree-view.interfaces.mjs +2 -0
  89. package/esm2022/lib/atoms/tree-view/tree-view.module.mjs +44 -0
  90. package/esm2022/lib/atoms/typography/typography.component.mjs +3 -3
  91. package/esm2022/lib/atoms/typography/typography.module.mjs +4 -4
  92. package/esm2022/lib/atoms/uploader/uploader.component.mjs +3 -3
  93. package/esm2022/lib/atoms/uploader/uploader.module.mjs +4 -4
  94. package/esm2022/lib/molecules/card/card-actions/card-actions.component.mjs +3 -3
  95. package/esm2022/lib/molecules/card/card-body/card-body.component.mjs +3 -3
  96. package/esm2022/lib/molecules/card/card-footer/card-footer.component.mjs +3 -3
  97. package/esm2022/lib/molecules/card/card-header/card-header.component.mjs +3 -3
  98. package/esm2022/lib/molecules/card/card.component.mjs +3 -3
  99. package/esm2022/lib/molecules/card/card.module.mjs +4 -4
  100. package/esm2022/lib/molecules/dialog/confirmation-dialog/confirmation-dialog.component.mjs +3 -3
  101. package/esm2022/lib/molecules/dialog/dialog-actions/dialog-actions.component.mjs +3 -3
  102. package/esm2022/lib/molecules/dialog/dialog-titlebar/dialog-titlebar.component.mjs +3 -3
  103. package/esm2022/lib/molecules/dialog/dialog.component.mjs +3 -3
  104. package/esm2022/lib/molecules/dialog/dialog.module.mjs +4 -4
  105. package/esm2022/lib/molecules/grid-form/grid-form.component.mjs +3 -3
  106. package/esm2022/lib/molecules/grid-form/grid-form.module.mjs +4 -4
  107. package/esm2022/lib/molecules/grid-layout/grid-layout-item/grid-layout-item.component.mjs +3 -3
  108. package/esm2022/lib/molecules/grid-layout/grid-layout.component.mjs +3 -3
  109. package/esm2022/lib/molecules/grid-layout/grid-layout.module.mjs +4 -4
  110. package/esm2022/lib/molecules/grid-pagination/grid-pagination-spacer/grid-pagination-spacer.component.mjs +3 -3
  111. package/esm2022/lib/molecules/grid-pagination/grid-pagination.component.mjs +6 -6
  112. package/esm2022/lib/molecules/grid-pagination/grid-pagination.module.mjs +4 -4
  113. package/esm2022/lib/molecules/grid-pagination/kebab-menu-filter.pipe.mjs +3 -3
  114. package/esm2022/lib/molecules/molecules.module.mjs +4 -4
  115. package/esm2022/lib/molecules/tabstrip/tabstrip-tab/tabstrip-tab.component.mjs +3 -3
  116. package/esm2022/lib/molecules/tabstrip/tabstrip.component.mjs +3 -3
  117. package/esm2022/lib/molecules/tabstrip/tabstrip.module.mjs +4 -4
  118. package/esm2022/lib/shared.component.mjs +3 -3
  119. package/esm2022/lib/shared.module.mjs +4 -4
  120. package/esm2022/public-api.mjs +7 -1
  121. package/fesm2022/progress-chef-platform-shared-components.mjs +1501 -375
  122. package/fesm2022/progress-chef-platform-shared-components.mjs.map +1 -1
  123. package/lib/atoms/atoms.module.d.ts +5 -3
  124. package/lib/atoms/drag-and-drop/drag-and-drop.component.d.ts +10 -1
  125. package/lib/atoms/markdown-display/markdown-display.component.d.ts +22 -0
  126. package/lib/atoms/markdown-display/markdown-display.module.d.ts +8 -0
  127. package/lib/atoms/markdown-display/markdown-display.service.d.ts +23 -0
  128. package/lib/atoms/tree-list/tree-list.component.d.ts +288 -0
  129. package/lib/atoms/tree-list/tree-list.interfaces.d.ts +31 -0
  130. package/lib/atoms/tree-list/tree-list.module.d.ts +13 -0
  131. package/lib/atoms/tree-view/tree-view.component.d.ts +279 -0
  132. package/lib/atoms/tree-view/tree-view.interfaces.d.ts +23 -0
  133. package/lib/atoms/tree-view/tree-view.module.d.ts +13 -0
  134. package/package.json +2 -1
  135. package/public-api.d.ts +6 -0
@@ -0,0 +1,521 @@
1
+ import { Component, Input, Output, EventEmitter, ViewChild } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { of } from 'rxjs';
4
+ import { TreeViewModule } from '@progress/kendo-angular-treeview';
5
+ import { IconsModule } from '@progress/kendo-angular-icons';
6
+ import { ButtonComponent } from '../button/button.component';
7
+ import { IconComponent } from '../icon/icon.component';
8
+ import { LoaderComponent } from '../loader/loader.component';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "@angular/common";
11
+ import * as i2 from "@progress/kendo-angular-treeview";
12
+ /**
13
+ * Custom TreeView component that wraps Kendo's TreeView with design system styling.
14
+ *
15
+ * This component provides a hierarchical tree structure for displaying and navigating data.
16
+ * It supports selection, expansion, icons, and custom templates.
17
+ */
18
+ export class TreeViewComponent {
19
+ constructor() {
20
+ /**
21
+ * The data source for the tree view
22
+ */
23
+ this.data = [];
24
+ // Basic Properties
25
+ this.selectable = false;
26
+ this.filterable = false;
27
+ this.checkboxes = false;
28
+ this.checkable = false;
29
+ this.dragAndDrop = false;
30
+ this.expandable = true;
31
+ this.loading = false;
32
+ this.animate = true;
33
+ this.size = 'medium';
34
+ // Field Configuration
35
+ this.textField = 'text';
36
+ this.childrenField = 'children';
37
+ this.hasChildrenField = 'hasChildren';
38
+ this.expandedField = 'expanded';
39
+ this.selectedField = 'selected';
40
+ this.disabledField = 'disabled';
41
+ this.checkedField = 'checked';
42
+ this.iconClassField = 'iconClass';
43
+ this.iconField = 'icon';
44
+ this.imageUrlField = 'imageUrl';
45
+ this.spriteCssClassField = 'spriteCssClass';
46
+ // Selection and Expansion
47
+ this.disabledKeys = [];
48
+ this.expandBy = ''; //if expandBy is empty, expandedKeys will use index to track expansion. Otherwise, it will use the field name to decide the expandedKeys.
49
+ this.expandedKeys = [];
50
+ this.selectedKeys = [];
51
+ this.checkedKeys = [];
52
+ this.expandDisabledNodes = false;
53
+ this.disableNodes = false;
54
+ // Checkbox Configuration
55
+ this.enableCheck = false;
56
+ this.checkChildren = false;
57
+ this.checkDisabledChildren = false;
58
+ this.checkParents = false;
59
+ this.checkOnClick = false;
60
+ this.uncheckCollapsedChildren = false;
61
+ this.checkMode = "multiple";
62
+ this.pageSize = 0;
63
+ this.loadOnDemand = false;
64
+ // Filtering
65
+ this.filter = '';
66
+ // Keyboard Navigation
67
+ this.navigable = true;
68
+ // Basic Events
69
+ this.selectionChange = new EventEmitter();
70
+ this.expand = new EventEmitter();
71
+ this.collapse = new EventEmitter();
72
+ this.checkedChange = new EventEmitter();
73
+ this.nodeClick = new EventEmitter();
74
+ this.nodeDblClick = new EventEmitter();
75
+ // Drag and Drop Events
76
+ this.nodeDragStart = new EventEmitter();
77
+ this.nodeDrag = new EventEmitter();
78
+ this.nodeDrop = new EventEmitter();
79
+ this.nodeDragEnd = new EventEmitter();
80
+ this.addItem = new EventEmitter();
81
+ this.removeItem = new EventEmitter();
82
+ // Key Change Events (Two-way binding support)
83
+ this.expandedKeysChange = new EventEmitter();
84
+ this.selectedKeysChange = new EventEmitter();
85
+ this.checkedKeysChange = new EventEmitter();
86
+ // Filter Events
87
+ this.filterChange = new EventEmitter();
88
+ // Load More Events
89
+ this.loadMore = new EventEmitter();
90
+ // Children Loading Events
91
+ this.childrenLoaded = new EventEmitter();
92
+ /**
93
+ * Currently selected items
94
+ */
95
+ this.selectedItems = [];
96
+ /**
97
+ * Currently checked items
98
+ */
99
+ this.checkedItems = [];
100
+ /**
101
+ * Extracts and returns child items from a tree node using the configured children field.
102
+ * Provides a standardized way for the Kendo TreeView to access hierarchical child data
103
+ * regardless of the actual field name used in the data structure.
104
+ *
105
+ * @param dataItem - The tree node data item to extract children from
106
+ * @returns Observable array of child items or empty array if no children exist
107
+ */
108
+ this.children = (dataItem) => of(dataItem[this.childrenField]);
109
+ /**
110
+ * Determines whether a tree node has child items for proper expand/collapse icon display.
111
+ * Checks for the existence of children property and logs the result for debugging purposes.
112
+ * Used by the TreeView to decide whether to show expansion indicators for each node.
113
+ *
114
+ * @param dataItem - The tree node data item to check for children
115
+ * @returns Boolean indicating whether the node has children that can be expanded
116
+ */
117
+ this.hasChildren = (dataItem) => { return !!dataItem[this.childrenField]; };
118
+ }
119
+ /**
120
+ * Generates CSS classes for the tree-view container element based on current component state.
121
+ * Applies conditional styling classes to reflect loading states and enable appropriate visual feedback.
122
+ *
123
+ * @returns A space-separated string of CSS class names to apply to the tree-view container
124
+ */
125
+ getTreeViewClasses() {
126
+ const classes = ['lib-tree-view'];
127
+ if (this.loading) {
128
+ classes.push('lib-tree-view--loading');
129
+ }
130
+ return classes.join(' ');
131
+ }
132
+ /**
133
+ * Provides comprehensive checkable settings configuration for the Kendo TreeView component.
134
+ * Aggregates all checkbox-related input properties into a single configuration object
135
+ * that controls checkbox behavior including parent-child relationships and interaction modes.
136
+ *
137
+ * @returns CheckableSettings object with all checkbox configuration options
138
+ */
139
+ get checkableSettings() {
140
+ return {
141
+ checkChildren: this.checkChildren,
142
+ checkDisabledChildren: this.checkDisabledChildren,
143
+ checkParents: this.checkParents,
144
+ enabled: this.enableCheck,
145
+ mode: this.checkMode,
146
+ checkOnClick: this.checkOnClick,
147
+ uncheckCollapsedChildren: this.uncheckCollapsedChildren,
148
+ };
149
+ }
150
+ // Event Handlers
151
+ /**
152
+ * Handles tree node selection changes when users select or deselect nodes.
153
+ * Updates the internal selected items state and propagates the selection event
154
+ * to parent components for external handling and synchronization.
155
+ *
156
+ * @param event - The selection change event containing the newly selected items array
157
+ */
158
+ onSelectionChange(event) {
159
+ this.selectedItems = event;
160
+ this.selectionChange.emit(event);
161
+ }
162
+ /**
163
+ * Handles checkbox state changes when users check or uncheck tree nodes.
164
+ * Updates the internal checked items state and emits the change event to notify
165
+ * parent components of the new checkbox selections for form validation or data processing.
166
+ *
167
+ * @param event - The checked change event containing the newly checked items array
168
+ */
169
+ onCheckedChange(event) {
170
+ this.checkedItems = event;
171
+ this.checkedChange.emit(event);
172
+ }
173
+ /**
174
+ * Handles tree node expansion events when users click expand icons or use keyboard navigation.
175
+ * Updates the node's expanded state in the data model and emits the expand event
176
+ * for parent components to handle lazy loading of child data or state persistence.
177
+ *
178
+ * @param event - The expand event containing the expanded node data and context information
179
+ */
180
+ onExpand(event) {
181
+ if (event.dataItem) {
182
+ event.dataItem[this.expandedField] = true;
183
+ }
184
+ this.expand.emit(event);
185
+ }
186
+ /**
187
+ * Handles tree node collapse events when users click collapse icons or use keyboard navigation.
188
+ * Updates the node's expanded state in the data model and emits the collapse event
189
+ * for parent components to handle state cleanup or memory optimization.
190
+ *
191
+ * @param event - The collapse event containing the collapsed node data and context information
192
+ */
193
+ onCollapse(event) {
194
+ if (event.dataItem) {
195
+ event.dataItem[this.expandedField] = false;
196
+ }
197
+ this.collapse.emit(event);
198
+ }
199
+ /**
200
+ * Handles single-click events on tree nodes for custom interaction handling.
201
+ * Propagates click events to parent components for navigation, selection logic,
202
+ * or custom actions based on the clicked node's data and context.
203
+ *
204
+ * @param event - The node click event containing clicked node data and mouse event details
205
+ */
206
+ onNodeClick(event) {
207
+ this.nodeClick.emit(event);
208
+ }
209
+ /**
210
+ * Handles double-click events on tree nodes for enhanced interaction patterns.
211
+ * Typically used for opening detailed views, editing modes, or quick actions
212
+ * that differ from single-click behavior. Emits event for parent component handling.
213
+ *
214
+ * @param event - The node double-click event containing node data and mouse event details
215
+ */
216
+ onNodeDblClick(event) {
217
+ this.nodeDblClick.emit(event);
218
+ }
219
+ /**
220
+ * Handles the initiation of drag operations when users start dragging tree nodes.
221
+ * Validates that drag-and-drop functionality is enabled before proceeding and
222
+ * emits the drag start event for parent components to handle drag state setup.
223
+ *
224
+ * @param event - The tree item drag start event containing source node and drag context
225
+ */
226
+ onNodeDragStart(event) {
227
+ if (!this.dragAndDrop) {
228
+ return;
229
+ }
230
+ this.nodeDragStart.emit(event);
231
+ }
232
+ /**
233
+ * Handles ongoing drag operations as users move nodes during drag-and-drop actions.
234
+ * Provides real-time feedback and validation during the drag process, allowing
235
+ * parent components to update UI indicators or validate drop targets.
236
+ *
237
+ * @param event - The tree item drag event containing current drag position and target information
238
+ */
239
+ onNodeDrag(event) {
240
+ this.nodeDrag.emit(event);
241
+ }
242
+ /**
243
+ * Handles the completion of drag operations when users finish dragging nodes.
244
+ * Provides cleanup and final processing for drag-and-drop operations, allowing
245
+ * parent components to finalize data updates and reset drag-related UI states.
246
+ *
247
+ * @param event - The tree item drag end event containing final drag state and completion context
248
+ */
249
+ onNodeDragEnd(event) {
250
+ this.nodeDragEnd.emit(event);
251
+ }
252
+ /**
253
+ * Handles item addition events when new nodes are added to the tree structure.
254
+ * Propagates add events to parent components for data persistence, validation,
255
+ * and tree structure updates to maintain data integrity.
256
+ *
257
+ * @param event - The tree item add event containing new item data and insertion context
258
+ */
259
+ onAddItem(event) {
260
+ this.addItem.emit(event);
261
+ }
262
+ /**
263
+ * Handles item removal events when nodes are deleted from the tree structure.
264
+ * Propagates remove events to parent components for confirmation dialogs, data cleanup,
265
+ * and cascading deletions of child nodes when necessary.
266
+ *
267
+ * @param event - The tree item remove event containing deleted item data and context
268
+ */
269
+ onRemoveItem(event) {
270
+ this.removeItem.emit(event);
271
+ }
272
+ /**
273
+ * Handles expanded keys changes for two-way binding support with parent components.
274
+ * Synchronizes internal expanded state with external data binding, enabling
275
+ * programmatic control of tree expansion and state persistence across component updates.
276
+ *
277
+ * @param keys - Array of string keys representing currently expanded tree nodes
278
+ */
279
+ onExpandedKeysChange(keys) {
280
+ this.expandedKeys = keys;
281
+ this.expandedKeysChange.emit(keys);
282
+ }
283
+ /**
284
+ * Handles selected keys changes for two-way binding support with parent components.
285
+ * Synchronizes internal selection state with external data binding, enabling
286
+ * programmatic control of tree selection and form integration capabilities.
287
+ *
288
+ * @param keys - Array of string keys representing currently selected tree nodes
289
+ */
290
+ onSelectedKeysChange(keys) {
291
+ this.selectedKeys = keys;
292
+ this.selectedKeysChange.emit(keys);
293
+ }
294
+ /**
295
+ * Handles checked keys changes for two-way binding support with parent components.
296
+ * Synchronizes internal checkbox state with external data binding, enabling
297
+ * programmatic control of checkbox selections and form validation integration.
298
+ *
299
+ * @param keys - Array of string keys representing currently checked tree nodes
300
+ */
301
+ onCheckedKeysChange(keys) {
302
+ this.checkedKeys = keys;
303
+ this.checkedKeysChange.emit(keys);
304
+ }
305
+ /**
306
+ * Handles filter text changes when users type in search fields or apply filtering criteria.
307
+ * Updates the internal filter state and propagates changes to parent components
308
+ * for server-side filtering or custom search logic implementation.
309
+ *
310
+ * @param filter - The filter string entered by the user for tree node searching
311
+ */
312
+ onFilterChange(filter) {
313
+ this.filter = filter;
314
+ this.filterChange.emit(filter);
315
+ }
316
+ /**
317
+ * Handle load more event
318
+ */
319
+ onLoadMore(event) {
320
+ this.loadMore.emit(event);
321
+ }
322
+ /**
323
+ * Handle children loaded event
324
+ */
325
+ onChildrenLoaded(event) {
326
+ this.childrenLoaded.emit(event);
327
+ }
328
+ // Utility Methods
329
+ /**
330
+ * Expand all nodes
331
+ */
332
+ expandAll() {
333
+ if (this.treeViewElement) {
334
+ // Implementation depends on Kendo TreeView API
335
+ }
336
+ }
337
+ /**
338
+ * Get item from lookup
339
+ */
340
+ itemLookup(index) {
341
+ if (this.treeViewElement) {
342
+ return this.treeViewElement.itemLookup(index);
343
+ }
344
+ return undefined;
345
+ }
346
+ /**
347
+ * Log function for debugging events
348
+ */
349
+ log(eventName, event) {
350
+ console.log(`${eventName}:`, event);
351
+ }
352
+ /**
353
+ * Handle drop event with custom logic
354
+ */
355
+ handleDrop(event) {
356
+ console.log('handleDrop:', event);
357
+ // Add custom drop handling logic here
358
+ this.nodeDrop.emit(event);
359
+ }
360
+ /**
361
+ * Handle node drag start event
362
+ */
363
+ onDragStart(event) {
364
+ if (!this.dragAndDrop) {
365
+ event.preventDefault();
366
+ }
367
+ }
368
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.18", ngImport: i0, type: TreeViewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
369
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.18", type: TreeViewComponent, isStandalone: true, selector: "lib-tree-view", inputs: { data: "data", selectable: "selectable", filterable: "filterable", checkboxes: "checkboxes", checkable: "checkable", dragAndDrop: "dragAndDrop", expandable: "expandable", loading: "loading", animate: "animate", size: "size", textField: "textField", childrenField: "childrenField", hasChildrenField: "hasChildrenField", expandedField: "expandedField", selectedField: "selectedField", disabledField: "disabledField", checkedField: "checkedField", iconClassField: "iconClassField", iconField: "iconField", imageUrlField: "imageUrlField", spriteCssClassField: "spriteCssClassField", disabledKeys: "disabledKeys", expandBy: "expandBy", expandedKeys: "expandedKeys", selectedKeys: "selectedKeys", checkedKeys: "checkedKeys", expandDisabledNodes: "expandDisabledNodes", disableNodes: "disableNodes", enableCheck: "enableCheck", checkChildren: "checkChildren", checkDisabledChildren: "checkDisabledChildren", checkParents: "checkParents", checkOnClick: "checkOnClick", uncheckCollapsedChildren: "uncheckCollapsedChildren", checkMode: "checkMode", fetchChildren: "fetchChildren", isChecked: "isChecked", isDisabled: "isDisabled", isExpanded: "isExpanded", isSelected: "isSelected", isVisible: "isVisible", nodeTemplate: "nodeTemplate", loadMoreButtonTemplate: "loadMoreButtonTemplate", loadMoreService: "loadMoreService", pageSize: "pageSize", loadOnDemand: "loadOnDemand", filter: "filter", filterSettings: "filterSettings", navigable: "navigable", trackBy: "trackBy" }, outputs: { selectionChange: "selectionChange", expand: "expand", collapse: "collapse", checkedChange: "checkedChange", nodeClick: "nodeClick", nodeDblClick: "nodeDblClick", nodeDragStart: "nodeDragStart", nodeDrag: "nodeDrag", nodeDrop: "nodeDrop", nodeDragEnd: "nodeDragEnd", addItem: "addItem", removeItem: "removeItem", expandedKeysChange: "expandedKeysChange", selectedKeysChange: "selectedKeysChange", checkedKeysChange: "checkedKeysChange", filterChange: "filterChange", loadMore: "loadMore", childrenLoaded: "childrenLoaded" }, viewQueries: [{ propertyName: "treeViewElement", first: true, predicate: ["treeViewElement"], descendants: true }], ngImport: i0, template: "<div [class]=\"getTreeViewClasses()\">\n\n <div class=\"treeview-panel\">\n\n <ng-container [ngSwitch]=\"checkable\">\n\n <kendo-treeview #treeViewElement *ngSwitchCase=\"true\" [children]=\"children\" kendoTreeViewHierarchyBinding\n kendoTreeViewExpandable [kendoTreeViewCheckable]=\"checkableSettings\" kendoTreeViewDragAndDrop\n kendoTreeViewDragAndDropEditing [nodes]=\"data\" [textField]=\"textField\" [childrenField]=\"childrenField\"\n [filterable]=\"filterable\" [expandBy]=\"expandBy\" [(expandedKeys)]=\"expandedKeys\"\n [expandDisabledNodes]=\"expandDisabledNodes\" (selectionChange)=\"onSelectionChange($event)\"\n (checkedChange)=\"onCheckedChange($event)\" (expand)=\"onExpand($event)\" (collapse)=\"onCollapse($event)\"\n (nodeClick)=\"onNodeClick($event)\" (expandedKeysChange)=\"onExpandedKeysChange($event)\"\n (nodeDragStart)=\"onDragStart($event)\" (nodeDrop)=\"handleDrop($event)\" (addItem)=\"log('addItem', $event)\"\n (removeItem)=\"log('removeItem', $event)\" (nodeDragEnd)=\"log('nodeDragEnd', $event)\"\n (nodeDrag)=\"onNodeDrag($event)\" class=\"lib-tree-view__kendo-tree\" [kendoTreeViewSelectable]=\"selectable\"\n [filter]=\"filter\" [size]=\"size\" [navigable]=\"navigable\" [loadOnDemand]=\"loadOnDemand\" [trackBy]=\"trackBy\"\n [hasChildren]=\"hasChildren\" [(selectedKeys)]=\"selectedKeys\" (filterChange)=\"onFilterChange($event)\">\n\n <!-- Custom Node Template -->\n <ng-template *ngIf=\"nodeTemplate\" kendoTreeViewNodeTemplate let-dataItem=\"dataItem\" let-index=\"index\">\n <ng-container [ngTemplateOutlet]=\"nodeTemplate\" [ngTemplateOutletContext]=\"{ \n $implicit: dataItem, \n dataItem: dataItem, \n index: index \n }\">\n </ng-container>\n </ng-template>\n\n <!-- Load More Button Template -->\n <ng-template *ngIf=\"loadMoreButtonTemplate\" kendoTreeViewLoadMoreButtonTemplate let-dataItem=\"dataItem\">\n <ng-container [ngTemplateOutlet]=\"loadMoreButtonTemplate\" [ngTemplateOutletContext]=\"{ \n $implicit: dataItem, \n dataItem: dataItem \n }\">\n </ng-container>\n </ng-template>\n\n </kendo-treeview>\n\n <!-- TreeView without checkable functionality -->\n <kendo-treeview #treeViewElement *ngSwitchDefault kendoTreeViewHierarchyBinding kendoTreeViewExpandable\n kendoTreeViewDragAndDrop kendoTreeViewDragAndDropEditing [nodes]=\"data\" [textField]=\"textField\"\n [childrenField]=\"childrenField\" [filterable]=\"filterable\" [expandBy]=\"expandBy\" [(expandedKeys)]=\"expandedKeys\"\n [expandDisabledNodes]=\"expandDisabledNodes\" (selectionChange)=\"onSelectionChange($event)\"\n (checkedChange)=\"onCheckedChange($event)\" (expand)=\"onExpand($event)\" (collapse)=\"onCollapse($event)\"\n (nodeClick)=\"onNodeClick($event)\" (expandedKeysChange)=\"onExpandedKeysChange($event)\"\n (nodeDragStart)=\"onDragStart($event)\" (nodeDrag)=\"onNodeDrag($event)\" (nodeDrop)=\"handleDrop($event)\"\n (addItem)=\"log('addItem', $event)\" (removeItem)=\"log('removeItem', $event)\"\n (nodeDragEnd)=\"log('nodeDragEnd', $event)\" class=\"lib-tree-view__kendo-tree\"\n [kendoTreeViewSelectable]=\"selectable\" [size]=\"size\" [navigable]=\"navigable\" [loadOnDemand]=\"loadOnDemand\"\n [trackBy]=\"trackBy\" [hasChildren]=\"hasChildren\" [(selectedKeys)]=\"selectedKeys\"\n (filterChange)=\"onFilterChange($event)\">\n\n <!-- Custom Node Template -->\n <ng-template *ngIf=\"nodeTemplate\" kendoTreeViewNodeTemplate let-dataItem=\"dataItem\" let-index=\"index\">\n <ng-container [ngTemplateOutlet]=\"nodeTemplate\" [ngTemplateOutletContext]=\"{ \n $implicit: dataItem, \n dataItem: dataItem, \n index: index \n }\">\n </ng-container>\n </ng-template>\n\n <!-- Load More Button Template -->\n <ng-template *ngIf=\"loadMoreButtonTemplate\" kendoTreeViewLoadMoreButtonTemplate let-dataItem=\"dataItem\">\n <ng-container [ngTemplateOutlet]=\"loadMoreButtonTemplate\" [ngTemplateOutletContext]=\"{ \n $implicit: dataItem, \n dataItem: dataItem \n }\">\n </ng-container>\n </ng-template>\n\n </kendo-treeview>\n </ng-container>\n\n <!-- Loading indicator -->\n <div *ngIf=\"loading\" class=\"lib-tree-view__loading\">\n <lib-loader size=\"medium\" type=\"pulsing\" themeColor=\"primary\"></lib-loader>\n </div>\n </div>\n", styles: [".lib-tree-view{position:relative;width:100%}.lib-tree-view__loading{position:absolute;inset:0;z-index:10;display:flex;align-items:center;justify-content:center;background-color:#fffc}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { 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: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i1.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "ngmodule", type: TreeViewModule }, { kind: "component", type: i2.TreeViewComponent, selector: "kendo-treeview", inputs: ["filterInputPlaceholder", "expandDisabledNodes", "animate", "nodeTemplate", "loadMoreButtonTemplate", "trackBy", "nodes", "textField", "hasChildren", "isChecked", "isDisabled", "hasCheckbox", "isExpanded", "isSelected", "isVisible", "navigable", "children", "loadOnDemand", "filterable", "filter", "size", "disableParentNodesOnly"], outputs: ["childrenLoaded", "blur", "focus", "expand", "collapse", "nodeDragStart", "nodeDrag", "filterStateChange", "nodeDrop", "nodeDragEnd", "addItem", "removeItem", "checkedChange", "selectionChange", "filterChange", "nodeClick", "nodeDblClick"], exportAs: ["kendoTreeView"] }, { kind: "directive", type: i2.NodeTemplateDirective, selector: "[kendoTreeViewNodeTemplate]" }, { kind: "directive", type: i2.CheckDirective, selector: "[kendoTreeViewCheckable]", inputs: ["isChecked", "checkBy", "checkedKeys", "kendoTreeViewCheckable"], outputs: ["checkedKeysChange"] }, { kind: "directive", type: i2.ExpandDirective, selector: "[kendoTreeViewExpandable]", inputs: ["isExpanded", "expandBy", "expandOnFilter", "expandedKeys"], outputs: ["expandedKeysChange"] }, { kind: "directive", type: i2.SelectDirective, selector: "[kendoTreeViewSelectable]", inputs: ["isSelected", "selectBy", "kendoTreeViewSelectable", "selectedKeys"], outputs: ["selectedKeysChange"] }, { kind: "directive", type: i2.HierarchyBindingDirective, selector: "[kendoTreeViewHierarchyBinding]", inputs: ["childrenField", "nodes", "isVisible", "loadOnDemand"] }, { kind: "directive", type: i2.DragAndDropDirective, selector: "[kendoTreeViewDragAndDrop]", inputs: ["allowCopy", "dropZoneTreeViews", "startDragAfter", "autoScroll"] }, { kind: "directive", type: i2.DragAndDropEditingDirective, selector: "[kendoTreeViewDragAndDropEditing]", inputs: ["editService"] }, { kind: "directive", type: i2.LoadMoreButtonTemplateDirective, selector: "[kendoTreeViewLoadMoreButtonTemplate]" }, { kind: "ngmodule", type: IconsModule }, { kind: "component", type: LoaderComponent, selector: "lib-loader", inputs: ["size", "type", "themeColor"] }] }); }
370
+ }
371
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.18", ngImport: i0, type: TreeViewComponent, decorators: [{
372
+ type: Component,
373
+ args: [{ standalone: true, selector: 'lib-tree-view', imports: [
374
+ CommonModule,
375
+ TreeViewModule,
376
+ IconsModule,
377
+ ButtonComponent,
378
+ IconComponent,
379
+ LoaderComponent
380
+ ], template: "<div [class]=\"getTreeViewClasses()\">\n\n <div class=\"treeview-panel\">\n\n <ng-container [ngSwitch]=\"checkable\">\n\n <kendo-treeview #treeViewElement *ngSwitchCase=\"true\" [children]=\"children\" kendoTreeViewHierarchyBinding\n kendoTreeViewExpandable [kendoTreeViewCheckable]=\"checkableSettings\" kendoTreeViewDragAndDrop\n kendoTreeViewDragAndDropEditing [nodes]=\"data\" [textField]=\"textField\" [childrenField]=\"childrenField\"\n [filterable]=\"filterable\" [expandBy]=\"expandBy\" [(expandedKeys)]=\"expandedKeys\"\n [expandDisabledNodes]=\"expandDisabledNodes\" (selectionChange)=\"onSelectionChange($event)\"\n (checkedChange)=\"onCheckedChange($event)\" (expand)=\"onExpand($event)\" (collapse)=\"onCollapse($event)\"\n (nodeClick)=\"onNodeClick($event)\" (expandedKeysChange)=\"onExpandedKeysChange($event)\"\n (nodeDragStart)=\"onDragStart($event)\" (nodeDrop)=\"handleDrop($event)\" (addItem)=\"log('addItem', $event)\"\n (removeItem)=\"log('removeItem', $event)\" (nodeDragEnd)=\"log('nodeDragEnd', $event)\"\n (nodeDrag)=\"onNodeDrag($event)\" class=\"lib-tree-view__kendo-tree\" [kendoTreeViewSelectable]=\"selectable\"\n [filter]=\"filter\" [size]=\"size\" [navigable]=\"navigable\" [loadOnDemand]=\"loadOnDemand\" [trackBy]=\"trackBy\"\n [hasChildren]=\"hasChildren\" [(selectedKeys)]=\"selectedKeys\" (filterChange)=\"onFilterChange($event)\">\n\n <!-- Custom Node Template -->\n <ng-template *ngIf=\"nodeTemplate\" kendoTreeViewNodeTemplate let-dataItem=\"dataItem\" let-index=\"index\">\n <ng-container [ngTemplateOutlet]=\"nodeTemplate\" [ngTemplateOutletContext]=\"{ \n $implicit: dataItem, \n dataItem: dataItem, \n index: index \n }\">\n </ng-container>\n </ng-template>\n\n <!-- Load More Button Template -->\n <ng-template *ngIf=\"loadMoreButtonTemplate\" kendoTreeViewLoadMoreButtonTemplate let-dataItem=\"dataItem\">\n <ng-container [ngTemplateOutlet]=\"loadMoreButtonTemplate\" [ngTemplateOutletContext]=\"{ \n $implicit: dataItem, \n dataItem: dataItem \n }\">\n </ng-container>\n </ng-template>\n\n </kendo-treeview>\n\n <!-- TreeView without checkable functionality -->\n <kendo-treeview #treeViewElement *ngSwitchDefault kendoTreeViewHierarchyBinding kendoTreeViewExpandable\n kendoTreeViewDragAndDrop kendoTreeViewDragAndDropEditing [nodes]=\"data\" [textField]=\"textField\"\n [childrenField]=\"childrenField\" [filterable]=\"filterable\" [expandBy]=\"expandBy\" [(expandedKeys)]=\"expandedKeys\"\n [expandDisabledNodes]=\"expandDisabledNodes\" (selectionChange)=\"onSelectionChange($event)\"\n (checkedChange)=\"onCheckedChange($event)\" (expand)=\"onExpand($event)\" (collapse)=\"onCollapse($event)\"\n (nodeClick)=\"onNodeClick($event)\" (expandedKeysChange)=\"onExpandedKeysChange($event)\"\n (nodeDragStart)=\"onDragStart($event)\" (nodeDrag)=\"onNodeDrag($event)\" (nodeDrop)=\"handleDrop($event)\"\n (addItem)=\"log('addItem', $event)\" (removeItem)=\"log('removeItem', $event)\"\n (nodeDragEnd)=\"log('nodeDragEnd', $event)\" class=\"lib-tree-view__kendo-tree\"\n [kendoTreeViewSelectable]=\"selectable\" [size]=\"size\" [navigable]=\"navigable\" [loadOnDemand]=\"loadOnDemand\"\n [trackBy]=\"trackBy\" [hasChildren]=\"hasChildren\" [(selectedKeys)]=\"selectedKeys\"\n (filterChange)=\"onFilterChange($event)\">\n\n <!-- Custom Node Template -->\n <ng-template *ngIf=\"nodeTemplate\" kendoTreeViewNodeTemplate let-dataItem=\"dataItem\" let-index=\"index\">\n <ng-container [ngTemplateOutlet]=\"nodeTemplate\" [ngTemplateOutletContext]=\"{ \n $implicit: dataItem, \n dataItem: dataItem, \n index: index \n }\">\n </ng-container>\n </ng-template>\n\n <!-- Load More Button Template -->\n <ng-template *ngIf=\"loadMoreButtonTemplate\" kendoTreeViewLoadMoreButtonTemplate let-dataItem=\"dataItem\">\n <ng-container [ngTemplateOutlet]=\"loadMoreButtonTemplate\" [ngTemplateOutletContext]=\"{ \n $implicit: dataItem, \n dataItem: dataItem \n }\">\n </ng-container>\n </ng-template>\n\n </kendo-treeview>\n </ng-container>\n\n <!-- Loading indicator -->\n <div *ngIf=\"loading\" class=\"lib-tree-view__loading\">\n <lib-loader size=\"medium\" type=\"pulsing\" themeColor=\"primary\"></lib-loader>\n </div>\n </div>\n", styles: [".lib-tree-view{position:relative;width:100%}.lib-tree-view__loading{position:absolute;inset:0;z-index:10;display:flex;align-items:center;justify-content:center;background-color:#fffc}\n"] }]
381
+ }], propDecorators: { treeViewElement: [{
382
+ type: ViewChild,
383
+ args: ['treeViewElement', { static: false }]
384
+ }], data: [{
385
+ type: Input
386
+ }], selectable: [{
387
+ type: Input
388
+ }], filterable: [{
389
+ type: Input
390
+ }], checkboxes: [{
391
+ type: Input
392
+ }], checkable: [{
393
+ type: Input
394
+ }], dragAndDrop: [{
395
+ type: Input
396
+ }], expandable: [{
397
+ type: Input
398
+ }], loading: [{
399
+ type: Input
400
+ }], animate: [{
401
+ type: Input
402
+ }], size: [{
403
+ type: Input
404
+ }], textField: [{
405
+ type: Input
406
+ }], childrenField: [{
407
+ type: Input
408
+ }], hasChildrenField: [{
409
+ type: Input
410
+ }], expandedField: [{
411
+ type: Input
412
+ }], selectedField: [{
413
+ type: Input
414
+ }], disabledField: [{
415
+ type: Input
416
+ }], checkedField: [{
417
+ type: Input
418
+ }], iconClassField: [{
419
+ type: Input
420
+ }], iconField: [{
421
+ type: Input
422
+ }], imageUrlField: [{
423
+ type: Input
424
+ }], spriteCssClassField: [{
425
+ type: Input
426
+ }], disabledKeys: [{
427
+ type: Input
428
+ }], expandBy: [{
429
+ type: Input
430
+ }], expandedKeys: [{
431
+ type: Input
432
+ }], selectedKeys: [{
433
+ type: Input
434
+ }], checkedKeys: [{
435
+ type: Input
436
+ }], expandDisabledNodes: [{
437
+ type: Input
438
+ }], disableNodes: [{
439
+ type: Input
440
+ }], enableCheck: [{
441
+ type: Input
442
+ }], checkChildren: [{
443
+ type: Input
444
+ }], checkDisabledChildren: [{
445
+ type: Input
446
+ }], checkParents: [{
447
+ type: Input
448
+ }], checkOnClick: [{
449
+ type: Input
450
+ }], uncheckCollapsedChildren: [{
451
+ type: Input
452
+ }], checkMode: [{
453
+ type: Input
454
+ }], fetchChildren: [{
455
+ type: Input
456
+ }], isChecked: [{
457
+ type: Input
458
+ }], isDisabled: [{
459
+ type: Input
460
+ }], isExpanded: [{
461
+ type: Input
462
+ }], isSelected: [{
463
+ type: Input
464
+ }], isVisible: [{
465
+ type: Input
466
+ }], nodeTemplate: [{
467
+ type: Input
468
+ }], loadMoreButtonTemplate: [{
469
+ type: Input
470
+ }], loadMoreService: [{
471
+ type: Input
472
+ }], pageSize: [{
473
+ type: Input
474
+ }], loadOnDemand: [{
475
+ type: Input
476
+ }], filter: [{
477
+ type: Input
478
+ }], filterSettings: [{
479
+ type: Input
480
+ }], navigable: [{
481
+ type: Input
482
+ }], trackBy: [{
483
+ type: Input
484
+ }], selectionChange: [{
485
+ type: Output
486
+ }], expand: [{
487
+ type: Output
488
+ }], collapse: [{
489
+ type: Output
490
+ }], checkedChange: [{
491
+ type: Output
492
+ }], nodeClick: [{
493
+ type: Output
494
+ }], nodeDblClick: [{
495
+ type: Output
496
+ }], nodeDragStart: [{
497
+ type: Output
498
+ }], nodeDrag: [{
499
+ type: Output
500
+ }], nodeDrop: [{
501
+ type: Output
502
+ }], nodeDragEnd: [{
503
+ type: Output
504
+ }], addItem: [{
505
+ type: Output
506
+ }], removeItem: [{
507
+ type: Output
508
+ }], expandedKeysChange: [{
509
+ type: Output
510
+ }], selectedKeysChange: [{
511
+ type: Output
512
+ }], checkedKeysChange: [{
513
+ type: Output
514
+ }], filterChange: [{
515
+ type: Output
516
+ }], loadMore: [{
517
+ type: Output
518
+ }], childrenLoaded: [{
519
+ type: Output
520
+ }] } });
521
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree-view.component.js","sourceRoot":"","sources":["../../../../../../projects/shared/src/lib/atoms/tree-view/tree-view.component.ts","../../../../../../projects/shared/src/lib/atoms/tree-view/tree-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, ViewChild, Renderer2, TemplateRef } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { Observable, of } from 'rxjs';\nimport {\n  TreeViewModule,\n  TreeViewComponent as KendoTreeViewComponent,\n  TreeItemLookup,\n  TreeItemAddRemoveArgs,\n  TreeItemDropEvent,\n  TreeItemDragStartEvent,\n  TreeItemDragEvent,\n  CheckableSettings,\n  CheckMode\n} from '@progress/kendo-angular-treeview';\nimport { IconsModule } from '@progress/kendo-angular-icons';\nimport { ButtonComponent } from '../button/button.component';\nimport { IconComponent } from '../icon/icon.component';\nimport { LoaderComponent } from '../loader/loader.component';\nimport { TreeViewNode } from './tree-view.interfaces';\n\n/**\n * Custom TreeView component that wraps Kendo's TreeView with design system styling.\n * \n * This component provides a hierarchical tree structure for displaying and navigating data.\n * It supports selection, expansion, icons, and custom templates.\n */\n@Component({\n  standalone: true,\n  selector: 'lib-tree-view',\n  templateUrl: './tree-view.component.html',\n  styleUrls: ['./tree-view.component.scss'],\n  imports: [\n    CommonModule,\n    TreeViewModule,\n    IconsModule,\n    ButtonComponent,\n    IconComponent,\n    LoaderComponent\n  ]\n})\nexport class TreeViewComponent {\n\n  /**\n   * ViewChild reference to the Kendo TreeView component instance\n   */\n  @ViewChild('treeViewElement', { static: false }) treeViewElement!: any;\n\n  /**\n   * The data source for the tree view\n   */\n  @Input() data: TreeViewNode[] = [];\n\n  // Basic Properties\n  @Input() selectable: boolean = false;\n  @Input() filterable: boolean = false;\n  @Input() checkboxes: boolean = false;\n  @Input() checkable: boolean = false;\n  @Input() dragAndDrop: boolean = false;\n  @Input() expandable: boolean = true;\n  @Input() loading: boolean = false;\n  @Input() animate: boolean = true;\n  @Input() size: 'small' | 'medium' | 'large' | 'none' = 'medium';\n\n  // Field Configuration\n  @Input() textField: string = 'text';\n  @Input() childrenField: string = 'children';\n  @Input() hasChildrenField: string = 'hasChildren';\n  @Input() expandedField: string = 'expanded';\n  @Input() selectedField: string = 'selected';\n  @Input() disabledField: string = 'disabled';\n  @Input() checkedField: string = 'checked';\n  @Input() iconClassField: string = 'iconClass';\n  @Input() iconField: string = 'icon';\n  @Input() imageUrlField: string = 'imageUrl';\n  @Input() spriteCssClassField: string = 'spriteCssClass';\n\n  // Selection and Expansion\n  @Input() disabledKeys: string[] = [];\n  @Input() expandBy: string | ((item: TreeViewNode) => string) = '';//if expandBy is empty, expandedKeys will use index to track expansion. Otherwise, it will use the field name to decide the expandedKeys.\n  @Input() expandedKeys: string[] = [];\n  @Input() selectedKeys: string[] = [];\n  @Input() checkedKeys: string[] = [];\n  @Input() expandDisabledNodes: boolean = false;\n  @Input() disableNodes: boolean = false;\n\n  // Checkbox Configuration\n  @Input() enableCheck: boolean = false;\n  @Input() checkChildren: boolean = false;\n  @Input() checkDisabledChildren: boolean = false;\n  @Input() checkParents: boolean = false;\n  @Input() checkOnClick: boolean = false;\n  @Input() uncheckCollapsedChildren: boolean = false;\n  @Input() checkMode: CheckMode = \"multiple\";\n\n  // Data Loading\n  @Input() fetchChildren: ((item: any) => any[]) | undefined;\n  @Input() isChecked: ((item: any) => boolean) | undefined;\n  @Input() isDisabled: ((item: any) => boolean) | undefined;\n  @Input() isExpanded: ((item: any) => boolean) | undefined;\n  @Input() isSelected: ((item: any) => boolean) | undefined;\n  @Input() isVisible: ((item: any) => boolean) | undefined;\n\n  // Templates\n  @Input() nodeTemplate: TemplateRef<any> | undefined;\n  @Input() loadMoreButtonTemplate: TemplateRef<any> | undefined;\n\n  // Load More Configuration\n  @Input() loadMoreService: ((item: any) => any[]) | undefined;\n  @Input() pageSize: number = 0;\n  @Input() loadOnDemand: boolean = false;\n\n  // Filtering\n  @Input() filter: string = '';\n  @Input() filterSettings: any;\n\n  // Keyboard Navigation\n  @Input() navigable: boolean = true;\n\n  // Track by function\n  @Input() trackBy: ((index: number, item: TreeViewNode) => any) | undefined;\n\n  // Basic Events\n  @Output() selectionChange = new EventEmitter<any>();\n  @Output() expand = new EventEmitter<any>();\n  @Output() collapse = new EventEmitter<any>();\n  @Output() checkedChange = new EventEmitter<any>();\n  @Output() nodeClick = new EventEmitter<any>();\n  @Output() nodeDblClick = new EventEmitter<any>();\n\n  // Drag and Drop Events\n  @Output() nodeDragStart = new EventEmitter<TreeItemDragStartEvent>();\n  @Output() nodeDrag = new EventEmitter<TreeItemDragEvent>();\n  @Output() nodeDrop = new EventEmitter<TreeItemDropEvent>();\n  @Output() nodeDragEnd = new EventEmitter<TreeItemDragEvent>();\n  @Output() addItem = new EventEmitter<TreeItemAddRemoveArgs>();\n  @Output() removeItem = new EventEmitter<TreeItemAddRemoveArgs>();\n\n  // Key Change Events (Two-way binding support)\n  @Output() expandedKeysChange = new EventEmitter<string[]>();\n  @Output() selectedKeysChange = new EventEmitter<string[]>();\n  @Output() checkedKeysChange = new EventEmitter<string[]>();\n\n  // Filter Events\n  @Output() filterChange = new EventEmitter<string>();\n\n  // Load More Events\n  @Output() loadMore = new EventEmitter<any>();\n\n  // Children Loading Events\n  @Output() childrenLoaded = new EventEmitter<any>();\n  /**\n   * Currently selected items\n   */\n  selectedItems: TreeViewNode[] = [];\n\n  /**\n   * Currently checked items\n   */\n  checkedItems: TreeViewNode[] = [];\n\n  /**\n   * Generates CSS classes for the tree-view container element based on current component state.\n   * Applies conditional styling classes to reflect loading states and enable appropriate visual feedback.\n   * \n   * @returns A space-separated string of CSS class names to apply to the tree-view container\n   */\n  getTreeViewClasses(): string {\n    const classes = ['lib-tree-view'];\n\n    if (this.loading) {\n      classes.push('lib-tree-view--loading');\n    }\n\n    return classes.join(' ');\n  }\n\n  /**\n   * Provides comprehensive checkable settings configuration for the Kendo TreeView component.\n   * Aggregates all checkbox-related input properties into a single configuration object\n   * that controls checkbox behavior including parent-child relationships and interaction modes.\n   * \n   * @returns CheckableSettings object with all checkbox configuration options\n   */\n  public get checkableSettings(): CheckableSettings {\n    return {\n      checkChildren: this.checkChildren,\n      checkDisabledChildren: this.checkDisabledChildren,\n      checkParents: this.checkParents,\n      enabled: this.enableCheck,\n      mode: this.checkMode,\n      checkOnClick: this.checkOnClick,\n      uncheckCollapsedChildren: this.uncheckCollapsedChildren,\n    };\n  }\n\n  /**\n   * Extracts and returns child items from a tree node using the configured children field.\n   * Provides a standardized way for the Kendo TreeView to access hierarchical child data\n   * regardless of the actual field name used in the data structure.\n   * \n   * @param dataItem - The tree node data item to extract children from\n   * @returns Observable array of child items or empty array if no children exist\n   */\n  public children = (dataItem: any): Observable<any[]> => of(dataItem[this.childrenField]);\n\n  /**\n   * Determines whether a tree node has child items for proper expand/collapse icon display.\n   * Checks for the existence of children property and logs the result for debugging purposes.\n   * Used by the TreeView to decide whether to show expansion indicators for each node.\n   * \n   * @param dataItem - The tree node data item to check for children\n   * @returns Boolean indicating whether the node has children that can be expanded\n   */\n  public hasChildren = (dataItem: any): boolean => { return !!dataItem[this.childrenField] };\n\n  // Event Handlers\n\n  /**\n   * Handles tree node selection changes when users select or deselect nodes.\n   * Updates the internal selected items state and propagates the selection event\n   * to parent components for external handling and synchronization.\n   * \n   * @param event - The selection change event containing the newly selected items array\n   */\n  onSelectionChange(event: any): void {\n    this.selectedItems = event;\n    this.selectionChange.emit(event);\n  }\n\n  /**\n   * Handles checkbox state changes when users check or uncheck tree nodes.\n   * Updates the internal checked items state and emits the change event to notify\n   * parent components of the new checkbox selections for form validation or data processing.\n   * \n   * @param event - The checked change event containing the newly checked items array\n   */\n  onCheckedChange(event: any): void {\n    this.checkedItems = event;\n    this.checkedChange.emit(event);\n  }\n\n  /**\n   * Handles tree node expansion events when users click expand icons or use keyboard navigation.\n   * Updates the node's expanded state in the data model and emits the expand event\n   * for parent components to handle lazy loading of child data or state persistence.\n   * \n   * @param event - The expand event containing the expanded node data and context information\n   */\n  onExpand(event: any): void {\n    if (event.dataItem) {\n      event.dataItem[this.expandedField] = true;\n    }\n    this.expand.emit(event);\n  }\n\n  /**\n   * Handles tree node collapse events when users click collapse icons or use keyboard navigation.\n   * Updates the node's expanded state in the data model and emits the collapse event\n   * for parent components to handle state cleanup or memory optimization.\n   * \n   * @param event - The collapse event containing the collapsed node data and context information\n   */\n  onCollapse(event: any): void {\n    if (event.dataItem) {\n      event.dataItem[this.expandedField] = false;\n    }\n    this.collapse.emit(event);\n  }\n\n  /**\n   * Handles single-click events on tree nodes for custom interaction handling.\n   * Propagates click events to parent components for navigation, selection logic,\n   * or custom actions based on the clicked node's data and context.\n   * \n   * @param event - The node click event containing clicked node data and mouse event details\n   */\n  onNodeClick(event: any): void {\n    this.nodeClick.emit(event);\n  }\n\n  /**\n   * Handles double-click events on tree nodes for enhanced interaction patterns.\n   * Typically used for opening detailed views, editing modes, or quick actions\n   * that differ from single-click behavior. Emits event for parent component handling.\n   * \n   * @param event - The node double-click event containing node data and mouse event details\n   */\n  onNodeDblClick(event: any): void {\n    this.nodeDblClick.emit(event);\n  }\n\n  /**\n   * Handles the initiation of drag operations when users start dragging tree nodes.\n   * Validates that drag-and-drop functionality is enabled before proceeding and\n   * emits the drag start event for parent components to handle drag state setup.\n   * \n   * @param event - The tree item drag start event containing source node and drag context\n   */\n  onNodeDragStart(event: TreeItemDragStartEvent): void {\n    if (!this.dragAndDrop) {\n      return;\n    }\n    this.nodeDragStart.emit(event);\n  }\n\n  /**\n   * Handles ongoing drag operations as users move nodes during drag-and-drop actions.\n   * Provides real-time feedback and validation during the drag process, allowing\n   * parent components to update UI indicators or validate drop targets.\n   * \n   * @param event - The tree item drag event containing current drag position and target information\n   */\n  onNodeDrag(event: TreeItemDragEvent): void {\n    this.nodeDrag.emit(event);\n  }\n\n\n  /**\n   * Handles the completion of drag operations when users finish dragging nodes.\n   * Provides cleanup and final processing for drag-and-drop operations, allowing\n   * parent components to finalize data updates and reset drag-related UI states.\n   * \n   * @param event - The tree item drag end event containing final drag state and completion context\n   */\n  onNodeDragEnd(event: TreeItemDragEvent): void {\n    this.nodeDragEnd.emit(event);\n  }\n\n  /**\n   * Handles item addition events when new nodes are added to the tree structure.\n   * Propagates add events to parent components for data persistence, validation,\n   * and tree structure updates to maintain data integrity.\n   * \n   * @param event - The tree item add event containing new item data and insertion context\n   */\n  onAddItem(event: TreeItemAddRemoveArgs): void {\n    this.addItem.emit(event);\n  }\n\n  /**\n   * Handles item removal events when nodes are deleted from the tree structure.\n   * Propagates remove events to parent components for confirmation dialogs, data cleanup,\n   * and cascading deletions of child nodes when necessary.\n   * \n   * @param event - The tree item remove event containing deleted item data and context\n   */\n  onRemoveItem(event: TreeItemAddRemoveArgs): void {\n    this.removeItem.emit(event);\n  }\n\n  /**\n   * Handles expanded keys changes for two-way binding support with parent components.\n   * Synchronizes internal expanded state with external data binding, enabling\n   * programmatic control of tree expansion and state persistence across component updates.\n   * \n   * @param keys - Array of string keys representing currently expanded tree nodes\n   */\n  onExpandedKeysChange(keys: string[]): void {\n    this.expandedKeys = keys;\n    this.expandedKeysChange.emit(keys);\n  }\n\n  /**\n   * Handles selected keys changes for two-way binding support with parent components.\n   * Synchronizes internal selection state with external data binding, enabling\n   * programmatic control of tree selection and form integration capabilities.\n   * \n   * @param keys - Array of string keys representing currently selected tree nodes\n   */\n  onSelectedKeysChange(keys: string[]): void {\n    this.selectedKeys = keys;\n    this.selectedKeysChange.emit(keys);\n  }\n\n  /**\n   * Handles checked keys changes for two-way binding support with parent components.\n   * Synchronizes internal checkbox state with external data binding, enabling\n   * programmatic control of checkbox selections and form validation integration.\n   * \n   * @param keys - Array of string keys representing currently checked tree nodes\n   */\n  onCheckedKeysChange(keys: string[]): void {\n    this.checkedKeys = keys;\n    this.checkedKeysChange.emit(keys);\n  }\n\n  /**\n   * Handles filter text changes when users type in search fields or apply filtering criteria.\n   * Updates the internal filter state and propagates changes to parent components\n   * for server-side filtering or custom search logic implementation.\n   * \n   * @param filter - The filter string entered by the user for tree node searching\n   */\n  onFilterChange(filter: string): void {\n    this.filter = filter;\n    this.filterChange.emit(filter);\n  }\n\n  /**\n   * Handle load more event\n   */\n  onLoadMore(event: any): void {\n    this.loadMore.emit(event);\n  }\n\n  /**\n   * Handle children loaded event\n   */\n  onChildrenLoaded(event: any): void {\n    this.childrenLoaded.emit(event);\n  }\n\n  // Utility Methods\n\n  /**\n   * Expand all nodes\n   */\n  expandAll(): void {\n    if (this.treeViewElement) {\n      // Implementation depends on Kendo TreeView API\n    }\n  }\n\n  /**\n   * Get item from lookup\n   */\n  itemLookup(index: string): TreeItemLookup | undefined {\n    if (this.treeViewElement) {\n      return this.treeViewElement.itemLookup(index);\n    }\n    return undefined;\n  }\n\n  /**\n   * Log function for debugging events\n   */\n  log(eventName: string, event: any): void {\n    console.log(`${eventName}:`, event);\n  }\n\n  /**\n   * Handle drop event with custom logic\n   */\n  handleDrop(event: any): void {\n    console.log('handleDrop:', event);\n    // Add custom drop handling logic here\n    this.nodeDrop.emit(event);\n  }\n\n  /**\n   * Handle node drag start event\n   */\n  onDragStart(event: any): void {\n    if (!this.dragAndDrop) {\n      event.preventDefault();\n    }\n  }\n}\n","<div [class]=\"getTreeViewClasses()\">\n\n  <div class=\"treeview-panel\">\n\n    <ng-container [ngSwitch]=\"checkable\">\n\n      <kendo-treeview #treeViewElement *ngSwitchCase=\"true\" [children]=\"children\" kendoTreeViewHierarchyBinding\n        kendoTreeViewExpandable [kendoTreeViewCheckable]=\"checkableSettings\" kendoTreeViewDragAndDrop\n        kendoTreeViewDragAndDropEditing [nodes]=\"data\" [textField]=\"textField\" [childrenField]=\"childrenField\"\n        [filterable]=\"filterable\" [expandBy]=\"expandBy\" [(expandedKeys)]=\"expandedKeys\"\n        [expandDisabledNodes]=\"expandDisabledNodes\" (selectionChange)=\"onSelectionChange($event)\"\n        (checkedChange)=\"onCheckedChange($event)\" (expand)=\"onExpand($event)\" (collapse)=\"onCollapse($event)\"\n        (nodeClick)=\"onNodeClick($event)\" (expandedKeysChange)=\"onExpandedKeysChange($event)\"\n        (nodeDragStart)=\"onDragStart($event)\" (nodeDrop)=\"handleDrop($event)\" (addItem)=\"log('addItem', $event)\"\n        (removeItem)=\"log('removeItem', $event)\" (nodeDragEnd)=\"log('nodeDragEnd', $event)\"\n        (nodeDrag)=\"onNodeDrag($event)\" class=\"lib-tree-view__kendo-tree\" [kendoTreeViewSelectable]=\"selectable\"\n        [filter]=\"filter\" [size]=\"size\" [navigable]=\"navigable\" [loadOnDemand]=\"loadOnDemand\" [trackBy]=\"trackBy\"\n        [hasChildren]=\"hasChildren\" [(selectedKeys)]=\"selectedKeys\" (filterChange)=\"onFilterChange($event)\">\n\n        <!-- Custom Node Template -->\n        <ng-template *ngIf=\"nodeTemplate\" kendoTreeViewNodeTemplate let-dataItem=\"dataItem\" let-index=\"index\">\n          <ng-container [ngTemplateOutlet]=\"nodeTemplate\" [ngTemplateOutletContext]=\"{ \n        $implicit: dataItem, \n        dataItem: dataItem, \n        index: index \n      }\">\n          </ng-container>\n        </ng-template>\n\n        <!-- Load More Button Template -->\n        <ng-template *ngIf=\"loadMoreButtonTemplate\" kendoTreeViewLoadMoreButtonTemplate let-dataItem=\"dataItem\">\n          <ng-container [ngTemplateOutlet]=\"loadMoreButtonTemplate\" [ngTemplateOutletContext]=\"{ \n        $implicit: dataItem, \n        dataItem: dataItem \n      }\">\n          </ng-container>\n        </ng-template>\n\n      </kendo-treeview>\n\n      <!-- TreeView without checkable functionality -->\n      <kendo-treeview #treeViewElement *ngSwitchDefault kendoTreeViewHierarchyBinding kendoTreeViewExpandable\n        kendoTreeViewDragAndDrop kendoTreeViewDragAndDropEditing [nodes]=\"data\" [textField]=\"textField\"\n        [childrenField]=\"childrenField\" [filterable]=\"filterable\" [expandBy]=\"expandBy\" [(expandedKeys)]=\"expandedKeys\"\n        [expandDisabledNodes]=\"expandDisabledNodes\" (selectionChange)=\"onSelectionChange($event)\"\n        (checkedChange)=\"onCheckedChange($event)\" (expand)=\"onExpand($event)\" (collapse)=\"onCollapse($event)\"\n        (nodeClick)=\"onNodeClick($event)\" (expandedKeysChange)=\"onExpandedKeysChange($event)\"\n        (nodeDragStart)=\"onDragStart($event)\" (nodeDrag)=\"onNodeDrag($event)\" (nodeDrop)=\"handleDrop($event)\"\n        (addItem)=\"log('addItem', $event)\" (removeItem)=\"log('removeItem', $event)\"\n        (nodeDragEnd)=\"log('nodeDragEnd', $event)\" class=\"lib-tree-view__kendo-tree\"\n        [kendoTreeViewSelectable]=\"selectable\" [size]=\"size\" [navigable]=\"navigable\" [loadOnDemand]=\"loadOnDemand\"\n        [trackBy]=\"trackBy\" [hasChildren]=\"hasChildren\" [(selectedKeys)]=\"selectedKeys\"\n        (filterChange)=\"onFilterChange($event)\">\n\n        <!-- Custom Node Template -->\n        <ng-template *ngIf=\"nodeTemplate\" kendoTreeViewNodeTemplate let-dataItem=\"dataItem\" let-index=\"index\">\n          <ng-container [ngTemplateOutlet]=\"nodeTemplate\" [ngTemplateOutletContext]=\"{ \n        $implicit: dataItem, \n        dataItem: dataItem, \n        index: index \n      }\">\n          </ng-container>\n        </ng-template>\n\n        <!-- Load More Button Template -->\n        <ng-template *ngIf=\"loadMoreButtonTemplate\" kendoTreeViewLoadMoreButtonTemplate let-dataItem=\"dataItem\">\n          <ng-container [ngTemplateOutlet]=\"loadMoreButtonTemplate\" [ngTemplateOutletContext]=\"{ \n        $implicit: dataItem, \n        dataItem: dataItem \n      }\">\n          </ng-container>\n        </ng-template>\n\n      </kendo-treeview>\n    </ng-container>\n\n    <!-- Loading indicator -->\n    <div *ngIf=\"loading\" class=\"lib-tree-view__loading\">\n      <lib-loader size=\"medium\" type=\"pulsing\" themeColor=\"primary\"></lib-loader>\n    </div>\n  </div>\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZS12aWV3LmludGVyZmFjZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zaGFyZWQvc3JjL2xpYi9hdG9tcy90cmVlLXZpZXcvdHJlZS12aWV3LmludGVyZmFjZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogVHJlZVZpZXcgbm9kZSBpbnRlcmZhY2Ugd2l0aCBjb21wcmVoZW5zaXZlIHByb3BlcnRpZXNcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUcmVlVmlld05vZGUge1xuICAvLyBDb3JlIFByb3BlcnRpZXNcbiAgdGV4dDogc3RyaW5nO1xuICB2YWx1ZT86IGFueTtcbiAgaWQ/OiBzdHJpbmcgfCBudW1iZXI7XG5cbiAgLy8gU3RhdGUgUHJvcGVydGllc1xuICBleHBhbmRlZD86IGJvb2xlYW47XG4gIHNlbGVjdGVkPzogYm9vbGVhbjtcbiAgZGlzYWJsZWQ/OiBib29sZWFuO1xuICBjaGVja2VkPzogYm9vbGVhbjtcbiAgdmlzaWJsZT86IGJvb2xlYW47XG5cbiAgLy8gSGllcmFyY2h5IFByb3BlcnRpZXNcbiAgY2hpbGRyZW4/OiBUcmVlVmlld05vZGVbXTtcbiAgcGFyZW50SWQ/OiBzdHJpbmcgfCBudW1iZXI7XG5cbiAgLy8gVmlzdWFsIFByb3BlcnRpZXNcbiAgaWNvbj86IHN0cmluZztcbiAgaWNvbkNsYXNzPzogc3RyaW5nO1xuICBpbWFnZVVybD86IHN0cmluZztcbiAgc3ByaXRlQ3NzQ2xhc3M/OiBzdHJpbmc7XG4gIGNzc0NsYXNzPzogc3RyaW5nO1xuXG4gIC8vIExvYWQgTW9yZSBQcm9wZXJ0aWVzXG4gIGhhc01vcmU/OiBib29sZWFuO1xuICBsb2FkTW9yZVRleHQ/OiBzdHJpbmc7XG5cbiAgLy8gQ3VzdG9tIFByb3BlcnRpZXNcbiAgW2tleTogc3RyaW5nXTogYW55O1xufVxuIl19