cps-ui-kit 18.11.0 → 19.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (85) hide show
  1. package/fesm2022/cps-ui-kit.mjs +347 -307
  2. package/fesm2022/cps-ui-kit.mjs.map +1 -1
  3. package/lib/components/cps-autocomplete/cps-autocomplete.component.d.ts +2 -2
  4. package/lib/components/cps-menu/cps-menu.component.d.ts +4 -3
  5. package/lib/components/cps-select/cps-select.component.d.ts +2 -2
  6. package/lib/components/cps-tree-table/cps-tree-table.component.d.ts +25 -1
  7. package/lib/services/cps-dialog/internal/components/cps-dialog/cps-dialog.component.d.ts +3 -3
  8. package/lib/services/cps-notification/internal/components/cps-notification-container/cps-notification-container.component.d.ts +3 -3
  9. package/package.json +6 -8
  10. package/styles/styles.scss +9 -0
  11. package/esm2022/cps-ui-kit.mjs +0 -5
  12. package/esm2022/lib/components/cps-autocomplete/cps-autocomplete.component.mjs +0 -948
  13. package/esm2022/lib/components/cps-button/cps-button.component.mjs +0 -205
  14. package/esm2022/lib/components/cps-button-toggle/cps-button-toggle.component.mjs +0 -239
  15. package/esm2022/lib/components/cps-checkbox/cps-checkbox.component.mjs +0 -154
  16. package/esm2022/lib/components/cps-chip/cps-chip.component.mjs +0 -94
  17. package/esm2022/lib/components/cps-datepicker/cps-datepicker.component.mjs +0 -382
  18. package/esm2022/lib/components/cps-divider/cps-divider.component.mjs +0 -60
  19. package/esm2022/lib/components/cps-expansion-panel/cps-expansion-panel.component.mjs +0 -213
  20. package/esm2022/lib/components/cps-file-upload/cps-file-upload.component.mjs +0 -182
  21. package/esm2022/lib/components/cps-icon/cps-icon.component.mjs +0 -203
  22. package/esm2022/lib/components/cps-info-circle/cps-info-circle.component.mjs +0 -61
  23. package/esm2022/lib/components/cps-input/cps-input.component.mjs +0 -385
  24. package/esm2022/lib/components/cps-loader/cps-loader.component.mjs +0 -58
  25. package/esm2022/lib/components/cps-menu/cps-menu.component.mjs +0 -572
  26. package/esm2022/lib/components/cps-paginator/cps-paginator.component.mjs +0 -118
  27. package/esm2022/lib/components/cps-paginator/pipes/cps-paginate.pipe.mjs +0 -30
  28. package/esm2022/lib/components/cps-progress-circular/cps-progress-circular.component.mjs +0 -51
  29. package/esm2022/lib/components/cps-progress-linear/cps-progress-linear.component.mjs +0 -75
  30. package/esm2022/lib/components/cps-radio-group/cps-radio/cps-radio.component.mjs +0 -42
  31. package/esm2022/lib/components/cps-radio-group/cps-radio-button/cps-radio-button.component.mjs +0 -77
  32. package/esm2022/lib/components/cps-radio-group/cps-radio-group.component.mjs +0 -225
  33. package/esm2022/lib/components/cps-scheduler/cps-scheduler.component.mjs +0 -682
  34. package/esm2022/lib/components/cps-scheduler/cps-scheduler.utils.mjs +0 -604
  35. package/esm2022/lib/components/cps-select/cps-select.component.mjs +0 -654
  36. package/esm2022/lib/components/cps-sidebar-menu/cps-sidebar-menu.component.mjs +0 -110
  37. package/esm2022/lib/components/cps-switch/cps-switch.component.mjs +0 -131
  38. package/esm2022/lib/components/cps-tab-group/cps-tab/cps-tab.component.mjs +0 -86
  39. package/esm2022/lib/components/cps-tab-group/cps-tab-group.component.mjs +0 -308
  40. package/esm2022/lib/components/cps-table/components/internal/cps-sort-icon/cps-sort-icon.component.mjs +0 -79
  41. package/esm2022/lib/components/cps-table/components/internal/table-column-filter/table-column-filter.component.mjs +0 -407
  42. package/esm2022/lib/components/cps-table/components/internal/table-column-filter-constraint/table-column-filter-constraint.component.mjs +0 -147
  43. package/esm2022/lib/components/cps-table/components/internal/table-row-menu/table-row-menu.component.mjs +0 -105
  44. package/esm2022/lib/components/cps-table/cps-column-filter-types.mjs +0 -29
  45. package/esm2022/lib/components/cps-table/cps-table.component.mjs +0 -1022
  46. package/esm2022/lib/components/cps-table/directives/cps-table-column-filter.directive.mjs +0 -181
  47. package/esm2022/lib/components/cps-table/directives/cps-table-column-resizable.directive.mjs +0 -22
  48. package/esm2022/lib/components/cps-table/directives/cps-table-column-sortable.directive.mjs +0 -47
  49. package/esm2022/lib/components/cps-table/directives/cps-table-header-selectable.directive.mjs +0 -32
  50. package/esm2022/lib/components/cps-table/directives/cps-table-row-selectable.directive.mjs +0 -35
  51. package/esm2022/lib/components/cps-table/directives/internal/table-unsort.directive.mjs +0 -212
  52. package/esm2022/lib/components/cps-table/pipes/cps-table-detect-filter-type.pipe.mjs +0 -29
  53. package/esm2022/lib/components/cps-tag/cps-tag.component.mjs +0 -121
  54. package/esm2022/lib/components/cps-textarea/cps-textarea.component.mjs +0 -290
  55. package/esm2022/lib/components/cps-timepicker/cps-timepicker.component.mjs +0 -370
  56. package/esm2022/lib/components/cps-tree-autocomplete/cps-tree-autocomplete.component.mjs +0 -273
  57. package/esm2022/lib/components/cps-tree-select/cps-tree-select.component.mjs +0 -87
  58. package/esm2022/lib/components/cps-tree-table/cps-tree-table.component.mjs +0 -1279
  59. package/esm2022/lib/components/cps-tree-table/directives/cps-tree-table-column-filter.directive.mjs +0 -174
  60. package/esm2022/lib/components/cps-tree-table/directives/cps-tree-table-column-resizable.directive.mjs +0 -22
  61. package/esm2022/lib/components/cps-tree-table/directives/cps-tree-table-column-sortable.directive.mjs +0 -47
  62. package/esm2022/lib/components/cps-tree-table/directives/cps-tree-table-header-selectable.directive.mjs +0 -33
  63. package/esm2022/lib/components/cps-tree-table/directives/cps-tree-table-row-selectable.directive.mjs +0 -36
  64. package/esm2022/lib/components/cps-tree-table/directives/cps-tree-table-row-toggler.directive.mjs +0 -48
  65. package/esm2022/lib/components/cps-tree-table/directives/internal/tree-table-unsort.directive.mjs +0 -352
  66. package/esm2022/lib/components/cps-tree-table/pipes/cps-tree-table-detect-filter-type.pipe.mjs +0 -30
  67. package/esm2022/lib/components/internal/cps-base-tree-dropdown/cps-base-tree-dropdown.component.mjs +0 -656
  68. package/esm2022/lib/directives/cps-tooltip/cps-tooltip.directive.mjs +0 -275
  69. package/esm2022/lib/pipes/internal/check-option-selected.pipe.mjs +0 -24
  70. package/esm2022/lib/pipes/internal/combine-labels.pipe.mjs +0 -25
  71. package/esm2022/lib/pipes/internal/label-by-value.pipe.mjs +0 -16
  72. package/esm2022/lib/services/cps-dialog/cps-dialog.service.mjs +0 -146
  73. package/esm2022/lib/services/cps-dialog/internal/components/cps-confirmation/cps-confirmation.component.mjs +0 -25
  74. package/esm2022/lib/services/cps-dialog/internal/components/cps-dialog/cps-dialog.component.mjs +0 -470
  75. package/esm2022/lib/services/cps-dialog/internal/directives/cps-dialog-content.directive.mjs +0 -18
  76. package/esm2022/lib/services/cps-dialog/utils/cps-dialog-config.mjs +0 -3
  77. package/esm2022/lib/services/cps-dialog/utils/cps-dialog-ref.mjs +0 -128
  78. package/esm2022/lib/services/cps-notification/cps-notification.service.mjs +0 -122
  79. package/esm2022/lib/services/cps-notification/internal/components/cps-notification-container/cps-notification-container.component.mjs +0 -95
  80. package/esm2022/lib/services/cps-notification/internal/components/cps-toast/cps-toast.component.mjs +0 -106
  81. package/esm2022/lib/services/cps-notification/utils/cps-notification-config.mjs +0 -27
  82. package/esm2022/lib/services/cps-notification/utils/internal/cps-notification-data.mjs +0 -12
  83. package/esm2022/lib/utils/colors-utils.mjs +0 -59
  84. package/esm2022/lib/utils/internal/size-utils.mjs +0 -24
  85. package/esm2022/public-api.mjs +0 -58
