@progress-chef/platform-shared-components 0.0.154 → 0.0.155
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.
- package/assets/icons/IconFont.css +6 -3
- package/assets/icons/IconFont.scss +6 -3
- package/assets/icons/IconFont.ttf +0 -0
- package/assets/icons/IconFont.woff +0 -0
- package/assets/icons/IconFont.woff2 +0 -0
- package/esm2022/lib/atoms/atoms.module.mjs +15 -1
- package/esm2022/lib/atoms/drag-and-drop/drag-and-drop.component.mjs +31 -3
- package/esm2022/lib/atoms/markdown-display/markdown-display.component.mjs +39 -0
- package/esm2022/lib/atoms/markdown-display/markdown-display.module.mjs +26 -0
- package/esm2022/lib/atoms/markdown-display/markdown-display.service.mjs +53 -0
- package/esm2022/lib/atoms/tree-list/tree-list.component.mjs +404 -0
- package/esm2022/lib/atoms/tree-list/tree-list.interfaces.mjs +2 -0
- package/esm2022/lib/atoms/tree-list/tree-list.module.mjs +44 -0
- package/esm2022/lib/atoms/tree-view/tree-view.component.mjs +521 -0
- package/esm2022/lib/atoms/tree-view/tree-view.interfaces.mjs +2 -0
- package/esm2022/lib/atoms/tree-view/tree-view.module.mjs +44 -0
- package/esm2022/public-api.mjs +7 -1
- package/fesm2022/progress-chef-platform-shared-components.mjs +1139 -13
- package/fesm2022/progress-chef-platform-shared-components.mjs.map +1 -1
- package/lib/atoms/atoms.module.d.ts +5 -3
- package/lib/atoms/drag-and-drop/drag-and-drop.component.d.ts +10 -1
- package/lib/atoms/markdown-display/markdown-display.component.d.ts +22 -0
- package/lib/atoms/markdown-display/markdown-display.module.d.ts +8 -0
- package/lib/atoms/markdown-display/markdown-display.service.d.ts +23 -0
- package/lib/atoms/tree-list/tree-list.component.d.ts +288 -0
- package/lib/atoms/tree-list/tree-list.interfaces.d.ts +31 -0
- package/lib/atoms/tree-list/tree-list.module.d.ts +13 -0
- package/lib/atoms/tree-view/tree-view.component.d.ts +279 -0
- package/lib/atoms/tree-view/tree-view.interfaces.d.ts +23 -0
- package/lib/atoms/tree-view/tree-view.module.d.ts +13 -0
- package/package.json +2 -1
- 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.17", ngImport: i0, type: TreeViewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
369
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.17", 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.17", 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":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,SAAS,EAA0B,MAAM,eAAe,CAAC;AAC1G,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAc,EAAE,EAAE,MAAM,MAAM,CAAC;AACtC,OAAO,EACL,cAAc,EASf,MAAM,kCAAkC,CAAC;AAC1C,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;;;;AAG7D;;;;;GAKG;AAeH,MAAM,OAAO,iBAAiB;IAd9B;QAqBE;;WAEG;QACM,SAAI,GAAmB,EAAE,CAAC;QAEnC,mBAAmB;QACV,eAAU,GAAY,KAAK,CAAC;QAC5B,eAAU,GAAY,KAAK,CAAC;QAC5B,eAAU,GAAY,KAAK,CAAC;QAC5B,cAAS,GAAY,KAAK,CAAC;QAC3B,gBAAW,GAAY,KAAK,CAAC;QAC7B,eAAU,GAAY,IAAI,CAAC;QAC3B,YAAO,GAAY,KAAK,CAAC;QACzB,YAAO,GAAY,IAAI,CAAC;QACxB,SAAI,GAA0C,QAAQ,CAAC;QAEhE,sBAAsB;QACb,cAAS,GAAW,MAAM,CAAC;QAC3B,kBAAa,GAAW,UAAU,CAAC;QACnC,qBAAgB,GAAW,aAAa,CAAC;QACzC,kBAAa,GAAW,UAAU,CAAC;QACnC,kBAAa,GAAW,UAAU,CAAC;QACnC,kBAAa,GAAW,UAAU,CAAC;QACnC,iBAAY,GAAW,SAAS,CAAC;QACjC,mBAAc,GAAW,WAAW,CAAC;QACrC,cAAS,GAAW,MAAM,CAAC;QAC3B,kBAAa,GAAW,UAAU,CAAC;QACnC,wBAAmB,GAAW,gBAAgB,CAAC;QAExD,0BAA0B;QACjB,iBAAY,GAAa,EAAE,CAAC;QAC5B,aAAQ,GAA8C,EAAE,CAAC,CAAA,yIAAyI;QAClM,iBAAY,GAAa,EAAE,CAAC;QAC5B,iBAAY,GAAa,EAAE,CAAC;QAC5B,gBAAW,GAAa,EAAE,CAAC;QAC3B,wBAAmB,GAAY,KAAK,CAAC;QACrC,iBAAY,GAAY,KAAK,CAAC;QAEvC,yBAAyB;QAChB,gBAAW,GAAY,KAAK,CAAC;QAC7B,kBAAa,GAAY,KAAK,CAAC;QAC/B,0BAAqB,GAAY,KAAK,CAAC;QACvC,iBAAY,GAAY,KAAK,CAAC;QAC9B,iBAAY,GAAY,KAAK,CAAC;QAC9B,6BAAwB,GAAY,KAAK,CAAC;QAC1C,cAAS,GAAc,UAAU,CAAC;QAgBlC,aAAQ,GAAW,CAAC,CAAC;QACrB,iBAAY,GAAY,KAAK,CAAC;QAEvC,YAAY;QACH,WAAM,GAAW,EAAE,CAAC;QAG7B,sBAAsB;QACb,cAAS,GAAY,IAAI,CAAC;QAKnC,eAAe;QACL,oBAAe,GAAG,IAAI,YAAY,EAAO,CAAC;QAC1C,WAAM,GAAG,IAAI,YAAY,EAAO,CAAC;QACjC,aAAQ,GAAG,IAAI,YAAY,EAAO,CAAC;QACnC,kBAAa,GAAG,IAAI,YAAY,EAAO,CAAC;QACxC,cAAS,GAAG,IAAI,YAAY,EAAO,CAAC;QACpC,iBAAY,GAAG,IAAI,YAAY,EAAO,CAAC;QAEjD,uBAAuB;QACb,kBAAa,GAAG,IAAI,YAAY,EAA0B,CAAC;QAC3D,aAAQ,GAAG,IAAI,YAAY,EAAqB,CAAC;QACjD,aAAQ,GAAG,IAAI,YAAY,EAAqB,CAAC;QACjD,gBAAW,GAAG,IAAI,YAAY,EAAqB,CAAC;QACpD,YAAO,GAAG,IAAI,YAAY,EAAyB,CAAC;QACpD,eAAU,GAAG,IAAI,YAAY,EAAyB,CAAC;QAEjE,8CAA8C;QACpC,uBAAkB,GAAG,IAAI,YAAY,EAAY,CAAC;QAClD,uBAAkB,GAAG,IAAI,YAAY,EAAY,CAAC;QAClD,sBAAiB,GAAG,IAAI,YAAY,EAAY,CAAC;QAE3D,gBAAgB;QACN,iBAAY,GAAG,IAAI,YAAY,EAAU,CAAC;QAEpD,mBAAmB;QACT,aAAQ,GAAG,IAAI,YAAY,EAAO,CAAC;QAE7C,0BAA0B;QAChB,mBAAc,GAAG,IAAI,YAAY,EAAO,CAAC;QACnD;;WAEG;QACH,kBAAa,GAAmB,EAAE,CAAC;QAEnC;;WAEG;QACH,iBAAY,GAAmB,EAAE,CAAC;QAqClC;;;;;;;WAOG;QACI,aAAQ,GAAG,CAAC,QAAa,EAAqB,EAAE,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC;QAEzF;;;;;;;WAOG;QACI,gBAAW,GAAG,CAAC,QAAa,EAAW,EAAE,GAAG,OAAO,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,CAAA,CAAC,CAAC,CAAC;KAoP5F;IAzSC;;;;;OAKG;IACH,kBAAkB;QAChB,MAAM,OAAO,GAAG,CAAC,eAAe,CAAC,CAAC;QAElC,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,OAAO,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC;QACzC,CAAC;QAED,OAAO,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC3B,CAAC;IAED;;;;;;OAMG;IACH,IAAW,iBAAiB;QAC1B,OAAO;YACL,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,qBAAqB,EAAE,IAAI,CAAC,qBAAqB;YACjD,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,OAAO,EAAE,IAAI,CAAC,WAAW;YACzB,IAAI,EAAE,IAAI,CAAC,SAAS;YACpB,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,wBAAwB,EAAE,IAAI,CAAC,wBAAwB;SACxD,CAAC;IACJ,CAAC;IAsBD,iBAAiB;IAEjB;;;;;;OAMG;IACH,iBAAiB,CAAC,KAAU;QAC1B,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC3B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC;IAED;;;;;;OAMG;IACH,eAAe,CAAC,KAAU;QACxB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAED;;;;;;OAMG;IACH,QAAQ,CAAC,KAAU;QACjB,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC;YACnB,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC;QAC5C,CAAC;QACD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC1B,CAAC;IAED;;;;;;OAMG;IACH,UAAU,CAAC,KAAU;QACnB,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC;YACnB,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,KAAK,CAAC;QAC7C,CAAC;QACD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;IAED;;;;;;OAMG;IACH,WAAW,CAAC,KAAU;QACpB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC7B,CAAC;IAED;;;;;;OAMG;IACH,cAAc,CAAC,KAAU;QACvB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IAED;;;;;;OAMG;IACH,eAAe,CAAC,KAA6B;QAC3C,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACtB,OAAO;QACT,CAAC;QACD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAED;;;;;;OAMG;IACH,UAAU,CAAC,KAAwB;QACjC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;IAGD;;;;;;OAMG;IACH,aAAa,CAAC,KAAwB;QACpC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;IAED;;;;;;OAMG;IACH,SAAS,CAAC,KAA4B;QACpC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC3B,CAAC;IAED;;;;;;OAMG;IACH,YAAY,CAAC,KAA4B;QACvC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC;IAED;;;;;;OAMG;IACH,oBAAoB,CAAC,IAAc;QACjC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACrC,CAAC;IAED;;;;;;OAMG;IACH,oBAAoB,CAAC,IAAc;QACjC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACrC,CAAC;IAED;;;;;;OAMG;IACH,mBAAmB,CAAC,IAAc;QAChC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC;IAED;;;;;;OAMG;IACH,cAAc,CAAC,MAAc;QAC3B,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACjC,CAAC;IAED;;OAEG;IACH,UAAU,CAAC,KAAU;QACnB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;IAED;;OAEG;IACH,gBAAgB,CAAC,KAAU;QACzB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAClC,CAAC;IAED,kBAAkB;IAElB;;OAEG;IACH,SAAS;QACP,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YACzB,+CAA+C;QACjD,CAAC;IACH,CAAC;IAED;;OAEG;IACH,UAAU,CAAC,KAAa;QACtB,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YACzB,OAAO,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QAChD,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAED;;OAEG;IACH,GAAG,CAAC,SAAiB,EAAE,KAAU;QAC/B,OAAO,CAAC,GAAG,CAAC,GAAG,SAAS,GAAG,EAAE,KAAK,CAAC,CAAC;IACtC,CAAC;IAED;;OAEG;IACH,UAAU,CAAC,KAAU;QACnB,OAAO,CAAC,GAAG,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;QAClC,sCAAsC;QACtC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;IAED;;OAEG;IACH,WAAW,CAAC,KAAU;QACpB,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACtB,KAAK,CAAC,cAAc,EAAE,CAAC;QACzB,CAAC;IACH,CAAC;+GAhaU,iBAAiB;mGAAjB,iBAAiB,opECxC9B,igJAiFA,kPDjDI,YAAY,qjBACZ,cAAc,+8DACd,WAAW,+BAGX,eAAe;;4FAGN,iBAAiB;kBAd7B,SAAS;iCACI,IAAI,YACN,eAAe,WAGhB;wBACP,YAAY;wBACZ,cAAc;wBACd,WAAW;wBACX,eAAe;wBACf,aAAa;wBACb,eAAe;qBAChB;8BAOgD,eAAe;sBAA/D,SAAS;uBAAC,iBAAiB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBAKtC,IAAI;sBAAZ,KAAK;gBAGG,UAAU;sBAAlB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBAGG,SAAS;sBAAjB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBAGG,YAAY;sBAApB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBACG,YAAY;sBAApB,KAAK;gBAGG,WAAW;sBAAnB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,qBAAqB;sBAA7B,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,wBAAwB;sBAAhC,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBAGG,YAAY;sBAApB,KAAK;gBACG,sBAAsB;sBAA9B,KAAK;gBAGG,eAAe;sBAAvB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBAGG,MAAM;sBAAd,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBAGG,SAAS;sBAAjB,KAAK;gBAGG,OAAO;sBAAf,KAAK;gBAGI,eAAe;sBAAxB,MAAM;gBACG,MAAM;sBAAf,MAAM;gBACG,QAAQ;sBAAjB,MAAM;gBACG,aAAa;sBAAtB,MAAM;gBACG,SAAS;sBAAlB,MAAM;gBACG,YAAY;sBAArB,MAAM;gBAGG,aAAa;sBAAtB,MAAM;gBACG,QAAQ;sBAAjB,MAAM;gBACG,QAAQ;sBAAjB,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACG,OAAO;sBAAhB,MAAM;gBACG,UAAU;sBAAnB,MAAM;gBAGG,kBAAkB;sBAA3B,MAAM;gBACG,kBAAkB;sBAA3B,MAAM;gBACG,iBAAiB;sBAA1B,MAAM;gBAGG,YAAY;sBAArB,MAAM;gBAGG,QAAQ;sBAAjB,MAAM;gBAGG,cAAc;sBAAvB,MAAM","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
|