@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.
Files changed (32) 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/atoms.module.mjs +15 -1
  7. package/esm2022/lib/atoms/drag-and-drop/drag-and-drop.component.mjs +31 -3
  8. package/esm2022/lib/atoms/markdown-display/markdown-display.component.mjs +39 -0
  9. package/esm2022/lib/atoms/markdown-display/markdown-display.module.mjs +26 -0
  10. package/esm2022/lib/atoms/markdown-display/markdown-display.service.mjs +53 -0
  11. package/esm2022/lib/atoms/tree-list/tree-list.component.mjs +404 -0
  12. package/esm2022/lib/atoms/tree-list/tree-list.interfaces.mjs +2 -0
  13. package/esm2022/lib/atoms/tree-list/tree-list.module.mjs +44 -0
  14. package/esm2022/lib/atoms/tree-view/tree-view.component.mjs +521 -0
  15. package/esm2022/lib/atoms/tree-view/tree-view.interfaces.mjs +2 -0
  16. package/esm2022/lib/atoms/tree-view/tree-view.module.mjs +44 -0
  17. package/esm2022/public-api.mjs +7 -1
  18. package/fesm2022/progress-chef-platform-shared-components.mjs +1139 -13
  19. package/fesm2022/progress-chef-platform-shared-components.mjs.map +1 -1
  20. package/lib/atoms/atoms.module.d.ts +5 -3
  21. package/lib/atoms/drag-and-drop/drag-and-drop.component.d.ts +10 -1
  22. package/lib/atoms/markdown-display/markdown-display.component.d.ts +22 -0
  23. package/lib/atoms/markdown-display/markdown-display.module.d.ts +8 -0
  24. package/lib/atoms/markdown-display/markdown-display.service.d.ts +23 -0
  25. package/lib/atoms/tree-list/tree-list.component.d.ts +288 -0
  26. package/lib/atoms/tree-list/tree-list.interfaces.d.ts +31 -0
  27. package/lib/atoms/tree-list/tree-list.module.d.ts +13 -0
  28. package/lib/atoms/tree-view/tree-view.component.d.ts +279 -0
  29. package/lib/atoms/tree-view/tree-view.interfaces.d.ts +23 -0
  30. package/lib/atoms/tree-view/tree-view.module.d.ts +13 -0
  31. package/package.json +2 -1
  32. package/public-api.d.ts +6 -0