@@ -1,1279 +0,0 @@
1
- import { ChangeDetectionStrategy, Component, ContentChild, EventEmitter, Inject, Input, Output, RendererStyleFlags2, ViewChild } from '@angular/core';
2
- import { CommonModule, DOCUMENT } from '@angular/common';
3
- import { FormsModule } from '@angular/forms';
4
- import { TreeTable, TreeTableService, TreeTableModule } from 'primeng/treetable';
5
- import { DomHandler } from 'primeng/dom';
6
- import { AngleDoubleLeftIcon } from 'primeng/icons/angledoubleleft';
7
- import { AngleLeftIcon } from 'primeng/icons/angleleft';
8
- import { AngleRightIcon } from 'primeng/icons/angleright';
9
- import { AngleDoubleRightIcon } from 'primeng/icons/angledoubleright';
10
- import { cloneDeep, isEqual } from 'lodash-es';
11
- import { CpsInputComponent } from '../cps-input/cps-input.component';
12
- import { CpsButtonComponent } from '../cps-button/cps-button.component';
13
- import { CpsMenuComponent } from '../cps-menu/cps-menu.component';
14
- import { CpsIconComponent } from '../cps-icon/cps-icon.component';
15
- import { CpsSelectComponent } from '../cps-select/cps-select.component';
16
- import { CpsLoaderComponent } from '../cps-loader/cps-loader.component';
17
- import { CpsTreeTableColumnSortableDirective } from './directives/cps-tree-table-column-sortable.directive';
18
- import { TreeTableUnsortDirective } from './directives/internal/tree-table-unsort.directive';
19
- import { TableRowMenuComponent } from '../cps-table/components/internal/table-row-menu/table-row-menu.component';
20
- import { convertSize } from '../../utils/internal/size-utils';
21
- import { CpsTreeTableHeaderSelectableDirective } from './directives/cps-tree-table-header-selectable.directive';
22
- import { CpsTreeTableRowSelectableDirective } from './directives/cps-tree-table-row-selectable.directive';
23
- import { CpsTreetableRowTogglerDirective } from './directives/cps-tree-table-row-toggler.directive';
24
- import { fromEvent } from 'rxjs';
25
- import { CpsTreeTableColumnFilterDirective } from './directives/cps-tree-table-column-filter.directive';
26
- import { CpsTreeTableDetectFilterTypePipe } from './pipes/cps-tree-table-detect-filter-type.pipe';
27
- import { CpsTreeTableColumnResizableDirective } from './directives/cps-tree-table-column-resizable.directive';
28
- import * as i0 from "@angular/core";
29
- import * as i1 from "@angular/forms";
30
- import * as i2 from "@angular/common";
31
- import * as i3 from "primeng/treetable";
32
- import * as i4 from "primeng/api";
33
- export function treeTableFactory(tableComponent) {
34
- return tableComponent.primengTreeTable;
35
- }
36
- /**
37
- * CpsTreeTableComponent is used to display hierarchical data in tabular format.
38
- * @group Components
39
- */
40
- export class CpsTreeTableComponent {
41
- /**
42
- * An array of objects to display.
43
- * @default []
44
- * @group Props
45
- */
46
- set data(value) {
47
- const clone = cloneDeep(value);
48
- if (clone && clone.length > 0) {
49
- let i = 0;
50
- clone.forEach((v) => {
51
- v._defaultSortOrder = i++;
52
- });
53
- }
54
- this._data = clone;
55
- }
56
- get data() {
57
- return this._data;
58
- }
59
- // eslint-disable-next-line no-useless-constructor
60
- constructor(cdRef, document, renderer, ngZone) {
61
- this.cdRef = cdRef;
62
- this.document = document;
63
- this.renderer = renderer;
64
- this.ngZone = ngZone;
65
- /**
66
- * An array of objects to represent dynamic columns.
67
- * @group Props
68
- */
69
- this.columns = [];
70
- /**
71
- * A key used to retrieve the header from columns.
72
- * @group Props
73
- */
74
- this.colHeaderName = 'header';
75
- /**
76
- * A key used to retrieve the field from columns.
77
- * @group Props
78
- */
79
- this.colFieldName = 'field';
80
- /**
81
- * A key used to retrieve the filter type from columns.
82
- * @group Props
83
- */
84
- this.colFilterTypeName = 'filterType';
85
- /**
86
- * A key used to retrieve the date format from columns.
87
- * @group Props
88
- */
89
- this.colDateFormatName = 'dateFormat';
90
- /**
91
- * Treetable min width of type number denoting pixels or string.
92
- * @group Props
93
- */
94
- this.minWidth = '';
95
- /**
96
- * Determines whether minWidth prop is used for treetable body only, excluding toolbar and paginator.
97
- * @group Props
98
- */
99
- this.minWidthForBodyOnly = true;
100
- /**
101
- * Determines whether the cell widths scale according to their content or not.
102
- * @group Props
103
- */
104
- this.autoLayout = true;
105
- /**
106
- * Determines whether the treetable should have alternating stripes.
107
- * @group Props
108
- */
109
- this.striped = true;
110
- /**
111
- * Determines whether the treetable should have borders.
112
- * @group Props
113
- */
114
- this.bordered = true;
115
- /**
116
- * Size of treetable cells, it can be "small", "normal" or "large".
117
- * @group Props
118
- */
119
- this.size = 'normal';
120
- /**
121
- * Determines whether the treetable should have row selection.
122
- * @group Props
123
- */
124
- this.selectable = false;
125
- /**
126
- * Determines whether the treetable should have rows highlighting on hover.
127
- * @group Props
128
- */
129
- this.rowHover = true;
130
- /**
131
- * Determines whether the treetable should show row menus.
132
- * @group Props
133
- */
134
- this.showRowMenu = false;
135
- /**
136
- * Determines whether the 'Remove' button should be displayed in the row menu.
137
- * Note: This setting only takes effect if 'showRowMenu' is true and 'rowMenuItems' is not set.
138
- * @group Props
139
- */
140
- this.showRowRemoveButton = true;
141
- /**
142
- * Determines whether the 'Edit' button should be displayed in the row menu.
143
- * Note: This setting only takes effect if 'showRowMenu' is true and 'rowMenuItems' is not set.
144
- * @group Props
145
- */
146
- this.showRowEditButton = true;
147
- /**
148
- * When enabled, a loader component is displayed.
149
- * @group Props
150
- */
151
- this.loading = false;
152
- /**
153
- * Inline style of the treetable.
154
- * @group Props
155
- */
156
- this.tableStyle = undefined;
157
- /**
158
- * Style class of the treetable.
159
- * @group Props
160
- */
161
- this.tableStyleClass = '';
162
- /**
163
- * Makes all columns sortable if columns prop is provided.
164
- * @group Props
165
- */
166
- this.sortable = false;
167
- /**
168
- * Determines whether sorting works on single column or on multiple columns.
169
- * @group Props
170
- */
171
- this.sortMode = 'single';
172
- /**
173
- * Determines whether to use the default sorting or a custom one using sortFunction.
174
- * @group Props
175
- */
176
- this.customSort = false;
177
- /**
178
- * Determines whether the treetable has a toolbar.
179
- * @group Props
180
- */
181
- this.hasToolbar = true;
182
- /**
183
- * Toolbar size, it can be "small" or "normal".
184
- * @group Props
185
- */
186
- this.toolbarSize = 'normal';
187
- /**
188
- * Toolbar title.
189
- * @group Props
190
- */
191
- this.toolbarTitle = '';
192
- /**
193
- * Toolbar icon name.
194
- * @group Props
195
- */
196
- this.toolbarIcon = '';
197
- /**
198
- * Toolbar icon color.
199
- * @group Props
200
- */
201
- this.toolbarIconColor = '';
202
- /**
203
- * Makes treetable scrollable.
204
- * @group Props
205
- */
206
- this.scrollable = true;
207
- /**
208
- * Height of the scroll viewport in fixed pixels or the "flex" keyword for a dynamic size.
209
- * @group Props
210
- */
211
- this.scrollHeight = '';
212
- /**
213
- * Determines whether only the elements within scrollable area should be added into the DOM. Works only if scrollable prop is true.
214
- * @group Props
215
- */
216
- this.virtualScroll = false;
217
- /**
218
- * Height of a virtual scroll item in fixed pixels.
219
- * @group Props
220
- */
221
- this.virtualScrollItemHeight = 0;
222
- /**
223
- * Determines how many additional elements to add to the DOM outside of the view.
224
- * @group Props
225
- */
226
- this.numToleratedItems = 10;
227
- /**
228
- * Determines whether the treetable should have paginator.
229
- * @group Props
230
- */
231
- this.paginator = false;
232
- /**
233
- * Determines whether to show paginator even there is only one page.
234
- * @group Props
235
- */
236
- this.alwaysShowPaginator = true;
237
- /**
238
- * Array of integer values to display inside rows per page dropdown of paginator.
239
- * @group Props
240
- */
241
- this.rowsPerPageOptions = [];
242
- /**
243
- * Index of the first row to be displayed.
244
- * @group Props
245
- */
246
- this.first = 0;
247
- /**
248
- * Number of rows to display per page.
249
- * @group Props
250
- */
251
- this.rows = 0;
252
- /**
253
- * Determines whether to reset page on rows change.
254
- * @group Props
255
- */
256
- this.resetPageOnRowsChange = false;
257
- /**
258
- * Determines whether to reset page on treetable data sorting.
259
- * @group Props
260
- */
261
- this.resetPageOnSort = true;
262
- /**
263
- * Number of total records.
264
- * @group Props
265
- */
266
- this.totalRecords = 0;
267
- /**
268
- * Text to display when there is no data.
269
- * @group Props
270
- */
271
- this.emptyMessage = 'No data';
272
- /**
273
- * Height of treetable's body when there is no data, of type number denoting pixels or string.
274
- * @group Props
275
- */
276
- this.emptyBodyHeight = '';
277
- /**
278
- * Defines if data is loaded and interacted with in lazy manner.
279
- * @group Props
280
- */
281
- this.lazy = false;
282
- /**
283
- * Determines whether to call lazy loading on initialization.
284
- * @group Props
285
- */
286
- this.lazyLoadOnInit = true;
287
- /**
288
- * Determines whether to show global filter in the toolbar.
289
- * @group Props
290
- */
291
- this.showGlobalFilter = false;
292
- /**
293
- * Global filter placeholder.
294
- * @group Props
295
- */
296
- this.globalFilterPlaceholder = 'Search';
297
- /**
298
- * An array of fields to use in global filtering.
299
- * @group Props
300
- */
301
- this.globalFilterFields = [];
302
- /**
303
- * Determines whether to clear global filter on data loading.
304
- * @group Props
305
- */
306
- this.clearGlobalFilterOnLoading = false;
307
- /**
308
- * Determines whether to show remove button in the toolbar when rows are selected.
309
- * @group Props
310
- */
311
- this.showRemoveBtnOnSelect = true;
312
- /**
313
- * Determines whether removeBtnOnSelect is disabled.
314
- * @group Props
315
- */
316
- this.removeBtnOnSelectDisabled = false;
317
- /**
318
- * Determines whether to show additional button in the toolbar when rows are selected.
319
- * @group Props
320
- */
321
- this.showAdditionalBtnOnSelect = false;
322
- /**
323
- * AdditionalBtnOnSelect title.
324
- * @group Props
325
- */
326
- this.additionalBtnOnSelectTitle = 'Select action';
327
- /**
328
- * AdditionalBtnOnSelect icon.
329
- * @group Props
330
- */
331
- this.additionalBtnOnSelectIcon = '';
332
- /**
333
- * Determines whether additionalBtnOnSelect is disabled.
334
- * @group Props
335
- */
336
- this.additionalBtnOnSelectDisabled = false;
337
- /**
338
- * Determines whether to show action button in the toolbar.
339
- * @group Props
340
- */
341
- this.showActionBtn = false;
342
- /**
343
- * Action button title.
344
- * @group Props
345
- */
346
- this.actionBtnTitle = 'Action';
347
- /**
348
- * Action button icon.
349
- * @group Props
350
- */
351
- this.actionBtnIcon = '';
352
- /**
353
- * Determines whether actionBtn is disabled.
354
- * @group Props
355
- */
356
- this.actionBtnDisabled = false;
357
- /**
358
- * Determines whether to show data reload button in the toolbar.
359
- * @group Props
360
- */
361
- this.showDataReloadBtn = false;
362
- /**
363
- * Determines whether dataReloadBtn is disabled.
364
- * @group Props
365
- */
366
- this.dataReloadBtnDisabled = false;
367
- /**
368
- * Determines whether the treetable should show columnsToggle menu, where you can choose which columns to be displayed. If external body template is provided, use columnsSelected event emitter.
369
- * @group Props
370
- */
371
- this.showColumnsToggleBtn = false;
372
- /**
373
- * Determines whether columnsToggle button is disabled.
374
- * @group Props
375
- */
376
- this.columnsToggleBtnDisabled = false;
377
- /**
378
- * Array of initial columns to show in the treetable. If not provided, all columns are initially visible.
379
- * @group Props
380
- */
381
- this.initialColumns = [];
382
- /**
383
- * Enable filtering on all columns.
384
- * @group Props
385
- */
386
- this.filterableByColumns = false;
387
- /**
388
- * If true, automatically detects filter type based on values, otherwise sets 'text' filter type for all columns.
389
- * Note: This setting only takes effect if 'filterableByColumns' is true.
390
- * @group Props
391
- */
392
- this.autoColumnFilterType = true;
393
- /**
394
- * If set to true, row data are rendered using innerHTML.
395
- * @group Props
396
- */
397
- this.renderDataAsHTML = false;
398
- /**
399
- * Determines whether columns are resizable.
400
- * In case of using a custom template for columns, it is also needed to add cpsTTColResizable directive to th elements.
401
- * @group Props
402
- */
403
- this.resizableColumns = false;
404
- /**
405
- * Determines how the columns are resized. It can be 'fit' (total width of the table stays the same) or 'expand' (total width of the table changes when resizing columns).
406
- * Note: This setting only takes effect if 'resizableColumns' is true.
407
- *
408
- * @group Props
409
- */
410
- this.columnResizeMode = 'fit';
411
- /**
412
- * Callback to invoke on selected rows change.
413
- * @param {any[]} any[] - selected rows.
414
- * @group Emits
415
- */
416
- this.rowsSelected = new EventEmitter();
417
- /**
418
- * Callback to invoke when action button is clicked.
419
- * @param {void} void - action button clicked.
420
- * @group Emits
421
- */
422
- this.actionBtnClicked = new EventEmitter();
423
- /**
424
- * Callback to invoke when additional button on select is clicked.
425
- * @param {any[]} any[] - selected data.
426
- * @group Emits
427
- */
428
- this.additionalBtnOnSelectClicked = new EventEmitter();
429
- /**
430
- * Callback to invoke when edit-row button is clicked.
431
- * @param {any} any - button clicked.
432
- * @group Emits
433
- */
434
- this.editRowBtnClicked = new EventEmitter();
435
- /**
436
- * Callback to invoke when rows are removed.
437
- * @param {any[]} any[] - array of rows to remove.
438
- * @group Emits
439
- */
440
- this.rowsToRemove = new EventEmitter();
441
- /**
442
- * Callback to invoke when page is changed.
443
- * @param {any} any - page changed.
444
- * @group Emits
445
- */
446
- this.pageChanged = new EventEmitter();
447
- /**
448
- * Callback to invoke when data is sorted.
449
- * @param {any} any - Sort data.
450
- * @group Emits
451
- */
452
- this.sorted = new EventEmitter();
453
- /**
454
- * Callback to invoke when data is filtered.
455
- * @param {any} any - Custom filter event.
456
- * @group Emits
457
- */
458
- this.filtered = new EventEmitter();
459
- /**
460
- * Callback to invoke on selected columns.
461
- * @param {any[]} object[] - selection changed.
462
- * @group Emits
463
- */
464
- this.columnsSelected = new EventEmitter();
465
- /**
466
- * Callback to invoke when paging, sorting or filtering happens in lazy mode.
467
- * @param {any} any - Custom lazy load event.
468
- * @group Emits
469
- */
470
- this.lazyLoaded = new EventEmitter();
471
- /**
472
- * Callback to invoke when data reload button is clicked.
473
- * @param {any} any - data reload button clicked.
474
- * @group Emits
475
- */
476
- this.dataReloadBtnClicked = new EventEmitter();
477
- /**
478
- * Callback to invoke when a node is expanded.
479
- * @param {any} any - Node instance.
480
- * @group Emits
481
- */
482
- this.nodeExpanded = new EventEmitter();
483
- /**
484
- * Callback to invoke when a node is collapsed.
485
- * @param {any} any - Node collapse event.
486
- * @group Emits
487
- */
488
- this.nodeCollapsed = new EventEmitter();
489
- /**
490
- * Callback to invoke when a node is selected.
491
- * @param {any} any - Node instance.
492
- * @group Emits
493
- */
494
- this.nodeSelected = new EventEmitter();
495
- /**
496
- * Callback to invoke when a node is unselected.
497
- * @param {any} any - Custom node unselect event.
498
- * @group Emits
499
- */
500
- this.nodeUnselected = new EventEmitter();
501
- /**
502
- * A function to implement custom sorting. customSort must be true.
503
- * @param {any} any - sort meta.
504
- * @group Emits
505
- */
506
- this.customSortFunction = new EventEmitter();
507
- this.selectedColumns = [];
508
- this.rowOptions = [];
509
- this.selectedRows = [];
510
- this.virtualScrollItemSize = 0;
511
- this.defScrollHeight = '';
512
- this._defScrollHeightPx = 0;
513
- this._defScrollHeightPxInitial = 0;
514
- this._scrollbarWidth = 0;
515
- this._scrollbarVisible = true;
516
- this._needRecalcAutoLayout = true;
517
- this._data = [];
518
- this.window = this.document.defaultView;
519
- this._resizeObserver = new ResizeObserver((entries) => {
520
- entries.forEach((entry) => {
521
- const body = entry.target;
522
- this._scrollbarVisible = body.scrollHeight > body.clientHeight;
523
- if (this._scrollbarVisible && this.virtualScroll)
524
- this.renderer.setStyle(this._scrollableBody, 'overflow', 'auto', RendererStyleFlags2.Important);
525
- let wScroll = this._scrollbarVisible ? this._scrollbarWidth : 0;
526
- if (wScroll > 0)
527
- wScroll -= 1;
528
- this.renderer.setStyle(this._headerBox, 'padding-right', `${wScroll}px`);
529
- this.renderer.setStyle(this._headerBox, 'border-right', wScroll > 0 ? '1px solid #d7d5d5' : 'unset');
530
- this._calcAutoLayoutHeaderWidths();
531
- });
532
- });
533
- }
534
- ngOnInit() {
535
- if (!this.scrollable)
536
- this.virtualScroll = false;
537
- this.emptyBodyHeight = convertSize(this.emptyBodyHeight);
538
- this.minWidth = convertSize(this.minWidth);
539
- if (this.showAdditionalBtnOnSelect)
540
- this.showRemoveBtnOnSelect = false;
541
- this.defScrollHeight = this.scrollHeight;
542
- if (this.virtualScroll) {
543
- this.window.addEventListener('resize', this._onWindowResize.bind(this));
544
- if (this.defScrollHeight && this.defScrollHeight !== 'flex') {
545
- this._defScrollHeightPx = parseInt(this.scrollHeight, 10);
546
- }
547
- }
548
- if (this.paginator) {
549
- if (this.rowsPerPageOptions.length < 1)
550
- this.rowsPerPageOptions = [5, 10, 25, 50];
551
- if (!this.rows)
552
- this.rows = this.rowsPerPageOptions[0];
553
- else {
554
- if (!this.rowsPerPageOptions.includes(this.rows)) {
555
- throw new Error('rowsPerPageOptions must include rows');
556
- }
557
- }
558
- this.rowOptions = this.rowsPerPageOptions.map((v) => ({
559
- label: '' + v,
560
- value: v
561
- }));
562
- }
563
- if (this.showGlobalFilter &&
564
- this.globalFilterFields?.length < 1 &&
565
- this.data?.length > 0) {
566
- this.globalFilterFields = Object.keys(this.data[0].data);
567
- }
568
- this.selectedColumns =
569
- this.initialColumns.length > 0 ? this.initialColumns : this.columns;
570
- }
571
- ngAfterViewInit() {
572
- this._setMinWidthOverall();
573
- this._scrollableBody = this.primengTreeTable.el.nativeElement.querySelector('.p-treetable-scrollable-body');
574
- if (this._scrollableBody) {
575
- if (this.minWidthForBodyOnly && this.minWidth) {
576
- const table = this._scrollableBody.querySelector('table');
577
- if (table)
578
- this.renderer.setStyle(table, 'min-width', this.minWidth);
579
- }
580
- if (this.virtualScroll) {
581
- if (this.defScrollHeight === 'flex') {
582
- this._defScrollHeightPx = this._scrollableBody.clientHeight;
583
- this._defScrollHeightPxInitial = this._defScrollHeightPx;
584
- }
585
- if (this.autoLayout) {
586
- this._scrollSubscription = fromEvent(this._scrollableBody, 'scroll').subscribe(() => {
587
- this._calcAutoLayoutHeaderWidths(true);
588
- });
589
- }
590
- }
591
- this._headerBox = this.primengTreeTable.el.nativeElement.querySelector('.p-treetable-scrollable-header-box');
592
- if (this._headerBox) {
593
- if (this.minWidthForBodyOnly && this.minWidth) {
594
- const table = this._headerBox.querySelector('table');
595
- if (table)
596
- this.renderer.setStyle(table, 'min-width', this.minWidth);
597
- }
598
- this._scrollbarWidth = DomHandler.calculateScrollbarWidth();
599
- this._resizeObserver.observe(this._scrollableBody);
600
- }
601
- if (this._needRecalcAutoLayout) {
602
- this._calcAutoLayoutHeaderWidths();
603
- this.cdRef.detectChanges();
604
- }
605
- }
606
- if (!this.scrollable) {
607
- const tableWrapper = this.primengTreeTable.el?.nativeElement?.querySelector('.p-treetable-wrapper');
608
- if (tableWrapper && this.minWidthForBodyOnly && this.minWidth) {
609
- const table = tableWrapper.querySelector('table');
610
- if (table)
611
- this.renderer.setStyle(table, 'min-width', this.minWidth);
612
- }
613
- }
614
- }
615
- ngAfterViewChecked() {
616
- if (this._needRecalcAutoLayout) {
617
- this._calcAutoLayoutHeaderWidths();
618
- this.cdRef.detectChanges();
619
- }
620
- if (!this.virtualScroll)
621
- return;
622
- if (!this._defScrollHeightPx && this.defScrollHeight === 'flex') {
623
- this._defScrollHeightPx = this._scrollableBody.clientHeight;
624
- this._defScrollHeightPxInitial = this._defScrollHeightPx;
625
- this.cdRef.detectChanges();
626
- }
627
- if (!this.virtualScrollItemSize) {
628
- setTimeout(() => {
629
- this._recalcVirtualHeight();
630
- this.cdRef.detectChanges();
631
- });
632
- }
633
- }
634
- ngOnChanges(changes) {
635
- if (this.loading) {
636
- this.clearSelection();
637
- if (this.clearGlobalFilterOnLoading)
638
- this.clearGlobalFilter();
639
- }
640
- if (this.virtualScrollItemHeight)
641
- this.virtualScrollItemSize = this.virtualScrollItemHeight;
642
- this._setMinWidthOverall();
643
- const dataChanges = changes?.data;
644
- if (dataChanges?.previousValue !== dataChanges?.currentValue) {
645
- this.clearSelection();
646
- setTimeout(() => {
647
- this._calcAutoLayoutHeaderWidths(true);
648
- });
649
- }
650
- this._calcAutoLayoutHeaderWidths(true);
651
- this._recalcVirtualHeight();
652
- }
653
- ngOnDestroy() {
654
- this._resizeObserver?.disconnect();
655
- if (this.virtualScroll) {
656
- if (this.autoLayout)
657
- this._scrollSubscription?.unsubscribe();
658
- this.window.removeEventListener('resize', this._onWindowResize.bind(this));
659
- }
660
- }
661
- _calcAutoLayoutHeaderWidths(forced = false) {
662
- this.ngZone.runOutsideAngular(() => {
663
- if (!this.autoLayout || !this.scrollable)
664
- return;
665
- if (!this._needRecalcAutoLayout && !forced)
666
- return;
667
- const headerRows = this._headerBox?.querySelectorAll('tr');
668
- if (!headerRows?.length)
669
- return;
670
- const headerCells = headerRows[headerRows.length - 1]?.querySelectorAll('th');
671
- if (!headerCells?.length)
672
- return;
673
- let hasSelectableCell = false;
674
- let hasRowMenuCell = false;
675
- const ths = Array.from(headerCells);
676
- if (ths.every((th) => th.offsetWidth === 0))
677
- return;
678
- const thWidths = ths.map((th) => {
679
- const wprev = th.style.width;
680
- const isSelectableCell = th.classList.contains('cps-treetable-selectable-cell');
681
- const isRowCell = th.classList.contains('cps-treetable-row-menu-cell');
682
- if (isSelectableCell)
683
- hasSelectableCell = true;
684
- if (isRowCell)
685
- hasRowMenuCell = true;
686
- let thWidth = 55;
687
- if (!isSelectableCell && !isRowCell) {
688
- this.renderer.setStyle(th, 'width', 'min-content');
689
- this.renderer.setStyle(th, 'display', 'block');
690
- this.renderer.setStyle(th, 'text-wrap', 'nowrap');
691
- thWidth = th.offsetWidth;
692
- this.renderer.setStyle(th, 'width', wprev);
693
- this.renderer.removeStyle(th, 'display');
694
- this.renderer.removeStyle(th, 'text-wrap');
695
- }
696
- return thWidth;
697
- });
698
- const bodyRows = this._scrollableBody?.querySelectorAll('tr');
699
- if (!bodyRows?.length)
700
- return;
701
- const tdWidths = [];
702
- const fragment = this.document.createDocumentFragment();
703
- const hiddenDiv = this.document.createElement('div');
704
- hiddenDiv.style.visibility = 'hidden';
705
- hiddenDiv.style.position = 'absolute';
706
- hiddenDiv.style.whiteSpace = 'nowrap';
707
- this.document.body.appendChild(hiddenDiv);
708
- bodyRows.forEach((tr) => {
709
- const tds = tr?.querySelectorAll('td');
710
- tds?.forEach((td, idx) => {
711
- const isSelectableOrRowMenuCell = td.classList.contains('cps-treetable-selectable-cell') ||
712
- td.classList.contains('cps-treetable-row-menu-cell');
713
- let tdWidth = 55;
714
- if (!isSelectableOrRowMenuCell) {
715
- const clonedTd = td.cloneNode(true);
716
- fragment.appendChild(clonedTd);
717
- this.renderer.setStyle(clonedTd, 'width', 'min-content');
718
- this.renderer.setStyle(clonedTd, 'display', 'block');
719
- hiddenDiv.innerHTML = clonedTd.innerHTML;
720
- hiddenDiv.style.width = 'auto';
721
- tdWidth = hiddenDiv.offsetWidth;
722
- fragment.removeChild(clonedTd);
723
- }
724
- if (!tdWidths[idx])
725
- tdWidths[idx] = 0;
726
- tdWidths[idx] = Math.max(tdWidths[idx], tdWidth);
727
- });
728
- });
729
- this.document.body.removeChild(hiddenDiv);
730
- if (thWidths.length !== tdWidths.length)
731
- return;
732
- const maxWidths = thWidths.map((v, idx) => Math.max(v, tdWidths[idx]));
733
- let sum = maxWidths.reduce((a, b) => a + b, 0);
734
- if (hasSelectableCell) {
735
- sum -= 55;
736
- maxWidths.shift();
737
- }
738
- if (hasRowMenuCell) {
739
- sum -= 55;
740
- maxWidths.pop();
741
- }
742
- const percentages = maxWidths.map((v) => (v / sum) * 100);
743
- headerCells.forEach((th, idx) => {
744
- if ((hasSelectableCell && idx === 0) ||
745
- (hasRowMenuCell && idx === headerCells.length - 1)) {
746
- this.renderer.setStyle(th, 'width', '55px');
747
- }
748
- else
749
- this.renderer.setStyle(th, 'width', percentages[hasSelectableCell ? idx - 1 : idx] + '%');
750
- });
751
- bodyRows.forEach((tr) => {
752
- const tds = tr?.querySelectorAll('td');
753
- tds?.forEach((td, idx) => {
754
- if ((hasSelectableCell && idx === 0) ||
755
- (hasRowMenuCell && idx === tds.length - 1)) {
756
- this.renderer.setStyle(td, 'width', '55px');
757
- }
758
- else {
759
- this.renderer.setStyle(td, 'width', percentages[hasSelectableCell ? idx - 1 : idx] + '%');
760
- }
761
- this.renderer.setStyle(td, 'opacity', '1');
762
- this.renderer.setStyle(td, 'overflow', 'hidden');
763
- if (this.bordered)
764
- this.renderer.setStyle(td, 'border-left-color', 'var(--cps-color-line-mid)');
765
- });
766
- });
767
- this._needRecalcAutoLayout = false;
768
- });
769
- }
770
- _updateVirtualScrollItemSize() {
771
- if (!this.virtualScroll || this.virtualScrollItemHeight)
772
- return;
773
- const trs = this.primengTreeTable?.el?.nativeElement
774
- ?.querySelector('.p-treetable-tbody')
775
- ?.querySelectorAll('tr');
776
- if (!trs?.length)
777
- return;
778
- if (!trs[0]?.offsetHeight)
779
- return;
780
- let h = 0;
781
- trs.forEach((tr, idx) => {
782
- let rh = 0;
783
- const tds = tr?.querySelectorAll('td');
784
- tds?.forEach((td) => {
785
- const wprev = td.style.width;
786
- this.renderer.setStyle(td, 'display', 'block');
787
- this.renderer.removeStyle(td, 'width');
788
- if (td.offsetHeight)
789
- rh = Math.max(rh, td.offsetHeight);
790
- this.renderer.removeStyle(td, 'display');
791
- this.renderer.setStyle(td, 'width', wprev);
792
- });
793
- if (rh) {
794
- h = idx === 0 ? rh : Math.min(h, rh);
795
- }
796
- });
797
- this.virtualScrollItemSize = h;
798
- }
799
- _setMinWidthOverall() {
800
- if (this.minWidthForBodyOnly || !this.minWidth || !this.primengTreeTable)
801
- return;
802
- const treeTableMain = this.primengTreeTable.el?.nativeElement?.querySelector('.p-treetable');
803
- if (treeTableMain) {
804
- this.renderer.setStyle(treeTableMain, 'overflow', 'auto');
805
- const paginatorEl = treeTableMain.querySelector('.p-paginator');
806
- if (paginatorEl)
807
- this.renderer.setStyle(paginatorEl, 'min-width', this.minWidth);
808
- const loadingOverlay = treeTableMain.querySelector('.p-treetable-loading-overlay');
809
- if (loadingOverlay)
810
- this.renderer.setStyle(loadingOverlay, 'min-width', this.minWidth);
811
- }
812
- const scrollableWrapper = this.primengTreeTable.el?.nativeElement?.querySelector('.p-treetable-scrollable-wrapper');
813
- if (scrollableWrapper)
814
- this.renderer.setStyle(scrollableWrapper, 'min-width', this.minWidth);
815
- if (!this.scrollable) {
816
- const tableWrapper = this.primengTreeTable.el?.nativeElement?.querySelector('.p-treetable-wrapper');
817
- if (tableWrapper)
818
- this.renderer.setStyle(tableWrapper, 'min-width', this.minWidth);
819
- }
820
- const treeTableHeader = this.primengTreeTable.el?.nativeElement?.querySelector('.p-treetable-header');
821
- if (treeTableHeader)
822
- this.renderer.setStyle(treeTableHeader, 'min-width', this.minWidth);
823
- }
824
- _onWindowResize() {
825
- // if (this.defScrollHeight === 'flex')
826
- // this.defScrollHeightPx = this.scrollableBody.clientHeight;
827
- clearTimeout(this._windowResizeDebouncer);
828
- this._windowResizeDebouncer = setTimeout(() => {
829
- this._recalcVirtualHeight();
830
- }, 100);
831
- }
832
- get styleClass() {
833
- const classesList = [];
834
- switch (this.size) {
835
- case 'small':
836
- classesList.push('p-treetable-sm');
837
- break;
838
- case 'large':
839
- classesList.push('p-treetable-lg');
840
- break;
841
- }
842
- if (this.hasToolbar) {
843
- switch (this.toolbarSize) {
844
- case 'small':
845
- classesList.push('cps-tbar-small');
846
- break;
847
- case 'normal':
848
- classesList.push('cps-tbar-normal');
849
- break;
850
- }
851
- }
852
- if (this.striped) {
853
- classesList.push('p-treetable-striped');
854
- }
855
- if (this.bordered) {
856
- classesList.push('p-treetable-gridlines');
857
- }
858
- return classesList.join(' ');
859
- }
860
- _recalcVirtualHeight() {
861
- if (!this._scrollbarVisible && this.virtualScroll)
862
- this.renderer.setStyle(this._scrollableBody, 'overflow', 'hidden', RendererStyleFlags2.Important);
863
- setTimeout(() => {
864
- if (this.virtualScroll && this.defScrollHeight) {
865
- this._updateVirtualScrollItemSize();
866
- const itemsLen = this.primengTreeTable.serializedValue?.length || 0;
867
- if (itemsLen < 1) {
868
- this.scrollHeight = this.emptyBodyHeight
869
- ? `calc(${this.emptyBodyHeight} + 1px)`
870
- : this.virtualScrollItemSize + 1 + 'px';
871
- }
872
- else {
873
- const curHeight = this.virtualScrollItemSize * itemsLen + 2;
874
- if (this.defScrollHeight === 'flex') {
875
- if (curHeight >= this._defScrollHeightPxInitial) {
876
- this.scrollHeight = 'flex';
877
- this.renderer.setStyle(this._scrollableBody, 'height', '100%');
878
- this.cdRef.markForCheck();
879
- return;
880
- }
881
- }
882
- this.scrollHeight =
883
- Math.min(this._defScrollHeightPx, curHeight) + 'px';
884
- }
885
- this.cdRef.markForCheck();
886
- }
887
- });
888
- }
889
- clearGlobalFilter() {
890
- this.globalFilterComp?.clear();
891
- }
892
- onSortFunction(event) {
893
- this.customSortFunction.emit(event);
894
- }
895
- onFilterGlobal(value) {
896
- this.primengTreeTable.filterGlobal(value, 'contains');
897
- }
898
- onClickAdditionalBtnOnSelect() {
899
- this.additionalBtnOnSelectClicked.emit(this.selectedRows);
900
- }
901
- onClickActionBtn() {
902
- this.actionBtnClicked.emit();
903
- }
904
- onReloadData() {
905
- if (this.dataReloadBtnDisabled)
906
- return;
907
- this.dataReloadBtnClicked.emit();
908
- }
909
- onColumnsToggle(event) {
910
- if (this.columnsToggleBtnDisabled)
911
- return;
912
- this.colToggleMenu?.toggle(event);
913
- }
914
- removeSelected() {
915
- this.rowsToRemove.emit(this.selectedRows);
916
- }
917
- clearSelection() {
918
- this.selectedRows = [];
919
- }
920
- onEditRowClicked(node) {
921
- this.editRowBtnClicked.emit(node);
922
- }
923
- onRemoveRowClicked(node) {
924
- this.rowsToRemove.emit([node]);
925
- }
926
- toggleAllColumns() {
927
- this.selectedColumns =
928
- this.selectedColumns.length < this.columns.length ? this.columns : [];
929
- this.columnsSelected.emit(this.selectedColumns);
930
- setTimeout(() => {
931
- this._calcAutoLayoutHeaderWidths(true);
932
- });
933
- }
934
- isColumnSelected(col) {
935
- return this.selectedColumns.some((item) => isEqual(item, col));
936
- }
937
- onRowsPerPageChanged() {
938
- if (this.resetPageOnRowsChange) {
939
- this.primengTreeTable.first = 0;
940
- }
941
- this.changePage(this.getPage());
942
- }
943
- getPageCount() {
944
- return Math.ceil(this.primengTreeTable.totalRecords / this.rows);
945
- }
946
- getPage() {
947
- return Math.floor(this.primengTreeTable.first / this.rows);
948
- }
949
- changePage(p) {
950
- const pc = Math.ceil(this.getPageCount());
951
- if (p >= 0 && p < pc) {
952
- this.first = this.rows * p;
953
- this.primengTreeTable.onPageChange({
954
- first: this.first,
955
- rows: this.rows
956
- });
957
- }
958
- }
959
- onPageChange(event) {
960
- this.first = event.first;
961
- this.rows = event.rows;
962
- const state = {
963
- page: this.getPage(),
964
- first: this.first,
965
- rows: this.rows,
966
- pageCount: Math.ceil(this.getPageCount())
967
- };
968
- this.pageChanged.emit(state);
969
- setTimeout(() => {
970
- this._calcAutoLayoutHeaderWidths(true);
971
- });
972
- }
973
- onLazyLoaded(event) {
974
- this.lazyLoaded.emit(event);
975
- }
976
- onNodeExpanded(event) {
977
- this.nodeExpanded.emit(event);
978
- setTimeout(() => {
979
- this._calcAutoLayoutHeaderWidths(true);
980
- });
981
- this._recalcVirtualHeight();
982
- }
983
- onNodeCollapsed(event) {
984
- this.nodeCollapsed.emit(event);
985
- setTimeout(() => {
986
- this._calcAutoLayoutHeaderWidths(true);
987
- });
988
- this._recalcVirtualHeight();
989
- }
990
- onNodeSelected(event) {
991
- this.nodeSelected.emit(event);
992
- }
993
- onNodeUnselected(event) {
994
- this.nodeUnselected.emit(event);
995
- }
996
- onSort(event) {
997
- this.sorted.emit(event);
998
- setTimeout(() => {
999
- this.cdRef.detectChanges();
1000
- this._calcAutoLayoutHeaderWidths(true);
1001
- });
1002
- }
1003
- onFilter(event) {
1004
- this.filtered.emit(event);
1005
- setTimeout(() => {
1006
- this._calcAutoLayoutHeaderWidths(true);
1007
- });
1008
- this._recalcVirtualHeight();
1009
- }
1010
- onSelectColumn(col) {
1011
- let res = [];
1012
- if (this.isColumnSelected(col)) {
1013
- res = this.selectedColumns.filter((v) => !isEqual(v, col));
1014
- }
1015
- else {
1016
- this.columns.forEach((o) => {
1017
- if (this.selectedColumns.some((v) => isEqual(v, o)) ||
1018
- isEqual(col, o)) {
1019
- res.push(o);
1020
- }
1021
- });
1022
- }
1023
- this.selectedColumns = res;
1024
- this.columnsSelected.emit(this.selectedColumns);
1025
- setTimeout(() => {
1026
- this._calcAutoLayoutHeaderWidths(true);
1027
- });
1028
- }
1029
- onSelectionChanged(selection) {
1030
- if (selection && !Array.isArray(selection))
1031
- selection = [selection];
1032
- this.rowsSelected.emit(selection);
1033
- }
1034
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.3", ngImport: i0, type: CpsTreeTableComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: DOCUMENT }, { token: i0.Renderer2 }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
1035
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.3", type: CpsTreeTableComponent, isStandalone: true, selector: "cps-tree-table", inputs: { columns: "columns", colHeaderName: "colHeaderName", colFieldName: "colFieldName", colFilterTypeName: "colFilterTypeName", colDateFormatName: "colDateFormatName", minWidth: "minWidth", minWidthForBodyOnly: "minWidthForBodyOnly", autoLayout: "autoLayout", striped: "striped", bordered: "bordered", size: "size", selectable: "selectable", rowHover: "rowHover", showRowMenu: "showRowMenu", showRowRemoveButton: "showRowRemoveButton", showRowEditButton: "showRowEditButton", rowMenuItems: "rowMenuItems", loading: "loading", tableStyle: "tableStyle", tableStyleClass: "tableStyleClass", sortable: "sortable", sortMode: "sortMode", customSort: "customSort", hasToolbar: "hasToolbar", toolbarSize: "toolbarSize", toolbarTitle: "toolbarTitle", toolbarIcon: "toolbarIcon", toolbarIconColor: "toolbarIconColor", scrollable: "scrollable", scrollHeight: "scrollHeight", virtualScroll: "virtualScroll", virtualScrollItemHeight: "virtualScrollItemHeight", numToleratedItems: "numToleratedItems", paginator: "paginator", alwaysShowPaginator: "alwaysShowPaginator", rowsPerPageOptions: "rowsPerPageOptions", first: "first", rows: "rows", resetPageOnRowsChange: "resetPageOnRowsChange", resetPageOnSort: "resetPageOnSort", totalRecords: "totalRecords", emptyMessage: "emptyMessage", emptyBodyHeight: "emptyBodyHeight", lazy: "lazy", lazyLoadOnInit: "lazyLoadOnInit", showGlobalFilter: "showGlobalFilter", globalFilterPlaceholder: "globalFilterPlaceholder", globalFilterFields: "globalFilterFields", clearGlobalFilterOnLoading: "clearGlobalFilterOnLoading", showRemoveBtnOnSelect: "showRemoveBtnOnSelect", removeBtnOnSelectDisabled: "removeBtnOnSelectDisabled", showAdditionalBtnOnSelect: "showAdditionalBtnOnSelect", additionalBtnOnSelectTitle: "additionalBtnOnSelectTitle", additionalBtnOnSelectIcon: "additionalBtnOnSelectIcon", additionalBtnOnSelectDisabled: "additionalBtnOnSelectDisabled", showActionBtn: "showActionBtn", actionBtnTitle: "actionBtnTitle", actionBtnIcon: "actionBtnIcon", actionBtnDisabled: "actionBtnDisabled", showDataReloadBtn: "showDataReloadBtn", dataReloadBtnDisabled: "dataReloadBtnDisabled", showColumnsToggleBtn: "showColumnsToggleBtn", columnsToggleBtnDisabled: "columnsToggleBtnDisabled", initialColumns: "initialColumns", filterableByColumns: "filterableByColumns", autoColumnFilterType: "autoColumnFilterType", renderDataAsHTML: "renderDataAsHTML", data: "data", resizableColumns: "resizableColumns", columnResizeMode: "columnResizeMode" }, outputs: { rowsSelected: "rowsSelected", actionBtnClicked: "actionBtnClicked", additionalBtnOnSelectClicked: "additionalBtnOnSelectClicked", editRowBtnClicked: "editRowBtnClicked", rowsToRemove: "rowsToRemove", pageChanged: "pageChanged", sorted: "sorted", filtered: "filtered", columnsSelected: "columnsSelected", lazyLoaded: "lazyLoaded", dataReloadBtnClicked: "dataReloadBtnClicked", nodeExpanded: "nodeExpanded", nodeCollapsed: "nodeCollapsed", nodeSelected: "nodeSelected", nodeUnselected: "nodeUnselected", customSortFunction: "customSortFunction" }, providers: [
1036
- TreeTableService,
1037
- {
1038
- provide: TreeTable,
1039
- useFactory: treeTableFactory,
1040
- // eslint-disable-next-line no-use-before-define
1041
- deps: [CpsTreeTableComponent]
1042
- }
1043
- ], queries: [{ propertyName: "toolbarTemplate", first: true, predicate: ["toolbar"], descendants: true }, { propertyName: "headerTemplate", first: true, predicate: ["header"], descendants: true }, { propertyName: "nestedHeaderTemplate", first: true, predicate: ["nestedHeader"], descendants: true }, { propertyName: "bodyTemplate", first: true, predicate: ["body"], descendants: true }, { propertyName: "colgroupTemplate", first: true, predicate: ["colgroup"], descendants: true }], viewQueries: [{ propertyName: "primengTreeTable", first: true, predicate: ["primengTreeTable"], descendants: true, static: true }, { propertyName: "globalFilterComp", first: true, predicate: ["globalFilterComp"], descendants: true }, { propertyName: "colToggleMenu", first: true, predicate: ["colToggleMenu"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<p-treeTable\n #primengTreeTable\n ttWithUnsort\n [ngClass]=\"{\n 'cps-treetable-loading': loading,\n 'cps-treetable-flex': defScrollHeight === 'flex',\n 'cps-treetable-nonvirtual': !virtualScroll,\n 'cps-treetable-autolayout-calced': autoLayout && scrollable\n }\"\n [value]=\"data\"\n [autoLayout]=\"autoLayout && !scrollable\"\n [scrollable]=\"scrollable\"\n [scrollHeight]=\"scrollHeight\"\n [virtualScroll]=\"virtualScroll\"\n [virtualScrollItemSize]=\"virtualScrollItemSize\"\n [virtualScrollOptions]=\"{\n numToleratedItems: numToleratedItems,\n autoSize: false\n }\"\n [columns]=\"selectedColumns\"\n [loading]=\"loading\"\n [rowHover]=\"rowHover\"\n [lazy]=\"lazy\"\n [(selection)]=\"selectedRows\"\n (selectionChange)=\"onSelectionChanged($event)\"\n compareSelectionBy=\"deepEquals\"\n [lazyLoadOnInit]=\"lazyLoadOnInit\"\n [styleClass]=\"styleClass\"\n [tableStyle]=\"tableStyle\"\n [tableStyleClass]=\"tableStyleClass\"\n [customSort]=\"customSort\"\n [sortMode]=\"sortMode\"\n [globalFilterFields]=\"globalFilterFields\"\n [paginator]=\"paginator\"\n [showCurrentPageReport]=\"true\"\n [alwaysShowPaginator]=\"alwaysShowPaginator\"\n [rows]=\"rows\"\n [first]=\"first\"\n [totalRecords]=\"totalRecords\"\n [resetPageOnSort]=\"resetPageOnSort\"\n [resizableColumns]=\"resizableColumns\"\n [columnResizeMode]=\"columnResizeMode\"\n currentPageReportTemplate=\"{first} - {last} of {totalRecords}\"\n (onPage)=\"onPageChange($event)\"\n (onSort)=\"onSort($event)\"\n (onFilter)=\"onFilter($event)\"\n (onLazyLoad)=\"onLazyLoaded($event)\"\n (sortFunction)=\"onSortFunction($event)\"\n (onNodeExpand)=\"onNodeExpanded($event)\"\n (onNodeCollapse)=\"onNodeCollapsed($event)\"\n (onNodeSelect)=\"onNodeSelected($event)\"\n (onNodeUnselect)=\"onNodeUnselected($event)\">\n @if (colgroupTemplate) {\n <ng-template pTemplate=\"colgroup\">\n <ng-container *ngTemplateOutlet=\"colgroupTemplate\"></ng-container>\n </ng-template>\n }\n <ng-template pTemplate=\"caption\" *ngIf=\"hasToolbar\">\n <ng-container *ngIf=\"toolbarTemplate\">\n <ng-container *ngTemplateOutlet=\"toolbarTemplate\"></ng-container>\n </ng-container>\n <ng-container *ngIf=\"!toolbarTemplate\">\n <div class=\"cps-treetable-tbar-left\">\n <div *ngIf=\"toolbarIcon\" class=\"cps-treetable-tbar-icon\">\n <cps-icon [icon]=\"toolbarIcon\" [color]=\"toolbarIconColor\"></cps-icon>\n </div>\n <div class=\"cps-treetable-tbar-title\">{{ toolbarTitle }}</div>\n <div *ngIf=\"showGlobalFilter\" class=\"cps-treetable-tbar-global-filter\">\n <cps-input\n #globalFilterComp\n prefixIcon=\"search\"\n [placeholder]=\"globalFilterPlaceholder\"\n (valueChanged)=\"onFilterGlobal($event)\"\n [clearable]=\"true\"\n [disabled]=\"loading\"\n [appearance]=\"toolbarSize === 'small' ? 'underlined' : 'outlined'\"\n [hideDetails]=\"true\">\n </cps-input>\n </div>\n </div>\n <div class=\"cps-treetable-tbar-right\">\n <div\n *ngIf=\"showRemoveBtnOnSelect && selectedRows.length > 0\"\n class=\"cps-treetable-tbar-btn-on-select\">\n <cps-button\n label=\"Remove\"\n [disabled]=\"removeBtnOnSelectDisabled\"\n color=\"prepared\"\n type=\"borderless\"\n icon=\"remove\"\n [size]=\"toolbarSize\"\n (clicked)=\"removeSelected()\">\n </cps-button>\n </div>\n <div\n *ngIf=\"showAdditionalBtnOnSelect && selectedRows.length > 0\"\n class=\"cps-treetable-tbar-btn-on-select\">\n <cps-button\n [label]=\"additionalBtnOnSelectTitle\"\n [disabled]=\"additionalBtnOnSelectDisabled\"\n color=\"prepared\"\n type=\"borderless\"\n [icon]=\"additionalBtnOnSelectIcon\"\n [size]=\"toolbarSize\"\n (clicked)=\"onClickAdditionalBtnOnSelect()\">\n </cps-button>\n </div>\n <div *ngIf=\"showActionBtn\" class=\"cps-treetable-tbar-action-btn\">\n <cps-button\n [label]=\"actionBtnTitle\"\n [disabled]=\"actionBtnDisabled\"\n color=\"prepared\"\n type=\"outlined\"\n [icon]=\"actionBtnIcon\"\n [size]=\"toolbarSize\"\n (clicked)=\"onClickActionBtn()\">\n </cps-button>\n </div>\n <div\n *ngIf=\"showColumnsToggleBtn && columns.length > 0\"\n class=\"cps-treetable-tbar-coltoggle-btn\"\n [ngClass]=\"{ 'btn-disabled': columnsToggleBtnDisabled }\">\n <cps-icon\n icon=\"columns\"\n size=\"normal\"\n [color]=\"\n columnsToggleBtnDisabled ? 'text-lightest' : 'prepared-lighten1'\n \"\n (click)=\"onColumnsToggle($event)\"></cps-icon>\n <cps-menu #colToggleMenu [withArrow]=\"false\">\n <div class=\"cps-treetable-coltoggle-menu\">\n <div\n class=\"cps-treetable-coltoggle-menu-item select-all-option\"\n [class.allselected]=\"selectedColumns.length === columns.length\"\n (click)=\"toggleAllColumns()\">\n <span class=\"cps-treetable-coltoggle-menu-item-left\">\n <span class=\"cps-treetable-coltoggle-menu-item-check\"> </span>\n <span class=\"cps-treetable-coltoggle-menu-item-label\"\n >Show all columns</span\n >\n </span>\n </div>\n <div\n *ngFor=\"let col of columns\"\n class=\"cps-treetable-coltoggle-menu-item\"\n (click)=\"onSelectColumn(col)\"\n [class.selected]=\"isColumnSelected(col)\">\n <span class=\"cps-treetable-coltoggle-menu-item-left\">\n <span class=\"cps-treetable-coltoggle-menu-item-check\"></span>\n <span class=\"cps-treetable-coltoggle-menu-item-label\">{{\n col[colHeaderName]\n }}</span>\n </span>\n </div>\n </div>\n </cps-menu>\n </div>\n <div\n *ngIf=\"showDataReloadBtn\"\n class=\"cps-treetable-tbar-reload-btn\"\n [ngClass]=\"{ 'btn-disabled': dataReloadBtnDisabled }\">\n <cps-icon\n icon=\"refresh\"\n size=\"18\"\n [color]=\"dataReloadBtnDisabled ? 'text-light' : 'prepared-lighten1'\"\n (click)=\"onReloadData()\">\n </cps-icon>\n </div>\n </div>\n </ng-container>\n </ng-template>\n\n <ng-template pTemplate=\"header\" *ngIf=\"nestedHeaderTemplate\" let-columns>\n <ng-container\n *ngTemplateOutlet=\"\n nestedHeaderTemplate;\n context: {\n $implicit: columns\n }\n \"></ng-container>\n </ng-template>\n\n <ng-template pTemplate=\"header\" *ngIf=\"!nestedHeaderTemplate\" let-columns>\n <tr>\n <!-- <th style=\"width: 3rem\" *ngIf=\"reorderableRows\"></th> -->\n <th\n *ngIf=\"selectable\"\n cpsTTHdrSelectable\n cpsTTColResizable\n [cpsTTColResizableDisabled]=\"!resizableColumns\"></th>\n <ng-container *ngIf=\"headerTemplate\">\n <ng-container\n *ngTemplateOutlet=\"\n headerTemplate;\n context: {\n $implicit: columns\n }\n \"></ng-container>\n </ng-container>\n <ng-container *ngIf=\"!headerTemplate && columns.length > 0\">\n <ng-container *ngIf=\"sortable\">\n @if (filterableByColumns) {\n <th\n *ngFor=\"let col of columns\"\n [cpsTTColSortable]=\"col[colFieldName]\"\n [cpsTTColFilter]=\"col[colFieldName]\"\n [filterType]=\"\n col[colFilterTypeName] ??\n (autoColumnFilterType\n ? (data | cpsTTDetectFilterType: col[colFieldName])\n : 'text')\n \"\n cpsTTColResizable\n [cpsTTColResizableDisabled]=\"!resizableColumns\">\n {{ col[colHeaderName] }}\n </th>\n } @else {\n <th\n *ngFor=\"let col of columns\"\n [cpsTTColSortable]=\"col[colFieldName]\"\n cpsTTColResizable\n [cpsTTColResizableDisabled]=\"!resizableColumns\">\n {{ col[colHeaderName] }}\n </th>\n }\n </ng-container>\n <ng-container *ngIf=\"!sortable\">\n @if (filterableByColumns) {\n <th\n *ngFor=\"let col of columns\"\n [cpsTTColFilter]=\"col[colFieldName]\"\n [filterType]=\"\n col[colFilterTypeName] ??\n (autoColumnFilterType\n ? (data | cpsTTDetectFilterType: col[colFieldName])\n : 'text')\n \"\n cpsTTColResizable\n [cpsTTColResizableDisabled]=\"!resizableColumns\">\n {{ col[colHeaderName] }}\n </th>\n } @else {\n <th\n *ngFor=\"let col of columns\"\n cpsTTColResizable\n [cpsTTColResizableDisabled]=\"!resizableColumns\">\n {{ col[colHeaderName] }}\n </th>\n }\n </ng-container>\n </ng-container>\n <th\n class=\"cps-treetable-row-menu-cell\"\n *ngIf=\"showRowMenu && (showRowRemoveButton || showRowEditButton)\"\n cpsTTColResizable\n [cpsTTColResizableDisabled]=\"!resizableColumns\"></th>\n </tr>\n </ng-template>\n\n <ng-template\n pTemplate=\"body\"\n let-rowData=\"rowData\"\n let-columns=\"columns\"\n let-rowNode\n let-rowIndex=\"rowIndex\">\n <tr\n [ttRow]=\"rowNode\"\n [ngClass]=\"{\n 'cps-treetable-row-selected':\n selectable && primengTreeTable.isSelected(rowNode.node)\n }\">\n <!-- <td *ngIf=\"reorderableRows\" class=\"cps-table-row-drag-handle-cell\">\n <span class=\"cps-table-row-drag-handle\" pReorderableRowHandle>\u2630</span>\n </td> -->\n <td [cpsTTRowSelectable]=\"rowNode\" *ngIf=\"selectable\"></td>\n <ng-container *ngIf=\"bodyTemplate\">\n <ng-container\n *ngTemplateOutlet=\"\n bodyTemplate;\n context: {\n $implicit: rowNode,\n rowIndex: rowIndex,\n columns: columns,\n rowData: rowData\n }\n \">\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"!bodyTemplate\">\n <ng-container *ngIf=\"columns.length > 0\">\n @if (renderDataAsHTML) {\n <ng-container *ngFor=\"let col of columns; let i = index\">\n <td\n *ngIf=\"i === 0\"\n [cpsTTRowToggler]=\"rowNode\"\n [innerHTML]=\"rowData[col[colFieldName]]\"></td>\n <td *ngIf=\"i > 0\" [innerHTML]=\"rowData[col[colFieldName]]\"></td>\n </ng-container>\n } @else {\n <ng-container *ngFor=\"let col of columns; let i = index\">\n <td *ngIf=\"i === 0\" [cpsTTRowToggler]=\"rowNode\">\n {{\n col[colDateFormatName]\n ? (rowData[col[colFieldName]]\n | date: col[colDateFormatName])\n : rowData[col[colFieldName]]\n }}\n </td>\n <td *ngIf=\"i > 0\">\n {{\n col[colDateFormatName]\n ? (rowData[col[colFieldName]]\n | date: col[colDateFormatName])\n : rowData[col[colFieldName]]\n }}\n </td>\n </ng-container>\n }\n </ng-container>\n </ng-container>\n <td\n *ngIf=\"showRowMenu && (showRowRemoveButton || showRowEditButton)\"\n class=\"cps-treetable-row-menu-cell\">\n <table-row-menu\n (editRowBtnClicked)=\"onEditRowClicked(rowNode.node)\"\n (removeRowBtnClicked)=\"onRemoveRowClicked(rowNode.node)\"\n [showRowRemoveButton]=\"showRowRemoveButton\"\n [showRowEditButton]=\"showRowEditButton\"\n [customItems]=\"rowMenuItems\">\n </table-row-menu>\n </td>\n </tr>\n </ng-template>\n <ng-template pTemplate=\"emptymessage\">\n <tr>\n <td\n colspan=\"100\"\n class=\"cps-treetable-empty-message-td\"\n [ngStyle]=\"{ height: emptyBodyHeight }\">\n {{ emptyMessage }}\n </td>\n </tr>\n </ng-template>\n <ng-template pTemplate=\"loadingicon\">\n <cps-loader [fullScreen]=\"false\" opacity=\"0\"></cps-loader>\n </ng-template>\n <ng-template pTemplate=\"paginatorleft\">\n <div class=\"cps-table-paginator-itms-per-page\">\n <span class=\"cps-table-paginator-items-per-page-title\"\n >Rows per page:\n </span>\n <cps-select\n [options]=\"rowOptions\"\n [hideDetails]=\"true\"\n [(ngModel)]=\"rows\"\n (valueChanged)=\"onRowsPerPageChanged()\"\n [returnObject]=\"false\"\n optionsClass=\"cps-paginator-page-options\">\n </cps-select>\n </div>\n </ng-template>\n\n <ng-template pTemplate=\"paginatorfirstpagelinkicon\">\n <AngleDoubleLeftIcon />\n </ng-template>\n <ng-template pTemplate=\"paginatorpreviouspagelinkicon\">\n <AngleLeftIcon />\n </ng-template>\n <ng-template pTemplate=\"paginatornextpagelinkicon\">\n <AngleRightIcon />\n </ng-template>\n <ng-template pTemplate=\"paginatorlastpagelinkicon\">\n <AngleDoubleRightIcon />\n </ng-template>\n</p-treeTable>\n", styles: [":host ::ng-deep .p-treetable{position:relative}:host ::ng-deep .p-component,:host ::ng-deep .p-component *{box-sizing:border-box}:host ::ng-deep .p-component{font-family:Source Sans Pro,sans-serif;font-size:14px;font-weight:400}:host ::ng-deep .p-treetable-scrollable-wrapper{position:relative;background:#fff}:host ::ng-deep .p-treetable-wrapper{background:#fff}:host ::ng-deep .cps-treetable-nonvirtual.cps-treetable-flex .p-treetable-flex-scrollable.cps-tbar-normal .p-treetable-scrollable-wrapper{height:calc(100% - 72px)}:host ::ng-deep .cps-treetable-nonvirtual.cps-treetable-flex .p-treetable-flex-scrollable.cps-tbar-small .p-treetable-scrollable-wrapper{height:calc(100% - 43px)}:host ::ng-deep .cps-treetable-nonvirtual.cps-treetable-flex .p-treetable-flex-scrollable .p-treetable-scrollable-wrapper .p-treetable-scrollable-view .p-treetable-scrollable-header{display:contents}:host ::ng-deep .p-treetable .p-treetable-scrollable-header,:host ::ng-deep .p-treetable .p-treetable-scrollable-footer{background:#fff}:host ::ng-deep .p-treetable-scrollable-header,:host ::ng-deep .p-treetable-scrollable-footer{overflow:hidden}:host ::ng-deep .p-treetable table{border-collapse:collapse;width:100%;table-layout:fixed}:host ::ng-deep .p-treetable .p-treetable-thead>tr>th{text-align:left;padding:1rem;border:1px solid var(--cps-color-line-mid);border-width:0 0 1px 1px;font-weight:400;color:var(--cps-color-text-mild);background:#fff;transition:box-shadow .2s;overflow:hidden}:host ::ng-deep .p-treetable-scrollable-body{overflow:auto!important;position:relative}:host ::ng-deep .cps-treetable-flex .p-treetable-scrollable-body{height:100%}:host ::ng-deep .p-treetable .p-treetable-tbody{background:#fff}:host ::ng-deep .p-treetable .p-treetable-tbody>tr{background:#fff;color:var(--cps-color-text-dark);transition:box-shadow .2s}:host ::ng-deep .p-treetable .p-treetable-tbody>tr.cps-treetable-row-selected{background-color:var(--cps-color-highlight-active)!important}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td{text-align:left;border:1px solid var(--cps-color-line-mid);border-width:0 0 1px 0;padding:1rem}:host ::ng-deep p-treetable:not(.cps-treetable-autolayout-calced) .p-treetable .p-treetable-tbody>tr>td{overflow:hidden}:host ::ng-deep .cps-treetable-autolayout-calced .p-treetable .p-treetable-scrollable-body .p-treetable-tbody>tr>td:not(.cps-treetable-row-toggler-cell):not(.cps-treetable-selectable-cell):not(.cps-treetable-row-menu-cell):not(.cps-treetable-empty-message-td){opacity:0;border-left-color:#fff}:host ::ng-deep .cps-treetable-autolayout-calced .p-treetable.p-treetable-striped .p-treetable-scrollable-body .p-treetable-tbody>tr:nth-child(odd)>td:not(.cps-treetable-row-toggler-cell):not(.cps-treetable-selectable-cell):not(.cps-treetable-row-menu-cell):not(.cps-treetable-empty-message-td){border-left-color:var(--cps-color-bg-light)}:host ::ng-deep .cps-treetable-autolayout-calced .p-treetable .p-treetable-scrollable-body .p-treetable-tbody>tr:hover>td:not(.cps-treetable-row-toggler-cell):not(.cps-treetable-selectable-cell):not(.cps-treetable-row-menu-cell):not(.cps-treetable-empty-message-td){border-left-color:var(--cps-color-highlight-hover)}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td:first-child{border-width:0 0 1px 1px}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td:last-child{border-width:0 1px 1px 0}:host ::ng-deep .p-treetable-auto-layout table{table-layout:auto}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td .p-treetable-toggler{width:1rem;height:1rem;color:var(--cps-color-text-dark);border:0 none;background:transparent;border-radius:50%;margin-right:.5rem}:host ::ng-deep .p-treetable-toggler{cursor:pointer;-webkit-user-select:none;user-select:none;display:inline-flex;align-items:center;justify-content:center;vertical-align:middle;overflow:hidden;position:relative}:host ::ng-deep .p-ripple{overflow:hidden;position:relative}:host ::ng-deep .p-link:focus{outline:0 none;outline-offset:0;box-shadow:unset}:host ::ng-deep .p-link{text-align:left;background-color:transparent;margin:0;padding:0;border:none;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:14px;font-family:Source Sans Pro,sans-serif;border-radius:6px}:host ::ng-deep input[type=button],:host ::ng-deep input[type=submit],:host ::ng-deep input[type=reset],:host ::ng-deep input[type=file]::-webkit-file-upload-button,:host ::ng-deep button{border-radius:0}:host ::ng-deep .p-treetable .p-treetable-tbody>tr:focus{outline:0 none;outline-offset:-.15rem}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td .p-treetable-toggler:enabled:hover{color:var(--cps-color-calm);border-color:transparent;background:unset}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td .p-treetable-toggler:focus{outline:0 none;outline-offset:0;box-shadow:unset}:host ::ng-deep .p-treetable .p-paginator{border-width:0 1px 1px 1px;border-radius:0}:host ::ng-deep .p-paginator{background:#fff;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;color:var(--cps-color-text-dark);padding:1rem;border:1px solid var(--cps-color-line-mid)}:host ::ng-deep .p-paginator-left-content{margin-right:auto}:host ::ng-deep .p-paginator-left-content .cps-table-paginator-itms-per-page{display:inline-flex;align-items:center}:host ::ng-deep .p-paginator-left-content .cps-table-paginator-itms-per-page .cps-table-paginator-items-per-page-title{font-family:Source Sans Pro,sans-serif;font-size:14px;margin-right:12px;cursor:default}:host ::ng-deep .p-paginator-left-content .cps-table-paginator-itms-per-page .cps-select-box{min-height:32px!important;background:transparent!important}:host ::ng-deep .p-paginator-left-content .cps-table-paginator-itms-per-page .cps-select-box .cps-select-box-items{font-size:14px!important}:host ::ng-deep .p-paginator-left-content .cps-table-paginator-itms-per-page .cps-select-box .cps-select-box-chevron .cps-icon{width:14px;height:14px}:host ::ng-deep .p-paginator .p-paginator-current{background-color:transparent;border:0 none;color:var(--cps-color-text-dark);min-width:3rem;margin:.143rem;padding:0 .5rem;font-family:Source Sans Pro,sans-serif;font-size:14px;height:unset}:host ::ng-deep .p-paginator-page,:host ::ng-deep .p-paginator-next,:host ::ng-deep .p-paginator-last,:host ::ng-deep .p-paginator-first,:host ::ng-deep .p-paginator-prev,:host ::ng-deep .p-paginator-current{cursor:pointer;display:inline-flex;align-items:center;justify-content:center;line-height:1;-webkit-user-select:none;user-select:none;overflow:hidden;position:relative}:host ::ng-deep .p-paginator-current{cursor:default}:host ::ng-deep .p-paginator .p-paginator-first:not(.p-disabled):not(.p-highlight):hover,:host ::ng-deep .p-paginator .p-paginator-prev:not(.p-disabled):not(.p-highlight):hover,:host ::ng-deep .p-paginator .p-paginator-next:not(.p-disabled):not(.p-highlight):hover,:host ::ng-deep .p-paginator .p-paginator-last:not(.p-disabled):not(.p-highlight):hover{background:var(--cps-color-highlight-hover);border-color:unset}:host ::ng-deep .p-paginator .p-paginator-first:not(.p-disabled):not(.p-highlight):active,:host ::ng-deep .p-paginator .p-paginator-prev:not(.p-disabled):not(.p-highlight):active,:host ::ng-deep .p-paginator .p-paginator-next:not(.p-disabled):not(.p-highlight):active,:host ::ng-deep .p-paginator .p-paginator-last:not(.p-disabled):not(.p-highlight):active{background:var(--cps-color-highlight-active)}:host ::ng-deep .p-paginator .p-paginator-first,:host ::ng-deep .p-paginator .p-paginator-prev,:host ::ng-deep .p-paginator .p-paginator-next,:host ::ng-deep .p-paginator .p-paginator-last{background-color:transparent;border:1px solid var(--cps-color-text-dark);border-radius:4px;color:var(--cps-color-text-dark);min-width:32px;height:32px;margin:.143rem;transition:box-shadow .2s}:host ::ng-deep .p-disabled,:host ::ng-deep .p-disabled *{cursor:default!important;pointer-events:none}:host ::ng-deep .p-paginator .p-paginator-pages .p-paginator-page.p-highlight{background:var(--cps-color-calm);border-color:var(--cps-color-calm);color:#fff}:host ::ng-deep .p-paginator .p-paginator-pages .p-paginator-page:not(.p-highlight):hover{background:var(--cps-color-highlight-hover);border-color:unset}:host ::ng-deep .p-paginator .p-paginator-pages .p-paginator-page:not(.p-highlight):active{background:var(--cps-color-highlight-active)}:host ::ng-deep .p-paginator .p-paginator-pages .p-paginator-page{background-color:transparent;border:1px solid var(--cps-color-text-dark);border-radius:4px;color:var(--cps-color-text-dark);min-width:32px;height:32px;margin:.143rem;transition:box-shadow .2s}:host ::ng-deep .p-paginator-element:focus{z-index:1;position:relative}:host ::ng-deep span.p-paginator-icon{display:contents}:host ::ng-deep .p-disabled,:host ::ng-deep .p-component:disabled{opacity:.4}:host ::ng-deep .cps-treetable-empty-message-td{text-align:center!important;font-weight:600;background:#fff}:host ::ng-deep .p-treetable.p-treetable-gridlines .p-treetable-header{border-width:1px 1px 0 1px}:host ::ng-deep .p-treetable .p-treetable-header{font-weight:600;display:flex;justify-content:space-between;align-items:center;padding:0 10px;border:unset;background:unset;border-top:1px solid var(--cps-color-line-mid);border-right:1px solid var(--cps-color-line-mid);border-left:4px solid var(--cps-color-surprise)!important;border-radius:4px 4px 0 0;font-size:16px;line-height:150%;background-color:#fff;color:var(--cps-color-text-darkest);overflow:auto}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-left{display:flex;align-items:center}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-left .cps-treetable-tbar-global-filter{margin-left:12px}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-left .cps-treetable-tbar-icon{display:flex;margin-right:8px}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-left .cps-treetable-tbar-title{cursor:default}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right{display:flex;align-items:center}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right .cps-treetable-tbar-btn-on-select{margin-right:4px}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right .cps-treetable-tbar-action-btn{margin-right:4px;margin-left:8px}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right .cps-treetable-tbar-coltoggle-btn,:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right .cps-treetable-tbar-reload-btn{display:contents}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right .cps-treetable-tbar-coltoggle-btn cps-icon,:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right .cps-treetable-tbar-reload-btn cps-icon{margin-left:12px;margin-right:4px}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right .cps-treetable-tbar-coltoggle-btn:not(.btn-disabled) cps-icon,:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right .cps-treetable-tbar-reload-btn:not(.btn-disabled) cps-icon{cursor:pointer}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right .cps-treetable-tbar-coltoggle-btn:not(.btn-disabled) cps-icon:hover .cps-icon,:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right .cps-treetable-tbar-reload-btn:not(.btn-disabled) cps-icon:hover .cps-icon{color:var(--cps-color-prepared)!important}:host ::ng-deep .cps-tbar-small.p-treetable .p-treetable-header{height:43px}:host ::ng-deep .cps-tbar-normal.p-treetable .p-treetable-header{height:72px}:host ::ng-deep .p-treetable .p-treetable-footer{background:#fff;color:#343a40;border:1px solid var(--cps-color-line-mid);border-width:0 0 1px 0;padding:1rem;font-weight:700}:host ::ng-deep .p-treetable .p-treetable-tfoot>tr>td{text-align:left;padding:1rem;border:1px solid var(--cps-color-line-mid);border-width:0 0 1px 0;font-weight:700;color:#343a40;background:#fff}:host ::ng-deep .p-treetable .p-sortable-column:not(.p-highlight):hover .cps-sortable-column-icon.sort-unsorted .sort-unsorted-arrow-up{border-bottom-color:var(--cps-color-text-mild)}:host ::ng-deep .p-treetable .p-sortable-column:not(.p-highlight):hover .cps-sortable-column-icon.sort-unsorted .sort-unsorted-arrow-down{border-top-color:var(--cps-color-text-mild)}:host ::ng-deep .p-icon-wrapper{display:inline-flex}:host ::ng-deep .p-icon{display:inline-block;width:1rem;height:1rem}:host ::ng-deep .p-treetable .p-sortable-column .cps-sortable-column-badge{display:inline-flex;align-items:center;justify-content:center;font-size:12px;vertical-align:top;color:var(--cps-color-calm);margin-left:.25rem}:host ::ng-deep .p-link{text-align:left;background-color:transparent;margin:0;padding:0;border:none;cursor:pointer;-webkit-user-select:none;user-select:none}:host ::ng-deep .p-treetable .p-sortable-column{cursor:pointer;-webkit-user-select:none;user-select:none}:host ::ng-deep .p-treetable .p-sortable-column:focus{box-shadow:none;outline:0 none}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td .p-treetable-toggler.p-icon{width:2rem;height:2rem}:host ::ng-deep .p-treetable .p-treetable-tbody>tr.p-highlight{background:#eff6ff;color:#1d4ed8}:host ::ng-deep .p-treetable.p-treetable-hoverable-rows .p-treetable-tbody>tr:not(.p-highlight):hover{background:var(--cps-color-highlight-hover)}:host ::ng-deep .p-treetable-hoverable-rows .p-treetable-tbody>tr{cursor:auto}:host ::ng-deep .p-treetable .p-column-resizer-helper{background:var(--cps-color-calm)}:host ::ng-deep .p-treetable .p-treetable-loading-overlay{position:absolute;display:flex;align-items:center;justify-content:center;z-index:1001;top:0;left:0;width:100%;height:100%;background-color:#fff;transition-duration:.2s;border:1px solid var(--cps-color-line-mid)}:host ::ng-deep .p-treetable.cps-tbar-small .p-treetable-loading-overlay{top:43px;height:calc(100% - 43px)}:host ::ng-deep .p-treetable.cps-tbar-normal .p-treetable-loading-overlay{top:72px;height:calc(100% - 72px)}:host ::ng-deep .cps-treetable-loading .p-treetable{min-height:200px}:host ::ng-deep .cps-treetable-loading .p-treetable.cps-tbar-normal{min-height:272px}:host ::ng-deep .cps-treetable-loading .p-treetable.cps-tbar-small{min-height:243px}:host ::ng-deep .cps-table-col-filter-menu-open .cps-table-col-filter-menu-button{color:var(--cps-color-text-dark)}:host ::ng-deep .p-treetable.p-treetable-gridlines .p-treetable-footer{border-width:0 1px 1px 1px}:host ::ng-deep .p-treetable.p-treetable-gridlines .p-treetable-top{border-width:0 1px 0 1px}:host ::ng-deep .p-treetable.p-treetable-gridlines .p-treetable-bottom{border-width:0 1px 1px 1px}:host ::ng-deep .p-treetable .p-treetable-thead>tr>th{border-width:1px 0 1px 1px}:host ::ng-deep .p-treetable .p-treetable-thead>tr>th:last-child{border-width:1px}:host ::ng-deep .p-treetable.p-treetable-gridlines .p-treetable-tbody>tr>td{border-width:0 0 1px 1px}:host ::ng-deep .p-treetable.p-treetable-gridlines .p-treetable-tfoot>tr>td{border-width:1px}:host ::ng-deep .p-treetable.p-treetable-gridlines .p-treetable-tbody>tr>td:last-child{border-width:0 1px 1px 1px}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td:only-child{border-width:0 1px 1px 1px}:host ::ng-deep .p-treetable.p-treetable-sm .p-treetable-thead>tr>th{padding:.5rem}:host ::ng-deep .p-treetable.p-treetable-sm .p-treetable-tbody>tr>td{padding:.5rem}:host ::ng-deep .p-treetable.p-treetable-sm .p-treetable-tfoot>tr>td{padding:.5rem}:host ::ng-deep .p-treetable.p-treetable-sm .p-treetable-footer{padding:.5rem}:host ::ng-deep .p-treetable.p-treetable-lg .p-treetable-thead>tr>th{padding:1.25rem}:host ::ng-deep .p-treetable.p-treetable-lg .p-treetable-tbody>tr>td{padding:1.25rem}:host ::ng-deep .p-treetable.p-treetable-lg .p-treetable-tfoot>tr>td{padding:1.25rem}:host ::ng-deep .p-treetable.p-treetable-lg .p-treetable-footer{padding:1.25rem}:host ::ng-deep .p-treetable.p-treetable-striped .p-treetable-tbody>tr:nth-child(odd){background:var(--cps-color-bg-light)}:host ::ng-deep .p-treetable.p-treetable-striped .p-treetable-tbody>tr:nth-child(2n){background:#fff}:host ::ng-deep .cps-treetable-row-menu-cell{width:55px;border-left:none!important}:host ::ng-deep .cps-treetable-selectable-cell{width:55px;text-align:center!important}:host ::ng-deep .p-checkbox{display:inline-flex;cursor:pointer;-webkit-user-select:none;user-select:none;vertical-align:bottom;position:relative;width:18px;height:18px}:host ::ng-deep .p-hidden-accessible{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}:host ::ng-deep .p-hidden-accessible input,:host ::ng-deep .p-hidden-accessible select{transform:scale(0)}:host ::ng-deep .p-checkbox .p-checkbox-box{background:#fff;width:18px;height:18px;color:var(--cps-color-text-dark);border:2px solid var(--cps-color-text-mild);border-radius:2px;transition:background-color .2s,color .2s,border-color .2s,box-shadow .2s}:host ::ng-deep .p-checkbox-box{display:flex;justify-content:center;align-items:center}:host ::ng-deep .p-checkbox .p-checkbox-box.p-highlight{border-color:var(--cps-color-calm);background:var(--cps-color-calm)}:host ::ng-deep .p-checkbox:not(.p-checkbox-disabled) .p-checkbox-box.p-highlight:hover{border-color:var(--cps-color-calm);background:var(--cps-color-calm);color:#fff}:host ::ng-deep .p-checkbox:not(.p-checkbox-disabled) .p-checkbox-box:hover{border-color:var(--cps-color-calm)}:host ::ng-deep .p-checkbox .p-checkbox-box .p-icon{width:14px;height:14px}:host ::ng-deep .p-checkbox .p-checkbox-box .p-checkbox-icon{transition-duration:.2s;color:#fff;font-size:14px}:host ::ng-deep .p-checkbox .p-checkbox-box minusicon .p-checkbox-icon{color:var(--cps-color-calm);width:12px}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td p-treetablecheckbox .p-checkbox{margin-right:0}::ng-deep .p-scrollbar-measure{width:100px;height:100px;overflow:scroll;position:absolute;top:-9999px}.cps-treetable-coltoggle-menu{display:block;max-height:242px;overflow-x:hidden;background:#fff}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item{padding:12px;justify-content:space-between;display:flex;cursor:pointer}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item:hover{background:var(--cps-color-highlight-hover)}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item-label{color:var(--cps-color-text-dark)}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item-left{display:flex;align-items:center;margin-right:8px}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item-check{background-color:transparent;border:0;width:16px;height:16px;cursor:pointer;display:inline-block;vertical-align:middle;box-sizing:border-box;position:relative;flex-shrink:0;transition:border-color 90ms cubic-bezier(0,0,.2,.1),background-color 90ms cubic-bezier(0,0,.2,.1);margin-right:8px;opacity:0}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item-check:after{color:var(--cps-color-calm);top:4px;left:1px;width:8px;height:3px;border-left:2px solid currentColor;transform:rotate(-45deg);opacity:1;box-sizing:content-box;position:absolute;content:\"\";border-bottom:2px solid currentColor;transition:opacity 90ms cubic-bezier(0,0,.2,.1)}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item.selected,.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item.allselected{font-weight:600}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item.selected .cps-treetable-coltoggle-menu-item-label,.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item.allselected .cps-treetable-coltoggle-menu-item-label{color:var(--cps-color-calm)}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item.selected .cps-treetable-coltoggle-menu-item-check,.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item.allselected .cps-treetable-coltoggle-menu-item-check{opacity:1}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item.selected{background:var(--cps-color-highlight-selected)}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item.highlighten{background:var(--cps-color-highlight-active)}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item.selected.highlighten{background:var(--cps-color-highlight-selected-dark)}.cps-treetable-coltoggle-menu .select-all-option{border-bottom:1px solid lightgrey;font-weight:600}::ng-deep .cps-select-options-menu.cps-paginator-page-options .cps-select-options-option{font-size:14px}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "pipe", type: i2.DatePipe, name: "date" }, { kind: "ngmodule", type: TreeTableModule }, { kind: "component", type: i3.TreeTable, selector: "p-treeTable", inputs: ["columns", "style", "styleClass", "tableStyle", "tableStyleClass", "autoLayout", "lazy", "lazyLoadOnInit", "paginator", "rows", "first", "pageLinks", "rowsPerPageOptions", "alwaysShowPaginator", "paginatorPosition", "paginatorStyleClass", "paginatorDropdownAppendTo", "currentPageReportTemplate", "showCurrentPageReport", "showJumpToPageDropdown", "showFirstLastIcon", "showPageLinks", "defaultSortOrder", "sortMode", "resetPageOnSort", "customSort", "selectionMode", "contextMenuSelection", "contextMenuSelectionMode", "dataKey", "metaKeySelection", "compareSelectionBy", "rowHover", "loading", "loadingIcon", "showLoader", "scrollable", "scrollHeight", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "virtualScrollDelay", "frozenWidth", "frozenColumns", "resizableColumns", "columnResizeMode", "reorderableColumns", "contextMenu", "rowTrackBy", "filters", "globalFilterFields", "filterDelay", "filterMode", "filterLocale", "paginatorLocale", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection", "value", "virtualRowHeight", "selectionKeys"], outputs: ["selectionChange", "contextMenuSelectionChange", "onFilter", "onNodeExpand", "onNodeCollapse", "onPage", "onSort", "onLazyLoad", "sortFunction", "onColResize", "onColReorder", "onNodeSelect", "onNodeUnselect", "onContextMenuSelect", "onHeaderCheckboxToggle", "onEditInit", "onEditComplete", "onEditCancel", "selectionKeysChange"] }, { kind: "directive", type: i4.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "directive", type: i3.TTRow, selector: "[ttRow]", inputs: ["ttRow"] }, { kind: "component", type: CpsInputComponent, selector: "cps-input", inputs: ["label", "hint", "placeholder", "disabled", "readonly", "width", "type", "loading", "clearable", "prefixIcon", "prefixIconClickable", "prefixIconSize", "prefixText", "hideDetails", "persistentClear", "error", "infoTooltip", "infoTooltipClass", "infoTooltipMaxWidth", "infoTooltipPersistent", "infoTooltipPosition", "appearance", "valueToDisplay", "value"], outputs: ["valueChanged", "focused", "prefixIconClicked", "blurred", "cleared", "enterClicked"] }, { kind: "component", type: CpsButtonComponent, selector: "cps-button", inputs: ["color", "contentColor", "borderRadius", "type", "label", "icon", "iconPosition", "size", "width", "height", "disabled", "loading"], outputs: ["clicked"] }, { kind: "component", type: CpsMenuComponent, selector: "cps-menu", inputs: ["header", "items", "withArrow", "compressed", "focusOnShow", "persistent", "containerClass", "showTransitionOptions", "hideTransitionOptions"], outputs: ["menuShown", "menuHidden", "beforeMenuHidden", "contentClicked"] }, { kind: "component", type: CpsIconComponent, selector: "cps-icon", inputs: ["icon", "size", "color"] }, { kind: "component", type: CpsSelectComponent, selector: "cps-select", inputs: ["label", "placeholder", "hint", "returnObject", "multiple", "disabled", "width", "selectAll", "chips", "closableChips", "clearable", "openOnClear", "options", "keepInitialOrder", "optionLabel", "optionValue", "optionInfo", "optionIcon", "optionIconColor", "hideDetails", "persistentClear", "prefixIcon", "prefixIconSize", "loading", "virtualScroll", "numToleratedItems", "infoTooltip", "infoTooltipClass", "infoTooltipMaxWidth", "infoTooltipPersistent", "infoTooltipPosition", "optionsClass", "appearance", "showChevron", "value"], outputs: ["valueChanged", "focused", "blurred"] }, { kind: "component", type: CpsLoaderComponent, selector: "cps-loader", inputs: ["fullScreen", "opacity", "labelColor", "showLabel"] }, { kind: "component", type: AngleDoubleLeftIcon, selector: "AngleDoubleLeftIcon" }, { kind: "component", type: AngleLeftIcon, selector: "AngleLeftIcon" }, { kind: "component", type: AngleRightIcon, selector: "AngleRightIcon" }, { kind: "component", type: AngleDoubleRightIcon, selector: "AngleDoubleRightIcon" }, { kind: "directive", type: CpsTreeTableColumnSortableDirective, selector: "[cpsTTColSortable]", inputs: ["cpsTTColSortable"] }, { kind: "directive", type: CpsTreeTableColumnFilterDirective, selector: "[cpsTTColFilter]", inputs: ["cpsTTColFilter", "filterType", "filterPersistent", "filterShowClearButton", "filterShowApplyButton", "filterShowCloseButton", "filterShowMatchModes", "filterMatchModes", "filterShowOperator", "filterHeaderTitle", "filterHideOnClear", "filterCategoryOptions", "filterAsButtonToggle", "filterSingleSelection", "filterPlaceholder"], exportAs: ["cpsTTColFilter"] }, { kind: "directive", type: CpsTreeTableHeaderSelectableDirective, selector: "[cpsTTHdrSelectable]" }, { kind: "directive", type: CpsTreeTableRowSelectableDirective, selector: "[cpsTTRowSelectable]", inputs: ["cpsTTRowSelectable"] }, { kind: "directive", type: CpsTreetableRowTogglerDirective, selector: "[cpsTTRowToggler]", inputs: ["cpsTTRowToggler"] }, { kind: "directive", type: CpsTreeTableColumnResizableDirective, selector: "[cpsTTColResizable]", inputs: ["cpsTTColResizableDisabled"] }, { kind: "directive", type: TreeTableUnsortDirective, selector: "[ttWithUnsort]" }, { kind: "component", type: TableRowMenuComponent, selector: "table-row-menu", inputs: ["showRowRemoveButton", "customItems", "showRowEditButton"], outputs: ["editRowBtnClicked", "removeRowBtnClicked"] }, { kind: "pipe", type: CpsTreeTableDetectFilterTypePipe, name: "cpsTTDetectFilterType" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
1044
- }
1045
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.3", ngImport: i0, type: CpsTreeTableComponent, decorators: [{
1046
- type: Component,
1047
- args: [{ selector: 'cps-tree-table', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [
1048
- FormsModule,
1049
- CommonModule,
1050
- TreeTableModule,
1051
- CpsInputComponent,
1052
- CpsButtonComponent,
1053
- CpsMenuComponent,
1054
- CpsIconComponent,
1055
- CpsSelectComponent,
1056
- CpsLoaderComponent,
1057
- AngleDoubleLeftIcon,
1058
- AngleLeftIcon,
1059
- AngleRightIcon,
1060
- AngleDoubleRightIcon,
1061
- CpsTreeTableColumnSortableDirective,
1062
- CpsTreeTableColumnFilterDirective,
1063
- CpsTreeTableHeaderSelectableDirective,
1064
- CpsTreeTableRowSelectableDirective,
1065
- CpsTreetableRowTogglerDirective,
1066
- CpsTreeTableColumnResizableDirective,
1067
- TreeTableUnsortDirective,
1068
- TableRowMenuComponent,
1069
- CpsTreeTableDetectFilterTypePipe
1070
- ], providers: [
1071
- TreeTableService,
1072
- {
1073
- provide: TreeTable,
1074
- useFactory: treeTableFactory,
1075
- // eslint-disable-next-line no-use-before-define
1076
- deps: [CpsTreeTableComponent]
1077
- }
1078
- ], template: "<p-treeTable\n #primengTreeTable\n ttWithUnsort\n [ngClass]=\"{\n 'cps-treetable-loading': loading,\n 'cps-treetable-flex': defScrollHeight === 'flex',\n 'cps-treetable-nonvirtual': !virtualScroll,\n 'cps-treetable-autolayout-calced': autoLayout && scrollable\n }\"\n [value]=\"data\"\n [autoLayout]=\"autoLayout && !scrollable\"\n [scrollable]=\"scrollable\"\n [scrollHeight]=\"scrollHeight\"\n [virtualScroll]=\"virtualScroll\"\n [virtualScrollItemSize]=\"virtualScrollItemSize\"\n [virtualScrollOptions]=\"{\n numToleratedItems: numToleratedItems,\n autoSize: false\n }\"\n [columns]=\"selectedColumns\"\n [loading]=\"loading\"\n [rowHover]=\"rowHover\"\n [lazy]=\"lazy\"\n [(selection)]=\"selectedRows\"\n (selectionChange)=\"onSelectionChanged($event)\"\n compareSelectionBy=\"deepEquals\"\n [lazyLoadOnInit]=\"lazyLoadOnInit\"\n [styleClass]=\"styleClass\"\n [tableStyle]=\"tableStyle\"\n [tableStyleClass]=\"tableStyleClass\"\n [customSort]=\"customSort\"\n [sortMode]=\"sortMode\"\n [globalFilterFields]=\"globalFilterFields\"\n [paginator]=\"paginator\"\n [showCurrentPageReport]=\"true\"\n [alwaysShowPaginator]=\"alwaysShowPaginator\"\n [rows]=\"rows\"\n [first]=\"first\"\n [totalRecords]=\"totalRecords\"\n [resetPageOnSort]=\"resetPageOnSort\"\n [resizableColumns]=\"resizableColumns\"\n [columnResizeMode]=\"columnResizeMode\"\n currentPageReportTemplate=\"{first} - {last} of {totalRecords}\"\n (onPage)=\"onPageChange($event)\"\n (onSort)=\"onSort($event)\"\n (onFilter)=\"onFilter($event)\"\n (onLazyLoad)=\"onLazyLoaded($event)\"\n (sortFunction)=\"onSortFunction($event)\"\n (onNodeExpand)=\"onNodeExpanded($event)\"\n (onNodeCollapse)=\"onNodeCollapsed($event)\"\n (onNodeSelect)=\"onNodeSelected($event)\"\n (onNodeUnselect)=\"onNodeUnselected($event)\">\n @if (colgroupTemplate) {\n <ng-template pTemplate=\"colgroup\">\n <ng-container *ngTemplateOutlet=\"colgroupTemplate\"></ng-container>\n </ng-template>\n }\n <ng-template pTemplate=\"caption\" *ngIf=\"hasToolbar\">\n <ng-container *ngIf=\"toolbarTemplate\">\n <ng-container *ngTemplateOutlet=\"toolbarTemplate\"></ng-container>\n </ng-container>\n <ng-container *ngIf=\"!toolbarTemplate\">\n <div class=\"cps-treetable-tbar-left\">\n <div *ngIf=\"toolbarIcon\" class=\"cps-treetable-tbar-icon\">\n <cps-icon [icon]=\"toolbarIcon\" [color]=\"toolbarIconColor\"></cps-icon>\n </div>\n <div class=\"cps-treetable-tbar-title\">{{ toolbarTitle }}</div>\n <div *ngIf=\"showGlobalFilter\" class=\"cps-treetable-tbar-global-filter\">\n <cps-input\n #globalFilterComp\n prefixIcon=\"search\"\n [placeholder]=\"globalFilterPlaceholder\"\n (valueChanged)=\"onFilterGlobal($event)\"\n [clearable]=\"true\"\n [disabled]=\"loading\"\n [appearance]=\"toolbarSize === 'small' ? 'underlined' : 'outlined'\"\n [hideDetails]=\"true\">\n </cps-input>\n </div>\n </div>\n <div class=\"cps-treetable-tbar-right\">\n <div\n *ngIf=\"showRemoveBtnOnSelect && selectedRows.length > 0\"\n class=\"cps-treetable-tbar-btn-on-select\">\n <cps-button\n label=\"Remove\"\n [disabled]=\"removeBtnOnSelectDisabled\"\n color=\"prepared\"\n type=\"borderless\"\n icon=\"remove\"\n [size]=\"toolbarSize\"\n (clicked)=\"removeSelected()\">\n </cps-button>\n </div>\n <div\n *ngIf=\"showAdditionalBtnOnSelect && selectedRows.length > 0\"\n class=\"cps-treetable-tbar-btn-on-select\">\n <cps-button\n [label]=\"additionalBtnOnSelectTitle\"\n [disabled]=\"additionalBtnOnSelectDisabled\"\n color=\"prepared\"\n type=\"borderless\"\n [icon]=\"additionalBtnOnSelectIcon\"\n [size]=\"toolbarSize\"\n (clicked)=\"onClickAdditionalBtnOnSelect()\">\n </cps-button>\n </div>\n <div *ngIf=\"showActionBtn\" class=\"cps-treetable-tbar-action-btn\">\n <cps-button\n [label]=\"actionBtnTitle\"\n [disabled]=\"actionBtnDisabled\"\n color=\"prepared\"\n type=\"outlined\"\n [icon]=\"actionBtnIcon\"\n [size]=\"toolbarSize\"\n (clicked)=\"onClickActionBtn()\">\n </cps-button>\n </div>\n <div\n *ngIf=\"showColumnsToggleBtn && columns.length > 0\"\n class=\"cps-treetable-tbar-coltoggle-btn\"\n [ngClass]=\"{ 'btn-disabled': columnsToggleBtnDisabled }\">\n <cps-icon\n icon=\"columns\"\n size=\"normal\"\n [color]=\"\n columnsToggleBtnDisabled ? 'text-lightest' : 'prepared-lighten1'\n \"\n (click)=\"onColumnsToggle($event)\"></cps-icon>\n <cps-menu #colToggleMenu [withArrow]=\"false\">\n <div class=\"cps-treetable-coltoggle-menu\">\n <div\n class=\"cps-treetable-coltoggle-menu-item select-all-option\"\n [class.allselected]=\"selectedColumns.length === columns.length\"\n (click)=\"toggleAllColumns()\">\n <span class=\"cps-treetable-coltoggle-menu-item-left\">\n <span class=\"cps-treetable-coltoggle-menu-item-check\"> </span>\n <span class=\"cps-treetable-coltoggle-menu-item-label\"\n >Show all columns</span\n >\n </span>\n </div>\n <div\n *ngFor=\"let col of columns\"\n class=\"cps-treetable-coltoggle-menu-item\"\n (click)=\"onSelectColumn(col)\"\n [class.selected]=\"isColumnSelected(col)\">\n <span class=\"cps-treetable-coltoggle-menu-item-left\">\n <span class=\"cps-treetable-coltoggle-menu-item-check\"></span>\n <span class=\"cps-treetable-coltoggle-menu-item-label\">{{\n col[colHeaderName]\n }}</span>\n </span>\n </div>\n </div>\n </cps-menu>\n </div>\n <div\n *ngIf=\"showDataReloadBtn\"\n class=\"cps-treetable-tbar-reload-btn\"\n [ngClass]=\"{ 'btn-disabled': dataReloadBtnDisabled }\">\n <cps-icon\n icon=\"refresh\"\n size=\"18\"\n [color]=\"dataReloadBtnDisabled ? 'text-light' : 'prepared-lighten1'\"\n (click)=\"onReloadData()\">\n </cps-icon>\n </div>\n </div>\n </ng-container>\n </ng-template>\n\n <ng-template pTemplate=\"header\" *ngIf=\"nestedHeaderTemplate\" let-columns>\n <ng-container\n *ngTemplateOutlet=\"\n nestedHeaderTemplate;\n context: {\n $implicit: columns\n }\n \"></ng-container>\n </ng-template>\n\n <ng-template pTemplate=\"header\" *ngIf=\"!nestedHeaderTemplate\" let-columns>\n <tr>\n <!-- <th style=\"width: 3rem\" *ngIf=\"reorderableRows\"></th> -->\n <th\n *ngIf=\"selectable\"\n cpsTTHdrSelectable\n cpsTTColResizable\n [cpsTTColResizableDisabled]=\"!resizableColumns\"></th>\n <ng-container *ngIf=\"headerTemplate\">\n <ng-container\n *ngTemplateOutlet=\"\n headerTemplate;\n context: {\n $implicit: columns\n }\n \"></ng-container>\n </ng-container>\n <ng-container *ngIf=\"!headerTemplate && columns.length > 0\">\n <ng-container *ngIf=\"sortable\">\n @if (filterableByColumns) {\n <th\n *ngFor=\"let col of columns\"\n [cpsTTColSortable]=\"col[colFieldName]\"\n [cpsTTColFilter]=\"col[colFieldName]\"\n [filterType]=\"\n col[colFilterTypeName] ??\n (autoColumnFilterType\n ? (data | cpsTTDetectFilterType: col[colFieldName])\n : 'text')\n \"\n cpsTTColResizable\n [cpsTTColResizableDisabled]=\"!resizableColumns\">\n {{ col[colHeaderName] }}\n </th>\n } @else {\n <th\n *ngFor=\"let col of columns\"\n [cpsTTColSortable]=\"col[colFieldName]\"\n cpsTTColResizable\n [cpsTTColResizableDisabled]=\"!resizableColumns\">\n {{ col[colHeaderName] }}\n </th>\n }\n </ng-container>\n <ng-container *ngIf=\"!sortable\">\n @if (filterableByColumns) {\n <th\n *ngFor=\"let col of columns\"\n [cpsTTColFilter]=\"col[colFieldName]\"\n [filterType]=\"\n col[colFilterTypeName] ??\n (autoColumnFilterType\n ? (data | cpsTTDetectFilterType: col[colFieldName])\n : 'text')\n \"\n cpsTTColResizable\n [cpsTTColResizableDisabled]=\"!resizableColumns\">\n {{ col[colHeaderName] }}\n </th>\n } @else {\n <th\n *ngFor=\"let col of columns\"\n cpsTTColResizable\n [cpsTTColResizableDisabled]=\"!resizableColumns\">\n {{ col[colHeaderName] }}\n </th>\n }\n </ng-container>\n </ng-container>\n <th\n class=\"cps-treetable-row-menu-cell\"\n *ngIf=\"showRowMenu && (showRowRemoveButton || showRowEditButton)\"\n cpsTTColResizable\n [cpsTTColResizableDisabled]=\"!resizableColumns\"></th>\n </tr>\n </ng-template>\n\n <ng-template\n pTemplate=\"body\"\n let-rowData=\"rowData\"\n let-columns=\"columns\"\n let-rowNode\n let-rowIndex=\"rowIndex\">\n <tr\n [ttRow]=\"rowNode\"\n [ngClass]=\"{\n 'cps-treetable-row-selected':\n selectable && primengTreeTable.isSelected(rowNode.node)\n }\">\n <!-- <td *ngIf=\"reorderableRows\" class=\"cps-table-row-drag-handle-cell\">\n <span class=\"cps-table-row-drag-handle\" pReorderableRowHandle>\u2630</span>\n </td> -->\n <td [cpsTTRowSelectable]=\"rowNode\" *ngIf=\"selectable\"></td>\n <ng-container *ngIf=\"bodyTemplate\">\n <ng-container\n *ngTemplateOutlet=\"\n bodyTemplate;\n context: {\n $implicit: rowNode,\n rowIndex: rowIndex,\n columns: columns,\n rowData: rowData\n }\n \">\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"!bodyTemplate\">\n <ng-container *ngIf=\"columns.length > 0\">\n @if (renderDataAsHTML) {\n <ng-container *ngFor=\"let col of columns; let i = index\">\n <td\n *ngIf=\"i === 0\"\n [cpsTTRowToggler]=\"rowNode\"\n [innerHTML]=\"rowData[col[colFieldName]]\"></td>\n <td *ngIf=\"i > 0\" [innerHTML]=\"rowData[col[colFieldName]]\"></td>\n </ng-container>\n } @else {\n <ng-container *ngFor=\"let col of columns; let i = index\">\n <td *ngIf=\"i === 0\" [cpsTTRowToggler]=\"rowNode\">\n {{\n col[colDateFormatName]\n ? (rowData[col[colFieldName]]\n | date: col[colDateFormatName])\n : rowData[col[colFieldName]]\n }}\n </td>\n <td *ngIf=\"i > 0\">\n {{\n col[colDateFormatName]\n ? (rowData[col[colFieldName]]\n | date: col[colDateFormatName])\n : rowData[col[colFieldName]]\n }}\n </td>\n </ng-container>\n }\n </ng-container>\n </ng-container>\n <td\n *ngIf=\"showRowMenu && (showRowRemoveButton || showRowEditButton)\"\n class=\"cps-treetable-row-menu-cell\">\n <table-row-menu\n (editRowBtnClicked)=\"onEditRowClicked(rowNode.node)\"\n (removeRowBtnClicked)=\"onRemoveRowClicked(rowNode.node)\"\n [showRowRemoveButton]=\"showRowRemoveButton\"\n [showRowEditButton]=\"showRowEditButton\"\n [customItems]=\"rowMenuItems\">\n </table-row-menu>\n </td>\n </tr>\n </ng-template>\n <ng-template pTemplate=\"emptymessage\">\n <tr>\n <td\n colspan=\"100\"\n class=\"cps-treetable-empty-message-td\"\n [ngStyle]=\"{ height: emptyBodyHeight }\">\n {{ emptyMessage }}\n </td>\n </tr>\n </ng-template>\n <ng-template pTemplate=\"loadingicon\">\n <cps-loader [fullScreen]=\"false\" opacity=\"0\"></cps-loader>\n </ng-template>\n <ng-template pTemplate=\"paginatorleft\">\n <div class=\"cps-table-paginator-itms-per-page\">\n <span class=\"cps-table-paginator-items-per-page-title\"\n >Rows per page:\n </span>\n <cps-select\n [options]=\"rowOptions\"\n [hideDetails]=\"true\"\n [(ngModel)]=\"rows\"\n (valueChanged)=\"onRowsPerPageChanged()\"\n [returnObject]=\"false\"\n optionsClass=\"cps-paginator-page-options\">\n </cps-select>\n </div>\n </ng-template>\n\n <ng-template pTemplate=\"paginatorfirstpagelinkicon\">\n <AngleDoubleLeftIcon />\n </ng-template>\n <ng-template pTemplate=\"paginatorpreviouspagelinkicon\">\n <AngleLeftIcon />\n </ng-template>\n <ng-template pTemplate=\"paginatornextpagelinkicon\">\n <AngleRightIcon />\n </ng-template>\n <ng-template pTemplate=\"paginatorlastpagelinkicon\">\n <AngleDoubleRightIcon />\n </ng-template>\n</p-treeTable>\n", styles: [":host ::ng-deep .p-treetable{position:relative}:host ::ng-deep .p-component,:host ::ng-deep .p-component *{box-sizing:border-box}:host ::ng-deep .p-component{font-family:Source Sans Pro,sans-serif;font-size:14px;font-weight:400}:host ::ng-deep .p-treetable-scrollable-wrapper{position:relative;background:#fff}:host ::ng-deep .p-treetable-wrapper{background:#fff}:host ::ng-deep .cps-treetable-nonvirtual.cps-treetable-flex .p-treetable-flex-scrollable.cps-tbar-normal .p-treetable-scrollable-wrapper{height:calc(100% - 72px)}:host ::ng-deep .cps-treetable-nonvirtual.cps-treetable-flex .p-treetable-flex-scrollable.cps-tbar-small .p-treetable-scrollable-wrapper{height:calc(100% - 43px)}:host ::ng-deep .cps-treetable-nonvirtual.cps-treetable-flex .p-treetable-flex-scrollable .p-treetable-scrollable-wrapper .p-treetable-scrollable-view .p-treetable-scrollable-header{display:contents}:host ::ng-deep .p-treetable .p-treetable-scrollable-header,:host ::ng-deep .p-treetable .p-treetable-scrollable-footer{background:#fff}:host ::ng-deep .p-treetable-scrollable-header,:host ::ng-deep .p-treetable-scrollable-footer{overflow:hidden}:host ::ng-deep .p-treetable table{border-collapse:collapse;width:100%;table-layout:fixed}:host ::ng-deep .p-treetable .p-treetable-thead>tr>th{text-align:left;padding:1rem;border:1px solid var(--cps-color-line-mid);border-width:0 0 1px 1px;font-weight:400;color:var(--cps-color-text-mild);background:#fff;transition:box-shadow .2s;overflow:hidden}:host ::ng-deep .p-treetable-scrollable-body{overflow:auto!important;position:relative}:host ::ng-deep .cps-treetable-flex .p-treetable-scrollable-body{height:100%}:host ::ng-deep .p-treetable .p-treetable-tbody{background:#fff}:host ::ng-deep .p-treetable .p-treetable-tbody>tr{background:#fff;color:var(--cps-color-text-dark);transition:box-shadow .2s}:host ::ng-deep .p-treetable .p-treetable-tbody>tr.cps-treetable-row-selected{background-color:var(--cps-color-highlight-active)!important}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td{text-align:left;border:1px solid var(--cps-color-line-mid);border-width:0 0 1px 0;padding:1rem}:host ::ng-deep p-treetable:not(.cps-treetable-autolayout-calced) .p-treetable .p-treetable-tbody>tr>td{overflow:hidden}:host ::ng-deep .cps-treetable-autolayout-calced .p-treetable .p-treetable-scrollable-body .p-treetable-tbody>tr>td:not(.cps-treetable-row-toggler-cell):not(.cps-treetable-selectable-cell):not(.cps-treetable-row-menu-cell):not(.cps-treetable-empty-message-td){opacity:0;border-left-color:#fff}:host ::ng-deep .cps-treetable-autolayout-calced .p-treetable.p-treetable-striped .p-treetable-scrollable-body .p-treetable-tbody>tr:nth-child(odd)>td:not(.cps-treetable-row-toggler-cell):not(.cps-treetable-selectable-cell):not(.cps-treetable-row-menu-cell):not(.cps-treetable-empty-message-td){border-left-color:var(--cps-color-bg-light)}:host ::ng-deep .cps-treetable-autolayout-calced .p-treetable .p-treetable-scrollable-body .p-treetable-tbody>tr:hover>td:not(.cps-treetable-row-toggler-cell):not(.cps-treetable-selectable-cell):not(.cps-treetable-row-menu-cell):not(.cps-treetable-empty-message-td){border-left-color:var(--cps-color-highlight-hover)}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td:first-child{border-width:0 0 1px 1px}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td:last-child{border-width:0 1px 1px 0}:host ::ng-deep .p-treetable-auto-layout table{table-layout:auto}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td .p-treetable-toggler{width:1rem;height:1rem;color:var(--cps-color-text-dark);border:0 none;background:transparent;border-radius:50%;margin-right:.5rem}:host ::ng-deep .p-treetable-toggler{cursor:pointer;-webkit-user-select:none;user-select:none;display:inline-flex;align-items:center;justify-content:center;vertical-align:middle;overflow:hidden;position:relative}:host ::ng-deep .p-ripple{overflow:hidden;position:relative}:host ::ng-deep .p-link:focus{outline:0 none;outline-offset:0;box-shadow:unset}:host ::ng-deep .p-link{text-align:left;background-color:transparent;margin:0;padding:0;border:none;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:14px;font-family:Source Sans Pro,sans-serif;border-radius:6px}:host ::ng-deep input[type=button],:host ::ng-deep input[type=submit],:host ::ng-deep input[type=reset],:host ::ng-deep input[type=file]::-webkit-file-upload-button,:host ::ng-deep button{border-radius:0}:host ::ng-deep .p-treetable .p-treetable-tbody>tr:focus{outline:0 none;outline-offset:-.15rem}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td .p-treetable-toggler:enabled:hover{color:var(--cps-color-calm);border-color:transparent;background:unset}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td .p-treetable-toggler:focus{outline:0 none;outline-offset:0;box-shadow:unset}:host ::ng-deep .p-treetable .p-paginator{border-width:0 1px 1px 1px;border-radius:0}:host ::ng-deep .p-paginator{background:#fff;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;color:var(--cps-color-text-dark);padding:1rem;border:1px solid var(--cps-color-line-mid)}:host ::ng-deep .p-paginator-left-content{margin-right:auto}:host ::ng-deep .p-paginator-left-content .cps-table-paginator-itms-per-page{display:inline-flex;align-items:center}:host ::ng-deep .p-paginator-left-content .cps-table-paginator-itms-per-page .cps-table-paginator-items-per-page-title{font-family:Source Sans Pro,sans-serif;font-size:14px;margin-right:12px;cursor:default}:host ::ng-deep .p-paginator-left-content .cps-table-paginator-itms-per-page .cps-select-box{min-height:32px!important;background:transparent!important}:host ::ng-deep .p-paginator-left-content .cps-table-paginator-itms-per-page .cps-select-box .cps-select-box-items{font-size:14px!important}:host ::ng-deep .p-paginator-left-content .cps-table-paginator-itms-per-page .cps-select-box .cps-select-box-chevron .cps-icon{width:14px;height:14px}:host ::ng-deep .p-paginator .p-paginator-current{background-color:transparent;border:0 none;color:var(--cps-color-text-dark);min-width:3rem;margin:.143rem;padding:0 .5rem;font-family:Source Sans Pro,sans-serif;font-size:14px;height:unset}:host ::ng-deep .p-paginator-page,:host ::ng-deep .p-paginator-next,:host ::ng-deep .p-paginator-last,:host ::ng-deep .p-paginator-first,:host ::ng-deep .p-paginator-prev,:host ::ng-deep .p-paginator-current{cursor:pointer;display:inline-flex;align-items:center;justify-content:center;line-height:1;-webkit-user-select:none;user-select:none;overflow:hidden;position:relative}:host ::ng-deep .p-paginator-current{cursor:default}:host ::ng-deep .p-paginator .p-paginator-first:not(.p-disabled):not(.p-highlight):hover,:host ::ng-deep .p-paginator .p-paginator-prev:not(.p-disabled):not(.p-highlight):hover,:host ::ng-deep .p-paginator .p-paginator-next:not(.p-disabled):not(.p-highlight):hover,:host ::ng-deep .p-paginator .p-paginator-last:not(.p-disabled):not(.p-highlight):hover{background:var(--cps-color-highlight-hover);border-color:unset}:host ::ng-deep .p-paginator .p-paginator-first:not(.p-disabled):not(.p-highlight):active,:host ::ng-deep .p-paginator .p-paginator-prev:not(.p-disabled):not(.p-highlight):active,:host ::ng-deep .p-paginator .p-paginator-next:not(.p-disabled):not(.p-highlight):active,:host ::ng-deep .p-paginator .p-paginator-last:not(.p-disabled):not(.p-highlight):active{background:var(--cps-color-highlight-active)}:host ::ng-deep .p-paginator .p-paginator-first,:host ::ng-deep .p-paginator .p-paginator-prev,:host ::ng-deep .p-paginator .p-paginator-next,:host ::ng-deep .p-paginator .p-paginator-last{background-color:transparent;border:1px solid var(--cps-color-text-dark);border-radius:4px;color:var(--cps-color-text-dark);min-width:32px;height:32px;margin:.143rem;transition:box-shadow .2s}:host ::ng-deep .p-disabled,:host ::ng-deep .p-disabled *{cursor:default!important;pointer-events:none}:host ::ng-deep .p-paginator .p-paginator-pages .p-paginator-page.p-highlight{background:var(--cps-color-calm);border-color:var(--cps-color-calm);color:#fff}:host ::ng-deep .p-paginator .p-paginator-pages .p-paginator-page:not(.p-highlight):hover{background:var(--cps-color-highlight-hover);border-color:unset}:host ::ng-deep .p-paginator .p-paginator-pages .p-paginator-page:not(.p-highlight):active{background:var(--cps-color-highlight-active)}:host ::ng-deep .p-paginator .p-paginator-pages .p-paginator-page{background-color:transparent;border:1px solid var(--cps-color-text-dark);border-radius:4px;color:var(--cps-color-text-dark);min-width:32px;height:32px;margin:.143rem;transition:box-shadow .2s}:host ::ng-deep .p-paginator-element:focus{z-index:1;position:relative}:host ::ng-deep span.p-paginator-icon{display:contents}:host ::ng-deep .p-disabled,:host ::ng-deep .p-component:disabled{opacity:.4}:host ::ng-deep .cps-treetable-empty-message-td{text-align:center!important;font-weight:600;background:#fff}:host ::ng-deep .p-treetable.p-treetable-gridlines .p-treetable-header{border-width:1px 1px 0 1px}:host ::ng-deep .p-treetable .p-treetable-header{font-weight:600;display:flex;justify-content:space-between;align-items:center;padding:0 10px;border:unset;background:unset;border-top:1px solid var(--cps-color-line-mid);border-right:1px solid var(--cps-color-line-mid);border-left:4px solid var(--cps-color-surprise)!important;border-radius:4px 4px 0 0;font-size:16px;line-height:150%;background-color:#fff;color:var(--cps-color-text-darkest);overflow:auto}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-left{display:flex;align-items:center}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-left .cps-treetable-tbar-global-filter{margin-left:12px}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-left .cps-treetable-tbar-icon{display:flex;margin-right:8px}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-left .cps-treetable-tbar-title{cursor:default}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right{display:flex;align-items:center}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right .cps-treetable-tbar-btn-on-select{margin-right:4px}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right .cps-treetable-tbar-action-btn{margin-right:4px;margin-left:8px}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right .cps-treetable-tbar-coltoggle-btn,:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right .cps-treetable-tbar-reload-btn{display:contents}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right .cps-treetable-tbar-coltoggle-btn cps-icon,:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right .cps-treetable-tbar-reload-btn cps-icon{margin-left:12px;margin-right:4px}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right .cps-treetable-tbar-coltoggle-btn:not(.btn-disabled) cps-icon,:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right .cps-treetable-tbar-reload-btn:not(.btn-disabled) cps-icon{cursor:pointer}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right .cps-treetable-tbar-coltoggle-btn:not(.btn-disabled) cps-icon:hover .cps-icon,:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right .cps-treetable-tbar-reload-btn:not(.btn-disabled) cps-icon:hover .cps-icon{color:var(--cps-color-prepared)!important}:host ::ng-deep .cps-tbar-small.p-treetable .p-treetable-header{height:43px}:host ::ng-deep .cps-tbar-normal.p-treetable .p-treetable-header{height:72px}:host ::ng-deep .p-treetable .p-treetable-footer{background:#fff;color:#343a40;border:1px solid var(--cps-color-line-mid);border-width:0 0 1px 0;padding:1rem;font-weight:700}:host ::ng-deep .p-treetable .p-treetable-tfoot>tr>td{text-align:left;padding:1rem;border:1px solid var(--cps-color-line-mid);border-width:0 0 1px 0;font-weight:700;color:#343a40;background:#fff}:host ::ng-deep .p-treetable .p-sortable-column:not(.p-highlight):hover .cps-sortable-column-icon.sort-unsorted .sort-unsorted-arrow-up{border-bottom-color:var(--cps-color-text-mild)}:host ::ng-deep .p-treetable .p-sortable-column:not(.p-highlight):hover .cps-sortable-column-icon.sort-unsorted .sort-unsorted-arrow-down{border-top-color:var(--cps-color-text-mild)}:host ::ng-deep .p-icon-wrapper{display:inline-flex}:host ::ng-deep .p-icon{display:inline-block;width:1rem;height:1rem}:host ::ng-deep .p-treetable .p-sortable-column .cps-sortable-column-badge{display:inline-flex;align-items:center;justify-content:center;font-size:12px;vertical-align:top;color:var(--cps-color-calm);margin-left:.25rem}:host ::ng-deep .p-link{text-align:left;background-color:transparent;margin:0;padding:0;border:none;cursor:pointer;-webkit-user-select:none;user-select:none}:host ::ng-deep .p-treetable .p-sortable-column{cursor:pointer;-webkit-user-select:none;user-select:none}:host ::ng-deep .p-treetable .p-sortable-column:focus{box-shadow:none;outline:0 none}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td .p-treetable-toggler.p-icon{width:2rem;height:2rem}:host ::ng-deep .p-treetable .p-treetable-tbody>tr.p-highlight{background:#eff6ff;color:#1d4ed8}:host ::ng-deep .p-treetable.p-treetable-hoverable-rows .p-treetable-tbody>tr:not(.p-highlight):hover{background:var(--cps-color-highlight-hover)}:host ::ng-deep .p-treetable-hoverable-rows .p-treetable-tbody>tr{cursor:auto}:host ::ng-deep .p-treetable .p-column-resizer-helper{background:var(--cps-color-calm)}:host ::ng-deep .p-treetable .p-treetable-loading-overlay{position:absolute;display:flex;align-items:center;justify-content:center;z-index:1001;top:0;left:0;width:100%;height:100%;background-color:#fff;transition-duration:.2s;border:1px solid var(--cps-color-line-mid)}:host ::ng-deep .p-treetable.cps-tbar-small .p-treetable-loading-overlay{top:43px;height:calc(100% - 43px)}:host ::ng-deep .p-treetable.cps-tbar-normal .p-treetable-loading-overlay{top:72px;height:calc(100% - 72px)}:host ::ng-deep .cps-treetable-loading .p-treetable{min-height:200px}:host ::ng-deep .cps-treetable-loading .p-treetable.cps-tbar-normal{min-height:272px}:host ::ng-deep .cps-treetable-loading .p-treetable.cps-tbar-small{min-height:243px}:host ::ng-deep .cps-table-col-filter-menu-open .cps-table-col-filter-menu-button{color:var(--cps-color-text-dark)}:host ::ng-deep .p-treetable.p-treetable-gridlines .p-treetable-footer{border-width:0 1px 1px 1px}:host ::ng-deep .p-treetable.p-treetable-gridlines .p-treetable-top{border-width:0 1px 0 1px}:host ::ng-deep .p-treetable.p-treetable-gridlines .p-treetable-bottom{border-width:0 1px 1px 1px}:host ::ng-deep .p-treetable .p-treetable-thead>tr>th{border-width:1px 0 1px 1px}:host ::ng-deep .p-treetable .p-treetable-thead>tr>th:last-child{border-width:1px}:host ::ng-deep .p-treetable.p-treetable-gridlines .p-treetable-tbody>tr>td{border-width:0 0 1px 1px}:host ::ng-deep .p-treetable.p-treetable-gridlines .p-treetable-tfoot>tr>td{border-width:1px}:host ::ng-deep .p-treetable.p-treetable-gridlines .p-treetable-tbody>tr>td:last-child{border-width:0 1px 1px 1px}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td:only-child{border-width:0 1px 1px 1px}:host ::ng-deep .p-treetable.p-treetable-sm .p-treetable-thead>tr>th{padding:.5rem}:host ::ng-deep .p-treetable.p-treetable-sm .p-treetable-tbody>tr>td{padding:.5rem}:host ::ng-deep .p-treetable.p-treetable-sm .p-treetable-tfoot>tr>td{padding:.5rem}:host ::ng-deep .p-treetable.p-treetable-sm .p-treetable-footer{padding:.5rem}:host ::ng-deep .p-treetable.p-treetable-lg .p-treetable-thead>tr>th{padding:1.25rem}:host ::ng-deep .p-treetable.p-treetable-lg .p-treetable-tbody>tr>td{padding:1.25rem}:host ::ng-deep .p-treetable.p-treetable-lg .p-treetable-tfoot>tr>td{padding:1.25rem}:host ::ng-deep .p-treetable.p-treetable-lg .p-treetable-footer{padding:1.25rem}:host ::ng-deep .p-treetable.p-treetable-striped .p-treetable-tbody>tr:nth-child(odd){background:var(--cps-color-bg-light)}:host ::ng-deep .p-treetable.p-treetable-striped .p-treetable-tbody>tr:nth-child(2n){background:#fff}:host ::ng-deep .cps-treetable-row-menu-cell{width:55px;border-left:none!important}:host ::ng-deep .cps-treetable-selectable-cell{width:55px;text-align:center!important}:host ::ng-deep .p-checkbox{display:inline-flex;cursor:pointer;-webkit-user-select:none;user-select:none;vertical-align:bottom;position:relative;width:18px;height:18px}:host ::ng-deep .p-hidden-accessible{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}:host ::ng-deep .p-hidden-accessible input,:host ::ng-deep .p-hidden-accessible select{transform:scale(0)}:host ::ng-deep .p-checkbox .p-checkbox-box{background:#fff;width:18px;height:18px;color:var(--cps-color-text-dark);border:2px solid var(--cps-color-text-mild);border-radius:2px;transition:background-color .2s,color .2s,border-color .2s,box-shadow .2s}:host ::ng-deep .p-checkbox-box{display:flex;justify-content:center;align-items:center}:host ::ng-deep .p-checkbox .p-checkbox-box.p-highlight{border-color:var(--cps-color-calm);background:var(--cps-color-calm)}:host ::ng-deep .p-checkbox:not(.p-checkbox-disabled) .p-checkbox-box.p-highlight:hover{border-color:var(--cps-color-calm);background:var(--cps-color-calm);color:#fff}:host ::ng-deep .p-checkbox:not(.p-checkbox-disabled) .p-checkbox-box:hover{border-color:var(--cps-color-calm)}:host ::ng-deep .p-checkbox .p-checkbox-box .p-icon{width:14px;height:14px}:host ::ng-deep .p-checkbox .p-checkbox-box .p-checkbox-icon{transition-duration:.2s;color:#fff;font-size:14px}:host ::ng-deep .p-checkbox .p-checkbox-box minusicon .p-checkbox-icon{color:var(--cps-color-calm);width:12px}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td p-treetablecheckbox .p-checkbox{margin-right:0}::ng-deep .p-scrollbar-measure{width:100px;height:100px;overflow:scroll;position:absolute;top:-9999px}.cps-treetable-coltoggle-menu{display:block;max-height:242px;overflow-x:hidden;background:#fff}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item{padding:12px;justify-content:space-between;display:flex;cursor:pointer}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item:hover{background:var(--cps-color-highlight-hover)}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item-label{color:var(--cps-color-text-dark)}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item-left{display:flex;align-items:center;margin-right:8px}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item-check{background-color:transparent;border:0;width:16px;height:16px;cursor:pointer;display:inline-block;vertical-align:middle;box-sizing:border-box;position:relative;flex-shrink:0;transition:border-color 90ms cubic-bezier(0,0,.2,.1),background-color 90ms cubic-bezier(0,0,.2,.1);margin-right:8px;opacity:0}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item-check:after{color:var(--cps-color-calm);top:4px;left:1px;width:8px;height:3px;border-left:2px solid currentColor;transform:rotate(-45deg);opacity:1;box-sizing:content-box;position:absolute;content:\"\";border-bottom:2px solid currentColor;transition:opacity 90ms cubic-bezier(0,0,.2,.1)}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item.selected,.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item.allselected{font-weight:600}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item.selected .cps-treetable-coltoggle-menu-item-label,.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item.allselected .cps-treetable-coltoggle-menu-item-label{color:var(--cps-color-calm)}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item.selected .cps-treetable-coltoggle-menu-item-check,.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item.allselected .cps-treetable-coltoggle-menu-item-check{opacity:1}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item.selected{background:var(--cps-color-highlight-selected)}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item.highlighten{background:var(--cps-color-highlight-active)}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item.selected.highlighten{background:var(--cps-color-highlight-selected-dark)}.cps-treetable-coltoggle-menu .select-all-option{border-bottom:1px solid lightgrey;font-weight:600}::ng-deep .cps-select-options-menu.cps-paginator-page-options .cps-select-options-option{font-size:14px}\n"] }]
1079
- }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: Document, decorators: [{
1080
- type: Inject,
1081
- args: [DOCUMENT]
1082
- }] }, { type: i0.Renderer2 }, { type: i0.NgZone }], propDecorators: { columns: [{
1083
- type: Input
1084
- }], colHeaderName: [{
1085
- type: Input
1086
- }], colFieldName: [{
1087
- type: Input
1088
- }], colFilterTypeName: [{
1089
- type: Input
1090
- }], colDateFormatName: [{
1091
- type: Input
1092
- }], minWidth: [{
1093
- type: Input
1094
- }], minWidthForBodyOnly: [{
1095
- type: Input
1096
- }], autoLayout: [{
1097
- type: Input
1098
- }], striped: [{
1099
- type: Input
1100
- }], bordered: [{
1101
- type: Input
1102
- }], size: [{
1103
- type: Input
1104
- }], selectable: [{
1105
- type: Input
1106
- }], rowHover: [{
1107
- type: Input
1108
- }], showRowMenu: [{
1109
- type: Input
1110
- }], showRowRemoveButton: [{
1111
- type: Input
1112
- }], showRowEditButton: [{
1113
- type: Input
1114
- }], rowMenuItems: [{
1115
- type: Input
1116
- }], loading: [{
1117
- type: Input
1118
- }], tableStyle: [{
1119
- type: Input
1120
- }], tableStyleClass: [{
1121
- type: Input
1122
- }], sortable: [{
1123
- type: Input
1124
- }], sortMode: [{
1125
- type: Input
1126
- }], customSort: [{
1127
- type: Input
1128
- }], hasToolbar: [{
1129
- type: Input
1130
- }], toolbarSize: [{
1131
- type: Input
1132
- }], toolbarTitle: [{
1133
- type: Input
1134
- }], toolbarIcon: [{
1135
- type: Input
1136
- }], toolbarIconColor: [{
1137
- type: Input
1138
- }], scrollable: [{
1139
- type: Input
1140
- }], scrollHeight: [{
1141
- type: Input
1142
- }], virtualScroll: [{
1143
- type: Input
1144
- }], virtualScrollItemHeight: [{
1145
- type: Input
1146
- }], numToleratedItems: [{
1147
- type: Input
1148
- }], paginator: [{
1149
- type: Input
1150
- }], alwaysShowPaginator: [{
1151
- type: Input
1152
- }], rowsPerPageOptions: [{
1153
- type: Input
1154
- }], first: [{
1155
- type: Input
1156
- }], rows: [{
1157
- type: Input
1158
- }], resetPageOnRowsChange: [{
1159
- type: Input
1160
- }], resetPageOnSort: [{
1161
- type: Input
1162
- }], totalRecords: [{
1163
- type: Input
1164
- }], emptyMessage: [{
1165
- type: Input
1166
- }], emptyBodyHeight: [{
1167
- type: Input
1168
- }], lazy: [{
1169
- type: Input
1170
- }], lazyLoadOnInit: [{
1171
- type: Input
1172
- }], showGlobalFilter: [{
1173
- type: Input
1174
- }], globalFilterPlaceholder: [{
1175
- type: Input
1176
- }], globalFilterFields: [{
1177
- type: Input
1178
- }], clearGlobalFilterOnLoading: [{
1179
- type: Input
1180
- }], showRemoveBtnOnSelect: [{
1181
- type: Input
1182
- }], removeBtnOnSelectDisabled: [{
1183
- type: Input
1184
- }], showAdditionalBtnOnSelect: [{
1185
- type: Input
1186
- }], additionalBtnOnSelectTitle: [{
1187
- type: Input
1188
- }], additionalBtnOnSelectIcon: [{
1189
- type: Input
1190
- }], additionalBtnOnSelectDisabled: [{
1191
- type: Input
1192
- }], showActionBtn: [{
1193
- type: Input
1194
- }], actionBtnTitle: [{
1195
- type: Input
1196
- }], actionBtnIcon: [{
1197
- type: Input
1198
- }], actionBtnDisabled: [{
1199
- type: Input
1200
- }], showDataReloadBtn: [{
1201
- type: Input
1202
- }], dataReloadBtnDisabled: [{
1203
- type: Input
1204
- }], showColumnsToggleBtn: [{
1205
- type: Input
1206
- }], columnsToggleBtnDisabled: [{
1207
- type: Input
1208
- }], initialColumns: [{
1209
- type: Input
1210
- }], filterableByColumns: [{
1211
- type: Input
1212
- }], autoColumnFilterType: [{
1213
- type: Input
1214
- }], renderDataAsHTML: [{
1215
- type: Input
1216
- }], data: [{
1217
- type: Input
1218
- }], resizableColumns: [{
1219
- type: Input
1220
- }], columnResizeMode: [{
1221
- type: Input
1222
- }], rowsSelected: [{
1223
- type: Output
1224
- }], actionBtnClicked: [{
1225
- type: Output
1226
- }], additionalBtnOnSelectClicked: [{
1227
- type: Output
1228
- }], editRowBtnClicked: [{
1229
- type: Output
1230
- }], rowsToRemove: [{
1231
- type: Output
1232
- }], pageChanged: [{
1233
- type: Output
1234
- }], sorted: [{
1235
- type: Output
1236
- }], filtered: [{
1237
- type: Output
1238
- }], columnsSelected: [{
1239
- type: Output
1240
- }], lazyLoaded: [{
1241
- type: Output
1242
- }], dataReloadBtnClicked: [{
1243
- type: Output
1244
- }], nodeExpanded: [{
1245
- type: Output
1246
- }], nodeCollapsed: [{
1247
- type: Output
1248
- }], nodeSelected: [{
1249
- type: Output
1250
- }], nodeUnselected: [{
1251
- type: Output
1252
- }], customSortFunction: [{
1253
- type: Output
1254
- }], toolbarTemplate: [{
1255
- type: ContentChild,
1256
- args: ['toolbar', { static: false }]
1257
- }], headerTemplate: [{
1258
- type: ContentChild,
1259
- args: ['header', { static: false }]
1260
- }], nestedHeaderTemplate: [{
1261
- type: ContentChild,
1262
- args: ['nestedHeader', { static: false }]
1263
- }], bodyTemplate: [{
1264
- type: ContentChild,
1265
- args: ['body', { static: false }]
1266
- }], colgroupTemplate: [{
1267
- type: ContentChild,
1268
- args: ['colgroup', { static: false }]
1269
- }], primengTreeTable: [{
1270
- type: ViewChild,
1271
- args: ['primengTreeTable', { static: true }]
1272
- }], globalFilterComp: [{
1273
- type: ViewChild,
1274
- args: ['globalFilterComp']
1275
- }], colToggleMenu: [{
1276
- type: ViewChild,
1277
- args: ['colToggleMenu']
1278
- }] } });
1279
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-tree-table.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-tree-table/cps-tree-table.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-tree-table/cps-tree-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewChecked,\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  EventEmitter,\n  Inject,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  Renderer2,\n  RendererStyleFlags2,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild\n} from '@angular/core';\nimport { CommonModule, DOCUMENT } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport {\n  TreeTable,\n  TreeTableService,\n  TreeTableModule,\n  TreeTableSortEvent\n} from 'primeng/treetable';\nimport { DomHandler } from 'primeng/dom';\nimport { AngleDoubleLeftIcon } from 'primeng/icons/angledoubleleft';\nimport { AngleLeftIcon } from 'primeng/icons/angleleft';\nimport { AngleRightIcon } from 'primeng/icons/angleright';\nimport { AngleDoubleRightIcon } from 'primeng/icons/angledoubleright';\nimport { cloneDeep, isEqual } from 'lodash-es';\nimport { CpsInputComponent } from '../cps-input/cps-input.component';\nimport { CpsButtonComponent } from '../cps-button/cps-button.component';\nimport { CpsMenuComponent, CpsMenuItem } from '../cps-menu/cps-menu.component';\nimport { CpsIconComponent } from '../cps-icon/cps-icon.component';\nimport { CpsSelectComponent } from '../cps-select/cps-select.component';\nimport { CpsLoaderComponent } from '../cps-loader/cps-loader.component';\nimport { CpsTreeTableColumnSortableDirective } from './directives/cps-tree-table-column-sortable.directive';\nimport { TreeTableUnsortDirective } from './directives/internal/tree-table-unsort.directive';\nimport { TableRowMenuComponent } from '../cps-table/components/internal/table-row-menu/table-row-menu.component';\nimport { convertSize } from '../../utils/internal/size-utils';\nimport { CpsTreeTableHeaderSelectableDirective } from './directives/cps-tree-table-header-selectable.directive';\nimport { CpsTreeTableRowSelectableDirective } from './directives/cps-tree-table-row-selectable.directive';\nimport { CpsTreetableRowTogglerDirective } from './directives/cps-tree-table-row-toggler.directive';\nimport { Subscription, fromEvent } from 'rxjs';\nimport { CpsTreeTableColumnFilterDirective } from './directives/cps-tree-table-column-filter.directive';\nimport { CpsTreeTableDetectFilterTypePipe } from './pipes/cps-tree-table-detect-filter-type.pipe';\nimport { CpsTreeTableColumnResizableDirective } from './directives/cps-tree-table-column-resizable.directive';\n\nexport function treeTableFactory(tableComponent: CpsTreeTableComponent) {\n  return tableComponent.primengTreeTable;\n}\n\n/**\n * CpsTreeTableSize is used to define the size of the tree table.\n * @group Types\n */\nexport type CpsTreeTableSize = 'small' | 'normal' | 'large';\n\n/**\n * CpsTreeTableToolbarSize is used to define the size of the tree table toolbar.\n * @group Types\n */\nexport type CpsTreeTableToolbarSize = 'small' | 'normal';\n\n/**\n * CpsTreeTableSortMode is used to define the sorting mode of the tree table.\n * @group Types\n */\nexport type CpsTreeTableSortMode = 'single' | 'multiple';\n\n/**\n * CpsTreeTableComponent is used to display hierarchical data in tabular format.\n * @group Components\n */\n@Component({\n  selector: 'cps-tree-table',\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    FormsModule,\n    CommonModule,\n    TreeTableModule,\n    CpsInputComponent,\n    CpsButtonComponent,\n    CpsMenuComponent,\n    CpsIconComponent,\n    CpsSelectComponent,\n    CpsLoaderComponent,\n    AngleDoubleLeftIcon,\n    AngleLeftIcon,\n    AngleRightIcon,\n    AngleDoubleRightIcon,\n    CpsTreeTableColumnSortableDirective,\n    CpsTreeTableColumnFilterDirective,\n    CpsTreeTableHeaderSelectableDirective,\n    CpsTreeTableRowSelectableDirective,\n    CpsTreetableRowTogglerDirective,\n    CpsTreeTableColumnResizableDirective,\n    TreeTableUnsortDirective,\n    TableRowMenuComponent,\n    CpsTreeTableDetectFilterTypePipe\n  ],\n  templateUrl: './cps-tree-table.component.html',\n  styleUrls: ['./cps-tree-table.component.scss'],\n  providers: [\n    TreeTableService,\n    {\n      provide: TreeTable,\n      useFactory: treeTableFactory,\n      // eslint-disable-next-line no-use-before-define\n      deps: [CpsTreeTableComponent]\n    }\n  ]\n})\nexport class CpsTreeTableComponent\n  implements OnInit, AfterViewInit, OnDestroy, AfterViewChecked, OnChanges\n{\n  /**\n   * An array of objects to represent dynamic columns.\n   * @group Props\n   */\n  @Input() columns: { [key: string]: any }[] = [];\n\n  /**\n   * A key used to retrieve the header from columns.\n   * @group Props\n   */\n  @Input() colHeaderName = 'header';\n\n  /**\n   * A key used to retrieve the field from columns.\n   * @group Props\n   */\n  @Input() colFieldName = 'field';\n\n  /**\n   * A key used to retrieve the filter type from columns.\n   * @group Props\n   */\n  @Input() colFilterTypeName = 'filterType';\n\n  /**\n   * A key used to retrieve the date format from columns.\n   * @group Props\n   */\n  @Input() colDateFormatName = 'dateFormat';\n\n  /**\n   * Treetable min width of type number denoting pixels or string.\n   * @group Props\n   */\n  @Input() minWidth: number | string = '';\n\n  /**\n   * Determines whether minWidth prop is used for treetable body only, excluding toolbar and paginator.\n   * @group Props\n   */\n  @Input() minWidthForBodyOnly = true;\n\n  /**\n   * Determines whether the cell widths scale according to their content or not.\n   * @group Props\n   */\n  @Input() autoLayout = true;\n\n  /**\n   * Determines whether the treetable should have alternating stripes.\n   * @group Props\n   */\n  @Input() striped = true;\n\n  /**\n   * Determines whether the treetable should have borders.\n   * @group Props\n   */\n  @Input() bordered = true;\n\n  /**\n   * Size of treetable cells, it can be \"small\", \"normal\" or \"large\".\n   * @group Props\n   */\n  @Input() size: CpsTreeTableSize = 'normal';\n\n  /**\n   * Determines whether the treetable should have row selection.\n   * @group Props\n   */\n  @Input() selectable = false;\n\n  /**\n   * Determines whether the treetable should have rows highlighting on hover.\n   * @group Props\n   */\n  @Input() rowHover = true;\n\n  /**\n   * Determines whether the treetable should show row menus.\n   * @group Props\n   */\n  @Input() showRowMenu = false;\n\n  /**\n   * Determines whether the 'Remove' button should be displayed in the row menu.\n   * Note: This setting only takes effect if 'showRowMenu' is true and 'rowMenuItems' is not set.\n   * @group Props\n   */\n  @Input() showRowRemoveButton = true;\n\n  /**\n   * Determines whether the 'Edit' button should be displayed in the row menu.\n   * Note: This setting only takes effect if 'showRowMenu' is true and 'rowMenuItems' is not set.\n   * @group Props\n   */\n  @Input() showRowEditButton = true;\n\n  /**\n   * Custom items to be displayed in the row menu.\n   * Note: This setting only takes effect if 'showRowMenu' is true.\n   * @group Props\n   */\n  @Input() rowMenuItems?: CpsMenuItem[];\n\n  /**\n   * When enabled, a loader component is displayed.\n   * @group Props\n   */\n  @Input() loading = false;\n\n  /**\n   * Inline style of the treetable.\n   * @group Props\n   */\n  @Input() tableStyle = undefined;\n\n  /**\n   * Style class of the treetable.\n   * @group Props\n   */\n  @Input() tableStyleClass = '';\n\n  /**\n   * Makes all columns sortable if columns prop is provided.\n   * @group Props\n   */\n  @Input() sortable = false;\n\n  /**\n   * Determines whether sorting works on single column or on multiple columns.\n   * @group Props\n   */\n  @Input() sortMode: CpsTreeTableSortMode = 'single';\n\n  /**\n   * Determines whether to use the default sorting or a custom one using sortFunction.\n   * @group Props\n   */\n  @Input() customSort = false;\n\n  /**\n   * Determines whether the treetable has a toolbar.\n   * @group Props\n   */\n  @Input() hasToolbar = true;\n\n  /**\n   * Toolbar size, it can be \"small\" or \"normal\".\n   * @group Props\n   */\n  @Input() toolbarSize: CpsTreeTableToolbarSize = 'normal';\n\n  /**\n   * Toolbar title.\n   * @group Props\n   */\n  @Input() toolbarTitle = '';\n\n  /**\n   * Toolbar icon name.\n   * @group Props\n   */\n  @Input() toolbarIcon = '';\n\n  /**\n   * Toolbar icon color.\n   * @group Props\n   */\n  @Input() toolbarIconColor = '';\n\n  /**\n   * Makes treetable scrollable.\n   * @group Props\n   */\n  @Input() scrollable = true;\n\n  /**\n   * Height of the scroll viewport in fixed pixels or the \"flex\" keyword for a dynamic size.\n   * @group Props\n   */\n  @Input() scrollHeight = '';\n\n  /**\n   * Determines whether only the elements within scrollable area should be added into the DOM. Works only if scrollable prop is true.\n   * @group Props\n   */\n  @Input() virtualScroll = false;\n\n  /**\n   * Height of a virtual scroll item in fixed pixels.\n   * @group Props\n   */\n  @Input() virtualScrollItemHeight = 0;\n\n  /**\n   * Determines how many additional elements to add to the DOM outside of the view.\n   * @group Props\n   */\n  @Input() numToleratedItems = 10;\n\n  /**\n   * Determines whether the treetable should have paginator.\n   * @group Props\n   */\n  @Input() paginator = false;\n\n  /**\n   * Determines whether to show paginator even there is only one page.\n   * @group Props\n   */\n  @Input() alwaysShowPaginator = true;\n\n  /**\n   * Array of integer values to display inside rows per page dropdown of paginator.\n   * @group Props\n   */\n  @Input() rowsPerPageOptions: number[] = [];\n\n  /**\n   * Index of the first row to be displayed.\n   * @group Props\n   */\n  @Input() first = 0;\n\n  /**\n   * Number of rows to display per page.\n   * @group Props\n   */\n  @Input() rows = 0;\n\n  /**\n   * Determines whether to reset page on rows change.\n   * @group Props\n   */\n  @Input() resetPageOnRowsChange = false;\n\n  /**\n   * Determines whether to reset page on treetable data sorting.\n   * @group Props\n   */\n  @Input() resetPageOnSort = true;\n\n  /**\n   * Number of total records.\n   * @group Props\n   */\n  @Input() totalRecords = 0;\n\n  /**\n   * Text to display when there is no data.\n   * @group Props\n   */\n  @Input() emptyMessage = 'No data';\n\n  /**\n   * Height of treetable's body when there is no data, of type number denoting pixels or string.\n   * @group Props\n   */\n  @Input() emptyBodyHeight: number | string = '';\n\n  /**\n   * Defines if data is loaded and interacted with in lazy manner.\n   * @group Props\n   */\n  @Input() lazy = false;\n\n  /**\n   * Determines whether to call lazy loading on initialization.\n   * @group Props\n   */\n  @Input() lazyLoadOnInit = true;\n\n  /**\n   * Determines whether to show global filter in the toolbar.\n   * @group Props\n   */\n  @Input() showGlobalFilter = false;\n\n  /**\n   * Global filter placeholder.\n   * @group Props\n   */\n  @Input() globalFilterPlaceholder = 'Search';\n\n  /**\n   * An array of fields to use in global filtering.\n   * @group Props\n   */\n  @Input() globalFilterFields: string[] = [];\n\n  /**\n   * Determines whether to clear global filter on data loading.\n   * @group Props\n   */\n  @Input() clearGlobalFilterOnLoading = false;\n\n  /**\n   * Determines whether to show remove button in the toolbar when rows are selected.\n   * @group Props\n   */\n  @Input() showRemoveBtnOnSelect = true;\n\n  /**\n   * Determines whether removeBtnOnSelect is disabled.\n   * @group Props\n   */\n  @Input() removeBtnOnSelectDisabled = false;\n\n  /**\n   * Determines whether to show additional button in the toolbar when rows are selected.\n   * @group Props\n   */\n  @Input() showAdditionalBtnOnSelect = false;\n\n  /**\n   * AdditionalBtnOnSelect title.\n   * @group Props\n   */\n  @Input() additionalBtnOnSelectTitle = 'Select action';\n\n  /**\n   * AdditionalBtnOnSelect icon.\n   * @group Props\n   */\n  @Input() additionalBtnOnSelectIcon = '';\n\n  /**\n   * Determines whether additionalBtnOnSelect is disabled.\n   * @group Props\n   */\n  @Input() additionalBtnOnSelectDisabled = false;\n\n  /**\n   * Determines whether to show action button in the toolbar.\n   * @group Props\n   */\n  @Input() showActionBtn = false;\n\n  /**\n   * Action button title.\n   * @group Props\n   */\n  @Input() actionBtnTitle = 'Action';\n\n  /**\n   * Action button icon.\n   * @group Props\n   */\n  @Input() actionBtnIcon = '';\n\n  /**\n   * Determines whether actionBtn is disabled.\n   * @group Props\n   */\n  @Input() actionBtnDisabled = false;\n\n  /**\n   * Determines whether to show data reload button in the toolbar.\n   * @group Props\n   */\n  @Input() showDataReloadBtn = false;\n\n  /**\n   * Determines whether dataReloadBtn is disabled.\n   * @group Props\n   */\n  @Input() dataReloadBtnDisabled = false;\n\n  /**\n   * Determines whether the treetable should show columnsToggle menu, where you can choose which columns to be displayed. If external body template is provided, use columnsSelected event emitter.\n   * @group Props\n   */\n  @Input() showColumnsToggleBtn = false;\n\n  /**\n   * Determines whether columnsToggle button is disabled.\n   * @group Props\n   */\n  @Input() columnsToggleBtnDisabled = false;\n\n  /**\n   * Array of initial columns to show in the treetable. If not provided, all columns are initially visible.\n   * @group Props\n   */\n  @Input() initialColumns: { [key: string]: any }[] = [];\n\n  /**\n   * Enable filtering on all columns.\n   * @group Props\n   */\n  @Input() filterableByColumns = false;\n\n  /**\n   * If true, automatically detects filter type based on values, otherwise sets 'text' filter type for all columns.\n   * Note: This setting only takes effect if 'filterableByColumns' is true.\n   * @group Props\n   */\n  @Input() autoColumnFilterType = true;\n\n  /**\n   * If set to true, row data are rendered using innerHTML.\n   * @group Props\n   */\n  @Input() renderDataAsHTML = false;\n\n  /**\n   * An array of objects to display.\n   * @default []\n   * @group Props\n   */\n  @Input() set data(value: any[]) {\n    const clone = cloneDeep(value);\n    if (clone && clone.length > 0) {\n      let i = 0;\n      clone.forEach((v: any) => {\n        v._defaultSortOrder = i++;\n      });\n    }\n    this._data = clone;\n  }\n\n  get data(): any[] {\n    return this._data;\n  }\n\n  /**\n   * Determines whether columns are resizable.\n   * In case of using a custom template for columns, it is also needed to add cpsTTColResizable directive to th elements.\n   * @group Props\n   */\n  @Input() resizableColumns = false;\n\n  /**\n   * Determines how the columns are resized. It can be 'fit' (total width of the table stays the same) or 'expand' (total width of the table changes when resizing columns).\n   * Note: This setting only takes effect if 'resizableColumns' is true.\n   *\n   * @group Props\n   */\n  @Input() columnResizeMode: 'fit' | 'expand' = 'fit';\n\n  /**\n   * Callback to invoke on selected rows change.\n   * @param {any[]} any[] - selected rows.\n   * @group Emits\n   */\n  @Output() rowsSelected = new EventEmitter<any[]>();\n\n  /**\n   * Callback to invoke when action button is clicked.\n   * @param {void} void - action button clicked.\n   * @group Emits\n   */\n  @Output() actionBtnClicked = new EventEmitter<void>();\n\n  /**\n   * Callback to invoke when additional button on select is clicked.\n   * @param {any[]} any[] - selected data.\n   * @group Emits\n   */\n  @Output() additionalBtnOnSelectClicked = new EventEmitter<any[]>();\n\n  /**\n   * Callback to invoke when edit-row button is clicked.\n   * @param {any} any - button clicked.\n   * @group Emits\n   */\n  @Output() editRowBtnClicked = new EventEmitter<any>();\n\n  /**\n   * Callback to invoke when rows are removed.\n   * @param {any[]} any[] - array of rows to remove.\n   * @group Emits\n   */\n  @Output() rowsToRemove = new EventEmitter<any[]>();\n\n  /**\n   * Callback to invoke when page is changed.\n   * @param {any} any - page changed.\n   * @group Emits\n   */\n  @Output() pageChanged = new EventEmitter<any>();\n\n  /**\n   * Callback to invoke when data is sorted.\n   * @param {any} any - Sort data.\n   * @group Emits\n   */\n  @Output() sorted = new EventEmitter<any>();\n\n  /**\n   * Callback to invoke when data is filtered.\n   * @param {any} any - Custom filter event.\n   * @group Emits\n   */\n  @Output() filtered = new EventEmitter<any>();\n\n  /**\n   * Callback to invoke on selected columns.\n   * @param {any[]} object[] - selection changed.\n   * @group Emits\n   */\n  @Output() columnsSelected = new EventEmitter<{ [key: string]: any }[]>();\n\n  /**\n   * Callback to invoke when paging, sorting or filtering happens in lazy mode.\n   * @param {any} any - Custom lazy load event.\n   * @group Emits\n   */\n  @Output() lazyLoaded = new EventEmitter<any>();\n\n  /**\n   * Callback to invoke when data reload button is clicked.\n   * @param {any} any - data reload button clicked.\n   * @group Emits\n   */\n  @Output() dataReloadBtnClicked = new EventEmitter<any>();\n\n  /**\n   * Callback to invoke when a node is expanded.\n   * @param {any} any - Node instance.\n   * @group Emits\n   */\n  @Output() nodeExpanded = new EventEmitter<any>();\n\n  /**\n   * Callback to invoke when a node is collapsed.\n   * @param {any} any - Node collapse event.\n   * @group Emits\n   */\n  @Output() nodeCollapsed = new EventEmitter<any>();\n\n  /**\n   * Callback to invoke when a node is selected.\n   * @param {any} any - Node instance.\n   * @group Emits\n   */\n  @Output() nodeSelected = new EventEmitter<any>();\n\n  /**\n   * Callback to invoke when a node is unselected.\n   * @param {any} any - Custom node unselect event.\n   * @group Emits\n   */\n  @Output() nodeUnselected = new EventEmitter<any>();\n\n  /**\n   * A function to implement custom sorting. customSort must be true.\n   * @param {any} any - sort meta.\n   * @group Emits\n   */\n  @Output() customSortFunction: EventEmitter<any> = new EventEmitter<any>();\n\n  @ContentChild('toolbar', { static: false })\n  public toolbarTemplate!: TemplateRef<any>;\n\n  @ContentChild('header', { static: false })\n  public headerTemplate!: TemplateRef<any>;\n\n  @ContentChild('nestedHeader', { static: false })\n  public nestedHeaderTemplate!: TemplateRef<any>;\n\n  @ContentChild('body', { static: false })\n  public bodyTemplate!: TemplateRef<any>;\n\n  @ContentChild('colgroup', { static: false })\n  public colgroupTemplate?: TemplateRef<any>;\n\n  @ViewChild('primengTreeTable', { static: true })\n  primengTreeTable!: TreeTable;\n\n  @ViewChild('globalFilterComp')\n  globalFilterComp!: CpsInputComponent;\n\n  @ViewChild('colToggleMenu')\n  colToggleMenu!: CpsMenuComponent;\n\n  selectedColumns: { [key: string]: any }[] = [];\n\n  rowOptions: { label: string; value: number }[] = [];\n\n  selectedRows: any = [];\n\n  virtualScrollItemSize = 0;\n  defScrollHeight = '';\n\n  private _defScrollHeightPx = 0;\n  private _defScrollHeightPxInitial = 0;\n\n  private _resizeObserver: ResizeObserver;\n  private _windowResizeDebouncer: any;\n  private _scrollSubscription?: Subscription;\n\n  private _headerBox: any;\n  private _scrollableBody: any;\n  private _scrollbarWidth = 0;\n  private _scrollbarVisible = true;\n\n  private _needRecalcAutoLayout = true;\n\n  private _data: any[] = [];\n\n  private window: Window;\n\n  // eslint-disable-next-line no-useless-constructor\n  constructor(\n    private cdRef: ChangeDetectorRef,\n    @Inject(DOCUMENT) private document: Document,\n    private renderer: Renderer2,\n    private ngZone: NgZone\n  ) {\n    this.window = this.document.defaultView as Window;\n    this._resizeObserver = new ResizeObserver((entries) => {\n      entries.forEach((entry) => {\n        const body = entry.target;\n        this._scrollbarVisible = body.scrollHeight > body.clientHeight;\n\n        if (this._scrollbarVisible && this.virtualScroll)\n          this.renderer.setStyle(\n            this._scrollableBody,\n            'overflow',\n            'auto',\n            RendererStyleFlags2.Important\n          );\n\n        let wScroll = this._scrollbarVisible ? this._scrollbarWidth : 0;\n        if (wScroll > 0) wScroll -= 1;\n\n        this.renderer.setStyle(\n          this._headerBox,\n          'padding-right',\n          `${wScroll}px`\n        );\n        this.renderer.setStyle(\n          this._headerBox,\n          'border-right',\n          wScroll > 0 ? '1px solid #d7d5d5' : 'unset'\n        );\n\n        this._calcAutoLayoutHeaderWidths();\n      });\n    });\n  }\n\n  ngOnInit(): void {\n    if (!this.scrollable) this.virtualScroll = false;\n    this.emptyBodyHeight = convertSize(this.emptyBodyHeight);\n    this.minWidth = convertSize(this.minWidth);\n\n    if (this.showAdditionalBtnOnSelect) this.showRemoveBtnOnSelect = false;\n\n    this.defScrollHeight = this.scrollHeight;\n    if (this.virtualScroll) {\n      this.window.addEventListener('resize', this._onWindowResize.bind(this));\n\n      if (this.defScrollHeight && this.defScrollHeight !== 'flex') {\n        this._defScrollHeightPx = parseInt(this.scrollHeight, 10);\n      }\n    }\n\n    if (this.paginator) {\n      if (this.rowsPerPageOptions.length < 1)\n        this.rowsPerPageOptions = [5, 10, 25, 50];\n\n      if (!this.rows) this.rows = this.rowsPerPageOptions[0];\n      else {\n        if (!this.rowsPerPageOptions.includes(this.rows)) {\n          throw new Error('rowsPerPageOptions must include rows');\n        }\n      }\n\n      this.rowOptions = this.rowsPerPageOptions.map((v) => ({\n        label: '' + v,\n        value: v\n      }));\n    }\n\n    if (\n      this.showGlobalFilter &&\n      this.globalFilterFields?.length < 1 &&\n      this.data?.length > 0\n    ) {\n      this.globalFilterFields = Object.keys(this.data[0].data);\n    }\n\n    this.selectedColumns =\n      this.initialColumns.length > 0 ? this.initialColumns : this.columns;\n  }\n\n  ngAfterViewInit(): void {\n    this._setMinWidthOverall();\n\n    this._scrollableBody = this.primengTreeTable.el.nativeElement.querySelector(\n      '.p-treetable-scrollable-body'\n    );\n    if (this._scrollableBody) {\n      if (this.minWidthForBodyOnly && this.minWidth) {\n        const table = this._scrollableBody.querySelector('table');\n        if (table) this.renderer.setStyle(table, 'min-width', this.minWidth);\n      }\n\n      if (this.virtualScroll) {\n        if (this.defScrollHeight === 'flex') {\n          this._defScrollHeightPx = this._scrollableBody.clientHeight;\n          this._defScrollHeightPxInitial = this._defScrollHeightPx;\n        }\n        if (this.autoLayout) {\n          this._scrollSubscription = fromEvent(\n            this._scrollableBody,\n            'scroll'\n          ).subscribe(() => {\n            this._calcAutoLayoutHeaderWidths(true);\n          });\n        }\n      }\n\n      this._headerBox = this.primengTreeTable.el.nativeElement.querySelector(\n        '.p-treetable-scrollable-header-box'\n      );\n\n      if (this._headerBox) {\n        if (this.minWidthForBodyOnly && this.minWidth) {\n          const table = this._headerBox.querySelector('table');\n          if (table) this.renderer.setStyle(table, 'min-width', this.minWidth);\n        }\n\n        this._scrollbarWidth = DomHandler.calculateScrollbarWidth();\n        this._resizeObserver.observe(this._scrollableBody);\n      }\n\n      if (this._needRecalcAutoLayout) {\n        this._calcAutoLayoutHeaderWidths();\n        this.cdRef.detectChanges();\n      }\n    }\n\n    if (!this.scrollable) {\n      const tableWrapper =\n        this.primengTreeTable.el?.nativeElement?.querySelector(\n          '.p-treetable-wrapper'\n        );\n      if (tableWrapper && this.minWidthForBodyOnly && this.minWidth) {\n        const table = tableWrapper.querySelector('table');\n        if (table) this.renderer.setStyle(table, 'min-width', this.minWidth);\n      }\n    }\n  }\n\n  ngAfterViewChecked() {\n    if (this._needRecalcAutoLayout) {\n      this._calcAutoLayoutHeaderWidths();\n      this.cdRef.detectChanges();\n    }\n    if (!this.virtualScroll) return;\n\n    if (!this._defScrollHeightPx && this.defScrollHeight === 'flex') {\n      this._defScrollHeightPx = this._scrollableBody.clientHeight;\n      this._defScrollHeightPxInitial = this._defScrollHeightPx;\n      this.cdRef.detectChanges();\n    }\n\n    if (!this.virtualScrollItemSize) {\n      setTimeout(() => {\n        this._recalcVirtualHeight();\n        this.cdRef.detectChanges();\n      });\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.loading) {\n      this.clearSelection();\n      if (this.clearGlobalFilterOnLoading) this.clearGlobalFilter();\n    }\n\n    if (this.virtualScrollItemHeight)\n      this.virtualScrollItemSize = this.virtualScrollItemHeight;\n\n    this._setMinWidthOverall();\n\n    const dataChanges = changes?.data;\n\n    if (dataChanges?.previousValue !== dataChanges?.currentValue) {\n      this.clearSelection();\n      setTimeout(() => {\n        this._calcAutoLayoutHeaderWidths(true);\n      });\n    }\n\n    this._calcAutoLayoutHeaderWidths(true);\n    this._recalcVirtualHeight();\n  }\n\n  ngOnDestroy(): void {\n    this._resizeObserver?.disconnect();\n    if (this.virtualScroll) {\n      if (this.autoLayout) this._scrollSubscription?.unsubscribe();\n      this.window.removeEventListener(\n        'resize',\n        this._onWindowResize.bind(this)\n      );\n    }\n  }\n\n  private _calcAutoLayoutHeaderWidths(forced = false) {\n    this.ngZone.runOutsideAngular(() => {\n      if (!this.autoLayout || !this.scrollable) return;\n\n      if (!this._needRecalcAutoLayout && !forced) return;\n\n      const headerRows = this._headerBox?.querySelectorAll('tr');\n      if (!headerRows?.length) return;\n\n      const headerCells =\n        headerRows[headerRows.length - 1]?.querySelectorAll('th');\n      if (!headerCells?.length) return;\n\n      let hasSelectableCell = false;\n      let hasRowMenuCell = false;\n\n      const ths = Array.from(headerCells);\n      if (ths.every((th: any) => th.offsetWidth === 0)) return;\n\n      const thWidths = ths.map((th: any) => {\n        const wprev = th.style.width;\n\n        const isSelectableCell = th.classList.contains(\n          'cps-treetable-selectable-cell'\n        );\n\n        const isRowCell = th.classList.contains('cps-treetable-row-menu-cell');\n\n        if (isSelectableCell) hasSelectableCell = true;\n        if (isRowCell) hasRowMenuCell = true;\n\n        let thWidth = 55;\n        if (!isSelectableCell && !isRowCell) {\n          this.renderer.setStyle(th, 'width', 'min-content');\n          this.renderer.setStyle(th, 'display', 'block');\n          this.renderer.setStyle(th, 'text-wrap', 'nowrap');\n          thWidth = th.offsetWidth;\n          this.renderer.setStyle(th, 'width', wprev);\n          this.renderer.removeStyle(th, 'display');\n          this.renderer.removeStyle(th, 'text-wrap');\n        }\n        return thWidth;\n      });\n\n      const bodyRows = this._scrollableBody?.querySelectorAll('tr');\n      if (!bodyRows?.length) return;\n\n      const tdWidths: number[] = [];\n      const fragment = this.document.createDocumentFragment();\n      const hiddenDiv = this.document.createElement('div');\n      hiddenDiv.style.visibility = 'hidden';\n      hiddenDiv.style.position = 'absolute';\n      hiddenDiv.style.whiteSpace = 'nowrap';\n\n      this.document.body.appendChild(hiddenDiv);\n      bodyRows.forEach((tr: HTMLElement) => {\n        const tds = tr?.querySelectorAll('td');\n        tds?.forEach((td: HTMLElement, idx: number) => {\n          const isSelectableOrRowMenuCell =\n            td.classList.contains('cps-treetable-selectable-cell') ||\n            td.classList.contains('cps-treetable-row-menu-cell');\n\n          let tdWidth = 55;\n          if (!isSelectableOrRowMenuCell) {\n            const clonedTd = td.cloneNode(true) as HTMLElement;\n            fragment.appendChild(clonedTd);\n            this.renderer.setStyle(clonedTd, 'width', 'min-content');\n            this.renderer.setStyle(clonedTd, 'display', 'block');\n            hiddenDiv.innerHTML = clonedTd.innerHTML;\n            hiddenDiv.style.width = 'auto';\n            tdWidth = hiddenDiv.offsetWidth;\n            fragment.removeChild(clonedTd);\n          }\n          if (!tdWidths[idx]) tdWidths[idx] = 0;\n          tdWidths[idx] = Math.max(tdWidths[idx], tdWidth);\n        });\n      });\n      this.document.body.removeChild(hiddenDiv);\n\n      if (thWidths.length !== tdWidths.length) return;\n\n      const maxWidths = thWidths.map((v, idx) => Math.max(v, tdWidths[idx]));\n      let sum = maxWidths.reduce((a, b) => a + b, 0);\n      if (hasSelectableCell) {\n        sum -= 55;\n        maxWidths.shift();\n      }\n      if (hasRowMenuCell) {\n        sum -= 55;\n        maxWidths.pop();\n      }\n\n      const percentages = maxWidths.map((v) => (v / sum) * 100);\n\n      headerCells.forEach((th: any, idx: number) => {\n        if (\n          (hasSelectableCell && idx === 0) ||\n          (hasRowMenuCell && idx === headerCells.length - 1)\n        ) {\n          this.renderer.setStyle(th, 'width', '55px');\n        } else\n          this.renderer.setStyle(\n            th,\n            'width',\n            percentages[hasSelectableCell ? idx - 1 : idx] + '%'\n          );\n      });\n\n      bodyRows.forEach((tr: HTMLElement) => {\n        const tds = tr?.querySelectorAll('td');\n        tds?.forEach((td: HTMLElement, idx: number) => {\n          if (\n            (hasSelectableCell && idx === 0) ||\n            (hasRowMenuCell && idx === tds.length - 1)\n          ) {\n            this.renderer.setStyle(td, 'width', '55px');\n          } else {\n            this.renderer.setStyle(\n              td,\n              'width',\n              percentages[hasSelectableCell ? idx - 1 : idx] + '%'\n            );\n          }\n          this.renderer.setStyle(td, 'opacity', '1');\n          this.renderer.setStyle(td, 'overflow', 'hidden');\n          if (this.bordered)\n            this.renderer.setStyle(\n              td,\n              'border-left-color',\n              'var(--cps-color-line-mid)'\n            );\n        });\n      });\n\n      this._needRecalcAutoLayout = false;\n    });\n  }\n\n  private _updateVirtualScrollItemSize() {\n    if (!this.virtualScroll || this.virtualScrollItemHeight) return;\n\n    const trs = this.primengTreeTable?.el?.nativeElement\n      ?.querySelector('.p-treetable-tbody')\n      ?.querySelectorAll('tr');\n\n    if (!trs?.length) return;\n    if (!trs[0]?.offsetHeight) return;\n\n    let h = 0;\n    trs.forEach((tr: HTMLElement, idx: number) => {\n      let rh = 0;\n      const tds = tr?.querySelectorAll('td');\n      tds?.forEach((td: HTMLElement) => {\n        const wprev = td.style.width;\n        this.renderer.setStyle(td, 'display', 'block');\n        this.renderer.removeStyle(td, 'width');\n        if (td.offsetHeight) rh = Math.max(rh, td.offsetHeight);\n        this.renderer.removeStyle(td, 'display');\n        this.renderer.setStyle(td, 'width', wprev);\n      });\n      if (rh) {\n        h = idx === 0 ? rh : Math.min(h, rh);\n      }\n    });\n\n    this.virtualScrollItemSize = h;\n  }\n\n  private _setMinWidthOverall() {\n    if (this.minWidthForBodyOnly || !this.minWidth || !this.primengTreeTable)\n      return;\n\n    const treeTableMain =\n      this.primengTreeTable.el?.nativeElement?.querySelector('.p-treetable');\n    if (treeTableMain) {\n      this.renderer.setStyle(treeTableMain, 'overflow', 'auto');\n      const paginatorEl = treeTableMain.querySelector('.p-paginator');\n      if (paginatorEl)\n        this.renderer.setStyle(paginatorEl, 'min-width', this.minWidth);\n      const loadingOverlay = treeTableMain.querySelector(\n        '.p-treetable-loading-overlay'\n      );\n      if (loadingOverlay)\n        this.renderer.setStyle(loadingOverlay, 'min-width', this.minWidth);\n    }\n\n    const scrollableWrapper =\n      this.primengTreeTable.el?.nativeElement?.querySelector(\n        '.p-treetable-scrollable-wrapper'\n      );\n    if (scrollableWrapper)\n      this.renderer.setStyle(scrollableWrapper, 'min-width', this.minWidth);\n\n    if (!this.scrollable) {\n      const tableWrapper =\n        this.primengTreeTable.el?.nativeElement?.querySelector(\n          '.p-treetable-wrapper'\n        );\n      if (tableWrapper)\n        this.renderer.setStyle(tableWrapper, 'min-width', this.minWidth);\n    }\n\n    const treeTableHeader =\n      this.primengTreeTable.el?.nativeElement?.querySelector(\n        '.p-treetable-header'\n      );\n    if (treeTableHeader)\n      this.renderer.setStyle(treeTableHeader, 'min-width', this.minWidth);\n  }\n\n  private _onWindowResize() {\n    // if (this.defScrollHeight === 'flex')\n    //   this.defScrollHeightPx = this.scrollableBody.clientHeight;\n\n    clearTimeout(this._windowResizeDebouncer);\n    this._windowResizeDebouncer = setTimeout(() => {\n      this._recalcVirtualHeight();\n    }, 100);\n  }\n\n  get styleClass() {\n    const classesList = [];\n    switch (this.size) {\n      case 'small':\n        classesList.push('p-treetable-sm');\n        break;\n      case 'large':\n        classesList.push('p-treetable-lg');\n        break;\n    }\n    if (this.hasToolbar) {\n      switch (this.toolbarSize) {\n        case 'small':\n          classesList.push('cps-tbar-small');\n          break;\n        case 'normal':\n          classesList.push('cps-tbar-normal');\n          break;\n      }\n    }\n    if (this.striped) {\n      classesList.push('p-treetable-striped');\n    }\n    if (this.bordered) {\n      classesList.push('p-treetable-gridlines');\n    }\n\n    return classesList.join(' ');\n  }\n\n  private _recalcVirtualHeight() {\n    if (!this._scrollbarVisible && this.virtualScroll)\n      this.renderer.setStyle(\n        this._scrollableBody,\n        'overflow',\n        'hidden',\n        RendererStyleFlags2.Important\n      );\n\n    setTimeout(() => {\n      if (this.virtualScroll && this.defScrollHeight) {\n        this._updateVirtualScrollItemSize();\n        const itemsLen = this.primengTreeTable.serializedValue?.length || 0;\n        if (itemsLen < 1) {\n          this.scrollHeight = this.emptyBodyHeight\n            ? (`calc(${this.emptyBodyHeight} + 1px)` as string)\n            : this.virtualScrollItemSize + 1 + 'px';\n        } else {\n          const curHeight = this.virtualScrollItemSize * itemsLen + 2;\n          if (this.defScrollHeight === 'flex') {\n            if (curHeight >= this._defScrollHeightPxInitial) {\n              this.scrollHeight = 'flex';\n              this.renderer.setStyle(this._scrollableBody, 'height', '100%');\n              this.cdRef.markForCheck();\n              return;\n            }\n          }\n          this.scrollHeight =\n            Math.min(this._defScrollHeightPx, curHeight) + 'px';\n        }\n        this.cdRef.markForCheck();\n      }\n    });\n  }\n\n  clearGlobalFilter() {\n    this.globalFilterComp?.clear();\n  }\n\n  onSortFunction(event: TreeTableSortEvent) {\n    this.customSortFunction.emit(event);\n  }\n\n  onFilterGlobal(value: string) {\n    this.primengTreeTable.filterGlobal(value, 'contains');\n  }\n\n  onClickAdditionalBtnOnSelect() {\n    this.additionalBtnOnSelectClicked.emit(this.selectedRows);\n  }\n\n  onClickActionBtn() {\n    this.actionBtnClicked.emit();\n  }\n\n  onReloadData() {\n    if (this.dataReloadBtnDisabled) return;\n    this.dataReloadBtnClicked.emit();\n  }\n\n  onColumnsToggle(event: any) {\n    if (this.columnsToggleBtnDisabled) return;\n    this.colToggleMenu?.toggle(event);\n  }\n\n  removeSelected() {\n    this.rowsToRemove.emit(this.selectedRows);\n  }\n\n  clearSelection() {\n    this.selectedRows = [];\n  }\n\n  onEditRowClicked(node: any) {\n    this.editRowBtnClicked.emit(node);\n  }\n\n  onRemoveRowClicked(node: any) {\n    this.rowsToRemove.emit([node]);\n  }\n\n  toggleAllColumns() {\n    this.selectedColumns =\n      this.selectedColumns.length < this.columns.length ? this.columns : [];\n    this.columnsSelected.emit(this.selectedColumns);\n    setTimeout(() => {\n      this._calcAutoLayoutHeaderWidths(true);\n    });\n  }\n\n  isColumnSelected(col: any) {\n    return this.selectedColumns.some((item) => isEqual(item, col));\n  }\n\n  onRowsPerPageChanged() {\n    if (this.resetPageOnRowsChange) {\n      this.primengTreeTable.first = 0;\n    }\n    this.changePage(this.getPage());\n  }\n\n  getPageCount() {\n    return Math.ceil(this.primengTreeTable.totalRecords / this.rows);\n  }\n\n  getPage(): number {\n    return Math.floor(this.primengTreeTable.first / this.rows);\n  }\n\n  changePage(p: number) {\n    const pc = Math.ceil(this.getPageCount());\n\n    if (p >= 0 && p < pc) {\n      this.first = this.rows * p;\n      this.primengTreeTable.onPageChange({\n        first: this.first,\n        rows: this.rows\n      });\n    }\n  }\n\n  onPageChange(event: any) {\n    this.first = event.first;\n    this.rows = event.rows;\n\n    const state = {\n      page: this.getPage(),\n      first: this.first,\n      rows: this.rows,\n      pageCount: Math.ceil(this.getPageCount())\n    };\n\n    this.pageChanged.emit(state);\n    setTimeout(() => {\n      this._calcAutoLayoutHeaderWidths(true);\n    });\n  }\n\n  onLazyLoaded(event: any) {\n    this.lazyLoaded.emit(event);\n  }\n\n  onNodeExpanded(event: any) {\n    this.nodeExpanded.emit(event);\n    setTimeout(() => {\n      this._calcAutoLayoutHeaderWidths(true);\n    });\n    this._recalcVirtualHeight();\n  }\n\n  onNodeCollapsed(event: any) {\n    this.nodeCollapsed.emit(event);\n    setTimeout(() => {\n      this._calcAutoLayoutHeaderWidths(true);\n    });\n    this._recalcVirtualHeight();\n  }\n\n  onNodeSelected(event: any) {\n    this.nodeSelected.emit(event);\n  }\n\n  onNodeUnselected(event: any) {\n    this.nodeUnselected.emit(event);\n  }\n\n  onSort(event: any) {\n    this.sorted.emit(event);\n    setTimeout(() => {\n      this.cdRef.detectChanges();\n      this._calcAutoLayoutHeaderWidths(true);\n    });\n  }\n\n  onFilter(event: any) {\n    this.filtered.emit(event);\n    setTimeout(() => {\n      this._calcAutoLayoutHeaderWidths(true);\n    });\n    this._recalcVirtualHeight();\n  }\n\n  onSelectColumn(col: any) {\n    let res = [] as any;\n    if (this.isColumnSelected(col)) {\n      res = this.selectedColumns.filter((v: any) => !isEqual(v, col));\n    } else {\n      this.columns.forEach((o) => {\n        if (\n          this.selectedColumns.some((v: any) => isEqual(v, o)) ||\n          isEqual(col, o)\n        ) {\n          res.push(o);\n        }\n      });\n    }\n    this.selectedColumns = res;\n    this.columnsSelected.emit(this.selectedColumns);\n    setTimeout(() => {\n      this._calcAutoLayoutHeaderWidths(true);\n    });\n  }\n\n  onSelectionChanged(selection: any) {\n    if (selection && !Array.isArray(selection)) selection = [selection];\n    this.rowsSelected.emit(selection);\n  }\n}\n","<p-treeTable\n  #primengTreeTable\n  ttWithUnsort\n  [ngClass]=\"{\n    'cps-treetable-loading': loading,\n    'cps-treetable-flex': defScrollHeight === 'flex',\n    'cps-treetable-nonvirtual': !virtualScroll,\n    'cps-treetable-autolayout-calced': autoLayout && scrollable\n  }\"\n  [value]=\"data\"\n  [autoLayout]=\"autoLayout && !scrollable\"\n  [scrollable]=\"scrollable\"\n  [scrollHeight]=\"scrollHeight\"\n  [virtualScroll]=\"virtualScroll\"\n  [virtualScrollItemSize]=\"virtualScrollItemSize\"\n  [virtualScrollOptions]=\"{\n    numToleratedItems: numToleratedItems,\n    autoSize: false\n  }\"\n  [columns]=\"selectedColumns\"\n  [loading]=\"loading\"\n  [rowHover]=\"rowHover\"\n  [lazy]=\"lazy\"\n  [(selection)]=\"selectedRows\"\n  (selectionChange)=\"onSelectionChanged($event)\"\n  compareSelectionBy=\"deepEquals\"\n  [lazyLoadOnInit]=\"lazyLoadOnInit\"\n  [styleClass]=\"styleClass\"\n  [tableStyle]=\"tableStyle\"\n  [tableStyleClass]=\"tableStyleClass\"\n  [customSort]=\"customSort\"\n  [sortMode]=\"sortMode\"\n  [globalFilterFields]=\"globalFilterFields\"\n  [paginator]=\"paginator\"\n  [showCurrentPageReport]=\"true\"\n  [alwaysShowPaginator]=\"alwaysShowPaginator\"\n  [rows]=\"rows\"\n  [first]=\"first\"\n  [totalRecords]=\"totalRecords\"\n  [resetPageOnSort]=\"resetPageOnSort\"\n  [resizableColumns]=\"resizableColumns\"\n  [columnResizeMode]=\"columnResizeMode\"\n  currentPageReportTemplate=\"{first} - {last} of {totalRecords}\"\n  (onPage)=\"onPageChange($event)\"\n  (onSort)=\"onSort($event)\"\n  (onFilter)=\"onFilter($event)\"\n  (onLazyLoad)=\"onLazyLoaded($event)\"\n  (sortFunction)=\"onSortFunction($event)\"\n  (onNodeExpand)=\"onNodeExpanded($event)\"\n  (onNodeCollapse)=\"onNodeCollapsed($event)\"\n  (onNodeSelect)=\"onNodeSelected($event)\"\n  (onNodeUnselect)=\"onNodeUnselected($event)\">\n  @if (colgroupTemplate) {\n    <ng-template pTemplate=\"colgroup\">\n      <ng-container *ngTemplateOutlet=\"colgroupTemplate\"></ng-container>\n    </ng-template>\n  }\n  <ng-template pTemplate=\"caption\" *ngIf=\"hasToolbar\">\n    <ng-container *ngIf=\"toolbarTemplate\">\n      <ng-container *ngTemplateOutlet=\"toolbarTemplate\"></ng-container>\n    </ng-container>\n    <ng-container *ngIf=\"!toolbarTemplate\">\n      <div class=\"cps-treetable-tbar-left\">\n        <div *ngIf=\"toolbarIcon\" class=\"cps-treetable-tbar-icon\">\n          <cps-icon [icon]=\"toolbarIcon\" [color]=\"toolbarIconColor\"></cps-icon>\n        </div>\n        <div class=\"cps-treetable-tbar-title\">{{ toolbarTitle }}</div>\n        <div *ngIf=\"showGlobalFilter\" class=\"cps-treetable-tbar-global-filter\">\n          <cps-input\n            #globalFilterComp\n            prefixIcon=\"search\"\n            [placeholder]=\"globalFilterPlaceholder\"\n            (valueChanged)=\"onFilterGlobal($event)\"\n            [clearable]=\"true\"\n            [disabled]=\"loading\"\n            [appearance]=\"toolbarSize === 'small' ? 'underlined' : 'outlined'\"\n            [hideDetails]=\"true\">\n          </cps-input>\n        </div>\n      </div>\n      <div class=\"cps-treetable-tbar-right\">\n        <div\n          *ngIf=\"showRemoveBtnOnSelect && selectedRows.length > 0\"\n          class=\"cps-treetable-tbar-btn-on-select\">\n          <cps-button\n            label=\"Remove\"\n            [disabled]=\"removeBtnOnSelectDisabled\"\n            color=\"prepared\"\n            type=\"borderless\"\n            icon=\"remove\"\n            [size]=\"toolbarSize\"\n            (clicked)=\"removeSelected()\">\n          </cps-button>\n        </div>\n        <div\n          *ngIf=\"showAdditionalBtnOnSelect && selectedRows.length > 0\"\n          class=\"cps-treetable-tbar-btn-on-select\">\n          <cps-button\n            [label]=\"additionalBtnOnSelectTitle\"\n            [disabled]=\"additionalBtnOnSelectDisabled\"\n            color=\"prepared\"\n            type=\"borderless\"\n            [icon]=\"additionalBtnOnSelectIcon\"\n            [size]=\"toolbarSize\"\n            (clicked)=\"onClickAdditionalBtnOnSelect()\">\n          </cps-button>\n        </div>\n        <div *ngIf=\"showActionBtn\" class=\"cps-treetable-tbar-action-btn\">\n          <cps-button\n            [label]=\"actionBtnTitle\"\n            [disabled]=\"actionBtnDisabled\"\n            color=\"prepared\"\n            type=\"outlined\"\n            [icon]=\"actionBtnIcon\"\n            [size]=\"toolbarSize\"\n            (clicked)=\"onClickActionBtn()\">\n          </cps-button>\n        </div>\n        <div\n          *ngIf=\"showColumnsToggleBtn && columns.length > 0\"\n          class=\"cps-treetable-tbar-coltoggle-btn\"\n          [ngClass]=\"{ 'btn-disabled': columnsToggleBtnDisabled }\">\n          <cps-icon\n            icon=\"columns\"\n            size=\"normal\"\n            [color]=\"\n              columnsToggleBtnDisabled ? 'text-lightest' : 'prepared-lighten1'\n            \"\n            (click)=\"onColumnsToggle($event)\"></cps-icon>\n          <cps-menu #colToggleMenu [withArrow]=\"false\">\n            <div class=\"cps-treetable-coltoggle-menu\">\n              <div\n                class=\"cps-treetable-coltoggle-menu-item select-all-option\"\n                [class.allselected]=\"selectedColumns.length === columns.length\"\n                (click)=\"toggleAllColumns()\">\n                <span class=\"cps-treetable-coltoggle-menu-item-left\">\n                  <span class=\"cps-treetable-coltoggle-menu-item-check\"> </span>\n                  <span class=\"cps-treetable-coltoggle-menu-item-label\"\n                    >Show all columns</span\n                  >\n                </span>\n              </div>\n              <div\n                *ngFor=\"let col of columns\"\n                class=\"cps-treetable-coltoggle-menu-item\"\n                (click)=\"onSelectColumn(col)\"\n                [class.selected]=\"isColumnSelected(col)\">\n                <span class=\"cps-treetable-coltoggle-menu-item-left\">\n                  <span class=\"cps-treetable-coltoggle-menu-item-check\"></span>\n                  <span class=\"cps-treetable-coltoggle-menu-item-label\">{{\n                    col[colHeaderName]\n                  }}</span>\n                </span>\n              </div>\n            </div>\n          </cps-menu>\n        </div>\n        <div\n          *ngIf=\"showDataReloadBtn\"\n          class=\"cps-treetable-tbar-reload-btn\"\n          [ngClass]=\"{ 'btn-disabled': dataReloadBtnDisabled }\">\n          <cps-icon\n            icon=\"refresh\"\n            size=\"18\"\n            [color]=\"dataReloadBtnDisabled ? 'text-light' : 'prepared-lighten1'\"\n            (click)=\"onReloadData()\">\n          </cps-icon>\n        </div>\n      </div>\n    </ng-container>\n  </ng-template>\n\n  <ng-template pTemplate=\"header\" *ngIf=\"nestedHeaderTemplate\" let-columns>\n    <ng-container\n      *ngTemplateOutlet=\"\n        nestedHeaderTemplate;\n        context: {\n          $implicit: columns\n        }\n      \"></ng-container>\n  </ng-template>\n\n  <ng-template pTemplate=\"header\" *ngIf=\"!nestedHeaderTemplate\" let-columns>\n    <tr>\n      <!-- <th style=\"width: 3rem\" *ngIf=\"reorderableRows\"></th> -->\n      <th\n        *ngIf=\"selectable\"\n        cpsTTHdrSelectable\n        cpsTTColResizable\n        [cpsTTColResizableDisabled]=\"!resizableColumns\"></th>\n      <ng-container *ngIf=\"headerTemplate\">\n        <ng-container\n          *ngTemplateOutlet=\"\n            headerTemplate;\n            context: {\n              $implicit: columns\n            }\n          \"></ng-container>\n      </ng-container>\n      <ng-container *ngIf=\"!headerTemplate && columns.length > 0\">\n        <ng-container *ngIf=\"sortable\">\n          @if (filterableByColumns) {\n            <th\n              *ngFor=\"let col of columns\"\n              [cpsTTColSortable]=\"col[colFieldName]\"\n              [cpsTTColFilter]=\"col[colFieldName]\"\n              [filterType]=\"\n                col[colFilterTypeName] ??\n                (autoColumnFilterType\n                  ? (data | cpsTTDetectFilterType: col[colFieldName])\n                  : 'text')\n              \"\n              cpsTTColResizable\n              [cpsTTColResizableDisabled]=\"!resizableColumns\">\n              {{ col[colHeaderName] }}\n            </th>\n          } @else {\n            <th\n              *ngFor=\"let col of columns\"\n              [cpsTTColSortable]=\"col[colFieldName]\"\n              cpsTTColResizable\n              [cpsTTColResizableDisabled]=\"!resizableColumns\">\n              {{ col[colHeaderName] }}\n            </th>\n          }\n        </ng-container>\n        <ng-container *ngIf=\"!sortable\">\n          @if (filterableByColumns) {\n            <th\n              *ngFor=\"let col of columns\"\n              [cpsTTColFilter]=\"col[colFieldName]\"\n              [filterType]=\"\n                col[colFilterTypeName] ??\n                (autoColumnFilterType\n                  ? (data | cpsTTDetectFilterType: col[colFieldName])\n                  : 'text')\n              \"\n              cpsTTColResizable\n              [cpsTTColResizableDisabled]=\"!resizableColumns\">\n              {{ col[colHeaderName] }}\n            </th>\n          } @else {\n            <th\n              *ngFor=\"let col of columns\"\n              cpsTTColResizable\n              [cpsTTColResizableDisabled]=\"!resizableColumns\">\n              {{ col[colHeaderName] }}\n            </th>\n          }\n        </ng-container>\n      </ng-container>\n      <th\n        class=\"cps-treetable-row-menu-cell\"\n        *ngIf=\"showRowMenu && (showRowRemoveButton || showRowEditButton)\"\n        cpsTTColResizable\n        [cpsTTColResizableDisabled]=\"!resizableColumns\"></th>\n    </tr>\n  </ng-template>\n\n  <ng-template\n    pTemplate=\"body\"\n    let-rowData=\"rowData\"\n    let-columns=\"columns\"\n    let-rowNode\n    let-rowIndex=\"rowIndex\">\n    <tr\n      [ttRow]=\"rowNode\"\n      [ngClass]=\"{\n        'cps-treetable-row-selected':\n          selectable && primengTreeTable.isSelected(rowNode.node)\n      }\">\n      <!-- <td *ngIf=\"reorderableRows\" class=\"cps-table-row-drag-handle-cell\">\n        <span class=\"cps-table-row-drag-handle\" pReorderableRowHandle>☰</span>\n      </td> -->\n      <td [cpsTTRowSelectable]=\"rowNode\" *ngIf=\"selectable\"></td>\n      <ng-container *ngIf=\"bodyTemplate\">\n        <ng-container\n          *ngTemplateOutlet=\"\n            bodyTemplate;\n            context: {\n              $implicit: rowNode,\n              rowIndex: rowIndex,\n              columns: columns,\n              rowData: rowData\n            }\n          \">\n        </ng-container>\n      </ng-container>\n      <ng-container *ngIf=\"!bodyTemplate\">\n        <ng-container *ngIf=\"columns.length > 0\">\n          @if (renderDataAsHTML) {\n            <ng-container *ngFor=\"let col of columns; let i = index\">\n              <td\n                *ngIf=\"i === 0\"\n                [cpsTTRowToggler]=\"rowNode\"\n                [innerHTML]=\"rowData[col[colFieldName]]\"></td>\n              <td *ngIf=\"i > 0\" [innerHTML]=\"rowData[col[colFieldName]]\"></td>\n            </ng-container>\n          } @else {\n            <ng-container *ngFor=\"let col of columns; let i = index\">\n              <td *ngIf=\"i === 0\" [cpsTTRowToggler]=\"rowNode\">\n                {{\n                  col[colDateFormatName]\n                    ? (rowData[col[colFieldName]]\n                      | date: col[colDateFormatName])\n                    : rowData[col[colFieldName]]\n                }}\n              </td>\n              <td *ngIf=\"i > 0\">\n                {{\n                  col[colDateFormatName]\n                    ? (rowData[col[colFieldName]]\n                      | date: col[colDateFormatName])\n                    : rowData[col[colFieldName]]\n                }}\n              </td>\n            </ng-container>\n          }\n        </ng-container>\n      </ng-container>\n      <td\n        *ngIf=\"showRowMenu && (showRowRemoveButton || showRowEditButton)\"\n        class=\"cps-treetable-row-menu-cell\">\n        <table-row-menu\n          (editRowBtnClicked)=\"onEditRowClicked(rowNode.node)\"\n          (removeRowBtnClicked)=\"onRemoveRowClicked(rowNode.node)\"\n          [showRowRemoveButton]=\"showRowRemoveButton\"\n          [showRowEditButton]=\"showRowEditButton\"\n          [customItems]=\"rowMenuItems\">\n        </table-row-menu>\n      </td>\n    </tr>\n  </ng-template>\n  <ng-template pTemplate=\"emptymessage\">\n    <tr>\n      <td\n        colspan=\"100\"\n        class=\"cps-treetable-empty-message-td\"\n        [ngStyle]=\"{ height: emptyBodyHeight }\">\n        {{ emptyMessage }}\n      </td>\n    </tr>\n  </ng-template>\n  <ng-template pTemplate=\"loadingicon\">\n    <cps-loader [fullScreen]=\"false\" opacity=\"0\"></cps-loader>\n  </ng-template>\n  <ng-template pTemplate=\"paginatorleft\">\n    <div class=\"cps-table-paginator-itms-per-page\">\n      <span class=\"cps-table-paginator-items-per-page-title\"\n        >Rows per page:\n      </span>\n      <cps-select\n        [options]=\"rowOptions\"\n        [hideDetails]=\"true\"\n        [(ngModel)]=\"rows\"\n        (valueChanged)=\"onRowsPerPageChanged()\"\n        [returnObject]=\"false\"\n        optionsClass=\"cps-paginator-page-options\">\n      </cps-select>\n    </div>\n  </ng-template>\n\n  <ng-template pTemplate=\"paginatorfirstpagelinkicon\">\n    <AngleDoubleLeftIcon />\n  </ng-template>\n  <ng-template pTemplate=\"paginatorpreviouspagelinkicon\">\n    <AngleLeftIcon />\n  </ng-template>\n  <ng-template pTemplate=\"paginatornextpagelinkicon\">\n    <AngleRightIcon />\n  </ng-template>\n  <ng-template pTemplate=\"paginatorlastpagelinkicon\">\n    <AngleDoubleRightIcon />\n  </ng-template>\n</p-treeTable>\n"]}