cps-ui-kit 0.71.0 → 0.73.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.
- package/README.md +1 -0
- package/esm2020/lib/components/cps-autocomplete/cps-autocomplete.component.mjs +3 -3
- package/esm2020/lib/components/cps-input/cps-input.component.mjs +3 -3
- package/esm2020/lib/components/cps-paginator/cps-paginator.component.mjs +5 -5
- package/esm2020/lib/components/cps-select/cps-select.component.mjs +3 -3
- package/esm2020/lib/components/cps-table/cps-table.component.mjs +78 -39
- package/esm2020/lib/components/cps-table/directives/cps-table-column-filter.directive.mjs +4 -4
- package/esm2020/lib/components/cps-table/directives/cps-table-column-sortable.directive.mjs +4 -4
- package/esm2020/lib/components/cps-table/directives/cps-table-header-selectable.directive.mjs +3 -3
- package/esm2020/lib/components/cps-table/directives/internal/table-unsort.directive.mjs +3 -3
- package/esm2020/lib/components/cps-tree-autocomplete/cps-tree-autocomplete.component.mjs +3 -3
- package/esm2020/lib/components/cps-tree-select/cps-tree-select.component.mjs +3 -3
- package/esm2020/lib/components/cps-tree-table/cps-tree-table.component.mjs +513 -0
- package/esm2020/lib/components/cps-tree-table/directives/cps-tree-table-column-sortable.directive.mjs +43 -0
- package/esm2020/lib/components/cps-tree-table/directives/cps-tree-table-header-selectable.directive.mjs +28 -0
- package/esm2020/lib/components/cps-tree-table/directives/cps-tree-table-row-toggler.directive.mjs +32 -0
- package/esm2020/lib/components/cps-tree-table/directives/internal/tree-table-unsort.directive.mjs +157 -0
- package/esm2020/lib/components/cps-tree-table/tree-table-sort-icon/tree-table-sort-icon.component.mjs +73 -0
- package/esm2020/public-api.mjs +5 -1
- package/fesm2015/cps-ui-kit.mjs +927 -76
- package/fesm2015/cps-ui-kit.mjs.map +1 -1
- package/fesm2020/cps-ui-kit.mjs +922 -76
- package/fesm2020/cps-ui-kit.mjs.map +1 -1
- package/lib/components/cps-paginator/cps-paginator.component.d.ts +2 -2
- package/lib/components/cps-table/cps-table.component.d.ts +19 -11
- package/lib/components/cps-table/directives/cps-table-column-filter.directive.d.ts +1 -1
- package/lib/components/cps-table/directives/cps-table-column-sortable.directive.d.ts +1 -1
- package/lib/components/cps-table/directives/cps-table-header-selectable.directive.d.ts +1 -1
- package/lib/components/cps-table/directives/internal/table-unsort.directive.d.ts +1 -1
- package/lib/components/cps-tree-table/cps-tree-table.component.d.ts +123 -0
- package/lib/components/cps-tree-table/directives/cps-tree-table-column-sortable.directive.d.ts +17 -0
- package/lib/components/cps-tree-table/directives/cps-tree-table-header-selectable.directive.d.ts +13 -0
- package/lib/components/cps-tree-table/directives/cps-tree-table-row-toggler.directive.d.ts +14 -0
- package/lib/components/cps-tree-table/directives/internal/tree-table-unsort.directive.d.ts +9 -0
- package/lib/components/cps-tree-table/tree-table-sort-icon/tree-table-sort-icon.component.d.ts +21 -0
- package/package.json +1 -1
- package/public-api.d.ts +4 -0
|
@@ -0,0 +1,513 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, ContentChild, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { TreeTable, TreeTableService, TreeTableModule } from 'primeng/treetable';
|
|
4
|
+
import { DomHandler } from 'primeng/dom';
|
|
5
|
+
import { CpsInputComponent } from '../cps-input/cps-input.component';
|
|
6
|
+
import { CpsButtonComponent } from '../cps-button/cps-button.component';
|
|
7
|
+
import { CpsMenuComponent } from '../cps-menu/cps-menu.component';
|
|
8
|
+
import { find, isEqual } from 'lodash-es';
|
|
9
|
+
import { CpsIconComponent } from '../cps-icon/cps-icon.component';
|
|
10
|
+
import { CpsSelectComponent } from '../cps-select/cps-select.component';
|
|
11
|
+
import { FormsModule } from '@angular/forms';
|
|
12
|
+
import { AngleDoubleLeftIcon } from 'primeng/icons/angledoubleleft';
|
|
13
|
+
import { AngleLeftIcon } from 'primeng/icons/angleleft';
|
|
14
|
+
import { AngleRightIcon } from 'primeng/icons/angleright';
|
|
15
|
+
import { AngleDoubleRightIcon } from 'primeng/icons/angledoubleright';
|
|
16
|
+
import { convertSize } from '../../utils/internal/size-utils';
|
|
17
|
+
import { CpsLoaderComponent } from '../cps-loader/cps-loader.component';
|
|
18
|
+
import { CpsTreeTableColumnSortableDirective } from './directives/cps-tree-table-column-sortable.directive';
|
|
19
|
+
import { TreeTableUnsortDirective } from './directives/internal/tree-table-unsort.directive';
|
|
20
|
+
import { TableRowMenuComponent } from '../cps-table/table-row-menu/table-row-menu.component';
|
|
21
|
+
import * as i0 from "@angular/core";
|
|
22
|
+
import * as i1 from "@angular/forms";
|
|
23
|
+
import * as i2 from "@angular/common";
|
|
24
|
+
import * as i3 from "primeng/treetable";
|
|
25
|
+
import * as i4 from "primeng/api";
|
|
26
|
+
export function treeTableFactory(tableComponent) {
|
|
27
|
+
return tableComponent.primengTreeTable;
|
|
28
|
+
}
|
|
29
|
+
export class CpsTreeTableComponent {
|
|
30
|
+
// eslint-disable-next-line no-useless-constructor
|
|
31
|
+
constructor(cdRef) {
|
|
32
|
+
this.cdRef = cdRef;
|
|
33
|
+
this.data = [];
|
|
34
|
+
this.columns = [];
|
|
35
|
+
this.colHeaderName = 'header';
|
|
36
|
+
this.colFieldName = 'field';
|
|
37
|
+
this.size = 'normal';
|
|
38
|
+
this.striped = true;
|
|
39
|
+
this.bordered = true;
|
|
40
|
+
this.tableStyle = undefined;
|
|
41
|
+
this.tableStyleClass = '';
|
|
42
|
+
this.selectable = false;
|
|
43
|
+
this.sortable = false; // makes all sortable if columns are provided
|
|
44
|
+
this.sortMode = 'single';
|
|
45
|
+
this.customSort = false;
|
|
46
|
+
this.hasToolbar = true;
|
|
47
|
+
this.toolbarSize = 'normal';
|
|
48
|
+
this.toolbarTitle = '';
|
|
49
|
+
this.rowHover = true;
|
|
50
|
+
this.showGlobalFilter = true;
|
|
51
|
+
this.globalFilterPlaceholder = 'Search';
|
|
52
|
+
this.globalFilterFields = [];
|
|
53
|
+
this.paginator = false;
|
|
54
|
+
this.alwaysShowPaginator = true;
|
|
55
|
+
this.rowsPerPageOptions = [];
|
|
56
|
+
this.first = 0;
|
|
57
|
+
this.rows = 0;
|
|
58
|
+
this.resetPageOnRowsChange = false;
|
|
59
|
+
this.resetPageOnSort = true;
|
|
60
|
+
this.emptyMessage = 'No data';
|
|
61
|
+
this.emptyBodyHeight = '';
|
|
62
|
+
this.lazy = false;
|
|
63
|
+
this.lazyLoadOnInit = true;
|
|
64
|
+
// @Input() showRowMenu = false; // TODO
|
|
65
|
+
this.showRowMenu = false; // TODO
|
|
66
|
+
this.loading = false;
|
|
67
|
+
this.scrollable = true;
|
|
68
|
+
this.scrollHeight = ''; // 'flex' or value+'px'
|
|
69
|
+
this.virtualScroll = false; // works only if scrollable is true
|
|
70
|
+
this.numToleratedItems = 10;
|
|
71
|
+
// @Input() showRemoveBtnOnSelect = false; // TODO
|
|
72
|
+
this.showRemoveBtnOnSelect = false; // TODO
|
|
73
|
+
this.showActionBtn = false;
|
|
74
|
+
this.actionBtnTitle = 'Action';
|
|
75
|
+
this.showColumnsToggle = false; // if external body template is provided, use columnsSelected event emitter
|
|
76
|
+
this.actionBtnClicked = new EventEmitter();
|
|
77
|
+
this.columnsSelected = new EventEmitter();
|
|
78
|
+
this.pageChanged = new EventEmitter();
|
|
79
|
+
this.lazyLoaded = new EventEmitter();
|
|
80
|
+
this.nodeExpanded = new EventEmitter();
|
|
81
|
+
this.nodeCollapsed = new EventEmitter();
|
|
82
|
+
this.nodeSelected = new EventEmitter();
|
|
83
|
+
this.nodeUnselected = new EventEmitter();
|
|
84
|
+
this.sorted = new EventEmitter();
|
|
85
|
+
this.editRowBtnClicked = new EventEmitter();
|
|
86
|
+
this.rowsRemoved = new EventEmitter();
|
|
87
|
+
/**
|
|
88
|
+
* A function to implement custom sorting. customSort must be true.
|
|
89
|
+
* @param {any} any - sort meta.
|
|
90
|
+
* @group Emits
|
|
91
|
+
*/
|
|
92
|
+
this.customSortFunction = new EventEmitter();
|
|
93
|
+
this.selectedColumns = [];
|
|
94
|
+
this.rowOptions = [];
|
|
95
|
+
this.selectedRows = [];
|
|
96
|
+
this.virtualScrollItemSize = 0;
|
|
97
|
+
this.defScrollHeightPx = 0;
|
|
98
|
+
this.defScrollHeight = '';
|
|
99
|
+
this.scrollbarWidth = 0;
|
|
100
|
+
this.resizeObserver = new ResizeObserver((entries) => {
|
|
101
|
+
entries.forEach((entry) => {
|
|
102
|
+
const body = entry.target;
|
|
103
|
+
const sbarVisible = body.scrollHeight > body.clientHeight;
|
|
104
|
+
let wScroll = sbarVisible ? this.scrollbarWidth : 0;
|
|
105
|
+
if (wScroll > 0)
|
|
106
|
+
wScroll -= 1;
|
|
107
|
+
this.headerBox.style.paddingRight = `${wScroll}px`;
|
|
108
|
+
this.headerBox.style.borderRight =
|
|
109
|
+
wScroll > 0 ? '1px solid #d7d5d5' : 'unset';
|
|
110
|
+
});
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
ngOnInit() {
|
|
114
|
+
this.emptyBodyHeight = convertSize(this.emptyBodyHeight);
|
|
115
|
+
if (!this.scrollable)
|
|
116
|
+
this.virtualScroll = false;
|
|
117
|
+
if (this.virtualScroll) {
|
|
118
|
+
this.defScrollHeight = this.scrollHeight;
|
|
119
|
+
if (this.defScrollHeight === 'flex')
|
|
120
|
+
window.addEventListener('resize', this._onWindowResize.bind(this));
|
|
121
|
+
if (this.defScrollHeight && this.defScrollHeight !== 'flex') {
|
|
122
|
+
this.defScrollHeightPx = parseInt(this.scrollHeight, 10);
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
if (this.paginator) {
|
|
126
|
+
if (this.rowsPerPageOptions.length < 1)
|
|
127
|
+
this.rowsPerPageOptions = [5, 10, 25, 50];
|
|
128
|
+
if (!this.rows)
|
|
129
|
+
this.rows = this.rowsPerPageOptions[0];
|
|
130
|
+
else {
|
|
131
|
+
if (!this.rowsPerPageOptions.includes(this.rows)) {
|
|
132
|
+
throw new Error('rowsPerPageOptions must include rows');
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
this.rowOptions = this.rowsPerPageOptions.map((v) => ({
|
|
136
|
+
label: '' + v,
|
|
137
|
+
value: v
|
|
138
|
+
}));
|
|
139
|
+
}
|
|
140
|
+
if (this.showGlobalFilter &&
|
|
141
|
+
this.globalFilterFields?.length < 1 &&
|
|
142
|
+
this.data?.length > 0) {
|
|
143
|
+
this.globalFilterFields = Object.keys(this.data[0].data);
|
|
144
|
+
}
|
|
145
|
+
this.selectedColumns = this.columns;
|
|
146
|
+
}
|
|
147
|
+
ngAfterViewInit() {
|
|
148
|
+
this.scrollableBody = this.primengTreeTable.el.nativeElement.querySelector('.p-treetable-scrollable-body');
|
|
149
|
+
if (this.scrollableBody) {
|
|
150
|
+
this.headerBox = this.primengTreeTable.el.nativeElement.querySelector('.p-treetable-scrollable-header-box');
|
|
151
|
+
if (this.virtualScroll && this.defScrollHeight === 'flex')
|
|
152
|
+
this.defScrollHeightPx = this.scrollableBody.clientHeight;
|
|
153
|
+
if (this.headerBox) {
|
|
154
|
+
this.scrollbarWidth = DomHandler.calculateScrollbarWidth();
|
|
155
|
+
this.resizeObserver.observe(this.scrollableBody);
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
ngAfterViewChecked() {
|
|
160
|
+
if (!this.virtualScroll || this.virtualScrollItemSize)
|
|
161
|
+
return;
|
|
162
|
+
this.virtualScrollItemSize =
|
|
163
|
+
this.primengTreeTable?.el?.nativeElement
|
|
164
|
+
?.querySelector('.p-treetable-tbody')
|
|
165
|
+
?.querySelector('tr')?.clientHeight || 0;
|
|
166
|
+
this.cdRef.detectChanges();
|
|
167
|
+
}
|
|
168
|
+
ngOnDestroy() {
|
|
169
|
+
this.resizeObserver?.disconnect();
|
|
170
|
+
if (this.virtualScroll && this.defScrollHeight === 'flex')
|
|
171
|
+
window.removeEventListener('resize', this._onWindowResize.bind(this));
|
|
172
|
+
}
|
|
173
|
+
_onWindowResize() {
|
|
174
|
+
this.defScrollHeightPx = this.scrollableBody.clientHeight;
|
|
175
|
+
}
|
|
176
|
+
get styleClass() {
|
|
177
|
+
const classesList = [];
|
|
178
|
+
switch (this.size) {
|
|
179
|
+
case 'small':
|
|
180
|
+
classesList.push('p-treetable-sm');
|
|
181
|
+
break;
|
|
182
|
+
case 'large':
|
|
183
|
+
classesList.push('p-treetable-lg');
|
|
184
|
+
break;
|
|
185
|
+
}
|
|
186
|
+
if (this.hasToolbar) {
|
|
187
|
+
switch (this.toolbarSize) {
|
|
188
|
+
case 'small':
|
|
189
|
+
classesList.push('cps-tbar-small');
|
|
190
|
+
break;
|
|
191
|
+
case 'normal':
|
|
192
|
+
classesList.push('cps-tbar-normal');
|
|
193
|
+
break;
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
if (this.striped) {
|
|
197
|
+
classesList.push('p-treetable-striped');
|
|
198
|
+
}
|
|
199
|
+
if (this.bordered) {
|
|
200
|
+
classesList.push('p-treetable-gridlines');
|
|
201
|
+
}
|
|
202
|
+
if (this.scrollHeight && !this.loading && this.data.length > 0) {
|
|
203
|
+
classesList.push('cps-treetable-bottom-bordered');
|
|
204
|
+
}
|
|
205
|
+
return classesList.join(' ');
|
|
206
|
+
}
|
|
207
|
+
onSortFunction(event) {
|
|
208
|
+
this.customSortFunction.emit(event);
|
|
209
|
+
}
|
|
210
|
+
_recalcVirtualHeight() {
|
|
211
|
+
if (this.virtualScroll && this.defScrollHeight) {
|
|
212
|
+
const itemsLen = this.primengTreeTable.serializedValue.length;
|
|
213
|
+
if (itemsLen < 1) {
|
|
214
|
+
this.scrollHeight = this.emptyBodyHeight
|
|
215
|
+
? `calc(${this.emptyBodyHeight} + 1px)`
|
|
216
|
+
: this.virtualScrollItemSize + 1 + 'px';
|
|
217
|
+
}
|
|
218
|
+
else {
|
|
219
|
+
const curHeight = this.virtualScrollItemSize * itemsLen + 2;
|
|
220
|
+
if (this.defScrollHeight === 'flex') {
|
|
221
|
+
if (curHeight >= this.defScrollHeightPx) {
|
|
222
|
+
this.scrollHeight = 'flex';
|
|
223
|
+
setTimeout(() => {
|
|
224
|
+
this.scrollableBody.style.height = '100%';
|
|
225
|
+
this.cdRef.markForCheck();
|
|
226
|
+
});
|
|
227
|
+
return;
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
this.scrollHeight = Math.min(this.defScrollHeightPx, curHeight) + 'px';
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
onFilterGlobal(value) {
|
|
235
|
+
this.primengTreeTable.filterGlobal(value, 'contains');
|
|
236
|
+
setTimeout(() => {
|
|
237
|
+
this._recalcVirtualHeight();
|
|
238
|
+
this.cdRef.markForCheck();
|
|
239
|
+
}, 300);
|
|
240
|
+
}
|
|
241
|
+
onClickActionBtn() {
|
|
242
|
+
this.actionBtnClicked.emit();
|
|
243
|
+
}
|
|
244
|
+
removeSelected() {
|
|
245
|
+
// TODO
|
|
246
|
+
// const indexes: number[] = this.primengTreeTable.selection.map(
|
|
247
|
+
// (s: any) => s._defaultSortOrder
|
|
248
|
+
// );
|
|
249
|
+
// indexes.sort((a, b) => b - a);
|
|
250
|
+
// this.data = this.data.filter(
|
|
251
|
+
// (v: any) => !indexes.includes(v._defaultSortOrder)
|
|
252
|
+
// );
|
|
253
|
+
// this.rowsRemoved.emit(
|
|
254
|
+
// this.selectedRows.map(({ _defaultSortOrder, ...rest }) => rest)
|
|
255
|
+
// );
|
|
256
|
+
// this.selectedRows = [];
|
|
257
|
+
}
|
|
258
|
+
onEditRowClicked(node) {
|
|
259
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
260
|
+
const { _defaultSortOrder, expanded, partialSelected, ...rest } = node;
|
|
261
|
+
this.editRowBtnClicked.emit(rest);
|
|
262
|
+
}
|
|
263
|
+
onRemoveRowClicked(node) {
|
|
264
|
+
// TODO remove children of nodes
|
|
265
|
+
// find by default sort order in object itself or in nested parent
|
|
266
|
+
// then find the node itself
|
|
267
|
+
this.selectedRows = this.selectedRows.filter((v) => v !== node);
|
|
268
|
+
this.data = this.data.filter((v) => v !== node);
|
|
269
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
270
|
+
const { _defaultSortOrder, expanded, partialSelected, ...rest } = node;
|
|
271
|
+
this.rowsRemoved.emit([rest]);
|
|
272
|
+
}
|
|
273
|
+
toggleAllColumns() {
|
|
274
|
+
this.selectedColumns =
|
|
275
|
+
this.selectedColumns.length < this.columns.length ? this.columns : [];
|
|
276
|
+
this.columnsSelected.emit(this.selectedColumns);
|
|
277
|
+
}
|
|
278
|
+
isColumnSelected(col) {
|
|
279
|
+
return !!find(this.selectedColumns, (item) => isEqual(item, col));
|
|
280
|
+
}
|
|
281
|
+
onRowsPerPageChanged() {
|
|
282
|
+
if (this.resetPageOnRowsChange) {
|
|
283
|
+
this.primengTreeTable.first = 0;
|
|
284
|
+
}
|
|
285
|
+
this.changePage(this.getPage());
|
|
286
|
+
}
|
|
287
|
+
getPageCount() {
|
|
288
|
+
return Math.ceil(this.primengTreeTable.totalRecords / this.rows);
|
|
289
|
+
}
|
|
290
|
+
getPage() {
|
|
291
|
+
return Math.floor(this.primengTreeTable.first / this.rows);
|
|
292
|
+
}
|
|
293
|
+
changePage(p) {
|
|
294
|
+
const pc = Math.ceil(this.getPageCount());
|
|
295
|
+
if (p >= 0 && p < pc) {
|
|
296
|
+
this.first = this.rows * p;
|
|
297
|
+
this.primengTreeTable.onPageChange({
|
|
298
|
+
first: this.first,
|
|
299
|
+
rows: this.rows
|
|
300
|
+
});
|
|
301
|
+
}
|
|
302
|
+
}
|
|
303
|
+
onPageChange(event) {
|
|
304
|
+
this.first = event.first;
|
|
305
|
+
this.rows = event.rows;
|
|
306
|
+
const state = {
|
|
307
|
+
page: this.getPage(),
|
|
308
|
+
first: this.first,
|
|
309
|
+
rows: this.rows,
|
|
310
|
+
pageCount: Math.ceil(this.getPageCount())
|
|
311
|
+
};
|
|
312
|
+
this.pageChanged.emit(state);
|
|
313
|
+
}
|
|
314
|
+
onLazyLoaded(event) {
|
|
315
|
+
this.lazyLoaded.emit(event);
|
|
316
|
+
}
|
|
317
|
+
onNodeExpanded(event) {
|
|
318
|
+
this.nodeExpanded.emit(event);
|
|
319
|
+
setTimeout(() => {
|
|
320
|
+
this._recalcVirtualHeight();
|
|
321
|
+
this.cdRef.markForCheck();
|
|
322
|
+
});
|
|
323
|
+
}
|
|
324
|
+
onNodeCollapsed(event) {
|
|
325
|
+
this.nodeCollapsed.emit(event);
|
|
326
|
+
setTimeout(() => {
|
|
327
|
+
this._recalcVirtualHeight();
|
|
328
|
+
this.cdRef.markForCheck();
|
|
329
|
+
});
|
|
330
|
+
}
|
|
331
|
+
onNodeSelected(event) {
|
|
332
|
+
this.nodeSelected.emit(event);
|
|
333
|
+
}
|
|
334
|
+
onNodeUnselected(event) {
|
|
335
|
+
this.nodeUnselected.emit(event);
|
|
336
|
+
}
|
|
337
|
+
onSort(event) {
|
|
338
|
+
this.sorted.emit(event);
|
|
339
|
+
}
|
|
340
|
+
onSelectColumn(col) {
|
|
341
|
+
let res = [];
|
|
342
|
+
if (this.isColumnSelected(col)) {
|
|
343
|
+
res = this.selectedColumns.filter((v) => !isEqual(v, col));
|
|
344
|
+
}
|
|
345
|
+
else {
|
|
346
|
+
this.columns.forEach((o) => {
|
|
347
|
+
if (this.selectedColumns.some((v) => isEqual(v, o)) ||
|
|
348
|
+
isEqual(col, o)) {
|
|
349
|
+
res.push(o);
|
|
350
|
+
}
|
|
351
|
+
});
|
|
352
|
+
}
|
|
353
|
+
this.selectedColumns = res;
|
|
354
|
+
this.columnsSelected.emit(this.selectedColumns);
|
|
355
|
+
}
|
|
356
|
+
}
|
|
357
|
+
CpsTreeTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CpsTreeTableComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
358
|
+
CpsTreeTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: CpsTreeTableComponent, isStandalone: true, selector: "cps-tree-table", inputs: { data: "data", columns: "columns", colHeaderName: "colHeaderName", colFieldName: "colFieldName", size: "size", striped: "striped", bordered: "bordered", tableStyle: "tableStyle", tableStyleClass: "tableStyleClass", selectable: "selectable", sortable: "sortable", sortMode: "sortMode", customSort: "customSort", hasToolbar: "hasToolbar", toolbarSize: "toolbarSize", toolbarTitle: "toolbarTitle", rowHover: "rowHover", showGlobalFilter: "showGlobalFilter", globalFilterPlaceholder: "globalFilterPlaceholder", globalFilterFields: "globalFilterFields", paginator: "paginator", alwaysShowPaginator: "alwaysShowPaginator", rowsPerPageOptions: "rowsPerPageOptions", first: "first", rows: "rows", resetPageOnRowsChange: "resetPageOnRowsChange", resetPageOnSort: "resetPageOnSort", emptyMessage: "emptyMessage", emptyBodyHeight: "emptyBodyHeight", lazy: "lazy", lazyLoadOnInit: "lazyLoadOnInit", loading: "loading", scrollable: "scrollable", scrollHeight: "scrollHeight", virtualScroll: "virtualScroll", numToleratedItems: "numToleratedItems", showActionBtn: "showActionBtn", actionBtnTitle: "actionBtnTitle", showColumnsToggle: "showColumnsToggle" }, outputs: { actionBtnClicked: "actionBtnClicked", columnsSelected: "columnsSelected", pageChanged: "pageChanged", lazyLoaded: "lazyLoaded", nodeExpanded: "nodeExpanded", nodeCollapsed: "nodeCollapsed", nodeSelected: "nodeSelected", nodeUnselected: "nodeUnselected", sorted: "sorted", editRowBtnClicked: "editRowBtnClicked", rowsRemoved: "rowsRemoved", customSortFunction: "customSortFunction" }, providers: [
|
|
359
|
+
TreeTableService,
|
|
360
|
+
{
|
|
361
|
+
provide: TreeTable,
|
|
362
|
+
useFactory: treeTableFactory,
|
|
363
|
+
// eslint-disable-next-line no-use-before-define
|
|
364
|
+
deps: [CpsTreeTableComponent]
|
|
365
|
+
}
|
|
366
|
+
], 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 }], viewQueries: [{ propertyName: "primengTreeTable", first: true, predicate: ["primengTreeTable"], descendants: true, static: true }], ngImport: i0, template: "<p-treeTable\n #primengTreeTable\n ttWithUnsort\n [ngClass]=\"{ 'cps-treetable-loading': loading }\"\n [value]=\"data\"\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 compareSelectionBy=\"equals\"\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 [resetPageOnSort]=\"resetPageOnSort\"\n currentPageReportTemplate=\"{first} - {last} of {totalRecords}\"\n (onPage)=\"onPageChange($event)\"\n (onSort)=\"onSort($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 <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>{{ toolbarTitle }}</div>\n <div *ngIf=\"showGlobalFilter\" class=\"cps-treetable-tbar-global-filter\">\n <cps-input\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-remove-btn\">\n <cps-button\n label=\"Remove\"\n color=\"prepared\"\n type=\"borderless\"\n icon=\"remove\"\n [size]=\"toolbarSize\"\n (clicked)=\"removeSelected()\">\n </cps-button>\n </div>\n <div *ngIf=\"showActionBtn\" class=\"cps-treetable-tbar-action-btn\">\n <cps-button\n [label]=\"actionBtnTitle\"\n color=\"prepared\"\n type=\"outlined\"\n [size]=\"toolbarSize\"\n (clicked)=\"onClickActionBtn()\">\n </cps-button>\n </div>\n <div\n *ngIf=\"showColumnsToggle && columns.length > 0\"\n class=\"cps-treetable-tbar-coltoggle-btn\">\n <cps-icon\n icon=\"columns\"\n size=\"normal\"\n color=\"prepared-lighten1\"\n (click)=\"colToggleMenu.toggle($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 </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 style=\"width: 55px\" *ngIf=\"selectable\">\n <p-treeTableHeaderCheckbox></p-treeTableHeaderCheckbox>\n </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 <th\n *ngFor=\"let col of columns\"\n [cpsTTColSortable]=\"col[colFieldName]\">\n {{ col[colHeaderName] }}\n </th>\n </ng-container>\n <ng-container *ngIf=\"!sortable\">\n <th *ngFor=\"let col of columns\">\n {{ col[colHeaderName] }}\n </th>\n </ng-container>\n </ng-container>\n <th class=\"cps-treetable-row-menu-cell\" *ngIf=\"showRowMenu\"></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 style=\"width: 55px\" *ngIf=\"selectable\">\n <p-treeTableCheckbox [value]=\"rowNode\"></p-treeTableCheckbox>\n </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 <td *ngFor=\"let col of columns; let i = index\">\n <p-treeTableToggler [rowNode]=\"rowNode\" *ngIf=\"i === 0\">\n </p-treeTableToggler>\n {{ rowData[col[colFieldName]] }}\n </td>\n </ng-container>\n </ng-container>\n <td *ngIf=\"showRowMenu\" class=\"cps-treetable-row-menu-cell\">\n <table-row-menu\n (editRowBtnClicked)=\"onEditRowClicked(rowNode.node)\"\n (removeRowBtnClicked)=\"onRemoveRowClicked(rowNode.node)\">\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}:host ::ng-deep .cps-treetable-bottom-bordered>.p-treetable-scrollable-wrapper{border-bottom:1px solid var(--cps-color-line-mid)}:host ::ng-deep .p-treetable .p-treetable-scrollable-header,:host ::ng-deep .p-treetable .p-treetable-scrollable-footer{background:white}: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:700;color:var(--cps-color-text-mild);background:white;transition:box-shadow .2s}:host ::ng-deep .p-treetable-scrollable-body{overflow:auto!important;position:relative}:host ::ng-deep .p-treetable .p-treetable-tbody>tr{background:#ffffff;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:#f1ebed!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 .p-treetable-tbody>tr>td:first-child{border-width:0 0 1px 1px}: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{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}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td .p-treetable-toggler:focus{outline:0 none;outline-offset:0}:host ::ng-deep .p-treetable .p-paginator-bottom{border-width:0 1px 1px 1px;border-radius:0}:host ::ng-deep .p-paginator{background:white;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;color:var(--cps-color-text-dark);padding:1rem;border: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}: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}: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 .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:#f8f4f5}: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:#f1eaec}: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:#f8f4f5}:host ::ng-deep .p-paginator .p-paginator-pages .p-paginator-page:not(.p-highlight):active{background:#f1eaec}: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:white}: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-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-right{display:flex;align-items:center}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right .cps-treetable-tbar-remove-btn{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{display:contents}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right .cps-treetable-tbar-coltoggle-btn cps-icon{margin-left:8px;margin-right:4px;cursor:pointer}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right .cps-treetable-tbar-coltoggle-btn 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:white;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:white}:host ::ng-deep .p-treetable .p-treetable-thead>tr>th:hover sortalticon{opacity:1}:host ::ng-deep .p-treetable .p-sortable-column:not(.p-highlight):hover{background:white;color:var(--cps-color-text-mild)}:host ::ng-deep .p-treetable .p-sortable-column.p-highlight:hover{background:white;color:var(--cps-color-text-mild)}:host ::ng-deep .p-treetable .p-sortable-column:not(.p-highlight):hover .p-sortable-column-icon{color:var(--cps-color-text-dark)}:host ::ng-deep .p-treetable .p-sortable-column .p-sortable-column-icon{color:var(--cps-color-text-mild);margin-left:.5rem}:host ::ng-deep .p-treetable .p-sortable-column.p-highlight .p-sortable-column-icon{color:var(--cps-color-calm)}: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-sortable-column-icon{width:13px;height:13px}:host ::ng-deep .p-treetable .p-sortable-column .p-sortable-column-badge{display:inline-flex;align-items:center;justify-content:center}:host ::ng-deep .p-treetable .p-sortable-column .p-column-title,:host ::ng-deep .p-treetable .p-sortable-column .p-sortable-column-icon,:host ::ng-deep .p-treetable .p-sortable-column .p-sortable-column-badge{vertical-align:unset}:host ::ng-deep .p-treetable .p-sortable-column .p-sortable-column-badge{border-radius:50%;height:1.125rem;min-width:1.125rem;line-height:1.125rem;color:var(--cps-color-calm);background:#f1eaec;margin-left:.5rem}: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:#f8f4f5}:host ::ng-deep .p-treetable-hoverable-rows .p-treetable-tbody>tr{cursor:auto}:host ::ng-deep .p-treetable .p-column-resizer-helper{background:#3b82f6}: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 .p-sortable-column.cps-treetable-col-filter-menu-open{cursor:default}:host ::ng-deep .cps-treetable-col-filter-menu-open .cps-treetable-col-filter-menu-button{color:var(--cps-color-text-dark)}:host ::ng-deep sortalticon{opacity:0}:host ::ng-deep p-treetablesorticon{display:inline-flex;align-items:baseline}: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-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(even){background:#ffffff}:host ::ng-deep .cps-treetable-row-menu-cell{width:55px;border-left:none!important}:host ::ng-deep td:has(p-treetablecheckbox){text-align:center!important}:host ::ng-deep th:has(p-treetableheadercheckbox){text-align:center!important;width:55px!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:#ffffff;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:white}.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:#f8f4f5}.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:#efe4e7}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item.highlighten{background:#f5eeef}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item.selected.highlighten{background:#e6d4d9}.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: "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", "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", "virtualRowHeight", "value", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection"], outputs: ["selectionChange", "contextMenuSelectionChange", "onFilter", "onNodeExpand", "onNodeCollapse", "onPage", "onSort", "onLazyLoad", "sortFunction", "onColResize", "onColReorder", "onNodeSelect", "onNodeUnselect", "onContextMenuSelect", "onHeaderCheckboxToggle", "onEditInit", "onEditComplete", "onEditCancel"] }, { kind: "directive", type: i4.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "component", type: i3.TreeTableToggler, selector: "p-treeTableToggler", inputs: ["rowNode"] }, { kind: "directive", type: i3.TTRow, selector: "[ttRow]", inputs: ["ttRow"] }, { kind: "component", type: i3.TTCheckbox, selector: "p-treeTableCheckbox", inputs: ["disabled", "value"] }, { kind: "component", type: i3.TTHeaderCheckbox, selector: "p-treeTableHeaderCheckbox" }, { kind: "component", type: CpsInputComponent, selector: "cps-input", inputs: ["label", "hint", "placeholder", "disabled", "width", "type", "loading", "clearable", "prefixIcon", "prefixIconClickable", "prefixIconSize", "prefixText", "hideDetails", "persistentClear", "error", "infoTooltip", "infoTooltipClass", "infoTooltipMaxWidth", "infoTooltipPersistent", "infoTooltipPosition", "appearance", "value"], outputs: ["valueChanged", "focused", "prefixIconClicked", "blurred", "cleared", "enterClicked"] }, { kind: "component", type: CpsButtonComponent, selector: "cps-button", inputs: ["color", "contentColor", "type", "label", "icon", "iconPosition", "size", "width", "height", "disabled", "loading"], outputs: ["clicked"] }, { kind: "component", type: CpsMenuComponent, selector: "cps-menu", inputs: ["header", "items", "withArrow", "compressed", "focusOnShow", "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", "optionLabel", "optionValue", "optionInfo", "hideDetails", "persistentClear", "prefixIcon", "prefixIconSize", "loading", "virtualScroll", "infoTooltip", "infoTooltipClass", "infoTooltipMaxWidth", "infoTooltipPersistent", "infoTooltipPosition", "optionsClass", "appearance", "value"], outputs: ["valueChanged"] }, { 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: TreeTableUnsortDirective, selector: "[ttWithUnsort]" }, { kind: "component", type: TableRowMenuComponent, selector: "table-row-menu", outputs: ["editRowBtnClicked", "removeRowBtnClicked"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
367
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CpsTreeTableComponent, decorators: [{
|
|
368
|
+
type: Component,
|
|
369
|
+
args: [{ selector: 'cps-tree-table', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [
|
|
370
|
+
FormsModule,
|
|
371
|
+
CommonModule,
|
|
372
|
+
TreeTableModule,
|
|
373
|
+
CpsInputComponent,
|
|
374
|
+
CpsButtonComponent,
|
|
375
|
+
CpsMenuComponent,
|
|
376
|
+
CpsIconComponent,
|
|
377
|
+
CpsSelectComponent,
|
|
378
|
+
CpsLoaderComponent,
|
|
379
|
+
AngleDoubleLeftIcon,
|
|
380
|
+
AngleLeftIcon,
|
|
381
|
+
AngleRightIcon,
|
|
382
|
+
AngleDoubleRightIcon,
|
|
383
|
+
CpsTreeTableColumnSortableDirective,
|
|
384
|
+
TreeTableUnsortDirective,
|
|
385
|
+
TableRowMenuComponent
|
|
386
|
+
], providers: [
|
|
387
|
+
TreeTableService,
|
|
388
|
+
{
|
|
389
|
+
provide: TreeTable,
|
|
390
|
+
useFactory: treeTableFactory,
|
|
391
|
+
// eslint-disable-next-line no-use-before-define
|
|
392
|
+
deps: [CpsTreeTableComponent]
|
|
393
|
+
}
|
|
394
|
+
], template: "<p-treeTable\n #primengTreeTable\n ttWithUnsort\n [ngClass]=\"{ 'cps-treetable-loading': loading }\"\n [value]=\"data\"\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 compareSelectionBy=\"equals\"\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 [resetPageOnSort]=\"resetPageOnSort\"\n currentPageReportTemplate=\"{first} - {last} of {totalRecords}\"\n (onPage)=\"onPageChange($event)\"\n (onSort)=\"onSort($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 <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>{{ toolbarTitle }}</div>\n <div *ngIf=\"showGlobalFilter\" class=\"cps-treetable-tbar-global-filter\">\n <cps-input\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-remove-btn\">\n <cps-button\n label=\"Remove\"\n color=\"prepared\"\n type=\"borderless\"\n icon=\"remove\"\n [size]=\"toolbarSize\"\n (clicked)=\"removeSelected()\">\n </cps-button>\n </div>\n <div *ngIf=\"showActionBtn\" class=\"cps-treetable-tbar-action-btn\">\n <cps-button\n [label]=\"actionBtnTitle\"\n color=\"prepared\"\n type=\"outlined\"\n [size]=\"toolbarSize\"\n (clicked)=\"onClickActionBtn()\">\n </cps-button>\n </div>\n <div\n *ngIf=\"showColumnsToggle && columns.length > 0\"\n class=\"cps-treetable-tbar-coltoggle-btn\">\n <cps-icon\n icon=\"columns\"\n size=\"normal\"\n color=\"prepared-lighten1\"\n (click)=\"colToggleMenu.toggle($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 </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 style=\"width: 55px\" *ngIf=\"selectable\">\n <p-treeTableHeaderCheckbox></p-treeTableHeaderCheckbox>\n </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 <th\n *ngFor=\"let col of columns\"\n [cpsTTColSortable]=\"col[colFieldName]\">\n {{ col[colHeaderName] }}\n </th>\n </ng-container>\n <ng-container *ngIf=\"!sortable\">\n <th *ngFor=\"let col of columns\">\n {{ col[colHeaderName] }}\n </th>\n </ng-container>\n </ng-container>\n <th class=\"cps-treetable-row-menu-cell\" *ngIf=\"showRowMenu\"></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 style=\"width: 55px\" *ngIf=\"selectable\">\n <p-treeTableCheckbox [value]=\"rowNode\"></p-treeTableCheckbox>\n </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 <td *ngFor=\"let col of columns; let i = index\">\n <p-treeTableToggler [rowNode]=\"rowNode\" *ngIf=\"i === 0\">\n </p-treeTableToggler>\n {{ rowData[col[colFieldName]] }}\n </td>\n </ng-container>\n </ng-container>\n <td *ngIf=\"showRowMenu\" class=\"cps-treetable-row-menu-cell\">\n <table-row-menu\n (editRowBtnClicked)=\"onEditRowClicked(rowNode.node)\"\n (removeRowBtnClicked)=\"onRemoveRowClicked(rowNode.node)\">\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}:host ::ng-deep .cps-treetable-bottom-bordered>.p-treetable-scrollable-wrapper{border-bottom:1px solid var(--cps-color-line-mid)}:host ::ng-deep .p-treetable .p-treetable-scrollable-header,:host ::ng-deep .p-treetable .p-treetable-scrollable-footer{background:white}: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:700;color:var(--cps-color-text-mild);background:white;transition:box-shadow .2s}:host ::ng-deep .p-treetable-scrollable-body{overflow:auto!important;position:relative}:host ::ng-deep .p-treetable .p-treetable-tbody>tr{background:#ffffff;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:#f1ebed!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 .p-treetable-tbody>tr>td:first-child{border-width:0 0 1px 1px}: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{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}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td .p-treetable-toggler:focus{outline:0 none;outline-offset:0}:host ::ng-deep .p-treetable .p-paginator-bottom{border-width:0 1px 1px 1px;border-radius:0}:host ::ng-deep .p-paginator{background:white;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;color:var(--cps-color-text-dark);padding:1rem;border: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}: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}: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 .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:#f8f4f5}: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:#f1eaec}: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:#f8f4f5}:host ::ng-deep .p-paginator .p-paginator-pages .p-paginator-page:not(.p-highlight):active{background:#f1eaec}: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:white}: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-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-right{display:flex;align-items:center}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right .cps-treetable-tbar-remove-btn{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{display:contents}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right .cps-treetable-tbar-coltoggle-btn cps-icon{margin-left:8px;margin-right:4px;cursor:pointer}:host ::ng-deep .p-treetable .p-treetable-header .cps-treetable-tbar-right .cps-treetable-tbar-coltoggle-btn 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:white;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:white}:host ::ng-deep .p-treetable .p-treetable-thead>tr>th:hover sortalticon{opacity:1}:host ::ng-deep .p-treetable .p-sortable-column:not(.p-highlight):hover{background:white;color:var(--cps-color-text-mild)}:host ::ng-deep .p-treetable .p-sortable-column.p-highlight:hover{background:white;color:var(--cps-color-text-mild)}:host ::ng-deep .p-treetable .p-sortable-column:not(.p-highlight):hover .p-sortable-column-icon{color:var(--cps-color-text-dark)}:host ::ng-deep .p-treetable .p-sortable-column .p-sortable-column-icon{color:var(--cps-color-text-mild);margin-left:.5rem}:host ::ng-deep .p-treetable .p-sortable-column.p-highlight .p-sortable-column-icon{color:var(--cps-color-calm)}: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-sortable-column-icon{width:13px;height:13px}:host ::ng-deep .p-treetable .p-sortable-column .p-sortable-column-badge{display:inline-flex;align-items:center;justify-content:center}:host ::ng-deep .p-treetable .p-sortable-column .p-column-title,:host ::ng-deep .p-treetable .p-sortable-column .p-sortable-column-icon,:host ::ng-deep .p-treetable .p-sortable-column .p-sortable-column-badge{vertical-align:unset}:host ::ng-deep .p-treetable .p-sortable-column .p-sortable-column-badge{border-radius:50%;height:1.125rem;min-width:1.125rem;line-height:1.125rem;color:var(--cps-color-calm);background:#f1eaec;margin-left:.5rem}: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:#f8f4f5}:host ::ng-deep .p-treetable-hoverable-rows .p-treetable-tbody>tr{cursor:auto}:host ::ng-deep .p-treetable .p-column-resizer-helper{background:#3b82f6}: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 .p-sortable-column.cps-treetable-col-filter-menu-open{cursor:default}:host ::ng-deep .cps-treetable-col-filter-menu-open .cps-treetable-col-filter-menu-button{color:var(--cps-color-text-dark)}:host ::ng-deep sortalticon{opacity:0}:host ::ng-deep p-treetablesorticon{display:inline-flex;align-items:baseline}: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-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(even){background:#ffffff}:host ::ng-deep .cps-treetable-row-menu-cell{width:55px;border-left:none!important}:host ::ng-deep td:has(p-treetablecheckbox){text-align:center!important}:host ::ng-deep th:has(p-treetableheadercheckbox){text-align:center!important;width:55px!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:#ffffff;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:white}.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:#f8f4f5}.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:#efe4e7}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item.highlighten{background:#f5eeef}.cps-treetable-coltoggle-menu .cps-treetable-coltoggle-menu-item.selected.highlighten{background:#e6d4d9}.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"] }]
|
|
395
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { data: [{
|
|
396
|
+
type: Input
|
|
397
|
+
}], columns: [{
|
|
398
|
+
type: Input
|
|
399
|
+
}], colHeaderName: [{
|
|
400
|
+
type: Input
|
|
401
|
+
}], colFieldName: [{
|
|
402
|
+
type: Input
|
|
403
|
+
}], size: [{
|
|
404
|
+
type: Input
|
|
405
|
+
}], striped: [{
|
|
406
|
+
type: Input
|
|
407
|
+
}], bordered: [{
|
|
408
|
+
type: Input
|
|
409
|
+
}], tableStyle: [{
|
|
410
|
+
type: Input
|
|
411
|
+
}], tableStyleClass: [{
|
|
412
|
+
type: Input
|
|
413
|
+
}], selectable: [{
|
|
414
|
+
type: Input
|
|
415
|
+
}], sortable: [{
|
|
416
|
+
type: Input
|
|
417
|
+
}], sortMode: [{
|
|
418
|
+
type: Input
|
|
419
|
+
}], customSort: [{
|
|
420
|
+
type: Input
|
|
421
|
+
}], hasToolbar: [{
|
|
422
|
+
type: Input
|
|
423
|
+
}], toolbarSize: [{
|
|
424
|
+
type: Input
|
|
425
|
+
}], toolbarTitle: [{
|
|
426
|
+
type: Input
|
|
427
|
+
}], rowHover: [{
|
|
428
|
+
type: Input
|
|
429
|
+
}], showGlobalFilter: [{
|
|
430
|
+
type: Input
|
|
431
|
+
}], globalFilterPlaceholder: [{
|
|
432
|
+
type: Input
|
|
433
|
+
}], globalFilterFields: [{
|
|
434
|
+
type: Input
|
|
435
|
+
}], paginator: [{
|
|
436
|
+
type: Input
|
|
437
|
+
}], alwaysShowPaginator: [{
|
|
438
|
+
type: Input
|
|
439
|
+
}], rowsPerPageOptions: [{
|
|
440
|
+
type: Input
|
|
441
|
+
}], first: [{
|
|
442
|
+
type: Input
|
|
443
|
+
}], rows: [{
|
|
444
|
+
type: Input
|
|
445
|
+
}], resetPageOnRowsChange: [{
|
|
446
|
+
type: Input
|
|
447
|
+
}], resetPageOnSort: [{
|
|
448
|
+
type: Input
|
|
449
|
+
}], emptyMessage: [{
|
|
450
|
+
type: Input
|
|
451
|
+
}], emptyBodyHeight: [{
|
|
452
|
+
type: Input
|
|
453
|
+
}], lazy: [{
|
|
454
|
+
type: Input
|
|
455
|
+
}], lazyLoadOnInit: [{
|
|
456
|
+
type: Input
|
|
457
|
+
}], loading: [{
|
|
458
|
+
type: Input
|
|
459
|
+
}], scrollable: [{
|
|
460
|
+
type: Input
|
|
461
|
+
}], scrollHeight: [{
|
|
462
|
+
type: Input
|
|
463
|
+
}], virtualScroll: [{
|
|
464
|
+
type: Input
|
|
465
|
+
}], numToleratedItems: [{
|
|
466
|
+
type: Input
|
|
467
|
+
}], showActionBtn: [{
|
|
468
|
+
type: Input
|
|
469
|
+
}], actionBtnTitle: [{
|
|
470
|
+
type: Input
|
|
471
|
+
}], showColumnsToggle: [{
|
|
472
|
+
type: Input
|
|
473
|
+
}], actionBtnClicked: [{
|
|
474
|
+
type: Output
|
|
475
|
+
}], columnsSelected: [{
|
|
476
|
+
type: Output
|
|
477
|
+
}], pageChanged: [{
|
|
478
|
+
type: Output
|
|
479
|
+
}], lazyLoaded: [{
|
|
480
|
+
type: Output
|
|
481
|
+
}], nodeExpanded: [{
|
|
482
|
+
type: Output
|
|
483
|
+
}], nodeCollapsed: [{
|
|
484
|
+
type: Output
|
|
485
|
+
}], nodeSelected: [{
|
|
486
|
+
type: Output
|
|
487
|
+
}], nodeUnselected: [{
|
|
488
|
+
type: Output
|
|
489
|
+
}], sorted: [{
|
|
490
|
+
type: Output
|
|
491
|
+
}], editRowBtnClicked: [{
|
|
492
|
+
type: Output
|
|
493
|
+
}], rowsRemoved: [{
|
|
494
|
+
type: Output
|
|
495
|
+
}], customSortFunction: [{
|
|
496
|
+
type: Output
|
|
497
|
+
}], toolbarTemplate: [{
|
|
498
|
+
type: ContentChild,
|
|
499
|
+
args: ['toolbar', { static: false }]
|
|
500
|
+
}], headerTemplate: [{
|
|
501
|
+
type: ContentChild,
|
|
502
|
+
args: ['header', { static: false }]
|
|
503
|
+
}], nestedHeaderTemplate: [{
|
|
504
|
+
type: ContentChild,
|
|
505
|
+
args: ['nestedHeader', { static: false }]
|
|
506
|
+
}], bodyTemplate: [{
|
|
507
|
+
type: ContentChild,
|
|
508
|
+
args: ['body', { static: false }]
|
|
509
|
+
}], primengTreeTable: [{
|
|
510
|
+
type: ViewChild,
|
|
511
|
+
args: ['primengTreeTable', { static: true }]
|
|
512
|
+
}] } });
|
|
513
|
+
//# 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  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  TemplateRef,\n  ViewChild\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport {\n  TreeTable,\n  TreeTableService,\n  TreeTableModule\n} from 'primeng/treetable';\nimport { DomHandler } from 'primeng/dom';\nimport { CpsInputComponent } from '../cps-input/cps-input.component';\nimport { CpsButtonComponent } from '../cps-button/cps-button.component';\nimport { CpsMenuComponent } from '../cps-menu/cps-menu.component';\nimport { find, isEqual } from 'lodash-es';\nimport { CpsIconComponent } from '../cps-icon/cps-icon.component';\nimport { CpsSelectComponent } from '../cps-select/cps-select.component';\nimport { FormsModule } from '@angular/forms';\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 { convertSize } from '../../utils/internal/size-utils';\nimport { CpsLoaderComponent } from '../cps-loader/cps-loader.component';\nimport { SortEvent } from 'primeng/api';\nimport { CpsTreeTableColumnSortableDirective } from './directives/cps-tree-table-column-sortable.directive';\nimport { TreeTableUnsortDirective } from './directives/internal/tree-table-unsort.directive';\nimport { TableRowMenuComponent } from '../cps-table/table-row-menu/table-row-menu.component';\n\nexport function treeTableFactory(tableComponent: CpsTreeTableComponent) {\n  return tableComponent.primengTreeTable;\n}\n\nexport type CpsTreeTableSize = 'small' | 'normal' | 'large';\nexport type CpsTreeTableToolbarSize = 'small' | 'normal';\nexport type CpsTreeTableSortMode = 'single' | 'multiple';\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    TreeTableUnsortDirective,\n    TableRowMenuComponent\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\n{\n  @Input() data: any[] = [];\n  @Input() columns: { [key: string]: any }[] = [];\n  @Input() colHeaderName = 'header';\n  @Input() colFieldName = 'field';\n\n  @Input() size: CpsTreeTableSize = 'normal';\n  @Input() striped = true;\n  @Input() bordered = true;\n  @Input() tableStyle = undefined;\n  @Input() tableStyleClass = '';\n  @Input() selectable = false;\n\n  @Input() sortable = false; // makes all sortable if columns are provided\n  @Input() sortMode: CpsTreeTableSortMode = 'single';\n  @Input() customSort = false;\n\n  @Input() hasToolbar = true;\n  @Input() toolbarSize: CpsTreeTableToolbarSize = 'normal';\n  @Input() toolbarTitle = '';\n\n  @Input() rowHover = true;\n\n  @Input() showGlobalFilter = true;\n  @Input() globalFilterPlaceholder = 'Search';\n  @Input() globalFilterFields: string[] = [];\n\n  @Input() paginator = false;\n  @Input() alwaysShowPaginator = true;\n  @Input() rowsPerPageOptions: number[] = [];\n  @Input() first = 0;\n  @Input() rows = 0;\n  @Input() resetPageOnRowsChange = false;\n  @Input() resetPageOnSort = true;\n\n  @Input() emptyMessage = 'No data';\n  @Input() emptyBodyHeight: number | string = '';\n\n  @Input() lazy = false;\n  @Input() lazyLoadOnInit = true;\n\n  // @Input() showRowMenu = false; // TODO\n  showRowMenu = false; // TODO\n\n  @Input() loading = false;\n\n  @Input() scrollable = true;\n  @Input() scrollHeight = ''; // 'flex' or value+'px'\n  @Input() virtualScroll = false; // works only if scrollable is true\n  @Input() numToleratedItems = 10;\n\n  // @Input() showRemoveBtnOnSelect = false; // TODO\n  showRemoveBtnOnSelect = false; // TODO\n\n  @Input() showActionBtn = false;\n  @Input() actionBtnTitle = 'Action';\n\n  @Input() showColumnsToggle = false; // if external body template is provided, use columnsSelected event emitter\n\n  @Output() actionBtnClicked = new EventEmitter<void>();\n  @Output() columnsSelected = new EventEmitter<{ [key: string]: any }[]>();\n  @Output() pageChanged = new EventEmitter<any>();\n  @Output() lazyLoaded = new EventEmitter<any>();\n  @Output() nodeExpanded = new EventEmitter<any>();\n  @Output() nodeCollapsed = new EventEmitter<any>();\n  @Output() nodeSelected = new EventEmitter<any>();\n  @Output() nodeUnselected = new EventEmitter<any>();\n  @Output() sorted = new EventEmitter<any>();\n  @Output() editRowBtnClicked = new EventEmitter<any>();\n  @Output() rowsRemoved = 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  @ViewChild('primengTreeTable', { static: true })\n  primengTreeTable!: TreeTable;\n\n  selectedColumns: { [key: string]: any }[] = [];\n\n  rowOptions: { label: string; value: number }[] = [];\n\n  selectedRows: any[] = [];\n\n  virtualScrollItemSize = 0;\n  defScrollHeightPx = 0;\n  defScrollHeight = '';\n\n  resizeObserver: ResizeObserver;\n  headerBox: any;\n  scrollableBody: any;\n  scrollbarWidth = 0;\n\n  // eslint-disable-next-line no-useless-constructor\n  constructor(private cdRef: ChangeDetectorRef) {\n    this.resizeObserver = new ResizeObserver((entries) => {\n      entries.forEach((entry) => {\n        const body = entry.target;\n        const sbarVisible = body.scrollHeight > body.clientHeight;\n\n        let wScroll = sbarVisible ? this.scrollbarWidth : 0;\n        if (wScroll > 0) wScroll -= 1;\n\n        this.headerBox.style.paddingRight = `${wScroll}px`;\n        this.headerBox.style.borderRight =\n          wScroll > 0 ? '1px solid #d7d5d5' : 'unset';\n      });\n    });\n  }\n\n  ngOnInit(): void {\n    this.emptyBodyHeight = convertSize(this.emptyBodyHeight);\n    if (!this.scrollable) this.virtualScroll = false;\n\n    if (this.virtualScroll) {\n      this.defScrollHeight = this.scrollHeight;\n\n      if (this.defScrollHeight === 'flex')\n        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 = this.columns;\n  }\n\n  ngAfterViewInit(): void {\n    this.scrollableBody = this.primengTreeTable.el.nativeElement.querySelector(\n      '.p-treetable-scrollable-body'\n    );\n    if (this.scrollableBody) {\n      this.headerBox = this.primengTreeTable.el.nativeElement.querySelector(\n        '.p-treetable-scrollable-header-box'\n      );\n      if (this.virtualScroll && this.defScrollHeight === 'flex')\n        this.defScrollHeightPx = this.scrollableBody.clientHeight;\n\n      if (this.headerBox) {\n        this.scrollbarWidth = DomHandler.calculateScrollbarWidth();\n        this.resizeObserver.observe(this.scrollableBody);\n      }\n    }\n  }\n\n  ngAfterViewChecked() {\n    if (!this.virtualScroll || this.virtualScrollItemSize) return;\n    this.virtualScrollItemSize =\n      this.primengTreeTable?.el?.nativeElement\n        ?.querySelector('.p-treetable-tbody')\n        ?.querySelector('tr')?.clientHeight || 0;\n    this.cdRef.detectChanges();\n  }\n\n  ngOnDestroy(): void {\n    this.resizeObserver?.disconnect();\n    if (this.virtualScroll && this.defScrollHeight === 'flex')\n      window.removeEventListener('resize', this._onWindowResize.bind(this));\n  }\n\n  private _onWindowResize() {\n    this.defScrollHeightPx = this.scrollableBody.clientHeight;\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    if (this.scrollHeight && !this.loading && this.data.length > 0) {\n      classesList.push('cps-treetable-bottom-bordered');\n    }\n\n    return classesList.join(' ');\n  }\n\n  onSortFunction(event: SortEvent) {\n    this.customSortFunction.emit(event);\n  }\n\n  private _recalcVirtualHeight() {\n    if (this.virtualScroll && this.defScrollHeight) {\n      const itemsLen = this.primengTreeTable.serializedValue.length;\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.defScrollHeightPx) {\n            this.scrollHeight = 'flex';\n            setTimeout(() => {\n              this.scrollableBody.style.height = '100%';\n              this.cdRef.markForCheck();\n            });\n            return;\n          }\n        }\n        this.scrollHeight = Math.min(this.defScrollHeightPx, curHeight) + 'px';\n      }\n    }\n  }\n\n  onFilterGlobal(value: string) {\n    this.primengTreeTable.filterGlobal(value, 'contains');\n    setTimeout(() => {\n      this._recalcVirtualHeight();\n      this.cdRef.markForCheck();\n    }, 300);\n  }\n\n  onClickActionBtn() {\n    this.actionBtnClicked.emit();\n  }\n\n  removeSelected() {\n    // TODO\n    // const indexes: number[] = this.primengTreeTable.selection.map(\n    //   (s: any) => s._defaultSortOrder\n    // );\n    // indexes.sort((a, b) => b - a);\n    // this.data = this.data.filter(\n    //   (v: any) => !indexes.includes(v._defaultSortOrder)\n    // );\n    // this.rowsRemoved.emit(\n    //   this.selectedRows.map(({ _defaultSortOrder, ...rest }) => rest)\n    // );\n    // this.selectedRows = [];\n  }\n\n  onEditRowClicked(node: any) {\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    const { _defaultSortOrder, expanded, partialSelected, ...rest } = node;\n    this.editRowBtnClicked.emit(rest);\n  }\n\n  onRemoveRowClicked(node: any) {\n    // TODO remove children of nodes\n\n    // find by default sort order in object itself or in nested parent\n    // then find the node itself\n    this.selectedRows = this.selectedRows.filter((v: any) => v !== node);\n    this.data = this.data.filter((v: any) => v !== node);\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    const { _defaultSortOrder, expanded, partialSelected, ...rest } = node;\n    this.rowsRemoved.emit([rest]);\n  }\n\n  toggleAllColumns() {\n    this.selectedColumns =\n      this.selectedColumns.length < this.columns.length ? this.columns : [];\n    this.columnsSelected.emit(this.selectedColumns);\n  }\n\n  isColumnSelected(col: any) {\n    return !!find(this.selectedColumns, (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  }\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._recalcVirtualHeight();\n      this.cdRef.markForCheck();\n    });\n  }\n\n  onNodeCollapsed(event: any) {\n    this.nodeCollapsed.emit(event);\n    setTimeout(() => {\n      this._recalcVirtualHeight();\n      this.cdRef.markForCheck();\n    });\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  }\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  }\n}\n","<p-treeTable\n  #primengTreeTable\n  ttWithUnsort\n  [ngClass]=\"{ 'cps-treetable-loading': loading }\"\n  [value]=\"data\"\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  compareSelectionBy=\"equals\"\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  [resetPageOnSort]=\"resetPageOnSort\"\n  currentPageReportTemplate=\"{first} - {last} of {totalRecords}\"\n  (onPage)=\"onPageChange($event)\"\n  (onSort)=\"onSort($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  <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>{{ toolbarTitle }}</div>\n        <div *ngIf=\"showGlobalFilter\" class=\"cps-treetable-tbar-global-filter\">\n          <cps-input\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-remove-btn\">\n          <cps-button\n            label=\"Remove\"\n            color=\"prepared\"\n            type=\"borderless\"\n            icon=\"remove\"\n            [size]=\"toolbarSize\"\n            (clicked)=\"removeSelected()\">\n          </cps-button>\n        </div>\n        <div *ngIf=\"showActionBtn\" class=\"cps-treetable-tbar-action-btn\">\n          <cps-button\n            [label]=\"actionBtnTitle\"\n            color=\"prepared\"\n            type=\"outlined\"\n            [size]=\"toolbarSize\"\n            (clicked)=\"onClickActionBtn()\">\n          </cps-button>\n        </div>\n        <div\n          *ngIf=\"showColumnsToggle && columns.length > 0\"\n          class=\"cps-treetable-tbar-coltoggle-btn\">\n          <cps-icon\n            icon=\"columns\"\n            size=\"normal\"\n            color=\"prepared-lighten1\"\n            (click)=\"colToggleMenu.toggle($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    </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 style=\"width: 55px\" *ngIf=\"selectable\">\n        <p-treeTableHeaderCheckbox></p-treeTableHeaderCheckbox>\n      </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          <th\n            *ngFor=\"let col of columns\"\n            [cpsTTColSortable]=\"col[colFieldName]\">\n            {{ col[colHeaderName] }}\n          </th>\n        </ng-container>\n        <ng-container *ngIf=\"!sortable\">\n          <th *ngFor=\"let col of columns\">\n            {{ col[colHeaderName] }}\n          </th>\n        </ng-container>\n      </ng-container>\n      <th class=\"cps-treetable-row-menu-cell\" *ngIf=\"showRowMenu\"></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 style=\"width: 55px\" *ngIf=\"selectable\">\n        <p-treeTableCheckbox [value]=\"rowNode\"></p-treeTableCheckbox>\n      </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          <td *ngFor=\"let col of columns; let i = index\">\n            <p-treeTableToggler [rowNode]=\"rowNode\" *ngIf=\"i === 0\">\n            </p-treeTableToggler>\n            {{ rowData[col[colFieldName]] }}\n          </td>\n        </ng-container>\n      </ng-container>\n      <td *ngIf=\"showRowMenu\" class=\"cps-treetable-row-menu-cell\">\n        <table-row-menu\n          (editRowBtnClicked)=\"onEditRowClicked(rowNode.node)\"\n          (removeRowBtnClicked)=\"onRemoveRowClicked(rowNode.node)\">\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"]}
|