@@ -0,0 +1,404 @@
1
+ import { Component, Input, Output, EventEmitter, ViewChild } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { TreeListModule } from '@progress/kendo-angular-treelist';
4
+ import { IconsModule } from '@progress/kendo-angular-icons';
5
+ import { ButtonComponent } from '../button/button.component';
6
+ import { IconComponent } from '../icon/icon.component';
7
+ import { LoaderComponent } from '../loader/loader.component';
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "@angular/common";
10
+ import * as i2 from "@progress/kendo-angular-treelist";
11
+ /**
12
+ * Custom TreeList component that wraps Kendo's TreeList with design system styling.
13
+ *
14
+ * This component provides a hierarchical data grid for displaying and editing tabular data.
15
+ * It supports selection, sorting, filtering, editing, and custom column templates.
16
+ */
17
+ export class TreeListComponent {
18
+ constructor() {
19
+ /**
20
+ * The data source for the tree list
21
+ */
22
+ this.data = [];
23
+ /**
24
+ * Column definitions for the tree list
25
+ */
26
+ this.columns = [];
27
+ /**
28
+ * Field name that contains the unique identifier for each node
29
+ */
30
+ this.idField = 'id';
31
+ /**
32
+ * Field name that contains the child nodes array (for hierarchical binding)
33
+ */
34
+ this.childrenField = 'children';
35
+ /**
36
+ * Field name that contains the parent identifier (for flat binding)
37
+ */
38
+ this.parentIdField = 'parentId';
39
+ /**
40
+ * Binding type: 'hierarchy' for nested data with children, 'flat' for parent-child relationship data
41
+ */
42
+ this.bindingType = 'hierarchy';
43
+ /**
44
+ * Enable selection functionality
45
+ */
46
+ this.selectable = false;
47
+ /**
48
+ * Enable sorting functionality
49
+ */
50
+ this.sortable = false;
51
+ /**
52
+ * Enable filtering functionality
53
+ */
54
+ this.filterable = false;
55
+ /**
56
+ * Enable resizing functionality
57
+ */
58
+ this.resizable = false;
59
+ /**
60
+ * Enable reordering functionality
61
+ */
62
+ this.reorderable = false;
63
+ /**
64
+ * Enable editing functionality
65
+ */
66
+ this.editable = false;
67
+ /**
68
+ * Loading state - shows loading indicator when true
69
+ */
70
+ this.loading = false;
71
+ /**
72
+ * Height of the tree list container
73
+ */
74
+ this.height = 'auto';
75
+ /**
76
+ * Enable virtual scrolling
77
+ */
78
+ this.scrollable = true;
79
+ /**
80
+ * Page size for pagination
81
+ */
82
+ this.pageSize = 0;
83
+ /**
84
+ * Enable pagination
85
+ */
86
+ this.pageable = false;
87
+ /**
88
+ * Current sort configuration
89
+ */
90
+ this.sort = [];
91
+ this.selectionChange = new EventEmitter();
92
+ this.expand = new EventEmitter();
93
+ this.collapse = new EventEmitter();
94
+ this.sortChange = new EventEmitter();
95
+ this.filterChange = new EventEmitter();
96
+ this.pageChange = new EventEmitter();
97
+ this.add = new EventEmitter();
98
+ this.edit = new EventEmitter();
99
+ this.cancelEvent = new EventEmitter();
100
+ this.save = new EventEmitter();
101
+ this.remove = new EventEmitter();
102
+ this.cellClick = new EventEmitter();
103
+ this.cellClose = new EventEmitter();
104
+ }
105
+ /**
106
+ * Generates CSS classes for the tree-list container element based on current state.
107
+ * Applies conditional classes for loading state and editing mode to enable appropriate styling.
108
+ *
109
+ * @returns A space-separated string of CSS class names to apply to the container
110
+ */
111
+ getTreeListClasses() {
112
+ const classes = ['lib-tree-list'];
113
+ if (this.loading) {
114
+ classes.push('lib-tree-list--loading');
115
+ }
116
+ if (this.editable) {
117
+ classes.push('lib-tree-list--editable');
118
+ }
119
+ return classes.join(' ');
120
+ }
121
+ /**
122
+ * Handles selection state changes when users select or deselect tree-list rows.
123
+ * Propagates the selection event to parent components for external handling.
124
+ *
125
+ * @param event - The selection change event containing selected items and metadata
126
+ */
127
+ onSelectionChange(event) {
128
+ this.selectionChange.emit(event);
129
+ }
130
+ /**
131
+ * Handles node expansion events when users expand collapsed hierarchical tree nodes.
132
+ * Emits the expand event to notify parent components of the state change for potential data loading.
133
+ *
134
+ * @param event - The expand event containing the expanded node data and index information
135
+ */
136
+ onExpand(event) {
137
+ this.expand.emit(event);
138
+ }
139
+ /**
140
+ * Handles node collapse events when users collapse expanded hierarchical tree nodes.
141
+ * Emits the collapse event to notify parent components of the state change for cleanup or optimization.
142
+ *
143
+ * @param event - The collapse event containing the collapsed node data and index information
144
+ */
145
+ onCollapse(event) {
146
+ this.collapse.emit(event);
147
+ }
148
+ /**
149
+ * Handles column sorting changes when users click on sortable column headers.
150
+ * Updates the internal sort state and propagates the change to parent components for data reordering.
151
+ *
152
+ * @param sort - Array of sort descriptors defining field names and sort directions (asc/desc)
153
+ */
154
+ onSortChange(sort) {
155
+ this.sort = sort;
156
+ this.sortChange.emit(sort);
157
+ }
158
+ /**
159
+ * Handles filter criteria changes when users interact with column filters or search functionality.
160
+ * Propagates filter events to parent components for server-side or client-side data filtering.
161
+ *
162
+ * @param filter - The filter object containing criteria, operators, and field specifications
163
+ */
164
+ onFilterChange(filter) {
165
+ this.filterChange.emit(filter);
166
+ }
167
+ /**
168
+ * Handles pagination navigation when users interact with pager controls.
169
+ * Propagates page change events to parent components for data loading of the requested page.
170
+ *
171
+ * @param event - The page change event containing skip, take, and page size information
172
+ */
173
+ onPageChange(event) {
174
+ this.pageChange.emit(event);
175
+ }
176
+ /**
177
+ * Handles add/create events when users initiate creation of new tree-list items.
178
+ * Propagates the add event to parent components for handling new item creation logic and validation.
179
+ *
180
+ * @param event - The add event containing parent item context and position information for insertion
181
+ */
182
+ onAdd(event) {
183
+ this.add.emit(event);
184
+ }
185
+ /**
186
+ * Handles edit mode activation when users enter editing mode for tree-list items.
187
+ * Propagates the edit event to parent components for setting up edit state and validation rules.
188
+ *
189
+ * @param event - The edit event containing the item data being edited and row context
190
+ */
191
+ onEdit(event) {
192
+ this.edit.emit(event);
193
+ }
194
+ /**
195
+ * Handles edit cancellation when users discard changes and exit editing mode without saving.
196
+ * Propagates the cancel event to parent components for cleanup and restoring original data state.
197
+ *
198
+ * @param event - The cancel event containing the item data that was being edited
199
+ */
200
+ onCancel(event) {
201
+ this.cancelEvent.emit(event);
202
+ }
203
+ /**
204
+ * Handles save operations when users commit changes after editing tree-list items.
205
+ * Propagates the save event to parent components for validation, persistence, and data refresh.
206
+ *
207
+ * @param event - The save event containing the modified item data and original values for comparison
208
+ */
209
+ onSave(event) {
210
+ this.save.emit(event);
211
+ }
212
+ /**
213
+ * Handles delete/removal operations when users confirm deletion of tree-list items.
214
+ * Propagates the remove event to parent components for confirmation dialogs and data deletion.
215
+ *
216
+ * @param event - The remove event containing the item data to be deleted and hierarchical context
217
+ */
218
+ onRemove(event) {
219
+ this.remove.emit(event);
220
+ }
221
+ /**
222
+ * Handles individual cell click events within the tree-list for custom interaction handling.
223
+ * Propagates cell click events to parent components for custom actions, navigation, or cell-specific logic.
224
+ *
225
+ * @param event - The cell click event containing cell data, coordinates, and column information
226
+ */
227
+ onCellClick(event) {
228
+ this.cellClick.emit(event);
229
+ }
230
+ /**
231
+ * Handles cell editor close events when users exit cell editing mode.
232
+ * Propagates cell close events to parent components for cleanup and state management.
233
+ *
234
+ * @param event - The cell close event containing editor state and any pending changes
235
+ */
236
+ onCellClose(event) {
237
+ this.cellClose.emit(event);
238
+ }
239
+ /**
240
+ * Handles edit button clicks from command column or custom templates to initiate item editing.
241
+ * Creates and emits a properly formatted EditEvent to notify parent components of edit intention.
242
+ * This method bridges custom UI elements with the standard Kendo TreeList editing workflow.
243
+ *
244
+ * @param dataItem - The tree-list item data object to be edited
245
+ */
246
+ onEditButtonClick(dataItem) {
247
+ // Emit the edit event to let parent component handle the editing logic
248
+ this.edit.emit({ dataItem });
249
+ }
250
+ /**
251
+ * Handles remove button clicks from command column or custom templates to initiate item deletion.
252
+ * Creates and emits a properly formatted RemoveEvent to notify parent components of deletion request.
253
+ * This method bridges custom UI elements with the standard Kendo TreeList removal workflow.
254
+ *
255
+ * @param dataItem - The tree-list item data object to be deleted
256
+ */
257
+ onRemoveButtonClick(dataItem) {
258
+ // Emit the remove event to let parent component handle the removal logic
259
+ this.remove.emit({ dataItem });
260
+ }
261
+ /**
262
+ * Recursively expands all collapsible nodes in the tree-list hierarchy.
263
+ * Iterates through all top-level data items and uses the Kendo TreeList API to expand each node,
264
+ * which triggers cascading expansion of all child nodes. Safely handles cases where the
265
+ * TreeList element is not yet initialized.
266
+ */
267
+ expandAll() {
268
+ if (this.treeListElement) {
269
+ // TreeList doesn't have expandAll, so we implement custom logic
270
+ this.data.forEach(item => {
271
+ if (this.treeListElement) {
272
+ this.treeListElement.expand(item);
273
+ }
274
+ });
275
+ }
276
+ }
277
+ /**
278
+ * Recursively collapses all expandable nodes in the tree-list hierarchy.
279
+ * Iterates through all top-level data items and uses the Kendo TreeList API to collapse each node,
280
+ * which triggers cascading collapse of all child nodes. Safely handles cases where the
281
+ * TreeList element is not yet initialized.
282
+ */
283
+ collapseAll() {
284
+ if (this.treeListElement) {
285
+ // TreeList doesn't have collapseAll, so we implement custom logic
286
+ this.data.forEach(item => {
287
+ if (this.treeListElement) {
288
+ this.treeListElement.collapse(item);
289
+ }
290
+ });
291
+ }
292
+ }
293
+ /**
294
+ * Provides a tracking function for Angular's ngFor optimization when rendering column definitions.
295
+ * Returns a unique identifier for each column to help Angular efficiently track and update
296
+ * column elements during re-rendering. Falls back to array index if no field property exists.
297
+ *
298
+ * @param index - The array index of the column in the columns collection
299
+ * @param column - The column configuration object containing field and other properties
300
+ * @returns A unique identifier for the column (field name or array index)
301
+ */
302
+ trackByColumn(index, column) {
303
+ return column.field || index;
304
+ }
305
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TreeListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
306
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.17", type: TreeListComponent, isStandalone: true, selector: "lib-tree-list", inputs: { data: "data", columns: "columns", idField: "idField", childrenField: "childrenField", parentIdField: "parentIdField", bindingType: "bindingType", fetchChildren: "fetchChildren", hasChildren: "hasChildren", isExpanded: "isExpanded", selectable: "selectable", sortable: "sortable", filterable: "filterable", resizable: "resizable", reorderable: "reorderable", editable: "editable", loading: "loading", height: "height", scrollable: "scrollable", pageSize: "pageSize", pageable: "pageable", sort: "sort", cellTemplate: "cellTemplate", headerTemplate: "headerTemplate", footerTemplate: "footerTemplate", editTemplate: "editTemplate", commandTemplate: "commandTemplate", noRecordsTemplate: "noRecordsTemplate", loadingTemplate: "loadingTemplate" }, outputs: { selectionChange: "selectionChange", expand: "expand", collapse: "collapse", sortChange: "sortChange", filterChange: "filterChange", pageChange: "pageChange", add: "add", edit: "edit", cancelEvent: "cancelEvent", save: "save", remove: "remove", cellClick: "cellClick", cellClose: "cellClose" }, viewQueries: [{ propertyName: "treeListElement", first: true, predicate: ["treeListElement"], descendants: true }], ngImport: i0, template: "<div [class]=\"getTreeListClasses()\">\n <!-- Enhanced TreeList with Hierarchy Binding -->\n <kendo-treelist *ngIf=\"bindingType === 'hierarchy'\" [kendoTreeListHierarchyBinding]=\"data\"\n [childrenField]=\"childrenField\" [idField]=\"idField\" class=\"lib-tree-list__kendo-treelist\" [selectable]=\"selectable\"\n (selectionChange)=\"onSelectionChange($event)\" [sortable]=\"sortable\" [sort]=\"sort\"\n (sortChange)=\"onSortChange($event)\" [filterable]=\"filterable\" (filterChange)=\"onFilterChange($event)\"\n [pageable]=\"pageable\" [pageSize]=\"pageSize\" (pageChange)=\"onPageChange($event)\" [resizable]=\"resizable\"\n [reorderable]=\"reorderable\" [height]=\"height\" [scrollable]=\"scrollable\" [navigable]=\"editable\"\n (expand)=\"onExpand($event)\" (collapse)=\"onCollapse($event)\" (cellClick)=\"onCellClick($event)\"\n (cellClose)=\"onCellClose($event)\" (add)=\"onAdd($event)\" (edit)=\"onEdit($event)\" (cancel)=\"onCancel($event)\"\n (save)=\"onSave($event)\" (remove)=\"onRemove($event)\" kendoTreeListExpandable [initiallyExpanded]=\"true\"\n kendoTreeListSelectable>\n\n <!-- Dynamic columns with templates -->\n <kendo-treelist-column *ngFor=\"let column of columns; trackBy: trackByColumn; let i = index\" [field]=\"column.field\"\n [title]=\"column.title || column.field\" [width]=\"column.width\" [locked]=\"column.locked\" [hidden]=\"column.hidden\"\n [sortable]=\"column.sortable !== undefined ? column.sortable : sortable\"\n [filterable]=\"column.filterable !== undefined ? column.filterable : filterable\"\n [editable]=\"column.editable !== undefined ? column.editable : editable\" [format]=\"column.format\"\n [expandable]=\"i === 0\">\n\n <!-- Custom cell template -->\n <ng-template *ngIf=\"column.template\" kendoTreeListCellTemplate let-dataItem=\"dataItem\" let-rowIndex=\"rowIndex\"\n let-columnIndex=\"columnIndex\">\n <ng-container [ngTemplateOutlet]=\"column.template\" [ngTemplateOutletContext]=\"{ \n $implicit: dataItem, \n dataItem: dataItem, \n rowIndex: rowIndex, \n columnIndex: columnIndex,\n field: column.field,\n value: dataItem[column.field]\n }\">\n </ng-container>\n </ng-template>\n\n <!-- Custom header template -->\n <ng-template *ngIf=\"column.headerTemplate\" kendoTreeListHeaderTemplate>\n <ng-container [ngTemplateOutlet]=\"column.headerTemplate\" [ngTemplateOutletContext]=\"{ column: column }\">\n </ng-container>\n </ng-template>\n\n <!-- Custom footer template -->\n <ng-template *ngIf=\"column.footerTemplate\" kendoTreeListFooterTemplate>\n <ng-container [ngTemplateOutlet]=\"column.footerTemplate\" [ngTemplateOutletContext]=\"{ column: column }\">\n </ng-container>\n </ng-template>\n\n <!-- Edit template for inline editing -->\n <ng-template *ngIf=\"editable && column.editTemplate\" kendoTreeListEditTemplate let-dataItem=\"dataItem\"\n let-formGroup=\"formGroup\">\n <ng-container [ngTemplateOutlet]=\"column.editTemplate\" [ngTemplateOutletContext]=\"{ \n dataItem: dataItem, \n formGroup: formGroup,\n field: column.field\n }\">\n </ng-container>\n </ng-template>\n </kendo-treelist-column>\n\n <!-- Command column for editing actions -->\n <kendo-treelist-command-column *ngIf=\"editable\" title=\"Actions\" width=\"150\" [locked]=\"false\">\n <ng-template kendoTreeListCellTemplate let-isNew=\"isNew\" let-dataItem=\"dataItem\" let-cellContext=\"cellContext\">\n <lib-button *ngIf=\"!isNew\" label=\"\" iconName=\"edit\" size=\"medium\" fillMode=\"flat\" themeColor=\"primary\"\n [iconButton]=\"true\" (buttonClick)=\"onEditButtonClick(dataItem)\" [attr.aria-label]=\"'Edit ' + dataItem.name\">\n </lib-button>\n <lib-button *ngIf=\"!isNew\" label=\"\" iconName=\"delete\" size=\"medium\" fillMode=\"flat\" themeColor=\"error\"\n [iconButton]=\"true\" (buttonClick)=\"onRemoveButtonClick(dataItem)\"\n [attr.aria-label]=\"'Delete ' + dataItem.name\">\n </lib-button>\n </ng-template>\n </kendo-treelist-command-column>\n </kendo-treelist>\n\n <!-- Enhanced TreeList with Flat Binding -->\n <kendo-treelist *ngIf=\"bindingType === 'flat'\" [kendoTreeListFlatBinding]=\"data\" [parentIdField]=\"parentIdField\"\n [idField]=\"idField\" class=\"lib-tree-list__kendo-treelist\" [selectable]=\"selectable\"\n (selectionChange)=\"onSelectionChange($event)\" [sortable]=\"sortable\" [sort]=\"sort\"\n (sortChange)=\"onSortChange($event)\" [filterable]=\"filterable\" (filterChange)=\"onFilterChange($event)\"\n [pageable]=\"pageable\" [pageSize]=\"pageSize\" (pageChange)=\"onPageChange($event)\" [resizable]=\"resizable\"\n [reorderable]=\"reorderable\" [height]=\"height\" [scrollable]=\"scrollable\" [navigable]=\"editable\"\n (expand)=\"onExpand($event)\" (collapse)=\"onCollapse($event)\" (cellClick)=\"onCellClick($event)\"\n (cellClose)=\"onCellClose($event)\" (add)=\"onAdd($event)\" (edit)=\"onEdit($event)\" (cancel)=\"onCancel($event)\"\n (save)=\"onSave($event)\" (remove)=\"onRemove($event)\">\n\n <!-- Dynamic columns with templates for flat binding -->\n <kendo-treelist-column *ngFor=\"let column of columns; trackBy: trackByColumn; let i = index\" [field]=\"column.field\"\n [title]=\"column.title || column.field\" [width]=\"column.width\" [locked]=\"column.locked\" [hidden]=\"column.hidden\"\n [sortable]=\"column.sortable !== undefined ? column.sortable : sortable\"\n [filterable]=\"column.filterable !== undefined ? column.filterable : filterable\"\n [editable]=\"column.editable !== undefined ? column.editable : editable\" [format]=\"column.format\"\n [expandable]=\"i === 0\">\n\n <!-- Custom cell template -->\n <ng-template *ngIf=\"column.template\" kendoTreeListCellTemplate let-dataItem=\"dataItem\" let-rowIndex=\"rowIndex\"\n let-columnIndex=\"columnIndex\">\n <ng-container [ngTemplateOutlet]=\"column.template\" [ngTemplateOutletContext]=\"{ \n $implicit: dataItem, \n dataItem: dataItem, \n rowIndex: rowIndex, \n columnIndex: columnIndex,\n field: column.field,\n value: dataItem[column.field]\n }\">\n </ng-container>\n </ng-template>\n\n <!-- Custom header template -->\n <ng-template *ngIf=\"column.headerTemplate\" kendoTreeListHeaderTemplate>\n <ng-container [ngTemplateOutlet]=\"column.headerTemplate\" [ngTemplateOutletContext]=\"{ column: column }\">\n </ng-container>\n </ng-template>\n\n <!-- Custom footer template -->\n <ng-template *ngIf=\"column.footerTemplate\" kendoTreeListFooterTemplate>\n <ng-container [ngTemplateOutlet]=\"column.footerTemplate\" [ngTemplateOutletContext]=\"{ column: column }\">\n </ng-container>\n </ng-template>\n\n <!-- Edit template for inline editing -->\n <ng-template *ngIf=\"editable && column.editTemplate\" kendoTreeListEditTemplate let-dataItem=\"dataItem\"\n let-formGroup=\"formGroup\">\n <ng-container [ngTemplateOutlet]=\"column.editTemplate\" [ngTemplateOutletContext]=\"{ \n dataItem: dataItem, \n formGroup: formGroup,\n field: column.field\n }\">\n </ng-container>\n </ng-template>\n </kendo-treelist-column>\n\n <!-- Command column for editing actions -->\n <kendo-treelist-command-column *ngIf=\"editable\" title=\"Actions\" width=\"150\" [locked]=\"false\">\n <ng-template kendoTreeListCellTemplate let-isNew=\"isNew\" let-dataItem=\"dataItem\">\n <lib-button *ngIf=\"!isNew\" label=\"\" iconName=\"edit\" size=\"medium\" fillMode=\"flat\" themeColor=\"primary\"\n [iconButton]=\"true\" (buttonClick)=\"onEditButtonClick(dataItem)\" [attr.aria-label]=\"'Edit ' + dataItem.name\">\n </lib-button>\n <lib-button *ngIf=\"!isNew\" label=\"\" iconName=\"delete\" size=\"medium\" fillMode=\"flat\" themeColor=\"error\"\n [iconButton]=\"true\" (buttonClick)=\"onRemoveButtonClick(dataItem)\"\n [attr.aria-label]=\"'Delete ' + dataItem.name\">\n </lib-button>\n </ng-template>\n </kendo-treelist-command-column>\n </kendo-treelist>\n\n <!-- Loading indicator -->\n <div *ngIf=\"loading\" class=\"lib-tree-list__loading\">\n <lib-loader size=\"medium\" type=\"pulsing\" themeColor=\"primary\"></lib-loader>\n </div>\n</div>\n", styles: [".lib-tree-list{position:relative;width:100%}::ng-deep .k-grid tr{height:50px}::ng-deep .pagination-wrapper{display:flex;width:100%}::ng-deep .pagination-disabled{color:#6c6f72!important;pointer-events:none}::ng-deep .lib-grid-select-all-message-container{height:2rem;display:none;gap:.25rem;justify-content:center;align-items:center;background-color:#eceff5!important;font-family:Inter,sans-serif!important;font-weight:400!important;font-style:normal;font-size:12px!important;line-height:16px!important;letter-spacing:.25px!important}::ng-deep .lib-grid-select-all-message-container .select-all-handler{cursor:pointer}::ng-deep .lib-grid-select-all-message-container .lib-grid-select-all-message{display:flex;gap:.25rem}::ng-deep .lib-grid-select-all-message-container .lib-grid-select-all-message .all-selected-icon{color:#198038}::ng-deep .disabled{cursor:none!important;pointer-events:none;opacity:.5}::ng-deep .lib-grid-select-all-message-show{display:flex!important}::ng-deep .k-grid .k-table-th,::ng-deep .k-grid .k-table-th.k-sorted{font-family:Inter,sans-serif!important;font-weight:600!important;font-style:normal!important;font-size:12px!important;line-height:16px!important;letter-spacing:.25px!important;background-color:#dee6f7!important;border-bottom-color:#ebecec!important;border-bottom-style:solid!important;border-bottom-width:2px!important;border-right:0px!important;border-left:0px!important;cursor:default!important}::ng-deep .k-grid .k-table-th .k-cell-inner,::ng-deep .k-grid .k-table-th.k-sorted .k-cell-inner{padding-right:.5rem;border-right:2px solid #C2D2F3!important}::ng-deep .k-grid .k-table-th .k-cell-inner .k-link,::ng-deep .k-grid .k-table-th.k-sorted .k-cell-inner .k-link{cursor:default!important}::ng-deep .k-grid .k-table-th:focus,::ng-deep .k-grid .k-table-th.k-sorted:focus{box-shadow:none!important}::ng-deep .k-grid .k-table-th.k-sorted{font-family:Inter,sans-serif!important;font-weight:600!important;font-style:normal!important;font-size:12px!important;line-height:16px!important;letter-spacing:.25px!important;background-color:#dee6f7!important}::ng-deep .k-grid tbody>tr:not(.k-detail-row):hover{background-color:#d0dcf5!important}::ng-deep .k-grid .k-table-row.k-selected>.k-table-td{background-color:#c9d7f4!important}::ng-deep .k-grid .k-table-row.k-disabled>.k-table-td{background-color:#fff!important}::ng-deep .k-grid .k-table-td{border-bottom-color:#ebecec!important;border-bottom-style:solid!important;border-bottom-width:1px!important;border-right:0px!important;border-left:0px!important}::ng-deep .k-grid td,::ng-deep .k-grid .k-table-td{white-space:nowrap!important}::ng-deep .k-table-alt-row{background-color:inherit!important}::ng-deep .k-grid .k-table-td{font-family:Inter,sans-serif!important;font-weight:400!important;font-style:normal;font-size:12px!important;line-height:16px!important;letter-spacing:.25px!important}::ng-deep .k-grid-norecords{text-align:center!important;opacity:.4}::ng-deep .k-grid-norecords td{padding:14px 0 14px 24px!important}::ng-deep kendo-pager.k-pager-wrap.k-grid-pager{font-family:Inter,sans-serif!important;font-weight:400!important;font-style:normal!important;font-size:14px!important;line-height:20px!important;letter-spacing:.25px!important}::ng-deep .k-pager{border-style:none!important}::ng-deep .k-input-value-text{overflow:unset!important}::ng-deep .k-grid th.k-header{vertical-align:middle!important;padding-left:16px;padding-right:.5rem}::ng-deep .grid-column,::ng-deep .kebab-column,::ng-deep .delete-column{padding:0!important}::ng-deep .grid-column kendo-button,::ng-deep .kebab-column kendo-button,::ng-deep .delete-column kendo-button{align-items:center!important;justify-content:center!important;display:flex!important}::ng-deep .k-checkbox{width:20px!important;height:20px!important;border-radius:0!important}::ng-deep .k-grid .k-hierarchy-cell,::ng-deep .k-grid .k-hierarchy-col{width:0;display:none}::ng-deep .k-grid .k-detail-row .k-detail-cell{background-color:#f4f8fa!important;padding:16px!important}::ng-deep .delete-icon{color:#dc267f!important;padding-left:12px;cursor:pointer}::ng-deep .remove-tooltip kendo-tooltip.k-tooltip{background-color:#fff;color:#000}::ng-deep .hide-header .k-grid-header{border:0px!important}::ng-deep .k-grouping-header{background-color:#eceff5!important}::ng-deep .k-grid-toolbar{padding:4px 16px!important;height:54px;background-color:#eceff5!important}::ng-deep .k-grid td:not(.kebab-column):not(.expand-column){padding-left:16px!important;padding-right:16px!important}::ng-deep .view-header .k-table-thead tr{height:50px}::ng-deep .hide-header .k-table-thead tr{height:0px;padding:0;display:block}::ng-deep td.kebab-column{display:flex;justify-content:center;align-items:center;height:inherit}::ng-deep .k-grid .k-table-td>.k-checkbox{vertical-align:middle!important}::ng-deep .kebab .k-button,::ng-deep .expand-column .k-button{border:0px}::ng-deep .expand-column{pointer-events:all!important}::ng-deep .expand-column-text{margin-right:32px}::ng-deep .expand-row{display:flex;align-items:center;justify-content:flex-end}::ng-deep .column-cursor-pointer{cursor:pointer}::ng-deep .column-content-nowrap .k-grid .k-table-th,::ng-deep .column-content-nowrap .k-grid td,::ng-deep .column-content-nowrap .k-grid .k-table-td{white-space:nowrap;text-overflow:clip}::ng-deep kendo-grid.k-grid .k-table-alt-row .k-grid-content-sticky,::ng-deep kendo-grid.k-grid .k-grid-row-sticky.k-table-alt-row td,::ng-deep kendo-grid.k-grid .k-grid-row-sticky.k-table-alt-row .k-table-td,::ng-deep .k-master-row.k-table-alt-row .k-grid-content-sticky,::ng-deep .k-master-row.k-table-alt-row .k-grid-row-sticky{background-color:#fff}::ng-deep kendo-grid.k-grid .k-grid-content-sticky:hover,::ng-deep kendo-grid.k-grid .k-grid-content-sticky.k-hover,::ng-deep kendo-grid.k-grid .k-table-row:hover .k-grid-content-sticky{background-color:#d0dcf5!important}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: TreeListModule }, { kind: "component", type: i2.TreeListComponent, selector: "kendo-treelist", inputs: ["aria-label", "data", "pageSize", "height", "rowHeight", "skip", "scrollable", "sort", "trackBy", "filter", "virtualColumns", "filterable", "sortable", "pageable", "navigable", "autoSize", "rowClass", "resizable", "reorderable", "loading", "columnMenu", "hideHeader", "idField", "selectable", "isSelected", "rowReorderable", "columns", "fetchChildren", "hasChildren", "isExpanded"], outputs: ["selectionChange", "filterChange", "pageChange", "sortChange", "dataStateChange", "edit", "cancel", "save", "remove", "add", "cellClose", "cellClick", "pdfExport", "excelExport", "columnResize", "columnReorder", "columnVisibilityChange", "columnLockedChange", "scrollBottom", "contentScroll", "expand", "collapse", "expandStateChange", "rowReorder"], exportAs: ["kendoTreeList"] }, { kind: "directive", type: i2.HierarchyBindingDirective, selector: "[kendoTreeListHierarchyBinding]", inputs: ["childrenField", "kendoTreeListHierarchyBinding"], exportAs: ["kendoTreeListHierarchyBinding"] }, { kind: "directive", type: i2.FlatBindingDirective, selector: "[kendoTreeListFlatBinding]", inputs: ["parentIdField", "idField", "kendoTreeListFlatBinding"], exportAs: ["kendoTreeListFlatBinding"] }, { kind: "directive", type: i2.ExpandableDirective, selector: "[kendoTreeListExpandable]", inputs: ["expandedKeys", "initiallyExpanded", "expandBy"], outputs: ["expandedKeysChange"], exportAs: ["kendoTreeListExpandable"] }, { kind: "directive", type: i2.SelectableDirective, selector: "[kendoTreeListSelectable]", inputs: ["selectable", "selectedItems", "itemKey", "columnKey"], outputs: ["selectedItemsChange"], exportAs: ["kendoTreeListSelectable"] }, { kind: "component", type: i2.ColumnComponent, selector: "kendo-treelist-column", inputs: ["expandable", "field", "format", "sortable", "editor", "filter", "filterable", "editable"] }, { kind: "component", type: i2.CommandColumnComponent, selector: "kendo-treelist-command-column" }, { kind: "directive", type: i2.CellTemplateDirective, selector: "[kendoTreeListCellTemplate]" }, { kind: "directive", type: i2.EditTemplateDirective, selector: "[kendoTreeListEditTemplate]" }, { kind: "directive", type: i2.FooterTemplateDirective, selector: "[kendoTreeListFooterTemplate]" }, { kind: "directive", type: i2.HeaderTemplateDirective, selector: "[kendoTreeListHeaderTemplate]" }, { kind: "ngmodule", type: IconsModule }, { kind: "component", type: ButtonComponent, selector: "lib-button", inputs: ["size", "rounded", "fillMode", "themeColor", "label", "iconName", "disabled", "toggleable", "iconPosition", "fontType", "width", "iconButton", "projectedIcon", "formatFn", "iconFontSize"], outputs: ["buttonClick"] }, { kind: "component", type: LoaderComponent, selector: "lib-loader", inputs: ["size", "type", "themeColor"] }] }); }
307
+ }
308
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TreeListComponent, decorators: [{
309
+ type: Component,
310
+ args: [{ standalone: true, selector: 'lib-tree-list', imports: [
311
+ CommonModule,
312
+ TreeListModule,
313
+ IconsModule,
314
+ ButtonComponent,
315
+ IconComponent,
316
+ LoaderComponent
317
+ ], template: "<div [class]=\"getTreeListClasses()\">\n <!-- Enhanced TreeList with Hierarchy Binding -->\n <kendo-treelist *ngIf=\"bindingType === 'hierarchy'\" [kendoTreeListHierarchyBinding]=\"data\"\n [childrenField]=\"childrenField\" [idField]=\"idField\" class=\"lib-tree-list__kendo-treelist\" [selectable]=\"selectable\"\n (selectionChange)=\"onSelectionChange($event)\" [sortable]=\"sortable\" [sort]=\"sort\"\n (sortChange)=\"onSortChange($event)\" [filterable]=\"filterable\" (filterChange)=\"onFilterChange($event)\"\n [pageable]=\"pageable\" [pageSize]=\"pageSize\" (pageChange)=\"onPageChange($event)\" [resizable]=\"resizable\"\n [reorderable]=\"reorderable\" [height]=\"height\" [scrollable]=\"scrollable\" [navigable]=\"editable\"\n (expand)=\"onExpand($event)\" (collapse)=\"onCollapse($event)\" (cellClick)=\"onCellClick($event)\"\n (cellClose)=\"onCellClose($event)\" (add)=\"onAdd($event)\" (edit)=\"onEdit($event)\" (cancel)=\"onCancel($event)\"\n (save)=\"onSave($event)\" (remove)=\"onRemove($event)\" kendoTreeListExpandable [initiallyExpanded]=\"true\"\n kendoTreeListSelectable>\n\n <!-- Dynamic columns with templates -->\n <kendo-treelist-column *ngFor=\"let column of columns; trackBy: trackByColumn; let i = index\" [field]=\"column.field\"\n [title]=\"column.title || column.field\" [width]=\"column.width\" [locked]=\"column.locked\" [hidden]=\"column.hidden\"\n [sortable]=\"column.sortable !== undefined ? column.sortable : sortable\"\n [filterable]=\"column.filterable !== undefined ? column.filterable : filterable\"\n [editable]=\"column.editable !== undefined ? column.editable : editable\" [format]=\"column.format\"\n [expandable]=\"i === 0\">\n\n <!-- Custom cell template -->\n <ng-template *ngIf=\"column.template\" kendoTreeListCellTemplate let-dataItem=\"dataItem\" let-rowIndex=\"rowIndex\"\n let-columnIndex=\"columnIndex\">\n <ng-container [ngTemplateOutlet]=\"column.template\" [ngTemplateOutletContext]=\"{ \n $implicit: dataItem, \n dataItem: dataItem, \n rowIndex: rowIndex, \n columnIndex: columnIndex,\n field: column.field,\n value: dataItem[column.field]\n }\">\n </ng-container>\n </ng-template>\n\n <!-- Custom header template -->\n <ng-template *ngIf=\"column.headerTemplate\" kendoTreeListHeaderTemplate>\n <ng-container [ngTemplateOutlet]=\"column.headerTemplate\" [ngTemplateOutletContext]=\"{ column: column }\">\n </ng-container>\n </ng-template>\n\n <!-- Custom footer template -->\n <ng-template *ngIf=\"column.footerTemplate\" kendoTreeListFooterTemplate>\n <ng-container [ngTemplateOutlet]=\"column.footerTemplate\" [ngTemplateOutletContext]=\"{ column: column }\">\n </ng-container>\n </ng-template>\n\n <!-- Edit template for inline editing -->\n <ng-template *ngIf=\"editable && column.editTemplate\" kendoTreeListEditTemplate let-dataItem=\"dataItem\"\n let-formGroup=\"formGroup\">\n <ng-container [ngTemplateOutlet]=\"column.editTemplate\" [ngTemplateOutletContext]=\"{ \n dataItem: dataItem, \n formGroup: formGroup,\n field: column.field\n }\">\n </ng-container>\n </ng-template>\n </kendo-treelist-column>\n\n <!-- Command column for editing actions -->\n <kendo-treelist-command-column *ngIf=\"editable\" title=\"Actions\" width=\"150\" [locked]=\"false\">\n <ng-template kendoTreeListCellTemplate let-isNew=\"isNew\" let-dataItem=\"dataItem\" let-cellContext=\"cellContext\">\n <lib-button *ngIf=\"!isNew\" label=\"\" iconName=\"edit\" size=\"medium\" fillMode=\"flat\" themeColor=\"primary\"\n [iconButton]=\"true\" (buttonClick)=\"onEditButtonClick(dataItem)\" [attr.aria-label]=\"'Edit ' + dataItem.name\">\n </lib-button>\n <lib-button *ngIf=\"!isNew\" label=\"\" iconName=\"delete\" size=\"medium\" fillMode=\"flat\" themeColor=\"error\"\n [iconButton]=\"true\" (buttonClick)=\"onRemoveButtonClick(dataItem)\"\n [attr.aria-label]=\"'Delete ' + dataItem.name\">\n </lib-button>\n </ng-template>\n </kendo-treelist-command-column>\n </kendo-treelist>\n\n <!-- Enhanced TreeList with Flat Binding -->\n <kendo-treelist *ngIf=\"bindingType === 'flat'\" [kendoTreeListFlatBinding]=\"data\" [parentIdField]=\"parentIdField\"\n [idField]=\"idField\" class=\"lib-tree-list__kendo-treelist\" [selectable]=\"selectable\"\n (selectionChange)=\"onSelectionChange($event)\" [sortable]=\"sortable\" [sort]=\"sort\"\n (sortChange)=\"onSortChange($event)\" [filterable]=\"filterable\" (filterChange)=\"onFilterChange($event)\"\n [pageable]=\"pageable\" [pageSize]=\"pageSize\" (pageChange)=\"onPageChange($event)\" [resizable]=\"resizable\"\n [reorderable]=\"reorderable\" [height]=\"height\" [scrollable]=\"scrollable\" [navigable]=\"editable\"\n (expand)=\"onExpand($event)\" (collapse)=\"onCollapse($event)\" (cellClick)=\"onCellClick($event)\"\n (cellClose)=\"onCellClose($event)\" (add)=\"onAdd($event)\" (edit)=\"onEdit($event)\" (cancel)=\"onCancel($event)\"\n (save)=\"onSave($event)\" (remove)=\"onRemove($event)\">\n\n <!-- Dynamic columns with templates for flat binding -->\n <kendo-treelist-column *ngFor=\"let column of columns; trackBy: trackByColumn; let i = index\" [field]=\"column.field\"\n [title]=\"column.title || column.field\" [width]=\"column.width\" [locked]=\"column.locked\" [hidden]=\"column.hidden\"\n [sortable]=\"column.sortable !== undefined ? column.sortable : sortable\"\n [filterable]=\"column.filterable !== undefined ? column.filterable : filterable\"\n [editable]=\"column.editable !== undefined ? column.editable : editable\" [format]=\"column.format\"\n [expandable]=\"i === 0\">\n\n <!-- Custom cell template -->\n <ng-template *ngIf=\"column.template\" kendoTreeListCellTemplate let-dataItem=\"dataItem\" let-rowIndex=\"rowIndex\"\n let-columnIndex=\"columnIndex\">\n <ng-container [ngTemplateOutlet]=\"column.template\" [ngTemplateOutletContext]=\"{ \n $implicit: dataItem, \n dataItem: dataItem, \n rowIndex: rowIndex, \n columnIndex: columnIndex,\n field: column.field,\n value: dataItem[column.field]\n }\">\n </ng-container>\n </ng-template>\n\n <!-- Custom header template -->\n <ng-template *ngIf=\"column.headerTemplate\" kendoTreeListHeaderTemplate>\n <ng-container [ngTemplateOutlet]=\"column.headerTemplate\" [ngTemplateOutletContext]=\"{ column: column }\">\n </ng-container>\n </ng-template>\n\n <!-- Custom footer template -->\n <ng-template *ngIf=\"column.footerTemplate\" kendoTreeListFooterTemplate>\n <ng-container [ngTemplateOutlet]=\"column.footerTemplate\" [ngTemplateOutletContext]=\"{ column: column }\">\n </ng-container>\n </ng-template>\n\n <!-- Edit template for inline editing -->\n <ng-template *ngIf=\"editable && column.editTemplate\" kendoTreeListEditTemplate let-dataItem=\"dataItem\"\n let-formGroup=\"formGroup\">\n <ng-container [ngTemplateOutlet]=\"column.editTemplate\" [ngTemplateOutletContext]=\"{ \n dataItem: dataItem, \n formGroup: formGroup,\n field: column.field\n }\">\n </ng-container>\n </ng-template>\n </kendo-treelist-column>\n\n <!-- Command column for editing actions -->\n <kendo-treelist-command-column *ngIf=\"editable\" title=\"Actions\" width=\"150\" [locked]=\"false\">\n <ng-template kendoTreeListCellTemplate let-isNew=\"isNew\" let-dataItem=\"dataItem\">\n <lib-button *ngIf=\"!isNew\" label=\"\" iconName=\"edit\" size=\"medium\" fillMode=\"flat\" themeColor=\"primary\"\n [iconButton]=\"true\" (buttonClick)=\"onEditButtonClick(dataItem)\" [attr.aria-label]=\"'Edit ' + dataItem.name\">\n </lib-button>\n <lib-button *ngIf=\"!isNew\" label=\"\" iconName=\"delete\" size=\"medium\" fillMode=\"flat\" themeColor=\"error\"\n [iconButton]=\"true\" (buttonClick)=\"onRemoveButtonClick(dataItem)\"\n [attr.aria-label]=\"'Delete ' + dataItem.name\">\n </lib-button>\n </ng-template>\n </kendo-treelist-command-column>\n </kendo-treelist>\n\n <!-- Loading indicator -->\n <div *ngIf=\"loading\" class=\"lib-tree-list__loading\">\n <lib-loader size=\"medium\" type=\"pulsing\" themeColor=\"primary\"></lib-loader>\n </div>\n</div>\n", styles: [".lib-tree-list{position:relative;width:100%}::ng-deep .k-grid tr{height:50px}::ng-deep .pagination-wrapper{display:flex;width:100%}::ng-deep .pagination-disabled{color:#6c6f72!important;pointer-events:none}::ng-deep .lib-grid-select-all-message-container{height:2rem;display:none;gap:.25rem;justify-content:center;align-items:center;background-color:#eceff5!important;font-family:Inter,sans-serif!important;font-weight:400!important;font-style:normal;font-size:12px!important;line-height:16px!important;letter-spacing:.25px!important}::ng-deep .lib-grid-select-all-message-container .select-all-handler{cursor:pointer}::ng-deep .lib-grid-select-all-message-container .lib-grid-select-all-message{display:flex;gap:.25rem}::ng-deep .lib-grid-select-all-message-container .lib-grid-select-all-message .all-selected-icon{color:#198038}::ng-deep .disabled{cursor:none!important;pointer-events:none;opacity:.5}::ng-deep .lib-grid-select-all-message-show{display:flex!important}::ng-deep .k-grid .k-table-th,::ng-deep .k-grid .k-table-th.k-sorted{font-family:Inter,sans-serif!important;font-weight:600!important;font-style:normal!important;font-size:12px!important;line-height:16px!important;letter-spacing:.25px!important;background-color:#dee6f7!important;border-bottom-color:#ebecec!important;border-bottom-style:solid!important;border-bottom-width:2px!important;border-right:0px!important;border-left:0px!important;cursor:default!important}::ng-deep .k-grid .k-table-th .k-cell-inner,::ng-deep .k-grid .k-table-th.k-sorted .k-cell-inner{padding-right:.5rem;border-right:2px solid #C2D2F3!important}::ng-deep .k-grid .k-table-th .k-cell-inner .k-link,::ng-deep .k-grid .k-table-th.k-sorted .k-cell-inner .k-link{cursor:default!important}::ng-deep .k-grid .k-table-th:focus,::ng-deep .k-grid .k-table-th.k-sorted:focus{box-shadow:none!important}::ng-deep .k-grid .k-table-th.k-sorted{font-family:Inter,sans-serif!important;font-weight:600!important;font-style:normal!important;font-size:12px!important;line-height:16px!important;letter-spacing:.25px!important;background-color:#dee6f7!important}::ng-deep .k-grid tbody>tr:not(.k-detail-row):hover{background-color:#d0dcf5!important}::ng-deep .k-grid .k-table-row.k-selected>.k-table-td{background-color:#c9d7f4!important}::ng-deep .k-grid .k-table-row.k-disabled>.k-table-td{background-color:#fff!important}::ng-deep .k-grid .k-table-td{border-bottom-color:#ebecec!important;border-bottom-style:solid!important;border-bottom-width:1px!important;border-right:0px!important;border-left:0px!important}::ng-deep .k-grid td,::ng-deep .k-grid .k-table-td{white-space:nowrap!important}::ng-deep .k-table-alt-row{background-color:inherit!important}::ng-deep .k-grid .k-table-td{font-family:Inter,sans-serif!important;font-weight:400!important;font-style:normal;font-size:12px!important;line-height:16px!important;letter-spacing:.25px!important}::ng-deep .k-grid-norecords{text-align:center!important;opacity:.4}::ng-deep .k-grid-norecords td{padding:14px 0 14px 24px!important}::ng-deep kendo-pager.k-pager-wrap.k-grid-pager{font-family:Inter,sans-serif!important;font-weight:400!important;font-style:normal!important;font-size:14px!important;line-height:20px!important;letter-spacing:.25px!important}::ng-deep .k-pager{border-style:none!important}::ng-deep .k-input-value-text{overflow:unset!important}::ng-deep .k-grid th.k-header{vertical-align:middle!important;padding-left:16px;padding-right:.5rem}::ng-deep .grid-column,::ng-deep .kebab-column,::ng-deep .delete-column{padding:0!important}::ng-deep .grid-column kendo-button,::ng-deep .kebab-column kendo-button,::ng-deep .delete-column kendo-button{align-items:center!important;justify-content:center!important;display:flex!important}::ng-deep .k-checkbox{width:20px!important;height:20px!important;border-radius:0!important}::ng-deep .k-grid .k-hierarchy-cell,::ng-deep .k-grid .k-hierarchy-col{width:0;display:none}::ng-deep .k-grid .k-detail-row .k-detail-cell{background-color:#f4f8fa!important;padding:16px!important}::ng-deep .delete-icon{color:#dc267f!important;padding-left:12px;cursor:pointer}::ng-deep .remove-tooltip kendo-tooltip.k-tooltip{background-color:#fff;color:#000}::ng-deep .hide-header .k-grid-header{border:0px!important}::ng-deep .k-grouping-header{background-color:#eceff5!important}::ng-deep .k-grid-toolbar{padding:4px 16px!important;height:54px;background-color:#eceff5!important}::ng-deep .k-grid td:not(.kebab-column):not(.expand-column){padding-left:16px!important;padding-right:16px!important}::ng-deep .view-header .k-table-thead tr{height:50px}::ng-deep .hide-header .k-table-thead tr{height:0px;padding:0;display:block}::ng-deep td.kebab-column{display:flex;justify-content:center;align-items:center;height:inherit}::ng-deep .k-grid .k-table-td>.k-checkbox{vertical-align:middle!important}::ng-deep .kebab .k-button,::ng-deep .expand-column .k-button{border:0px}::ng-deep .expand-column{pointer-events:all!important}::ng-deep .expand-column-text{margin-right:32px}::ng-deep .expand-row{display:flex;align-items:center;justify-content:flex-end}::ng-deep .column-cursor-pointer{cursor:pointer}::ng-deep .column-content-nowrap .k-grid .k-table-th,::ng-deep .column-content-nowrap .k-grid td,::ng-deep .column-content-nowrap .k-grid .k-table-td{white-space:nowrap;text-overflow:clip}::ng-deep kendo-grid.k-grid .k-table-alt-row .k-grid-content-sticky,::ng-deep kendo-grid.k-grid .k-grid-row-sticky.k-table-alt-row td,::ng-deep kendo-grid.k-grid .k-grid-row-sticky.k-table-alt-row .k-table-td,::ng-deep .k-master-row.k-table-alt-row .k-grid-content-sticky,::ng-deep .k-master-row.k-table-alt-row .k-grid-row-sticky{background-color:#fff}::ng-deep kendo-grid.k-grid .k-grid-content-sticky:hover,::ng-deep kendo-grid.k-grid .k-grid-content-sticky.k-hover,::ng-deep kendo-grid.k-grid .k-table-row:hover .k-grid-content-sticky{background-color:#d0dcf5!important}\n"] }]
318
+ }], propDecorators: { treeListElement: [{
319
+ type: ViewChild,
320
+ args: ['treeListElement', { static: false }]
321
+ }], data: [{
322
+ type: Input
323
+ }], columns: [{
324
+ type: Input
325
+ }], idField: [{
326
+ type: Input
327
+ }], childrenField: [{
328
+ type: Input
329
+ }], parentIdField: [{
330
+ type: Input
331
+ }], bindingType: [{
332
+ type: Input
333
+ }], fetchChildren: [{
334
+ type: Input
335
+ }], hasChildren: [{
336
+ type: Input
337
+ }], isExpanded: [{
338
+ type: Input
339
+ }], selectable: [{
340
+ type: Input
341
+ }], sortable: [{
342
+ type: Input
343
+ }], filterable: [{
344
+ type: Input
345
+ }], resizable: [{
346
+ type: Input
347
+ }], reorderable: [{
348
+ type: Input
349
+ }], editable: [{
350
+ type: Input
351
+ }], loading: [{
352
+ type: Input
353
+ }], height: [{
354
+ type: Input
355
+ }], scrollable: [{
356
+ type: Input
357
+ }], pageSize: [{
358
+ type: Input
359
+ }], pageable: [{
360
+ type: Input
361
+ }], sort: [{
362
+ type: Input
363
+ }], cellTemplate: [{
364
+ type: Input
365
+ }], headerTemplate: [{
366
+ type: Input
367
+ }], footerTemplate: [{
368
+ type: Input
369
+ }], editTemplate: [{
370
+ type: Input
371
+ }], commandTemplate: [{
372
+ type: Input
373
+ }], noRecordsTemplate: [{
374
+ type: Input
375
+ }], loadingTemplate: [{
376
+ type: Input
377
+ }], selectionChange: [{
378
+ type: Output
379
+ }], expand: [{
380
+ type: Output
381
+ }], collapse: [{
382
+ type: Output
383
+ }], sortChange: [{
384
+ type: Output
385
+ }], filterChange: [{
386
+ type: Output
387
+ }], pageChange: [{
388
+ type: Output
389
+ }], add: [{
390
+ type: Output
391
+ }], edit: [{
392
+ type: Output
393
+ }], cancelEvent: [{
394
+ type: Output
395
+ }], save: [{
396
+ type: Output
397
+ }], remove: [{
398
+ type: Output
399
+ }], cellClick: [{
400
+ type: Output
401
+ }], cellClose: [{
402
+ type: Output
403
+ }] } });
404
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree-list.component.js","sourceRoot":"","sources":["../../../../../../projects/shared/src/lib/atoms/tree-list/tree-list.component.ts","../../../../../../projects/shared/src/lib/atoms/tree-list/tree-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, ViewChild } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport {\n  TreeListModule,\n  TreeListComponent as KendoTreeListComponent,\n  AddEvent,\n  CancelEvent,\n  EditEvent,\n  RemoveEvent,\n  SaveEvent,\n  PageChangeEvent\n} from '@progress/kendo-angular-treelist';\nimport { SortDescriptor } from '@progress/kendo-data-query';\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 { TreeListNode, TreeListColumn } from './tree-list.interfaces';\n\n/**\n * Custom TreeList component that wraps Kendo's TreeList with design system styling.\n * \n * This component provides a hierarchical data grid for displaying and editing tabular data.\n * It supports selection, sorting, filtering, editing, and custom column templates.\n */\n@Component({\n  standalone: true,\n  selector: 'lib-tree-list',\n  templateUrl: './tree-list.component.html',\n  styleUrls: ['./tree-list.component.scss'],\n  imports: [\n    CommonModule,\n    TreeListModule,\n    IconsModule,\n    ButtonComponent,\n    IconComponent,\n    LoaderComponent\n  ]\n})\nexport class TreeListComponent {\n  /**\n   * ViewChild reference to the Kendo TreeList component instance\n   */\n  @ViewChild('treeListElement', { static: false }) treeListElement!: KendoTreeListComponent;\n\n  /**\n   * The data source for the tree list\n   */\n  @Input() data: TreeListNode[] = [];\n\n  /**\n   * Column definitions for the tree list\n   */\n  @Input() columns: TreeListColumn[] = [];\n\n  /**\n   * Field name that contains the unique identifier for each node\n   */\n  @Input() idField: string = 'id';\n\n  /**\n   * Field name that contains the child nodes array (for hierarchical binding)\n   */\n  @Input() childrenField: string = 'children';\n\n  /**\n   * Field name that contains the parent identifier (for flat binding)\n   */\n  @Input() parentIdField: string = 'parentId';\n\n  /**\n   * Binding type: 'hierarchy' for nested data with children, 'flat' for parent-child relationship data\n   */\n  @Input() bindingType: 'hierarchy' | 'flat' = 'hierarchy';\n\n  /**\n   * Callback function that retrieves child nodes for a particular node (for manual binding)\n   */\n  @Input() fetchChildren: ((item: any) => any[]) | undefined;\n\n  /**\n   * Callback function that determines if a particular node has children (for manual binding)\n   */\n  @Input() hasChildren: ((item: any) => boolean) | undefined;\n\n  /**\n   * Callback function that determines if a particular node is expanded (for manual binding)\n   */\n  @Input() isExpanded: ((item: any) => boolean) | undefined;\n\n  /**\n   * Enable selection functionality\n   */\n  @Input() selectable: boolean = false;\n\n  /**\n   * Enable sorting functionality\n   */\n  @Input() sortable: boolean = false;\n\n  /**\n   * Enable filtering functionality\n   */\n  @Input() filterable: boolean = false;\n\n  /**\n   * Enable resizing functionality\n   */\n  @Input() resizable: boolean = false;\n\n  /**\n   * Enable reordering functionality\n   */\n  @Input() reorderable: boolean = false;\n\n  /**\n   * Enable editing functionality\n   */\n  @Input() editable: boolean = false;\n\n  /**\n   * Loading state - shows loading indicator when true\n   */\n  @Input() loading: boolean = false;\n\n  /**\n   * Height of the tree list container\n   */\n  @Input() height: number | string = 'auto';\n\n  /**\n   * Enable virtual scrolling\n   */\n  @Input() scrollable: boolean = true;\n\n  /**\n   * Page size for pagination\n   */\n  @Input() pageSize: number = 0;\n\n  /**\n   * Enable pagination\n   */\n  @Input() pageable: boolean = false;\n\n  /**\n   * Current sort configuration\n   */\n  @Input() sort: SortDescriptor[] = [];\n\n  /**\n   * Custom cell template\n   */\n  @Input() cellTemplate?: any;\n\n  /**\n   * Custom header template\n   */\n  @Input() headerTemplate?: any;\n\n  /**\n   * Custom footer template\n   */\n  @Input() footerTemplate?: any;\n\n  /**\n   * Custom edit template\n   */\n  @Input() editTemplate?: any;\n\n  /**\n   * Custom command column template\n   */\n  @Input() commandTemplate?: any;\n\n  /**\n   * Custom no records template\n   */\n  @Input() noRecordsTemplate?: any;\n\n  /**\n   * Custom loading template\n   */\n  @Input() loadingTemplate?: any;\n\n\n\n  @Output() selectionChange = new EventEmitter<any>();\n  @Output() expand = new EventEmitter<{ dataItem: TreeListNode; index: string }>();\n  @Output() collapse = new EventEmitter<{ dataItem: TreeListNode; index: string }>();\n  @Output() sortChange = new EventEmitter<SortDescriptor[]>();\n  @Output() filterChange = new EventEmitter<any>();\n  @Output() pageChange = new EventEmitter<PageChangeEvent>();\n  @Output() add = new EventEmitter<AddEvent>();\n  @Output() edit = new EventEmitter<EditEvent>();\n  @Output() cancelEvent = new EventEmitter<CancelEvent>();\n  @Output() save = new EventEmitter<SaveEvent>();\n  @Output() remove = new EventEmitter<RemoveEvent>();\n\n  @Output() cellClick = new EventEmitter<any>();\n  @Output() cellClose = new EventEmitter<any>();\n\n  /**\n   * Generates CSS classes for the tree-list container element based on current state.\n   * Applies conditional classes for loading state and editing mode to enable appropriate styling.\n   * \n   * @returns A space-separated string of CSS class names to apply to the container\n   */\n  getTreeListClasses(): string {\n    const classes = ['lib-tree-list'];\n\n    if (this.loading) {\n      classes.push('lib-tree-list--loading');\n    }\n\n    if (this.editable) {\n      classes.push('lib-tree-list--editable');\n    }\n\n    return classes.join(' ');\n  }\n\n  /**\n   * Handles selection state changes when users select or deselect tree-list rows.\n   * Propagates the selection event to parent components for external handling.\n   * \n   * @param event - The selection change event containing selected items and metadata\n   */\n  onSelectionChange(event: any): void {\n    this.selectionChange.emit(event);\n  }\n\n  /**\n   * Handles node expansion events when users expand collapsed hierarchical tree nodes.\n   * Emits the expand event to notify parent components of the state change for potential data loading.\n   * \n   * @param event - The expand event containing the expanded node data and index information\n   */\n  onExpand(event: any): void {\n    this.expand.emit(event);\n  }\n\n  /**\n   * Handles node collapse events when users collapse expanded hierarchical tree nodes.\n   * Emits the collapse event to notify parent components of the state change for cleanup or optimization.\n   * \n   * @param event - The collapse event containing the collapsed node data and index information\n   */\n  onCollapse(event: any): void {\n    this.collapse.emit(event);\n  }\n\n  /**\n   * Handles column sorting changes when users click on sortable column headers.\n   * Updates the internal sort state and propagates the change to parent components for data reordering.\n   * \n   * @param sort - Array of sort descriptors defining field names and sort directions (asc/desc)\n   */\n  onSortChange(sort: SortDescriptor[]): void {\n    this.sort = sort;\n    this.sortChange.emit(sort);\n  }\n\n  /**\n   * Handles filter criteria changes when users interact with column filters or search functionality.\n   * Propagates filter events to parent components for server-side or client-side data filtering.\n   * \n   * @param filter - The filter object containing criteria, operators, and field specifications\n   */\n  onFilterChange(filter: any): void {\n    this.filterChange.emit(filter);\n  }\n\n  /**\n   * Handles pagination navigation when users interact with pager controls.\n   * Propagates page change events to parent components for data loading of the requested page.\n   * \n   * @param event - The page change event containing skip, take, and page size information\n   */\n  onPageChange(event: PageChangeEvent): void {\n    this.pageChange.emit(event);\n  }\n\n  /**\n   * Handles add/create events when users initiate creation of new tree-list items.\n   * Propagates the add event to parent components for handling new item creation logic and validation.\n   * \n   * @param event - The add event containing parent item context and position information for insertion\n   */\n  onAdd(event: AddEvent): void {\n    this.add.emit(event);\n  }\n\n  /**\n   * Handles edit mode activation when users enter editing mode for tree-list items.\n   * Propagates the edit event to parent components for setting up edit state and validation rules.\n   * \n   * @param event - The edit event containing the item data being edited and row context\n   */\n  onEdit(event: EditEvent): void {\n    this.edit.emit(event);\n  }\n\n  /**\n   * Handles edit cancellation when users discard changes and exit editing mode without saving.\n   * Propagates the cancel event to parent components for cleanup and restoring original data state.\n   * \n   * @param event - The cancel event containing the item data that was being edited\n   */\n  onCancel(event: CancelEvent): void {\n    this.cancelEvent.emit(event);\n  }\n\n  /**\n   * Handles save operations when users commit changes after editing tree-list items.\n   * Propagates the save event to parent components for validation, persistence, and data refresh.\n   * \n   * @param event - The save event containing the modified item data and original values for comparison\n   */\n  onSave(event: SaveEvent): void {\n    this.save.emit(event);\n  }\n\n  /**\n   * Handles delete/removal operations when users confirm deletion of tree-list items.\n   * Propagates the remove event to parent components for confirmation dialogs and data deletion.\n   * \n   * @param event - The remove event containing the item data to be deleted and hierarchical context\n   */\n  onRemove(event: RemoveEvent): void {\n    this.remove.emit(event);\n  }\n\n  /**\n   * Handles individual cell click events within the tree-list for custom interaction handling.\n   * Propagates cell click events to parent components for custom actions, navigation, or cell-specific logic.\n   * \n   * @param event - The cell click event containing cell data, coordinates, and column information\n   */\n  onCellClick(event: any): void {\n    this.cellClick.emit(event);\n  }\n\n  /**\n   * Handles cell editor close events when users exit cell editing mode.\n   * Propagates cell close events to parent components for cleanup and state management.\n   * \n   * @param event - The cell close event containing editor state and any pending changes\n   */\n  onCellClose(event: any): void {\n    this.cellClose.emit(event);\n  }\n\n  /**\n   * Handles edit button clicks from command column or custom templates to initiate item editing.\n   * Creates and emits a properly formatted EditEvent to notify parent components of edit intention.\n   * This method bridges custom UI elements with the standard Kendo TreeList editing workflow.\n   * \n   * @param dataItem - The tree-list item data object to be edited\n   */\n  onEditButtonClick(dataItem: any): void {\n    // Emit the edit event to let parent component handle the editing logic\n    this.edit.emit({ dataItem } as EditEvent);\n  }\n\n  /**\n   * Handles remove button clicks from command column or custom templates to initiate item deletion.\n   * Creates and emits a properly formatted RemoveEvent to notify parent components of deletion request.\n   * This method bridges custom UI elements with the standard Kendo TreeList removal workflow.\n   * \n   * @param dataItem - The tree-list item data object to be deleted\n   */\n  onRemoveButtonClick(dataItem: any): void {\n    // Emit the remove event to let parent component handle the removal logic\n    this.remove.emit({ dataItem } as RemoveEvent);\n  }\n\n  /**\n   * Recursively expands all collapsible nodes in the tree-list hierarchy.\n   * Iterates through all top-level data items and uses the Kendo TreeList API to expand each node,\n   * which triggers cascading expansion of all child nodes. Safely handles cases where the\n   * TreeList element is not yet initialized.\n   */\n  expandAll(): void {\n    if (this.treeListElement) {\n      // TreeList doesn't have expandAll, so we implement custom logic\n      this.data.forEach(item => {\n        if (this.treeListElement) {\n          this.treeListElement.expand(item);\n        }\n      });\n    }\n  }\n\n  /**\n   * Recursively collapses all expandable nodes in the tree-list hierarchy.\n   * Iterates through all top-level data items and uses the Kendo TreeList API to collapse each node,\n   * which triggers cascading collapse of all child nodes. Safely handles cases where the\n   * TreeList element is not yet initialized.\n   */\n  collapseAll(): void {\n    if (this.treeListElement) {\n      // TreeList doesn't have collapseAll, so we implement custom logic\n      this.data.forEach(item => {\n        if (this.treeListElement) {\n          this.treeListElement.collapse(item);\n        }\n      });\n    }\n  }\n\n  /**\n   * Provides a tracking function for Angular's ngFor optimization when rendering column definitions.\n   * Returns a unique identifier for each column to help Angular efficiently track and update\n   * column elements during re-rendering. Falls back to array index if no field property exists.\n   * \n   * @param index - The array index of the column in the columns collection\n   * @param column - The column configuration object containing field and other properties\n   * @returns A unique identifier for the column (field name or array index)\n   */\n  trackByColumn(index: number, column: TreeListColumn): any {\n    return column.field || index;\n  }\n}\n","<div [class]=\"getTreeListClasses()\">\n  <!-- Enhanced TreeList with Hierarchy Binding -->\n  <kendo-treelist *ngIf=\"bindingType === 'hierarchy'\" [kendoTreeListHierarchyBinding]=\"data\"\n    [childrenField]=\"childrenField\" [idField]=\"idField\" class=\"lib-tree-list__kendo-treelist\" [selectable]=\"selectable\"\n    (selectionChange)=\"onSelectionChange($event)\" [sortable]=\"sortable\" [sort]=\"sort\"\n    (sortChange)=\"onSortChange($event)\" [filterable]=\"filterable\" (filterChange)=\"onFilterChange($event)\"\n    [pageable]=\"pageable\" [pageSize]=\"pageSize\" (pageChange)=\"onPageChange($event)\" [resizable]=\"resizable\"\n    [reorderable]=\"reorderable\" [height]=\"height\" [scrollable]=\"scrollable\" [navigable]=\"editable\"\n    (expand)=\"onExpand($event)\" (collapse)=\"onCollapse($event)\" (cellClick)=\"onCellClick($event)\"\n    (cellClose)=\"onCellClose($event)\" (add)=\"onAdd($event)\" (edit)=\"onEdit($event)\" (cancel)=\"onCancel($event)\"\n    (save)=\"onSave($event)\" (remove)=\"onRemove($event)\" kendoTreeListExpandable [initiallyExpanded]=\"true\"\n    kendoTreeListSelectable>\n\n    <!-- Dynamic columns with templates -->\n    <kendo-treelist-column *ngFor=\"let column of columns; trackBy: trackByColumn; let i = index\" [field]=\"column.field\"\n      [title]=\"column.title || column.field\" [width]=\"column.width\" [locked]=\"column.locked\" [hidden]=\"column.hidden\"\n      [sortable]=\"column.sortable !== undefined ? column.sortable : sortable\"\n      [filterable]=\"column.filterable !== undefined ? column.filterable : filterable\"\n      [editable]=\"column.editable !== undefined ? column.editable : editable\" [format]=\"column.format\"\n      [expandable]=\"i === 0\">\n\n      <!-- Custom cell template -->\n      <ng-template *ngIf=\"column.template\" kendoTreeListCellTemplate let-dataItem=\"dataItem\" let-rowIndex=\"rowIndex\"\n        let-columnIndex=\"columnIndex\">\n        <ng-container [ngTemplateOutlet]=\"column.template\" [ngTemplateOutletContext]=\"{ \n            $implicit: dataItem, \n            dataItem: dataItem, \n            rowIndex: rowIndex, \n            columnIndex: columnIndex,\n            field: column.field,\n            value: dataItem[column.field]\n          }\">\n        </ng-container>\n      </ng-template>\n\n      <!-- Custom header template -->\n      <ng-template *ngIf=\"column.headerTemplate\" kendoTreeListHeaderTemplate>\n        <ng-container [ngTemplateOutlet]=\"column.headerTemplate\" [ngTemplateOutletContext]=\"{ column: column }\">\n        </ng-container>\n      </ng-template>\n\n      <!-- Custom footer template -->\n      <ng-template *ngIf=\"column.footerTemplate\" kendoTreeListFooterTemplate>\n        <ng-container [ngTemplateOutlet]=\"column.footerTemplate\" [ngTemplateOutletContext]=\"{ column: column }\">\n        </ng-container>\n      </ng-template>\n\n      <!-- Edit template for inline editing -->\n      <ng-template *ngIf=\"editable && column.editTemplate\" kendoTreeListEditTemplate let-dataItem=\"dataItem\"\n        let-formGroup=\"formGroup\">\n        <ng-container [ngTemplateOutlet]=\"column.editTemplate\" [ngTemplateOutletContext]=\"{ \n            dataItem: dataItem, \n            formGroup: formGroup,\n            field: column.field\n          }\">\n        </ng-container>\n      </ng-template>\n    </kendo-treelist-column>\n\n    <!-- Command column for editing actions -->\n    <kendo-treelist-command-column *ngIf=\"editable\" title=\"Actions\" width=\"150\" [locked]=\"false\">\n      <ng-template kendoTreeListCellTemplate let-isNew=\"isNew\" let-dataItem=\"dataItem\" let-cellContext=\"cellContext\">\n        <lib-button *ngIf=\"!isNew\" label=\"\" iconName=\"edit\" size=\"medium\" fillMode=\"flat\" themeColor=\"primary\"\n          [iconButton]=\"true\" (buttonClick)=\"onEditButtonClick(dataItem)\" [attr.aria-label]=\"'Edit ' + dataItem.name\">\n        </lib-button>\n        <lib-button *ngIf=\"!isNew\" label=\"\" iconName=\"delete\" size=\"medium\" fillMode=\"flat\" themeColor=\"error\"\n          [iconButton]=\"true\" (buttonClick)=\"onRemoveButtonClick(dataItem)\"\n          [attr.aria-label]=\"'Delete ' + dataItem.name\">\n        </lib-button>\n      </ng-template>\n    </kendo-treelist-command-column>\n  </kendo-treelist>\n\n  <!-- Enhanced TreeList with Flat Binding -->\n  <kendo-treelist *ngIf=\"bindingType === 'flat'\" [kendoTreeListFlatBinding]=\"data\" [parentIdField]=\"parentIdField\"\n    [idField]=\"idField\" class=\"lib-tree-list__kendo-treelist\" [selectable]=\"selectable\"\n    (selectionChange)=\"onSelectionChange($event)\" [sortable]=\"sortable\" [sort]=\"sort\"\n    (sortChange)=\"onSortChange($event)\" [filterable]=\"filterable\" (filterChange)=\"onFilterChange($event)\"\n    [pageable]=\"pageable\" [pageSize]=\"pageSize\" (pageChange)=\"onPageChange($event)\" [resizable]=\"resizable\"\n    [reorderable]=\"reorderable\" [height]=\"height\" [scrollable]=\"scrollable\" [navigable]=\"editable\"\n    (expand)=\"onExpand($event)\" (collapse)=\"onCollapse($event)\" (cellClick)=\"onCellClick($event)\"\n    (cellClose)=\"onCellClose($event)\" (add)=\"onAdd($event)\" (edit)=\"onEdit($event)\" (cancel)=\"onCancel($event)\"\n    (save)=\"onSave($event)\" (remove)=\"onRemove($event)\">\n\n    <!-- Dynamic columns with templates for flat binding -->\n    <kendo-treelist-column *ngFor=\"let column of columns; trackBy: trackByColumn; let i = index\" [field]=\"column.field\"\n      [title]=\"column.title || column.field\" [width]=\"column.width\" [locked]=\"column.locked\" [hidden]=\"column.hidden\"\n      [sortable]=\"column.sortable !== undefined ? column.sortable : sortable\"\n      [filterable]=\"column.filterable !== undefined ? column.filterable : filterable\"\n      [editable]=\"column.editable !== undefined ? column.editable : editable\" [format]=\"column.format\"\n      [expandable]=\"i === 0\">\n\n      <!-- Custom cell template -->\n      <ng-template *ngIf=\"column.template\" kendoTreeListCellTemplate let-dataItem=\"dataItem\" let-rowIndex=\"rowIndex\"\n        let-columnIndex=\"columnIndex\">\n        <ng-container [ngTemplateOutlet]=\"column.template\" [ngTemplateOutletContext]=\"{ \n            $implicit: dataItem, \n            dataItem: dataItem, \n            rowIndex: rowIndex, \n            columnIndex: columnIndex,\n            field: column.field,\n            value: dataItem[column.field]\n          }\">\n        </ng-container>\n      </ng-template>\n\n      <!-- Custom header template -->\n      <ng-template *ngIf=\"column.headerTemplate\" kendoTreeListHeaderTemplate>\n        <ng-container [ngTemplateOutlet]=\"column.headerTemplate\" [ngTemplateOutletContext]=\"{ column: column }\">\n        </ng-container>\n      </ng-template>\n\n      <!-- Custom footer template -->\n      <ng-template *ngIf=\"column.footerTemplate\" kendoTreeListFooterTemplate>\n        <ng-container [ngTemplateOutlet]=\"column.footerTemplate\" [ngTemplateOutletContext]=\"{ column: column }\">\n        </ng-container>\n      </ng-template>\n\n      <!-- Edit template for inline editing -->\n      <ng-template *ngIf=\"editable && column.editTemplate\" kendoTreeListEditTemplate let-dataItem=\"dataItem\"\n        let-formGroup=\"formGroup\">\n        <ng-container [ngTemplateOutlet]=\"column.editTemplate\" [ngTemplateOutletContext]=\"{ \n            dataItem: dataItem, \n            formGroup: formGroup,\n            field: column.field\n          }\">\n        </ng-container>\n      </ng-template>\n    </kendo-treelist-column>\n\n    <!-- Command column for editing actions -->\n    <kendo-treelist-command-column *ngIf=\"editable\" title=\"Actions\" width=\"150\" [locked]=\"false\">\n      <ng-template kendoTreeListCellTemplate let-isNew=\"isNew\" let-dataItem=\"dataItem\">\n        <lib-button *ngIf=\"!isNew\" label=\"\" iconName=\"edit\" size=\"medium\" fillMode=\"flat\" themeColor=\"primary\"\n          [iconButton]=\"true\" (buttonClick)=\"onEditButtonClick(dataItem)\" [attr.aria-label]=\"'Edit ' + dataItem.name\">\n        </lib-button>\n        <lib-button *ngIf=\"!isNew\" label=\"\" iconName=\"delete\" size=\"medium\" fillMode=\"flat\" themeColor=\"error\"\n          [iconButton]=\"true\" (buttonClick)=\"onRemoveButtonClick(dataItem)\"\n          [attr.aria-label]=\"'Delete ' + dataItem.name\">\n        </lib-button>\n      </ng-template>\n    </kendo-treelist-command-column>\n  </kendo-treelist>\n\n  <!-- Loading indicator -->\n  <div *ngIf=\"loading\" class=\"lib-tree-list__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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZS1saXN0LmludGVyZmFjZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zaGFyZWQvc3JjL2xpYi9hdG9tcy90cmVlLWxpc3QvdHJlZS1saXN0LmludGVyZmFjZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogVHJlZUxpc3Qgbm9kZSBpbnRlcmZhY2VcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUcmVlTGlzdE5vZGUge1xuICBba2V5OiBzdHJpbmddOiBhbnk7XG4gIGlkPzogYW55O1xuICBwYXJlbnRJZD86IGFueTtcbiAgZXhwYW5kZWQ/OiBib29sZWFuO1xuICBoYXNDaGlsZHJlbj86IGJvb2xlYW47XG4gIGNoaWxkcmVuPzogVHJlZUxpc3ROb2RlW107XG59XG5cbi8qKlxuICogQ29sdW1uIGNvbmZpZ3VyYXRpb24gaW50ZXJmYWNlXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVHJlZUxpc3RDb2x1bW4ge1xuICBmaWVsZDogc3RyaW5nO1xuICB0aXRsZT86IHN0cmluZztcbiAgd2lkdGg/OiBudW1iZXIgfCBzdHJpbmc7XG4gIG1pbldpZHRoPzogbnVtYmVyO1xuICBtYXhXaWR0aD86IG51bWJlcjtcbiAgbG9ja2VkPzogYm9vbGVhbjtcbiAgaGlkZGVuPzogYm9vbGVhbjtcbiAgc29ydGFibGU/OiBib29sZWFuO1xuICBmaWx0ZXJhYmxlPzogYm9vbGVhbjtcbiAgZWRpdGFibGU/OiBib29sZWFuO1xuICBmb3JtYXQ/OiBzdHJpbmc7XG4gIHRlbXBsYXRlPzogYW55O1xuICBoZWFkZXJUZW1wbGF0ZT86IGFueTtcbiAgZm9vdGVyVGVtcGxhdGU/OiBhbnk7XG4gIFtrZXk6IHN0cmluZ106IGFueTtcbn1cbiJdfQ==
@@ -0,0 +1,44 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { TreeListComponent } from './tree-list.component';
4
+ import { TreeListModule as KendoTreeListModule } from '@progress/kendo-angular-treelist';
5
+ import { IconsModule } from '@progress/kendo-angular-icons';
6
+ import { ButtonModule } from '../button/button.module';
7
+ import { IconModule } from '../icon/icon.module';
8
+ import { LoaderModule } from '../loader/loader.module';
9
+ import * as i0 from "@angular/core";
10
+ export class TreeListModule {
11
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TreeListModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
12
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "19.2.17", ngImport: i0, type: TreeListModule, imports: [TreeListComponent,
13
+ CommonModule,
14
+ KendoTreeListModule,
15
+ IconsModule,
16
+ ButtonModule,
17
+ IconModule,
18
+ LoaderModule], exports: [TreeListComponent] }); }
19
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TreeListModule, imports: [TreeListComponent,
20
+ CommonModule,
21
+ KendoTreeListModule,
22
+ IconsModule,
23
+ ButtonModule,
24
+ IconModule,
25
+ LoaderModule] }); }
26
+ }
27
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: TreeListModule, decorators: [{
28
+ type: NgModule,
29
+ args: [{
30
+ imports: [
31
+ TreeListComponent,
32
+ CommonModule,
33
+ KendoTreeListModule,
34
+ IconsModule,
35
+ ButtonModule,
36
+ IconModule,
37
+ LoaderModule
38
+ ],
39
+ exports: [
40
+ TreeListComponent
41
+ ]
42
+ }]
43
+ }] });
44
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZS1saXN0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3NoYXJlZC9zcmMvbGliL2F0b21zL3RyZWUtbGlzdC90cmVlLWxpc3QubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzFELE9BQU8sRUFBRSxjQUFjLElBQUksbUJBQW1CLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUN6RixPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDNUQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUNqRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0seUJBQXlCLENBQUM7O0FBZ0J2RCxNQUFNLE9BQU8sY0FBYzsrR0FBZCxjQUFjO2dIQUFkLGNBQWMsWUFadkIsaUJBQWlCO1lBQ2pCLFlBQVk7WUFDWixtQkFBbUI7WUFDbkIsV0FBVztZQUNYLFlBQVk7WUFDWixVQUFVO1lBQ1YsWUFBWSxhQUdaLGlCQUFpQjtnSEFHUixjQUFjLFlBWnZCLGlCQUFpQjtZQUNqQixZQUFZO1lBQ1osbUJBQW1CO1lBQ25CLFdBQVc7WUFDWCxZQUFZO1lBQ1osVUFBVTtZQUNWLFlBQVk7OzRGQU1ILGNBQWM7a0JBZDFCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFO3dCQUNQLGlCQUFpQjt3QkFDakIsWUFBWTt3QkFDWixtQkFBbUI7d0JBQ25CLFdBQVc7d0JBQ1gsWUFBWTt3QkFDWixVQUFVO3dCQUNWLFlBQVk7cUJBQ2I7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLGlCQUFpQjtxQkFDbEI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IFRyZWVMaXN0Q29tcG9uZW50IH0gZnJvbSAnLi90cmVlLWxpc3QuY29tcG9uZW50JztcbmltcG9ydCB7IFRyZWVMaXN0TW9kdWxlIGFzIEtlbmRvVHJlZUxpc3RNb2R1bGUgfSBmcm9tICdAcHJvZ3Jlc3Mva2VuZG8tYW5ndWxhci10cmVlbGlzdCc7XG5pbXBvcnQgeyBJY29uc01vZHVsZSB9IGZyb20gJ0Bwcm9ncmVzcy9rZW5kby1hbmd1bGFyLWljb25zJztcbmltcG9ydCB7IEJ1dHRvbk1vZHVsZSB9IGZyb20gJy4uL2J1dHRvbi9idXR0b24ubW9kdWxlJztcbmltcG9ydCB7IEljb25Nb2R1bGUgfSBmcm9tICcuLi9pY29uL2ljb24ubW9kdWxlJztcbmltcG9ydCB7IExvYWRlck1vZHVsZSB9IGZyb20gJy4uL2xvYWRlci9sb2FkZXIubW9kdWxlJztcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIFRyZWVMaXN0Q29tcG9uZW50LFxuICAgIENvbW1vbk1vZHVsZSxcbiAgICBLZW5kb1RyZWVMaXN0TW9kdWxlLFxuICAgIEljb25zTW9kdWxlLFxuICAgIEJ1dHRvbk1vZHVsZSxcbiAgICBJY29uTW9kdWxlLFxuICAgIExvYWRlck1vZHVsZVxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgVHJlZUxpc3RDb21wb25lbnRcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBUcmVlTGlzdE1vZHVsZSB7IH1cbiJdfQ==