@paperless/angular 1.12.4 → 1.13.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/esm2020/lib/base/form.component.mjs +105 -0
- package/esm2020/lib/base/upload.component.mjs +56 -0
- package/esm2020/lib/base/value-accessor.mjs +42 -0
- package/esm2020/lib/directives/p-cropper.directive.mjs +37 -0
- package/esm2020/lib/directives/p-datepicker.directive.mjs +37 -0
- package/esm2020/lib/directives/p-page-size-select.directive.mjs +42 -0
- package/esm2020/lib/directives/p-pagination.directive.mjs +42 -0
- package/esm2020/lib/directives/p-select.directive.mjs +37 -0
- package/{esm2022 → esm2020}/lib/modules/overlay/overlay.module.mjs +14 -14
- package/esm2020/lib/modules/overlay/overlay.ref.mjs +12 -0
- package/esm2020/lib/modules/overlay/services/overlay.service.mjs +74 -0
- package/esm2020/lib/modules/table/base/table.component.mjs +209 -0
- package/esm2020/lib/modules/table/components/table/table.component.mjs +683 -0
- package/esm2020/lib/modules/table/components/table-cell/table-cell.component.mjs +212 -0
- package/esm2020/lib/modules/table/components/table-column/table-column.component.mjs +56 -0
- package/{esm2022 → esm2020}/lib/modules/table/directives/p-table-custom-filter.directive.mjs +3 -3
- package/{esm2022 → esm2020}/lib/modules/table/directives/p-table-filter-modal.directive.mjs +3 -3
- package/esm2020/lib/modules/table/directives/p-table-footer.directive.mjs +52 -0
- package/esm2020/lib/modules/table/directives/p-table-header.directive.mjs +60 -0
- package/esm2020/lib/modules/table/directives/p-table-ngx.directive.mjs +121 -0
- package/esm2020/lib/modules/table/directives/p-table.directive.mjs +78 -0
- package/{esm2022 → esm2020}/lib/modules/table/table.module.mjs +4 -4
- package/esm2020/lib/modules/toast/components/toast-container/toast-container.component.mjs +36 -0
- package/esm2020/lib/modules/toast/directives/toast.directive.mjs +51 -0
- package/esm2020/lib/modules/toast/services/toast.service.mjs +53 -0
- package/{esm2022 → esm2020}/lib/modules/toast/toast.module.mjs +4 -4
- package/{esm2022 → esm2020}/lib/paperless.module.mjs +4 -4
- package/esm2020/lib/pipes/currency.pipe.mjs +20 -0
- package/esm2020/lib/pipes/date.pipe.mjs +20 -0
- package/esm2020/lib/pipes/safe.pipe.mjs +33 -0
- package/esm2020/lib/stencil/components.mjs +1466 -0
- package/esm2020/lib/stencil.module.mjs +17 -0
- package/fesm2015/paperless-angular.mjs +3805 -0
- package/fesm2015/paperless-angular.mjs.map +1 -0
- package/{fesm2022 → fesm2020}/paperless-angular.mjs +496 -698
- package/{fesm2022 → fesm2020}/paperless-angular.mjs.map +1 -1
- package/package.json +11 -5
- package/esm2022/lib/base/form.component.mjs +0 -103
- package/esm2022/lib/base/upload.component.mjs +0 -57
- package/esm2022/lib/base/value-accessor.mjs +0 -44
- package/esm2022/lib/directives/p-cropper.directive.mjs +0 -37
- package/esm2022/lib/directives/p-datepicker.directive.mjs +0 -37
- package/esm2022/lib/directives/p-page-size-select.directive.mjs +0 -42
- package/esm2022/lib/directives/p-pagination.directive.mjs +0 -42
- package/esm2022/lib/directives/p-select.directive.mjs +0 -37
- package/esm2022/lib/modules/overlay/overlay.ref.mjs +0 -14
- package/esm2022/lib/modules/overlay/services/overlay.service.mjs +0 -77
- package/esm2022/lib/modules/table/base/table.component.mjs +0 -211
- package/esm2022/lib/modules/table/components/table/table.component.mjs +0 -734
- package/esm2022/lib/modules/table/components/table-cell/table-cell.component.mjs +0 -230
- package/esm2022/lib/modules/table/components/table-column/table-column.component.mjs +0 -59
- package/esm2022/lib/modules/table/directives/p-table-footer.directive.mjs +0 -52
- package/esm2022/lib/modules/table/directives/p-table-header.directive.mjs +0 -60
- package/esm2022/lib/modules/table/directives/p-table-ngx.directive.mjs +0 -122
- package/esm2022/lib/modules/table/directives/p-table.directive.mjs +0 -78
- package/esm2022/lib/modules/toast/components/toast-container/toast-container.component.mjs +0 -39
- package/esm2022/lib/modules/toast/directives/toast.directive.mjs +0 -51
- package/esm2022/lib/modules/toast/services/toast.service.mjs +0 -51
- package/esm2022/lib/pipes/currency.pipe.mjs +0 -21
- package/esm2022/lib/pipes/date.pipe.mjs +0 -21
- package/esm2022/lib/pipes/safe.pipe.mjs +0 -34
- package/esm2022/lib/stencil/components.mjs +0 -1582
- package/esm2022/lib/stencil.module.mjs +0 -17
- /package/{esm2022 → esm2020}/lib/animations/fade.mjs +0 -0
- /package/{esm2022 → esm2020}/lib/animations/index.mjs +0 -0
- /package/{esm2022 → esm2020}/lib/animations/slide.mjs +0 -0
- /package/{esm2022 → esm2020}/lib/base/index.mjs +0 -0
- /package/{esm2022 → esm2020}/lib/directives/index.mjs +0 -0
- /package/{esm2022 → esm2020}/lib/modules/index.mjs +0 -0
- /package/{esm2022 → esm2020}/lib/modules/overlay/index.mjs +0 -0
- /package/{esm2022 → esm2020}/lib/modules/overlay/services/index.mjs +0 -0
- /package/{esm2022 → esm2020}/lib/modules/table/base/index.mjs +0 -0
- /package/{esm2022 → esm2020}/lib/modules/table/components/index.mjs +0 -0
- /package/{esm2022 → esm2020}/lib/modules/table/components/table/constants.mjs +0 -0
- /package/{esm2022 → esm2020}/lib/modules/table/directives/index.mjs +0 -0
- /package/{esm2022 → esm2020}/lib/modules/table/index.mjs +0 -0
- /package/{esm2022 → esm2020}/lib/modules/table/utils.mjs +0 -0
- /package/{esm2022 → esm2020}/lib/modules/toast/components/index.mjs +0 -0
- /package/{esm2022 → esm2020}/lib/modules/toast/directives/index.mjs +0 -0
- /package/{esm2022 → esm2020}/lib/modules/toast/index.mjs +0 -0
- /package/{esm2022 → esm2020}/lib/modules/toast/services/index.mjs +0 -0
- /package/{esm2022 → esm2020}/lib/modules/toast/types.mjs +0 -0
- /package/{esm2022 → esm2020}/lib/pipes/index.mjs +0 -0
- /package/{esm2022 → esm2020}/lib/stencil/angular-component-lib/utils.mjs +0 -0
- /package/{esm2022 → esm2020}/lib/stencil/index.mjs +0 -0
- /package/{esm2022 → esm2020}/paperless-angular.mjs +0 -0
- /package/{esm2022 → esm2020}/public-api.mjs +0 -0
|
@@ -1,734 +0,0 @@
|
|
|
1
|
-
import { __decorate } from "tslib";
|
|
2
|
-
import { ChangeDetectionStrategy, Component, ContentChild, ContentChildren, EventEmitter, HostListener, Input, Output, TemplateRef, } from '@angular/core';
|
|
3
|
-
import { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy';
|
|
4
|
-
import { BehaviorSubject, distinctUntilChanged } from 'rxjs';
|
|
5
|
-
import { TableCustomFilterDirective, TableFilterModalDirective, } from '../../directives';
|
|
6
|
-
import { TableColumn } from '../table-column/table-column.component';
|
|
7
|
-
import { defaultSize, defaultSizeOptions } from './constants';
|
|
8
|
-
import * as i0 from "@angular/core";
|
|
9
|
-
import * as i1 from "@angular/common";
|
|
10
|
-
import * as i2 from "../../../../stencil/components";
|
|
11
|
-
import * as i3 from "../table-cell/table-cell.component";
|
|
12
|
-
import * as i4 from "../../directives/p-table-footer.directive";
|
|
13
|
-
import * as i5 from "../../directives/p-table-header.directive";
|
|
14
|
-
let Table = class Table {
|
|
15
|
-
/**
|
|
16
|
-
* The items to be fed to the table
|
|
17
|
-
*/
|
|
18
|
-
items;
|
|
19
|
-
/**
|
|
20
|
-
* Wether data is loading
|
|
21
|
-
*/
|
|
22
|
-
loading = false;
|
|
23
|
-
/**
|
|
24
|
-
* Wether the header should show loading state
|
|
25
|
-
*/
|
|
26
|
-
headerLoading = false;
|
|
27
|
-
/**
|
|
28
|
-
* Wether the footer should show loading state
|
|
29
|
-
*/
|
|
30
|
-
footerLoading = false;
|
|
31
|
-
/**
|
|
32
|
-
* The amount of loading rows to show
|
|
33
|
-
*/
|
|
34
|
-
amountOfLoadingRows = 6;
|
|
35
|
-
/**
|
|
36
|
-
* Wether to enable selection
|
|
37
|
-
*/
|
|
38
|
-
enableRowSelection = true;
|
|
39
|
-
/**
|
|
40
|
-
* Wether to enable row clicking
|
|
41
|
-
*/
|
|
42
|
-
enableRowClick = true;
|
|
43
|
-
/**
|
|
44
|
-
* The current selection of items
|
|
45
|
-
*/
|
|
46
|
-
selectedRows = [];
|
|
47
|
-
/**
|
|
48
|
-
* Event whenever the current selection changes
|
|
49
|
-
*/
|
|
50
|
-
selectedRowsChange = new EventEmitter();
|
|
51
|
-
/**
|
|
52
|
-
* The key to determine if a row is selected
|
|
53
|
-
*/
|
|
54
|
-
selectionKey;
|
|
55
|
-
/**
|
|
56
|
-
* A key to determine if a row can be selected
|
|
57
|
-
*/
|
|
58
|
-
canSelectKey;
|
|
59
|
-
/**
|
|
60
|
-
* Event whenever a row is clicked
|
|
61
|
-
*/
|
|
62
|
-
rowClick = new EventEmitter();
|
|
63
|
-
/**
|
|
64
|
-
* Event whenever a row is selected
|
|
65
|
-
*/
|
|
66
|
-
rowSelected = new EventEmitter();
|
|
67
|
-
/**
|
|
68
|
-
* Event whenever a row is deselected
|
|
69
|
-
*/
|
|
70
|
-
rowDeselected = new EventEmitter();
|
|
71
|
-
/** START HEADER */
|
|
72
|
-
/**
|
|
73
|
-
* Wether to show the header
|
|
74
|
-
*/
|
|
75
|
-
enableHeader = true;
|
|
76
|
-
/**
|
|
77
|
-
* Quick filters to show
|
|
78
|
-
*/
|
|
79
|
-
quickFilters = [];
|
|
80
|
-
/**
|
|
81
|
-
* Active quick filter identifier
|
|
82
|
-
*/
|
|
83
|
-
activeQuickFilterIdentifier;
|
|
84
|
-
/**
|
|
85
|
-
* Wether to show the search input
|
|
86
|
-
*/
|
|
87
|
-
enableSearch = true;
|
|
88
|
-
/**
|
|
89
|
-
* The query to show in the search bar
|
|
90
|
-
*/
|
|
91
|
-
query;
|
|
92
|
-
/**
|
|
93
|
-
* Wether to show the filter button
|
|
94
|
-
*/
|
|
95
|
-
enableFilter = true;
|
|
96
|
-
/**
|
|
97
|
-
* The amount of filters being selected
|
|
98
|
-
*/
|
|
99
|
-
selectedFiltersAmount;
|
|
100
|
-
/**
|
|
101
|
-
* The template for the filter button text
|
|
102
|
-
*/
|
|
103
|
-
filterButtonTemplate;
|
|
104
|
-
/**
|
|
105
|
-
* Wether to show the edit button
|
|
106
|
-
*/
|
|
107
|
-
enableEdit = true;
|
|
108
|
-
/**
|
|
109
|
-
* Wether the edit button is loading
|
|
110
|
-
*/
|
|
111
|
-
editButtonLoading = false;
|
|
112
|
-
/**
|
|
113
|
-
* The edit button icon
|
|
114
|
-
*/
|
|
115
|
-
editButtonIcon = 'pencil';
|
|
116
|
-
/**
|
|
117
|
-
* The edit button text if changed
|
|
118
|
-
*/
|
|
119
|
-
editButtonText;
|
|
120
|
-
/**
|
|
121
|
-
* The template for the edit button text
|
|
122
|
-
*/
|
|
123
|
-
editButtonTemplate;
|
|
124
|
-
/**
|
|
125
|
-
* Event when one of the quick filters is clicked
|
|
126
|
-
*/
|
|
127
|
-
quickFilter = new EventEmitter();
|
|
128
|
-
/**
|
|
129
|
-
* Event when the query changes
|
|
130
|
-
*/
|
|
131
|
-
queryChange = new EventEmitter();
|
|
132
|
-
/**
|
|
133
|
-
* Event when the filter button is clicked
|
|
134
|
-
*/
|
|
135
|
-
filter = new EventEmitter();
|
|
136
|
-
/**
|
|
137
|
-
* Event when the edit button is clicked
|
|
138
|
-
*/
|
|
139
|
-
edit = new EventEmitter();
|
|
140
|
-
/** START FOOTER */
|
|
141
|
-
/**
|
|
142
|
-
* Wether to show the footer
|
|
143
|
-
*/
|
|
144
|
-
enableFooter = true;
|
|
145
|
-
/**
|
|
146
|
-
* Wether to enable page size select
|
|
147
|
-
*/
|
|
148
|
-
enablePageSize = true;
|
|
149
|
-
/**
|
|
150
|
-
* Wether to enable pagination
|
|
151
|
-
*/
|
|
152
|
-
enablePagination = true;
|
|
153
|
-
/**
|
|
154
|
-
* Wether to enable export
|
|
155
|
-
*/
|
|
156
|
-
enableExport = true;
|
|
157
|
-
/**
|
|
158
|
-
* The current page
|
|
159
|
-
*/
|
|
160
|
-
page = 1;
|
|
161
|
-
/**
|
|
162
|
-
* The total amount of items
|
|
163
|
-
*/
|
|
164
|
-
total;
|
|
165
|
-
/**
|
|
166
|
-
* Event whenever the page changes
|
|
167
|
-
*/
|
|
168
|
-
pageChange = new EventEmitter();
|
|
169
|
-
/**
|
|
170
|
-
* The amount of items per page
|
|
171
|
-
*/
|
|
172
|
-
pageSize = defaultSize;
|
|
173
|
-
/**
|
|
174
|
-
* The options for the page size
|
|
175
|
-
*/
|
|
176
|
-
pageSizeOptions = defaultSizeOptions;
|
|
177
|
-
/**
|
|
178
|
-
* Event whenever the page changes
|
|
179
|
-
*/
|
|
180
|
-
pageSizeChange = new EventEmitter();
|
|
181
|
-
/**
|
|
182
|
-
* Event whenever the page changes
|
|
183
|
-
*/
|
|
184
|
-
export = new EventEmitter();
|
|
185
|
-
/**
|
|
186
|
-
* Wether to hide when there is only 1 page available
|
|
187
|
-
*/
|
|
188
|
-
hideOnSinglePage = true;
|
|
189
|
-
/* Empty state start */
|
|
190
|
-
emptyStateType = 'no_filter';
|
|
191
|
-
emptyStateIllustration = 'empty-state-add';
|
|
192
|
-
emptyStateHeader;
|
|
193
|
-
emptyStateContent;
|
|
194
|
-
emptyStateAction;
|
|
195
|
-
enableEmptyStateAction = true;
|
|
196
|
-
emptyStateFilteredIllustration = 'empty-state-search';
|
|
197
|
-
emptyStateFilteredHeader;
|
|
198
|
-
emptyStateFilteredContent;
|
|
199
|
-
/**
|
|
200
|
-
* Event whenever the empty state is clicked
|
|
201
|
-
*/
|
|
202
|
-
emptyStateActionClick = new EventEmitter();
|
|
203
|
-
/* Empty state end */
|
|
204
|
-
columns = [];
|
|
205
|
-
parsedItems = [];
|
|
206
|
-
loadingRows = Array.from({
|
|
207
|
-
length: this.amountOfLoadingRows,
|
|
208
|
-
});
|
|
209
|
-
_ctrlDown = false;
|
|
210
|
-
// Angular stuff
|
|
211
|
-
// custom filter template
|
|
212
|
-
headerCustomFilterTemplate;
|
|
213
|
-
// column templates
|
|
214
|
-
_columnDefinitions;
|
|
215
|
-
set columnDefinitions(v) {
|
|
216
|
-
this._columnDefinitions = v;
|
|
217
|
-
this._generateColumns();
|
|
218
|
-
}
|
|
219
|
-
get columnDefinitions() {
|
|
220
|
-
return this._columnDefinitions;
|
|
221
|
-
}
|
|
222
|
-
// filter modal
|
|
223
|
-
filterModalTemplate;
|
|
224
|
-
filterModalShow$ = new BehaviorSubject(false);
|
|
225
|
-
filterModalHeaderText = 'Filters';
|
|
226
|
-
filterModalSaveText = 'Save';
|
|
227
|
-
filterModalCancelText = 'Cancel';
|
|
228
|
-
filterModalResetText = 'Reset filters';
|
|
229
|
-
filterModalShowReset = false;
|
|
230
|
-
filterModalShowResetMobile = false;
|
|
231
|
-
filterModalShow = new EventEmitter();
|
|
232
|
-
filterModalSave = new EventEmitter();
|
|
233
|
-
filterModalReset = new EventEmitter();
|
|
234
|
-
constructor() { }
|
|
235
|
-
ngOnInit() {
|
|
236
|
-
this._parseItems(this.items);
|
|
237
|
-
this.loadingRows = Array.from({
|
|
238
|
-
length: this.amountOfLoadingRows,
|
|
239
|
-
});
|
|
240
|
-
this.filterModalShow$
|
|
241
|
-
.pipe(untilDestroyed(this), distinctUntilChanged())
|
|
242
|
-
.subscribe((value) => this.filterModalShow.next(value));
|
|
243
|
-
// this._generateColumns();
|
|
244
|
-
}
|
|
245
|
-
ngOnChanges(changes) {
|
|
246
|
-
if (changes['items']) {
|
|
247
|
-
this._parseItems(changes['items'].currentValue);
|
|
248
|
-
}
|
|
249
|
-
if (changes['amountOfLoadingRows']) {
|
|
250
|
-
this.loadingRows = Array.from({
|
|
251
|
-
length: changes['amountOfLoadingRows'].currentValue,
|
|
252
|
-
});
|
|
253
|
-
}
|
|
254
|
-
}
|
|
255
|
-
// @HostListener('body:tableDefinitionChanged', { target: 'body' })
|
|
256
|
-
// onTableDefinitionUpdated() {
|
|
257
|
-
// this._generateColumns();
|
|
258
|
-
// }
|
|
259
|
-
keyDown({ key }) {
|
|
260
|
-
if (key !== 'Control' || this._ctrlDown === true) {
|
|
261
|
-
return;
|
|
262
|
-
}
|
|
263
|
-
this._ctrlDown = true;
|
|
264
|
-
}
|
|
265
|
-
keyUp({ key }) {
|
|
266
|
-
if (key !== 'Control' || this._ctrlDown === false) {
|
|
267
|
-
return;
|
|
268
|
-
}
|
|
269
|
-
this._ctrlDown = false;
|
|
270
|
-
}
|
|
271
|
-
visibilityChange() {
|
|
272
|
-
if (document.visibilityState !== 'hidden' || this._ctrlDown === false) {
|
|
273
|
-
return;
|
|
274
|
-
}
|
|
275
|
-
this._ctrlDown = false;
|
|
276
|
-
}
|
|
277
|
-
onQueryChange({ detail }) {
|
|
278
|
-
this.queryChange.emit(detail);
|
|
279
|
-
}
|
|
280
|
-
onQuickFilter({ detail }) {
|
|
281
|
-
this.quickFilter.emit(detail);
|
|
282
|
-
}
|
|
283
|
-
onPageSizeChange({ detail }) {
|
|
284
|
-
this.pageSize = detail;
|
|
285
|
-
this.pageSizeChange.emit(detail);
|
|
286
|
-
}
|
|
287
|
-
onPageChange({ detail }) {
|
|
288
|
-
this.page = detail;
|
|
289
|
-
this.pageChange.emit(detail);
|
|
290
|
-
}
|
|
291
|
-
onFilterModalSave() {
|
|
292
|
-
this.filterModalSave.next();
|
|
293
|
-
this.filterModalShow$.next(false);
|
|
294
|
-
}
|
|
295
|
-
onFilterModalReset(resetQuickFilter = false) {
|
|
296
|
-
this.filterModalReset.next(resetQuickFilter);
|
|
297
|
-
this.filterModalShow$.next(false);
|
|
298
|
-
}
|
|
299
|
-
emptyStateClicked() {
|
|
300
|
-
if (!this.enableEmptyStateAction) {
|
|
301
|
-
return;
|
|
302
|
-
}
|
|
303
|
-
this.emptyStateActionClick.emit();
|
|
304
|
-
}
|
|
305
|
-
_parseItems(items) {
|
|
306
|
-
if (!items) {
|
|
307
|
-
this.parsedItems = [];
|
|
308
|
-
return;
|
|
309
|
-
}
|
|
310
|
-
if (Array.isArray(items)) {
|
|
311
|
-
this.parsedItems = items;
|
|
312
|
-
return;
|
|
313
|
-
}
|
|
314
|
-
this.parsedItems = JSON.parse(items);
|
|
315
|
-
}
|
|
316
|
-
_generateColumns() {
|
|
317
|
-
// const definitions =
|
|
318
|
-
// this._el.nativeElement.querySelectorAll('p-table-definition');
|
|
319
|
-
const definitionsArray = Array.from(this._columnDefinitions);
|
|
320
|
-
definitionsArray[definitionsArray.length - 1].isLast = true;
|
|
321
|
-
this.columns = definitionsArray;
|
|
322
|
-
}
|
|
323
|
-
// private _getHeader() {
|
|
324
|
-
// return (
|
|
325
|
-
// <p-table-row variant="header">
|
|
326
|
-
// {this._columns.map((col: TableDefinition, index) => (
|
|
327
|
-
// <p-table-column
|
|
328
|
-
// definition={col}
|
|
329
|
-
// value={col.name}
|
|
330
|
-
// variant="header"
|
|
331
|
-
// checkbox={this._getCheckbox(index, null, 'header')}
|
|
332
|
-
// index={index}
|
|
333
|
-
// ></p-table-column>
|
|
334
|
-
// ))}
|
|
335
|
-
// </p-table-row>
|
|
336
|
-
// );
|
|
337
|
-
// }
|
|
338
|
-
// private _getRows() {
|
|
339
|
-
// if (this.loading) {
|
|
340
|
-
// return Array.from(
|
|
341
|
-
// {
|
|
342
|
-
// length: this.amountOfLoadingRows,
|
|
343
|
-
// },
|
|
344
|
-
// (_, i) => (
|
|
345
|
-
// <p-table-row
|
|
346
|
-
// enableHover={
|
|
347
|
-
// this.enableRowSelection || this.enableRowClick
|
|
348
|
-
// }
|
|
349
|
-
// >
|
|
350
|
-
// {this._getLoadingColumns(i)}
|
|
351
|
-
// </p-table-row>
|
|
352
|
-
// )
|
|
353
|
-
// );
|
|
354
|
-
// }
|
|
355
|
-
// return this._items.map((item, index) => (
|
|
356
|
-
// <p-table-row
|
|
357
|
-
// enableHover={this.enableRowSelection || this.enableRowClick}
|
|
358
|
-
// onClick={(ev) => this._rowClick(ev, index)}
|
|
359
|
-
// >
|
|
360
|
-
// {this._getRowColumns(item, index)}
|
|
361
|
-
// </p-table-row>
|
|
362
|
-
// ));
|
|
363
|
-
// }
|
|
364
|
-
// private _getRowColumns(item, index) {
|
|
365
|
-
// return this._columns.map((col: TableDefinition, colIndex) => {
|
|
366
|
-
// return (
|
|
367
|
-
// <p-table-column
|
|
368
|
-
// definition={col}
|
|
369
|
-
// item={item}
|
|
370
|
-
// checkbox={this._getCheckbox(colIndex, index)}
|
|
371
|
-
// index={colIndex}
|
|
372
|
-
// rowIndex={index}
|
|
373
|
-
// ></p-table-column>
|
|
374
|
-
// );
|
|
375
|
-
// });
|
|
376
|
-
// }
|
|
377
|
-
// private _getLoadingColumns(index) {
|
|
378
|
-
// return this._columns.map((col: TableDefinition, colIndex) => {
|
|
379
|
-
// return (
|
|
380
|
-
// <p-table-column
|
|
381
|
-
// definition={col}
|
|
382
|
-
// variant="loading"
|
|
383
|
-
// checkbox={this._getCheckbox(colIndex, index, 'loading')}
|
|
384
|
-
// index={colIndex}
|
|
385
|
-
// rowIndex={index}
|
|
386
|
-
// ></p-table-column>
|
|
387
|
-
// );
|
|
388
|
-
// });
|
|
389
|
-
// }
|
|
390
|
-
// private _getCheckbox(
|
|
391
|
-
// index,
|
|
392
|
-
// rowIndex,
|
|
393
|
-
// variant: 'header' | 'default' | 'loading' = 'default'
|
|
394
|
-
// ) {
|
|
395
|
-
// if (!this.enableRowSelection || !this.selectionKey || index !== 0) {
|
|
396
|
-
// return;
|
|
397
|
-
// }
|
|
398
|
-
// if (variant === 'loading') {
|
|
399
|
-
// return <p-loader variant="ghost" class="rounded w-6 h-6" />;
|
|
400
|
-
// }
|
|
401
|
-
// if (variant === 'header') {
|
|
402
|
-
// return (
|
|
403
|
-
// <input
|
|
404
|
-
// class="p-input"
|
|
405
|
-
// type="checkbox"
|
|
406
|
-
// onChange={(ev) => this._selectAllChange(ev)}
|
|
407
|
-
// checked={this._selectionContainsAll()}
|
|
408
|
-
// indeterminate={this._selectionIndeterminate()}
|
|
409
|
-
// />
|
|
410
|
-
// );
|
|
411
|
-
// }
|
|
412
|
-
// const item = this._items[rowIndex];
|
|
413
|
-
// return (
|
|
414
|
-
// <input
|
|
415
|
-
// class="p-input"
|
|
416
|
-
// type="checkbox"
|
|
417
|
-
// onChange={(ev) => this._checkboxChange(ev?.target, rowIndex)}
|
|
418
|
-
// disabled={this.canSelectKey && !item[this.canSelectKey]}
|
|
419
|
-
// checked={this._selectionContains(item, rowIndex)}
|
|
420
|
-
// />
|
|
421
|
-
// );
|
|
422
|
-
// }
|
|
423
|
-
_checkboxDisabled(item) {
|
|
424
|
-
return this.canSelectKey && !item[this.canSelectKey];
|
|
425
|
-
}
|
|
426
|
-
_selectAllChange($event) {
|
|
427
|
-
if (!this.enableRowSelection) {
|
|
428
|
-
return;
|
|
429
|
-
}
|
|
430
|
-
const value = this._getCheckedValue($event.target);
|
|
431
|
-
if (value) {
|
|
432
|
-
const toAdd = [];
|
|
433
|
-
for (let i = 0; i < this.parsedItems.length; i++) {
|
|
434
|
-
const row = this.parsedItems[i];
|
|
435
|
-
if (this.canSelectKey && !row[this.canSelectKey]) {
|
|
436
|
-
continue;
|
|
437
|
-
}
|
|
438
|
-
if (this._selectionContains(row, i)) {
|
|
439
|
-
continue;
|
|
440
|
-
}
|
|
441
|
-
toAdd.push(row);
|
|
442
|
-
this.rowSelected.emit(row);
|
|
443
|
-
}
|
|
444
|
-
this.selectedRows = [...this.selectedRows, ...toAdd];
|
|
445
|
-
this.selectedRowsChange.emit(this.selectedRows);
|
|
446
|
-
return;
|
|
447
|
-
}
|
|
448
|
-
for (let i = 0; i < this.selectedRows.length; i++) {
|
|
449
|
-
const value = this.selectedRows[i];
|
|
450
|
-
const row = this.parsedItems.find((d) => this._getSelectionValue(d, i) ===
|
|
451
|
-
this._getSelectionValue(value, i));
|
|
452
|
-
if (!row) {
|
|
453
|
-
continue;
|
|
454
|
-
}
|
|
455
|
-
this.rowDeselected.emit(row);
|
|
456
|
-
}
|
|
457
|
-
this.selectedRows = [];
|
|
458
|
-
this.selectedRowsChange.emit(this.selectedRows);
|
|
459
|
-
}
|
|
460
|
-
_checkboxChange(target, index) {
|
|
461
|
-
if (!this.enableRowSelection) {
|
|
462
|
-
return;
|
|
463
|
-
}
|
|
464
|
-
const row = this.parsedItems[index];
|
|
465
|
-
if (this.canSelectKey && !row[this.canSelectKey]) {
|
|
466
|
-
target.checked = false;
|
|
467
|
-
return;
|
|
468
|
-
}
|
|
469
|
-
const value = this._getCheckedValue(target);
|
|
470
|
-
if (value) {
|
|
471
|
-
this.selectedRows = [...this.selectedRows, row];
|
|
472
|
-
this.selectedRowsChange.emit(this.selectedRows);
|
|
473
|
-
this.rowSelected.emit(row);
|
|
474
|
-
return;
|
|
475
|
-
}
|
|
476
|
-
const indexOfToRemove = this._selectionContains(row, index, true);
|
|
477
|
-
// we need to do this, because splice does not trigger the selection setter.
|
|
478
|
-
const selection = [...this.selectedRows];
|
|
479
|
-
selection.splice(indexOfToRemove, 1);
|
|
480
|
-
this.selectedRows = selection;
|
|
481
|
-
this.selectedRowsChange.emit(this.selectedRows);
|
|
482
|
-
this.rowDeselected.emit(row);
|
|
483
|
-
}
|
|
484
|
-
_getCheckedValue(target) {
|
|
485
|
-
return target?.checked;
|
|
486
|
-
}
|
|
487
|
-
_getSelectionValue(row, index) {
|
|
488
|
-
return this.selectionKey ? row?.[this.selectionKey] || index : index;
|
|
489
|
-
}
|
|
490
|
-
_selectionContains(row, index, returnIndex = false) {
|
|
491
|
-
const returnValue = this.selectedRows.findIndex((item) => this._getSelectionValue(row, index) ===
|
|
492
|
-
this._getSelectionValue(item, index));
|
|
493
|
-
return !returnIndex ? returnValue >= 0 : returnValue;
|
|
494
|
-
}
|
|
495
|
-
_selectionContainsAll() {
|
|
496
|
-
let returnValue = true;
|
|
497
|
-
if (!this.parsedItems?.length) {
|
|
498
|
-
return false;
|
|
499
|
-
}
|
|
500
|
-
for (let i = 0; i < this.parsedItems?.length; i++) {
|
|
501
|
-
const item = this.parsedItems[i];
|
|
502
|
-
const contains = this._selectionContains(item, i);
|
|
503
|
-
if (!contains) {
|
|
504
|
-
returnValue = false;
|
|
505
|
-
break;
|
|
506
|
-
}
|
|
507
|
-
}
|
|
508
|
-
return returnValue;
|
|
509
|
-
}
|
|
510
|
-
_selectionIndeterminate() {
|
|
511
|
-
if (!this.parsedItems?.length || !this.selectedRows?.length) {
|
|
512
|
-
return false;
|
|
513
|
-
}
|
|
514
|
-
let containsCount = 0;
|
|
515
|
-
for (let i = 0; i < this.parsedItems?.length; i++) {
|
|
516
|
-
const item = this.parsedItems[i];
|
|
517
|
-
const contains = this._selectionContains(item, i);
|
|
518
|
-
if (contains) {
|
|
519
|
-
containsCount++;
|
|
520
|
-
}
|
|
521
|
-
}
|
|
522
|
-
return containsCount > 0 && containsCount !== this.parsedItems.length;
|
|
523
|
-
}
|
|
524
|
-
_rowClick($event, index) {
|
|
525
|
-
const target = $event.target;
|
|
526
|
-
if (target.tagName.toLowerCase() === 'input' ||
|
|
527
|
-
target.type === 'checkbox') {
|
|
528
|
-
return;
|
|
529
|
-
}
|
|
530
|
-
const row = this._findRow(target);
|
|
531
|
-
const action = this._findRowAction(target);
|
|
532
|
-
if (action) {
|
|
533
|
-
return;
|
|
534
|
-
}
|
|
535
|
-
if (this.enableRowClick) {
|
|
536
|
-
const item = this.parsedItems[index];
|
|
537
|
-
this.rowClick.emit({
|
|
538
|
-
item,
|
|
539
|
-
ctrlDown: this._ctrlDown,
|
|
540
|
-
});
|
|
541
|
-
return;
|
|
542
|
-
}
|
|
543
|
-
if (!this.enableRowSelection) {
|
|
544
|
-
return;
|
|
545
|
-
}
|
|
546
|
-
const checkbox = row?.querySelector('input[type="checkbox"]');
|
|
547
|
-
if (!checkbox) {
|
|
548
|
-
return;
|
|
549
|
-
}
|
|
550
|
-
checkbox.checked = !checkbox.checked;
|
|
551
|
-
this._checkboxChange(checkbox, index);
|
|
552
|
-
}
|
|
553
|
-
_findRow(el) {
|
|
554
|
-
if (!el) {
|
|
555
|
-
return el;
|
|
556
|
-
}
|
|
557
|
-
if (el?.tagName?.toLowerCase() === 'p-table-row') {
|
|
558
|
-
return el;
|
|
559
|
-
}
|
|
560
|
-
return this._findRow(el?.parentElement);
|
|
561
|
-
}
|
|
562
|
-
_findRowAction(el) {
|
|
563
|
-
if (!el) {
|
|
564
|
-
return null;
|
|
565
|
-
}
|
|
566
|
-
if (el.getAttribute('data-is-action') !== null &&
|
|
567
|
-
el.getAttribute('data-is-action') !== 'false') {
|
|
568
|
-
return el;
|
|
569
|
-
}
|
|
570
|
-
if (el?.tagName?.toLowerCase() === 'p-table-row') {
|
|
571
|
-
return null;
|
|
572
|
-
}
|
|
573
|
-
return this._findRowAction(el?.parentElement);
|
|
574
|
-
}
|
|
575
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: Table, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
576
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: Table, selector: "p-table-ngx", inputs: { items: "items", loading: "loading", headerLoading: "headerLoading", footerLoading: "footerLoading", amountOfLoadingRows: "amountOfLoadingRows", enableRowSelection: "enableRowSelection", enableRowClick: "enableRowClick", selectedRows: "selectedRows", selectionKey: "selectionKey", canSelectKey: "canSelectKey", enableHeader: "enableHeader", quickFilters: "quickFilters", activeQuickFilterIdentifier: "activeQuickFilterIdentifier", enableSearch: "enableSearch", query: "query", enableFilter: "enableFilter", selectedFiltersAmount: "selectedFiltersAmount", filterButtonTemplate: "filterButtonTemplate", enableEdit: "enableEdit", editButtonLoading: "editButtonLoading", editButtonIcon: "editButtonIcon", editButtonText: "editButtonText", editButtonTemplate: "editButtonTemplate", enableFooter: "enableFooter", enablePageSize: "enablePageSize", enablePagination: "enablePagination", enableExport: "enableExport", page: "page", total: "total", pageSize: "pageSize", pageSizeOptions: "pageSizeOptions", hideOnSinglePage: "hideOnSinglePage", emptyStateType: "emptyStateType", emptyStateIllustration: "emptyStateIllustration", emptyStateHeader: "emptyStateHeader", emptyStateContent: "emptyStateContent", emptyStateAction: "emptyStateAction", enableEmptyStateAction: "enableEmptyStateAction", emptyStateFilteredIllustration: "emptyStateFilteredIllustration", emptyStateFilteredHeader: "emptyStateFilteredHeader", emptyStateFilteredContent: "emptyStateFilteredContent", filterModalHeaderText: "filterModalHeaderText", filterModalSaveText: "filterModalSaveText", filterModalCancelText: "filterModalCancelText", filterModalResetText: "filterModalResetText", filterModalShowReset: "filterModalShowReset", filterModalShowResetMobile: "filterModalShowResetMobile" }, outputs: { selectedRowsChange: "selectedRowsChange", rowClick: "rowClick", rowSelected: "rowSelected", rowDeselected: "rowDeselected", quickFilter: "quickFilter", queryChange: "queryChange", filter: "filter", edit: "edit", pageChange: "pageChange", pageSizeChange: "pageSizeChange", export: "export", emptyStateActionClick: "emptyStateActionClick", filterModalShow: "filterModalShow", filterModalSave: "filterModalSave", filterModalReset: "filterModalReset" }, host: { listeners: { "document:keydown": "keyDown($event)", "document:keyup": "keyUp($event)", "document:visibilitychange": "visibilityChange($event)" } }, queries: [{ propertyName: "headerCustomFilterTemplate", first: true, predicate: TableCustomFilterDirective, descendants: true, read: TemplateRef, static: true }, { propertyName: "filterModalTemplate", first: true, predicate: TableFilterModalDirective, descendants: true, read: TemplateRef, static: true }, { propertyName: "columnDefinitions", predicate: TableColumn }], usesOnChanges: true, ngImport: i0, template: "<p-table-container>\n <p-table-header\n *ngIf=\"enableHeader\"\n [quickFilters]=\"quickFilters\"\n [activeQuickFilterIdentifier]=\"activeQuickFilterIdentifier\"\n (quickFilter)=\"onQuickFilter($event)\"\n [enableSearch]=\"enableSearch\"\n [query]=\"query\"\n (queryChange)=\"onQueryChange($event)\"\n [enableFilter]=\"enableFilter\"\n [selectedFiltersAmount]=\"selectedFiltersAmount\"\n [filterButtonTemplate]=\"filterButtonTemplate\"\n (filter)=\"filterModalShow$.next(true)\"\n [enableEdit]=\"enableEdit\"\n [canEdit]=\"!!selectedRows.length\"\n [editButtonTemplate]=\"editButtonTemplate\"\n [editLoading]=\"editButtonLoading\"\n [editText]=\"editButtonText\"\n [editIcon]=\"editButtonIcon\"\n (edit)=\"edit.emit()\"\n [itemsSelectedAmount]=\"selectedRows.length\"\n [loading]=\"headerLoading\"\n >\n <ng-container *ngIf=\"headerCustomFilterTemplate\">\n <ng-container\n *ngTemplateOutlet=\"headerCustomFilterTemplate\"\n ></ng-container>\n </ng-container>\n </p-table-header>\n\n <p-table-row variant=\"header\">\n <ng-container *ngFor=\"let col of columns; let index = index\">\n <p-table-cell-ngx\n [definition]=\"col\"\n [value]=\"col.name\"\n variant=\"header\"\n [index]=\"index\"\n [checkbox]=\"\n (index === 0 || col.hasCheckbox) && enableRowSelection\n ? checkboxTemplate\n : undefined\n \"\n ></p-table-cell-ngx>\n <ng-template #checkboxTemplate>\n <input\n class=\"p-input\"\n type=\"checkbox\"\n (change)=\"_selectAllChange($event)\"\n [checked]=\"_selectionContainsAll()\"\n [indeterminate]=\"_selectionIndeterminate()\"\n />\n </ng-template>\n </ng-container>\n </p-table-row>\n\n <div class=\"flex flex-col\">\n <ng-container *ngIf=\"loading; else contentTemplate\">\n <p-table-row\n *ngFor=\"let r of loadingRows; let rowIndex = index\"\n [enableHover]=\"enableRowSelection || enableRowClick\"\n >\n <ng-container *ngFor=\"let col of columns; let index = index\">\n <p-table-cell-ngx\n [definition]=\"col\"\n variant=\"loading\"\n [checkbox]=\"\n (index === 0 || col.hasCheckbox) &&\n enableRowSelection\n ? checkboxTemplate\n : undefined\n \"\n [index]=\"index\"\n [rowIndex]=\"rowIndex\"\n ></p-table-cell-ngx>\n <ng-template #checkboxTemplate>\n <p-loader\n variant=\"ghost\"\n class=\"h-6 w-6 rounded\"\n ></p-loader>\n </ng-template>\n </ng-container>\n </p-table-row>\n </ng-container>\n\n <ng-template #contentTemplate>\n <ng-container *ngIf=\"items?.length; else emptyStateTemplate\">\n <p-table-row\n *ngFor=\"let item of items; let rowIndex = index\"\n [enableHover]=\"enableRowSelection || enableRowClick\"\n (click)=\"_rowClick($event, rowIndex)\"\n >\n <ng-container\n *ngFor=\"let col of columns; let index = index\"\n >\n <p-table-cell-ngx\n [definition]=\"col\"\n [item]=\"item\"\n [checkbox]=\"\n (index === 0 || col.hasCheckbox) &&\n enableRowSelection\n ? checkboxTemplate\n : undefined\n \"\n [index]=\"index\"\n [rowIndex]=\"rowIndex\"\n [template]=\"col.template\"\n ></p-table-cell-ngx>\n\n <ng-template #checkboxTemplate>\n <input\n class=\"p-input\"\n type=\"checkbox\"\n (change)=\"\n _checkboxChange($event.target, rowIndex)\n \"\n [disabled]=\"_checkboxDisabled(item)\"\n [checked]=\"_selectionContains(item, rowIndex)\"\n />\n </ng-template>\n </ng-container>\n </p-table-row>\n </ng-container>\n </ng-template>\n </div>\n\n <p-table-footer\n *ngIf=\"enableFooter\"\n [hideOnSinglePage]=\"hideOnSinglePage\"\n [enablePageSize]=\"enablePageSize\"\n [pageSize]=\"pageSize\"\n [pageSizeOptions]=\"pageSizeOptions\"\n (pageSizeChange)=\"onPageSizeChange($event)\"\n [enablePagination]=\"enablePagination\"\n [page]=\"page\"\n [total]=\"total\"\n (pageChange)=\"onPageChange($event)\"\n [enableExport]=\"enableExport\"\n (export)=\"export.emit()\"\n [loading]=\"footerLoading\"\n ></p-table-footer>\n</p-table-container>\n\n<ng-container *ngIf=\"filterModalTemplate\">\n <p-modal\n [header]=\"filterModalHeaderText\"\n [show]=\"filterModalShow$ | async\"\n (closed)=\"filterModalShow$.next(false)\"\n >\n <div slot=\"content\" class=\"flex flex-col gap-6\">\n <ng-container\n *ngTemplateOutlet=\"filterModalTemplate\"\n ></ng-container>\n </div>\n <div slot=\"footer\" class=\"flex w-full justify-between gap-4\">\n <p-button\n *ngIf=\"filterModalShowResetMobile\"\n class=\"flex w-full tablet:w-auto desktop-xs:hidden\"\n variant=\"secondary\"\n (onClick)=\"onFilterModalReset(true)\"\n >\n {{ filterModalResetText }}\n </p-button>\n <p-button\n *ngIf=\"filterModalShowReset\"\n class=\"hidden w-full tablet:w-auto desktop-xs:flex\"\n variant=\"secondary\"\n (onClick)=\"onFilterModalReset()\"\n >\n {{ filterModalResetText }}\n </p-button>\n <p-button\n class=\"ml-auto w-full tablet:w-auto\"\n icon=\"checkmark\"\n (onClick)=\"onFilterModalSave()\"\n >\n {{ filterModalSaveText }}\n </p-button>\n </div>\n </p-modal>\n</ng-container>\n\n<ng-template #emptyStateTemplate>\n <div\n *ngIf=\"emptyStateType === 'filtered'; else emptyStateNonFilterTemplate\"\n class=\"\n flex\n max-w-[20rem]\n flex-col\n items-center\n self-center\n py-24\n text-center\n \"\n >\n <p-illustration\n [variant]=\"emptyStateFilteredIllustration\"\n class=\"mb-6\"\n ></p-illustration>\n <p class=\"text-storm-default font-semibold\">\n {{ emptyStateFilteredHeader }}\n </p>\n <p class=\"mb-14 text-sm text-storm-medium\">\n {{ emptyStateFilteredContent }}\n </p>\n </div>\n</ng-template>\n\n<ng-template #emptyStateNonFilterTemplate>\n <div\n class=\"\n flex\n max-w-[20rem]\n flex-col\n items-center\n self-center\n py-24\n text-center\n \"\n [class.cursor-pointer]=\"enableEmptyStateAction\"\n (click)=\"emptyStateClicked()\"\n >\n <p-illustration\n [variant]=\"emptyStateIllustration\"\n class=\"mb-6\"\n ></p-illustration>\n <p class=\"text-storm-default font-semibold\">\n {{ emptyStateHeader }}\n </p>\n <p class=\"mb-6 text-sm text-storm-medium\">\n {{ emptyStateContent }}\n </p>\n <p-button\n *ngIf=\"enableEmptyStateAction\"\n variant=\"secondary\"\n icon=\"plus\"\n size=\"small\"\n >\n {{ emptyStateAction }}\n </p-button>\n </div>\n</ng-template>\n", styles: [":host{display:flex;flex-direction:column}:host .p-input[type=checkbox]{flex-shrink:0}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.PButton, selector: "p-button", inputs: ["chevron", "chevronPosition", "disabled", "href", "icon", "iconFlip", "iconOnly", "iconPosition", "iconRotate", "inheritText", "loading", "size", "target", "underline", "variant"] }, { kind: "component", type: i2.PIllustration, selector: "p-illustration", inputs: ["variant"] }, { kind: "component", type: i2.PLoader, selector: "p-loader", inputs: ["color", "modalDescription", "modalTitle", "show", "variant"] }, { kind: "component", type: i2.PModal, selector: "p-modal", inputs: ["applyBlur", "backdropClickClose", "header", "padding", "scrollLock", "show", "showClose", "showMobileFooter", "size", "variant"] }, { kind: "component", type: i2.PTableContainer, selector: "p-table-container" }, { kind: "component", type: i2.PTableFooter, selector: "p-table-footer", inputs: ["enableExport", "enablePageSize", "enablePagination", "hideOnSinglePage", "loading", "page", "pageSize", "pageSizeOptions", "total"] }, { kind: "component", type: i2.PTableHeader, selector: "p-table-header", inputs: ["activeQuickFilterIdentifier", "canEdit", "editButtonTemplate", "editIcon", "editLoading", "editText", "enableEdit", "enableFilter", "enableSearch", "filterButtonTemplate", "itemsSelectedAmount", "loading", "query", "quickFilters", "selectedFiltersAmount"] }, { kind: "component", type: i2.PTableRow, selector: "p-table-row", inputs: ["enableHover", "variant"] }, { kind: "component", type: i3.TableCell, selector: "p-table-cell-ngx", inputs: ["variant", "index", "rowIndex", "definition", "item", "value", "checkbox", "template"] }, { kind: "directive", type: i4.TableFooterDirective, selector: "p-table-footer" }, { kind: "directive", type: i5.TableHeaderDirective, selector: "p-table-header" }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
577
|
-
};
|
|
578
|
-
Table = __decorate([
|
|
579
|
-
UntilDestroy({ checkProperties: true })
|
|
580
|
-
], Table);
|
|
581
|
-
export { Table };
|
|
582
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: Table, decorators: [{
|
|
583
|
-
type: Component,
|
|
584
|
-
args: [{ selector: 'p-table-ngx', changeDetection: ChangeDetectionStrategy.OnPush, template: "<p-table-container>\n <p-table-header\n *ngIf=\"enableHeader\"\n [quickFilters]=\"quickFilters\"\n [activeQuickFilterIdentifier]=\"activeQuickFilterIdentifier\"\n (quickFilter)=\"onQuickFilter($event)\"\n [enableSearch]=\"enableSearch\"\n [query]=\"query\"\n (queryChange)=\"onQueryChange($event)\"\n [enableFilter]=\"enableFilter\"\n [selectedFiltersAmount]=\"selectedFiltersAmount\"\n [filterButtonTemplate]=\"filterButtonTemplate\"\n (filter)=\"filterModalShow$.next(true)\"\n [enableEdit]=\"enableEdit\"\n [canEdit]=\"!!selectedRows.length\"\n [editButtonTemplate]=\"editButtonTemplate\"\n [editLoading]=\"editButtonLoading\"\n [editText]=\"editButtonText\"\n [editIcon]=\"editButtonIcon\"\n (edit)=\"edit.emit()\"\n [itemsSelectedAmount]=\"selectedRows.length\"\n [loading]=\"headerLoading\"\n >\n <ng-container *ngIf=\"headerCustomFilterTemplate\">\n <ng-container\n *ngTemplateOutlet=\"headerCustomFilterTemplate\"\n ></ng-container>\n </ng-container>\n </p-table-header>\n\n <p-table-row variant=\"header\">\n <ng-container *ngFor=\"let col of columns; let index = index\">\n <p-table-cell-ngx\n [definition]=\"col\"\n [value]=\"col.name\"\n variant=\"header\"\n [index]=\"index\"\n [checkbox]=\"\n (index === 0 || col.hasCheckbox) && enableRowSelection\n ? checkboxTemplate\n : undefined\n \"\n ></p-table-cell-ngx>\n <ng-template #checkboxTemplate>\n <input\n class=\"p-input\"\n type=\"checkbox\"\n (change)=\"_selectAllChange($event)\"\n [checked]=\"_selectionContainsAll()\"\n [indeterminate]=\"_selectionIndeterminate()\"\n />\n </ng-template>\n </ng-container>\n </p-table-row>\n\n <div class=\"flex flex-col\">\n <ng-container *ngIf=\"loading; else contentTemplate\">\n <p-table-row\n *ngFor=\"let r of loadingRows; let rowIndex = index\"\n [enableHover]=\"enableRowSelection || enableRowClick\"\n >\n <ng-container *ngFor=\"let col of columns; let index = index\">\n <p-table-cell-ngx\n [definition]=\"col\"\n variant=\"loading\"\n [checkbox]=\"\n (index === 0 || col.hasCheckbox) &&\n enableRowSelection\n ? checkboxTemplate\n : undefined\n \"\n [index]=\"index\"\n [rowIndex]=\"rowIndex\"\n ></p-table-cell-ngx>\n <ng-template #checkboxTemplate>\n <p-loader\n variant=\"ghost\"\n class=\"h-6 w-6 rounded\"\n ></p-loader>\n </ng-template>\n </ng-container>\n </p-table-row>\n </ng-container>\n\n <ng-template #contentTemplate>\n <ng-container *ngIf=\"items?.length; else emptyStateTemplate\">\n <p-table-row\n *ngFor=\"let item of items; let rowIndex = index\"\n [enableHover]=\"enableRowSelection || enableRowClick\"\n (click)=\"_rowClick($event, rowIndex)\"\n >\n <ng-container\n *ngFor=\"let col of columns; let index = index\"\n >\n <p-table-cell-ngx\n [definition]=\"col\"\n [item]=\"item\"\n [checkbox]=\"\n (index === 0 || col.hasCheckbox) &&\n enableRowSelection\n ? checkboxTemplate\n : undefined\n \"\n [index]=\"index\"\n [rowIndex]=\"rowIndex\"\n [template]=\"col.template\"\n ></p-table-cell-ngx>\n\n <ng-template #checkboxTemplate>\n <input\n class=\"p-input\"\n type=\"checkbox\"\n (change)=\"\n _checkboxChange($event.target, rowIndex)\n \"\n [disabled]=\"_checkboxDisabled(item)\"\n [checked]=\"_selectionContains(item, rowIndex)\"\n />\n </ng-template>\n </ng-container>\n </p-table-row>\n </ng-container>\n </ng-template>\n </div>\n\n <p-table-footer\n *ngIf=\"enableFooter\"\n [hideOnSinglePage]=\"hideOnSinglePage\"\n [enablePageSize]=\"enablePageSize\"\n [pageSize]=\"pageSize\"\n [pageSizeOptions]=\"pageSizeOptions\"\n (pageSizeChange)=\"onPageSizeChange($event)\"\n [enablePagination]=\"enablePagination\"\n [page]=\"page\"\n [total]=\"total\"\n (pageChange)=\"onPageChange($event)\"\n [enableExport]=\"enableExport\"\n (export)=\"export.emit()\"\n [loading]=\"footerLoading\"\n ></p-table-footer>\n</p-table-container>\n\n<ng-container *ngIf=\"filterModalTemplate\">\n <p-modal\n [header]=\"filterModalHeaderText\"\n [show]=\"filterModalShow$ | async\"\n (closed)=\"filterModalShow$.next(false)\"\n >\n <div slot=\"content\" class=\"flex flex-col gap-6\">\n <ng-container\n *ngTemplateOutlet=\"filterModalTemplate\"\n ></ng-container>\n </div>\n <div slot=\"footer\" class=\"flex w-full justify-between gap-4\">\n <p-button\n *ngIf=\"filterModalShowResetMobile\"\n class=\"flex w-full tablet:w-auto desktop-xs:hidden\"\n variant=\"secondary\"\n (onClick)=\"onFilterModalReset(true)\"\n >\n {{ filterModalResetText }}\n </p-button>\n <p-button\n *ngIf=\"filterModalShowReset\"\n class=\"hidden w-full tablet:w-auto desktop-xs:flex\"\n variant=\"secondary\"\n (onClick)=\"onFilterModalReset()\"\n >\n {{ filterModalResetText }}\n </p-button>\n <p-button\n class=\"ml-auto w-full tablet:w-auto\"\n icon=\"checkmark\"\n (onClick)=\"onFilterModalSave()\"\n >\n {{ filterModalSaveText }}\n </p-button>\n </div>\n </p-modal>\n</ng-container>\n\n<ng-template #emptyStateTemplate>\n <div\n *ngIf=\"emptyStateType === 'filtered'; else emptyStateNonFilterTemplate\"\n class=\"\n flex\n max-w-[20rem]\n flex-col\n items-center\n self-center\n py-24\n text-center\n \"\n >\n <p-illustration\n [variant]=\"emptyStateFilteredIllustration\"\n class=\"mb-6\"\n ></p-illustration>\n <p class=\"text-storm-default font-semibold\">\n {{ emptyStateFilteredHeader }}\n </p>\n <p class=\"mb-14 text-sm text-storm-medium\">\n {{ emptyStateFilteredContent }}\n </p>\n </div>\n</ng-template>\n\n<ng-template #emptyStateNonFilterTemplate>\n <div\n class=\"\n flex\n max-w-[20rem]\n flex-col\n items-center\n self-center\n py-24\n text-center\n \"\n [class.cursor-pointer]=\"enableEmptyStateAction\"\n (click)=\"emptyStateClicked()\"\n >\n <p-illustration\n [variant]=\"emptyStateIllustration\"\n class=\"mb-6\"\n ></p-illustration>\n <p class=\"text-storm-default font-semibold\">\n {{ emptyStateHeader }}\n </p>\n <p class=\"mb-6 text-sm text-storm-medium\">\n {{ emptyStateContent }}\n </p>\n <p-button\n *ngIf=\"enableEmptyStateAction\"\n variant=\"secondary\"\n icon=\"plus\"\n size=\"small\"\n >\n {{ emptyStateAction }}\n </p-button>\n </div>\n</ng-template>\n", styles: [":host{display:flex;flex-direction:column}:host .p-input[type=checkbox]{flex-shrink:0}\n"] }]
|
|
585
|
-
}], ctorParameters: function () { return []; }, propDecorators: { items: [{
|
|
586
|
-
type: Input
|
|
587
|
-
}], loading: [{
|
|
588
|
-
type: Input
|
|
589
|
-
}], headerLoading: [{
|
|
590
|
-
type: Input
|
|
591
|
-
}], footerLoading: [{
|
|
592
|
-
type: Input
|
|
593
|
-
}], amountOfLoadingRows: [{
|
|
594
|
-
type: Input
|
|
595
|
-
}], enableRowSelection: [{
|
|
596
|
-
type: Input
|
|
597
|
-
}], enableRowClick: [{
|
|
598
|
-
type: Input
|
|
599
|
-
}], selectedRows: [{
|
|
600
|
-
type: Input
|
|
601
|
-
}], selectedRowsChange: [{
|
|
602
|
-
type: Output
|
|
603
|
-
}], selectionKey: [{
|
|
604
|
-
type: Input
|
|
605
|
-
}], canSelectKey: [{
|
|
606
|
-
type: Input
|
|
607
|
-
}], rowClick: [{
|
|
608
|
-
type: Output
|
|
609
|
-
}], rowSelected: [{
|
|
610
|
-
type: Output
|
|
611
|
-
}], rowDeselected: [{
|
|
612
|
-
type: Output
|
|
613
|
-
}], enableHeader: [{
|
|
614
|
-
type: Input
|
|
615
|
-
}], quickFilters: [{
|
|
616
|
-
type: Input
|
|
617
|
-
}], activeQuickFilterIdentifier: [{
|
|
618
|
-
type: Input
|
|
619
|
-
}], enableSearch: [{
|
|
620
|
-
type: Input
|
|
621
|
-
}], query: [{
|
|
622
|
-
type: Input
|
|
623
|
-
}], enableFilter: [{
|
|
624
|
-
type: Input
|
|
625
|
-
}], selectedFiltersAmount: [{
|
|
626
|
-
type: Input
|
|
627
|
-
}], filterButtonTemplate: [{
|
|
628
|
-
type: Input
|
|
629
|
-
}], enableEdit: [{
|
|
630
|
-
type: Input
|
|
631
|
-
}], editButtonLoading: [{
|
|
632
|
-
type: Input
|
|
633
|
-
}], editButtonIcon: [{
|
|
634
|
-
type: Input
|
|
635
|
-
}], editButtonText: [{
|
|
636
|
-
type: Input
|
|
637
|
-
}], editButtonTemplate: [{
|
|
638
|
-
type: Input
|
|
639
|
-
}], quickFilter: [{
|
|
640
|
-
type: Output
|
|
641
|
-
}], queryChange: [{
|
|
642
|
-
type: Output
|
|
643
|
-
}], filter: [{
|
|
644
|
-
type: Output
|
|
645
|
-
}], edit: [{
|
|
646
|
-
type: Output
|
|
647
|
-
}], enableFooter: [{
|
|
648
|
-
type: Input
|
|
649
|
-
}], enablePageSize: [{
|
|
650
|
-
type: Input
|
|
651
|
-
}], enablePagination: [{
|
|
652
|
-
type: Input
|
|
653
|
-
}], enableExport: [{
|
|
654
|
-
type: Input
|
|
655
|
-
}], page: [{
|
|
656
|
-
type: Input
|
|
657
|
-
}], total: [{
|
|
658
|
-
type: Input
|
|
659
|
-
}], pageChange: [{
|
|
660
|
-
type: Output
|
|
661
|
-
}], pageSize: [{
|
|
662
|
-
type: Input
|
|
663
|
-
}], pageSizeOptions: [{
|
|
664
|
-
type: Input
|
|
665
|
-
}], pageSizeChange: [{
|
|
666
|
-
type: Output
|
|
667
|
-
}], export: [{
|
|
668
|
-
type: Output
|
|
669
|
-
}], hideOnSinglePage: [{
|
|
670
|
-
type: Input
|
|
671
|
-
}], emptyStateType: [{
|
|
672
|
-
type: Input
|
|
673
|
-
}], emptyStateIllustration: [{
|
|
674
|
-
type: Input
|
|
675
|
-
}], emptyStateHeader: [{
|
|
676
|
-
type: Input
|
|
677
|
-
}], emptyStateContent: [{
|
|
678
|
-
type: Input
|
|
679
|
-
}], emptyStateAction: [{
|
|
680
|
-
type: Input
|
|
681
|
-
}], enableEmptyStateAction: [{
|
|
682
|
-
type: Input
|
|
683
|
-
}], emptyStateFilteredIllustration: [{
|
|
684
|
-
type: Input
|
|
685
|
-
}], emptyStateFilteredHeader: [{
|
|
686
|
-
type: Input
|
|
687
|
-
}], emptyStateFilteredContent: [{
|
|
688
|
-
type: Input
|
|
689
|
-
}], emptyStateActionClick: [{
|
|
690
|
-
type: Output
|
|
691
|
-
}], headerCustomFilterTemplate: [{
|
|
692
|
-
type: ContentChild,
|
|
693
|
-
args: [TableCustomFilterDirective, {
|
|
694
|
-
read: TemplateRef,
|
|
695
|
-
static: true,
|
|
696
|
-
}]
|
|
697
|
-
}], columnDefinitions: [{
|
|
698
|
-
type: ContentChildren,
|
|
699
|
-
args: [TableColumn]
|
|
700
|
-
}], filterModalTemplate: [{
|
|
701
|
-
type: ContentChild,
|
|
702
|
-
args: [TableFilterModalDirective, {
|
|
703
|
-
read: TemplateRef,
|
|
704
|
-
static: true,
|
|
705
|
-
}]
|
|
706
|
-
}], filterModalHeaderText: [{
|
|
707
|
-
type: Input
|
|
708
|
-
}], filterModalSaveText: [{
|
|
709
|
-
type: Input
|
|
710
|
-
}], filterModalCancelText: [{
|
|
711
|
-
type: Input
|
|
712
|
-
}], filterModalResetText: [{
|
|
713
|
-
type: Input
|
|
714
|
-
}], filterModalShowReset: [{
|
|
715
|
-
type: Input
|
|
716
|
-
}], filterModalShowResetMobile: [{
|
|
717
|
-
type: Input
|
|
718
|
-
}], filterModalShow: [{
|
|
719
|
-
type: Output
|
|
720
|
-
}], filterModalSave: [{
|
|
721
|
-
type: Output
|
|
722
|
-
}], filterModalReset: [{
|
|
723
|
-
type: Output
|
|
724
|
-
}], keyDown: [{
|
|
725
|
-
type: HostListener,
|
|
726
|
-
args: ['document:keydown', ['$event']]
|
|
727
|
-
}], keyUp: [{
|
|
728
|
-
type: HostListener,
|
|
729
|
-
args: ['document:keyup', ['$event']]
|
|
730
|
-
}], visibilityChange: [{
|
|
731
|
-
type: HostListener,
|
|
732
|
-
args: ['document:visibilitychange', ['$event']]
|
|
733
|
-
}] } });
|
|
734
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../../projects/paperless/src/lib/modules/table/components/table/table.component.ts","../../../../../../../projects/paperless/src/lib/modules/table/components/table/table.component.html"],"names":[],"mappings":";AAAA,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,eAAe,EACf,YAAY,EACZ,YAAY,EACZ,KAAK,EAGL,MAAM,EAGN,WAAW,GACd,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAMrE,OAAO,EAAE,eAAe,EAAE,oBAAoB,EAAE,MAAM,MAAM,CAAC;AAC7D,OAAO,EACH,0BAA0B,EAC1B,yBAAyB,GAC5B,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAE,WAAW,EAAE,MAAM,wCAAwC,CAAC;AACrE,OAAO,EAAE,WAAW,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;;;;;;;AASvD,IAAM,KAAK,GAAX,MAAM,KAAK;IACd;;OAEG;IACM,KAAK,CAAU;IAExB;;OAEG;IACM,OAAO,GAAY,KAAK,CAAC;IAElC;;OAEG;IACM,aAAa,GAAY,KAAK,CAAC;IAExC;;OAEG;IACM,aAAa,GAAY,KAAK,CAAC;IAExC;;OAEG;IACM,mBAAmB,GAAW,CAAC,CAAC;IAEzC;;OAEG;IACM,kBAAkB,GAAY,IAAI,CAAC;IAE5C;;OAEG;IACM,cAAc,GAAY,IAAI,CAAC;IAExC;;OAEG;IACM,YAAY,GAAU,EAAE,CAAC;IAElC;;OAEG;IACO,kBAAkB,GAAsB,IAAI,YAAY,EAAE,CAAC;IAErE;;OAEG;IACM,YAAY,CAAqB;IAE1C;;OAEG;IACM,YAAY,CAAqB;IAE1C;;OAEG;IACO,QAAQ,GAAgC,IAAI,YAAY,EAAE,CAAC;IAErE;;OAEG;IACO,WAAW,GAAsB,IAAI,YAAY,EAAE,CAAC;IAE9D;;OAEG;IACO,aAAa,GAAsB,IAAI,YAAY,EAAE,CAAC;IAEhE,mBAAmB;IAEnB;;OAEG;IACM,YAAY,GAAY,IAAI,CAAC;IAEtC;;OAEG;IACM,YAAY,GAAkB,EAAE,CAAC;IAE1C;;OAEG;IACM,2BAA2B,CAAqB;IAEzD;;OAEG;IACM,YAAY,GAAY,IAAI,CAAC;IAEtC;;OAEG;IACM,KAAK,CAAqB;IAEnC;;OAEG;IACM,YAAY,GAAY,IAAI,CAAC;IAEtC;;OAEG;IACM,qBAAqB,CAAqB;IAEnD;;OAEG;IACM,oBAAoB,CAAM;IAEnC;;OAEG;IACM,UAAU,GAAY,IAAI,CAAC;IAEpC;;OAEG;IACM,iBAAiB,GAAY,KAAK,CAAC;IAE5C;;OAEG;IACM,cAAc,GAAgB,QAAQ,CAAC;IAEhD;;OAEG;IACM,cAAc,CAAU;IAEjC;;OAEG;IACM,kBAAkB,CAAM;IAEjC;;OAEG;IACO,WAAW,GAA8B,IAAI,YAAY,EAAE,CAAC;IAEtE;;OAEG;IACO,WAAW,GAAyB,IAAI,YAAY,EAAE,CAAC;IAEjE;;OAEG;IACO,MAAM,GAAuB,IAAI,YAAY,EAAE,CAAC;IAE1D;;OAEG;IACO,IAAI,GAAuB,IAAI,YAAY,EAAE,CAAC;IAExD,mBAAmB;IAEnB;;OAEG;IACM,YAAY,GAAY,IAAI,CAAC;IAEtC;;OAEG;IACM,cAAc,GAAY,IAAI,CAAC;IAExC;;OAEG;IACM,gBAAgB,GAAY,IAAI,CAAC;IAE1C;;OAEG;IACM,YAAY,GAAY,IAAI,CAAC;IAEtC;;OAEG;IACM,IAAI,GAAW,CAAC,CAAC;IAE1B;;OAEG;IACM,KAAK,CAAU;IAExB;;OAEG;IACO,UAAU,GAAyB,IAAI,YAAY,EAAE,CAAC;IAEhE;;OAEG;IACM,QAAQ,GAAW,WAAW,CAAC;IAExC;;OAEG;IACM,eAAe,GAAa,kBAAkB,CAAC;IAExD;;OAEG;IACO,cAAc,GAAyB,IAAI,YAAY,EAAE,CAAC;IAEpE;;OAEG;IACO,MAAM,GAAyB,IAAI,YAAY,EAAE,CAAC;IAE5D;;OAEG;IACM,gBAAgB,GAAY,IAAI,CAAC;IAE1C,uBAAuB;IACd,cAAc,GAA6B,WAAW,CAAC;IAEvD,sBAAsB,GAAwB,iBAAiB,CAAC;IAChE,gBAAgB,CAAU;IAC1B,iBAAiB,CAAU;IAC3B,gBAAgB,CAAU;IAE1B,sBAAsB,GAAY,IAAI,CAAC;IAEvC,8BAA8B,GACnC,oBAAoB,CAAC;IAChB,wBAAwB,CAAU;IAClC,yBAAyB,CAAU;IAE5C;;OAEG;IACO,qBAAqB,GAAuB,IAAI,YAAY,EAAE,CAAC;IAEzE,qBAAqB;IAEd,OAAO,GAAU,EAAE,CAAC;IACpB,WAAW,GAAU,EAAE,CAAC;IACxB,WAAW,GAAG,KAAK,CAAC,IAAI,CAAC;QAC5B,MAAM,EAAE,IAAI,CAAC,mBAAmB;KACnC,CAAC,CAAC;IACK,SAAS,GAAG,KAAK,CAAC;IAE1B,gBAAgB;IAChB,yBAAyB;IAKlB,0BAA0B,CAA+B;IAEhE,mBAAmB;IACX,kBAAkB,CAA0B;IAEpD,IACI,iBAAiB,CAAC,CAAyB;QAC3C,IAAI,CAAC,kBAAkB,GAAG,CAAC,CAAC;QAC5B,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC5B,CAAC;IACD,IAAI,iBAAiB;QACjB,OAAO,IAAI,CAAC,kBAAkB,CAAC;IACnC,CAAC;IAED,eAAe;IAKR,mBAAmB,CAA+B;IAElD,gBAAgB,GAAG,IAAI,eAAe,CAAC,KAAK,CAAC,CAAC;IAE5C,qBAAqB,GAAW,SAAS,CAAC;IAC1C,mBAAmB,GAAW,MAAM,CAAC;IACrC,qBAAqB,GAAW,QAAQ,CAAC;IACzC,oBAAoB,GAAW,eAAe,CAAC;IAE/C,oBAAoB,GAAY,KAAK,CAAC;IACtC,0BAA0B,GAAY,KAAK,CAAC;IAE3C,eAAe,GAA0B,IAAI,YAAY,EAAE,CAAC;IAC5D,eAAe,GAAuB,IAAI,YAAY,EAAE,CAAC;IACzD,gBAAgB,GAA0B,IAAI,YAAY,EAAE,CAAC;IAEvE,gBAAe,CAAC;IAEhB,QAAQ;QACJ,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAE7B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,IAAI,CAAC;YAC1B,MAAM,EAAE,IAAI,CAAC,mBAAmB;SACnC,CAAC,CAAC;QAEH,IAAI,CAAC,gBAAgB;aAChB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,oBAAoB,EAAE,CAAC;aAClD,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;QAC5D,2BAA2B;IAC/B,CAAC;IAED,WAAW,CAAC,OAAsB;QAC9B,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE;YAClB,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,YAAY,CAAC,CAAC;SACnD;QAED,IAAI,OAAO,CAAC,qBAAqB,CAAC,EAAE;YAChC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,IAAI,CAAC;gBAC1B,MAAM,EAAE,OAAO,CAAC,qBAAqB,CAAC,CAAC,YAAY;aACtD,CAAC,CAAC;SACN;IACL,CAAC;IAED,oEAAoE;IACpE,gCAAgC;IAChC,gCAAgC;IAChC,KAAK;IAGL,OAAO,CAAC,EAAE,GAAG,EAAmB;QAC5B,IAAI,GAAG,KAAK,SAAS,IAAI,IAAI,CAAC,SAAS,KAAK,IAAI,EAAE;YAC9C,OAAO;SACV;QAED,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;IAC1B,CAAC;IAGD,KAAK,CAAC,EAAE,GAAG,EAAmB;QAC1B,IAAI,GAAG,KAAK,SAAS,IAAI,IAAI,CAAC,SAAS,KAAK,KAAK,EAAE;YAC/C,OAAO;SACV;QAED,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IAC3B,CAAC;IAGD,gBAAgB;QACZ,IAAI,QAAQ,CAAC,eAAe,KAAK,QAAQ,IAAI,IAAI,CAAC,SAAS,KAAK,KAAK,EAAE;YACnE,OAAO;SACV;QAED,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IAC3B,CAAC;IAED,aAAa,CAAC,EAAE,MAAM,EAAO;QACzB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAClC,CAAC;IAED,aAAa,CAAC,EAAE,MAAM,EAAO;QACzB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAClC,CAAC;IAED,gBAAgB,CAAC,EAAE,MAAM,EAAO;QAC5B,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC;QACvB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACrC,CAAC;IAED,YAAY,CAAC,EAAE,MAAM,EAAO;QACxB,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC;QACnB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACjC,CAAC;IAED,iBAAiB;QACb,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,CAAC;QAC5B,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC;IAED,kBAAkB,CAAC,gBAAgB,GAAG,KAAK;QACvC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;QAC7C,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC;IAED,iBAAiB;QACb,IAAI,CAAC,IAAI,CAAC,sBAAsB,EAAE;YAC9B,OAAO;SACV;QAED,IAAI,CAAC,qBAAqB,CAAC,IAAI,EAAE,CAAC;IACtC,CAAC;IAEO,WAAW,CAAC,KAAa;QAC7B,IAAI,CAAC,KAAK,EAAE;YACR,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;YACtB,OAAO;SACV;QAED,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YACtB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;YACzB,OAAO;SACV;QAED,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IACzC,CAAC;IAEO,gBAAgB;QACpB,sBAAsB;QACtB,kEAAkE;QAClE,MAAM,gBAAgB,GAAG,KAAK,CAAC,IAAI,CAC/B,IAAI,CAAC,kBAAkB,CACT,CAAC;QACnB,gBAAgB,CAAC,gBAAgB,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC;QAE5D,IAAI,CAAC,OAAO,GAAG,gBAAgB,CAAC;IACpC,CAAC;IAED,0BAA0B;IAC1B,gBAAgB;IAChB,0CAA0C;IAC1C,qEAAqE;IACrE,mCAAmC;IACnC,wCAAwC;IACxC,wCAAwC;IACxC,wCAAwC;IACxC,2EAA2E;IAC3E,qCAAqC;IACrC,sCAAsC;IACtC,mBAAmB;IACnB,0BAA0B;IAC1B,UAAU;IACV,KAAK;IAEL,wBAAwB;IACxB,2BAA2B;IAC3B,8BAA8B;IAC9B,iBAAiB;IACjB,qDAAqD;IACrD,kBAAkB;IAClB,2BAA2B;IAC3B,gCAAgC;IAChC,qCAAqC;IACrC,0EAA0E;IAC1E,yBAAyB;IACzB,qBAAqB;IACrB,oDAAoD;IACpD,kCAAkC;IAClC,iBAAiB;IACjB,cAAc;IACd,SAAS;IAET,iDAAiD;IACjD,wBAAwB;IACxB,4EAA4E;IAC5E,2DAA2D;IAC3D,aAAa;IACb,kDAAkD;IAClD,0BAA0B;IAC1B,WAAW;IACX,KAAK;IAEL,yCAAyC;IACzC,sEAAsE;IACtE,oBAAoB;IACpB,+BAA+B;IAC/B,oCAAoC;IACpC,+BAA+B;IAC/B,iEAAiE;IACjE,oCAAoC;IACpC,oCAAoC;IACpC,kCAAkC;IAClC,cAAc;IACd,WAAW;IACX,KAAK;IAEL,uCAAuC;IACvC,sEAAsE;IACtE,oBAAoB;IACpB,+BAA+B;IAC/B,oCAAoC;IACpC,qCAAqC;IACrC,4EAA4E;IAC5E,oCAAoC;IACpC,oCAAoC;IACpC,kCAAkC;IAClC,cAAc;IACd,WAAW;IACX,KAAK;IAEL,yBAAyB;IACzB,cAAc;IACd,iBAAiB;IACjB,6DAA6D;IAC7D,OAAO;IACP,4EAA4E;IAC5E,mBAAmB;IACnB,SAAS;IAET,oCAAoC;IACpC,wEAAwE;IACxE,SAAS;IAET,mCAAmC;IACnC,oBAAoB;IACpB,sBAAsB;IACtB,mCAAmC;IACnC,mCAAmC;IACnC,gEAAgE;IAChE,0DAA0D;IAC1D,kEAAkE;IAClE,kBAAkB;IAClB,cAAc;IACd,SAAS;IAET,2CAA2C;IAE3C,gBAAgB;IAChB,kBAAkB;IAClB,+BAA+B;IAC/B,+BAA+B;IAC/B,6EAA6E;IAC7E,wEAAwE;IACxE,iEAAiE;IACjE,cAAc;IACd,UAAU;IACV,KAAK;IAEE,iBAAiB,CAAC,IAAS;QAC9B,OAAO,IAAI,CAAC,YAAY,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACzD,CAAC;IAEM,gBAAgB,CAAC,MAAW;QAC/B,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE;YAC1B,OAAO;SACV;QAED,MAAM,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QACnD,IAAI,KAAK,EAAE;YACP,MAAM,KAAK,GAAG,EAAE,CAAC;YACjB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAC9C,MAAM,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;gBAChC,IAAI,IAAI,CAAC,YAAY,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE;oBAC9C,SAAS;iBACZ;gBAED,IAAI,IAAI,CAAC,kBAAkB,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE;oBACjC,SAAS;iBACZ;gBAED,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;gBAChB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;aAC9B;YAED,IAAI,CAAC,YAAY,GAAG,CAAC,GAAG,IAAI,CAAC,YAAY,EAAE,GAAG,KAAK,CAAC,CAAC;YACrD,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YAChD,OAAO;SACV;QAED,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YAC/C,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YACnC,MAAM,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAC7B,CAAC,CAAC,EAAE,EAAE,CACF,IAAI,CAAC,kBAAkB,CAAC,CAAC,EAAE,CAAC,CAAC;gBAC7B,IAAI,CAAC,kBAAkB,CAAC,KAAK,EAAE,CAAC,CAAC,CACxC,CAAC;YAEF,IAAI,CAAC,GAAG,EAAE;gBACN,SAAS;aACZ;YAED,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;SAChC;QAED,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACvB,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACpD,CAAC;IAEM,eAAe,CAAC,MAAW,EAAE,KAAa;QAC7C,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE;YAC1B,OAAO;SACV;QAED,MAAM,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;QAEpC,IAAI,IAAI,CAAC,YAAY,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE;YAC9C,MAAM,CAAC,OAAO,GAAG,KAAK,CAAC;YACvB,OAAO;SACV;QAED,MAAM,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;QAC5C,IAAI,KAAK,EAAE;YACP,IAAI,CAAC,YAAY,GAAG,CAAC,GAAG,IAAI,CAAC,YAAY,EAAE,GAAG,CAAC,CAAC;YAChD,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YAChD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAC3B,OAAO;SACV;QAED,MAAM,eAAe,GAAG,IAAI,CAAC,kBAAkB,CAAC,GAAG,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;QAElE,4EAA4E;QAC5E,MAAM,SAAS,GAAG,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC;QACzC,SAAS,CAAC,MAAM,CAAC,eAAe,EAAE,CAAC,CAAC,CAAC;QACrC,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC;QAC9B,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAChD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACjC,CAAC;IAEO,gBAAgB,CAAC,MAAW;QAChC,OAAO,MAAM,EAAE,OAAO,CAAC;IAC3B,CAAC;IAEO,kBAAkB,CAAC,GAAQ,EAAE,KAAa;QAC9C,OAAO,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC;IACzE,CAAC;IAEM,kBAAkB,CACrB,GAAQ,EACR,KAAa,EACb,WAAW,GAAG,KAAK;QAEnB,MAAM,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,CAC3C,CAAC,IAAI,EAAE,EAAE,CACL,IAAI,CAAC,kBAAkB,CAAC,GAAG,EAAE,KAAK,CAAC;YACnC,IAAI,CAAC,kBAAkB,CAAC,IAAI,EAAE,KAAK,CAAC,CAC3C,CAAC;QACF,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,WAAW,IAAI,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC;IACzD,CAAC;IAEM,qBAAqB;QACxB,IAAI,WAAW,GAAG,IAAI,CAAC;QACvB,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,MAAM,EAAE;YAC3B,OAAO,KAAK,CAAC;SAChB;QAED,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,WAAW,EAAE,MAAM,EAAE,CAAC,EAAE,EAAE;YAC/C,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;YACjC,MAAM,QAAQ,GAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;YAElD,IAAI,CAAC,QAAQ,EAAE;gBACX,WAAW,GAAG,KAAK,CAAC;gBACpB,MAAM;aACT;SACJ;QAED,OAAO,WAAW,CAAC;IACvB,CAAC;IAEM,uBAAuB;QAC1B,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,MAAM,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,MAAM,EAAE;YACzD,OAAO,KAAK,CAAC;SAChB;QAED,IAAI,aAAa,GAAG,CAAC,CAAC;QACtB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,WAAW,EAAE,MAAM,EAAE,CAAC,EAAE,EAAE;YAC/C,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;YACjC,MAAM,QAAQ,GAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;YAElD,IAAI,QAAQ,EAAE;gBACV,aAAa,EAAE,CAAC;aACnB;SACJ;QAED,OAAO,aAAa,GAAG,CAAC,IAAI,aAAa,KAAK,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC;IAC1E,CAAC;IAEM,SAAS,CAAC,MAAkB,EAAE,KAAa;QAC9C,MAAM,MAAM,GAAG,MAAM,CAAC,MAAqB,CAAC;QAE5C,IACI,MAAM,CAAC,OAAO,CAAC,WAAW,EAAE,KAAK,OAAO;YACvC,MAA2B,CAAC,IAAI,KAAK,UAAU,EAClD;YACE,OAAO;SACV;QAED,MAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QAClC,MAAM,MAAM,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;QAE3C,IAAI,MAAM,EAAE;YACR,OAAO;SACV;QAED,IAAI,IAAI,CAAC,cAAc,EAAE;YACrB,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;YACrC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;gBACf,IAAI;gBACJ,QAAQ,EAAE,IAAI,CAAC,SAAS;aAC3B,CAAC,CAAC;YACH,OAAO;SACV;QAED,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE;YAC1B,OAAO;SACV;QAED,MAAM,QAAQ,GAAG,GAAG,EAAE,aAAa,CAAC,wBAAwB,CAAC,CAAC;QAE9D,IAAI,CAAC,QAAQ,EAAE;YACX,OAAO;SACV;QAED,QAAQ,CAAC,OAAO,GAAG,CAAC,QAAQ,CAAC,OAAO,CAAC;QACrC,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;IAC1C,CAAC;IAEO,QAAQ,CAAC,EAAsB;QACnC,IAAI,CAAC,EAAE,EAAE;YACL,OAAO,EAAE,CAAC;SACb;QAED,IAAI,EAAE,EAAE,OAAO,EAAE,WAAW,EAAE,KAAK,aAAa,EAAE;YAC9C,OAAO,EAAE,CAAC;SACb;QAED,OAAO,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,aAAa,CAAC,CAAC;IAC5C,CAAC;IAEO,cAAc,CAAC,EAAsB;QACzC,IAAI,CAAC,EAAE,EAAE;YACL,OAAO,IAAI,CAAC;SACf;QAED,IACI,EAAE,CAAC,YAAY,CAAC,gBAAgB,CAAC,KAAK,IAAI;YAC1C,EAAE,CAAC,YAAY,CAAC,gBAAgB,CAAC,KAAK,OAAO,EAC/C;YACE,OAAO,EAAE,CAAC;SACb;QAED,IAAI,EAAE,EAAE,OAAO,EAAE,WAAW,EAAE,KAAK,aAAa,EAAE;YAC9C,OAAO,IAAI,CAAC;SACf;QAED,OAAO,IAAI,CAAC,cAAc,CAAC,EAAE,EAAE,aAAa,CAAC,CAAC;IAClD,CAAC;uGAvtBQ,KAAK;2FAAL,KAAK,s7EA2PA,0BAA0B,2BAC9B,WAAW,iFAkBP,yBAAyB,2BAC7B,WAAW,kEAXJ,WAAW,kDCxShC,ovRAiPA;;AD7Ma,KAAK;IAPjB,YAAY,CAAC,EAAE,eAAe,EAAE,IAAI,EAAE,CAAC;GAO3B,KAAK,CAwtBjB;SAxtBY,KAAK;2FAAL,KAAK;kBANjB,SAAS;+BACI,aAAa,mBAGN,uBAAuB,CAAC,MAAM;0EAMtC,KAAK;sBAAb,KAAK;gBAKG,OAAO;sBAAf,KAAK;gBAKG,aAAa;sBAArB,KAAK;gBAKG,aAAa;sBAArB,KAAK;gBAKG,mBAAmB;sBAA3B,KAAK;gBAKG,kBAAkB;sBAA1B,KAAK;gBAKG,cAAc;sBAAtB,KAAK;gBAKG,YAAY;sBAApB,KAAK;gBAKI,kBAAkB;sBAA3B,MAAM;gBAKE,YAAY;sBAApB,KAAK;gBAKG,YAAY;sBAApB,KAAK;gBAKI,QAAQ;sBAAjB,MAAM;gBAKG,WAAW;sBAApB,MAAM;gBAKG,aAAa;sBAAtB,MAAM;gBAOE,YAAY;sBAApB,KAAK;gBAKG,YAAY;sBAApB,KAAK;gBAKG,2BAA2B;sBAAnC,KAAK;gBAKG,YAAY;sBAApB,KAAK;gBAKG,KAAK;sBAAb,KAAK;gBAKG,YAAY;sBAApB,KAAK;gBAKG,qBAAqB;sBAA7B,KAAK;gBAKG,oBAAoB;sBAA5B,KAAK;gBAKG,UAAU;sBAAlB,KAAK;gBAKG,iBAAiB;sBAAzB,KAAK;gBAKG,cAAc;sBAAtB,KAAK;gBAKG,cAAc;sBAAtB,KAAK;gBAKG,kBAAkB;sBAA1B,KAAK;gBAKI,WAAW;sBAApB,MAAM;gBAKG,WAAW;sBAApB,MAAM;gBAKG,MAAM;sBAAf,MAAM;gBAKG,IAAI;sBAAb,MAAM;gBAOE,YAAY;sBAApB,KAAK;gBAKG,cAAc;sBAAtB,KAAK;gBAKG,gBAAgB;sBAAxB,KAAK;gBAKG,YAAY;sBAApB,KAAK;gBAKG,IAAI;sBAAZ,KAAK;gBAKG,KAAK;sBAAb,KAAK;gBAKI,UAAU;sBAAnB,MAAM;gBAKE,QAAQ;sBAAhB,KAAK;gBAKG,eAAe;sBAAvB,KAAK;gBAKI,cAAc;sBAAvB,MAAM;gBAKG,MAAM;sBAAf,MAAM;gBAKE,gBAAgB;sBAAxB,KAAK;gBAGG,cAAc;sBAAtB,KAAK;gBAEG,sBAAsB;sBAA9B,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBAEG,sBAAsB;sBAA9B,KAAK;gBAEG,8BAA8B;sBAAtC,KAAK;gBAEG,wBAAwB;sBAAhC,KAAK;gBACG,yBAAyB;sBAAjC,KAAK;gBAKI,qBAAqB;sBAA9B,MAAM;gBAiBA,0BAA0B;sBAJhC,YAAY;uBAAC,0BAA0B,EAAE;wBACtC,IAAI,EAAE,WAAW;wBACjB,MAAM,EAAE,IAAI;qBACf;gBAOG,iBAAiB;sBADpB,eAAe;uBAAC,WAAW;gBAcrB,mBAAmB;sBAJzB,YAAY;uBAAC,yBAAyB,EAAE;wBACrC,IAAI,EAAE,WAAW;wBACjB,MAAM,EAAE,IAAI;qBACf;gBAKQ,qBAAqB;sBAA7B,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBACG,qBAAqB;sBAA7B,KAAK;gBACG,oBAAoB;sBAA5B,KAAK;gBAEG,oBAAoB;sBAA5B,KAAK;gBACG,0BAA0B;sBAAlC,KAAK;gBAEI,eAAe;sBAAxB,MAAM;gBACG,eAAe;sBAAxB,MAAM;gBACG,gBAAgB;sBAAzB,MAAM;gBAmCP,OAAO;sBADN,YAAY;uBAAC,kBAAkB,EAAE,CAAC,QAAQ,CAAC;gBAU5C,KAAK;sBADJ,YAAY;uBAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC;gBAU1C,gBAAgB;sBADf,YAAY;uBAAC,2BAA2B,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChild,\n    ContentChildren,\n    EventEmitter,\n    HostListener,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    QueryList,\n    SimpleChanges,\n    TemplateRef,\n} from '@angular/core';\nimport { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy';\nimport { QuickFilter, RowClickEvent } from '@paperless/core';\nimport {\n    IconVariant,\n    IllustrationVariant,\n} from '@paperless/core/dist/types/components';\nimport { BehaviorSubject, distinctUntilChanged } from 'rxjs';\nimport {\n    TableCustomFilterDirective,\n    TableFilterModalDirective,\n} from '../../directives';\nimport { TableColumn } from '../table-column/table-column.component';\nimport { defaultSize, defaultSizeOptions } from './constants';\n\n@UntilDestroy({ checkProperties: true })\n@Component({\n    selector: 'p-table-ngx',\n    templateUrl: 'table.component.html',\n    styleUrls: ['table.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class Table implements OnInit, OnChanges {\n    /**\n     * The items to be fed to the table\n     */\n    @Input() items!: string;\n\n    /**\n     * Wether data is loading\n     */\n    @Input() loading: boolean = false;\n\n    /**\n     * Wether the header should show loading state\n     */\n    @Input() headerLoading: boolean = false;\n\n    /**\n     * Wether the footer should show loading state\n     */\n    @Input() footerLoading: boolean = false;\n\n    /**\n     * The amount of loading rows to show\n     */\n    @Input() amountOfLoadingRows: number = 6;\n\n    /**\n     * Wether to enable selection\n     */\n    @Input() enableRowSelection: boolean = true;\n\n    /**\n     * Wether to enable row clicking\n     */\n    @Input() enableRowClick: boolean = true;\n\n    /**\n     * The current selection of items\n     */\n    @Input() selectedRows: any[] = [];\n\n    /**\n     * Event whenever the current selection changes\n     */\n    @Output() selectedRowsChange: EventEmitter<any> = new EventEmitter();\n\n    /**\n     * The key to determine if a row is selected\n     */\n    @Input() selectionKey: string | undefined;\n\n    /**\n     * A key to determine if a row can be selected\n     */\n    @Input() canSelectKey: string | undefined;\n\n    /**\n     * Event whenever a row is clicked\n     */\n    @Output() rowClick: EventEmitter<RowClickEvent> = new EventEmitter();\n\n    /**\n     * Event whenever a row is selected\n     */\n    @Output() rowSelected: EventEmitter<any> = new EventEmitter();\n\n    /**\n     * Event whenever a row is deselected\n     */\n    @Output() rowDeselected: EventEmitter<any> = new EventEmitter();\n\n    /** START HEADER */\n\n    /**\n     * Wether to show the header\n     */\n    @Input() enableHeader: boolean = true;\n\n    /**\n     * Quick filters to show\n     */\n    @Input() quickFilters: QuickFilter[] = [];\n\n    /**\n     * Active quick filter identifier\n     */\n    @Input() activeQuickFilterIdentifier: string | undefined;\n\n    /**\n     * Wether to show the search input\n     */\n    @Input() enableSearch: boolean = true;\n\n    /**\n     * The query to show in the search bar\n     */\n    @Input() query: string | undefined;\n\n    /**\n     * Wether to show the filter button\n     */\n    @Input() enableFilter: boolean = true;\n\n    /**\n     * The amount of filters being selected\n     */\n    @Input() selectedFiltersAmount: number | undefined;\n\n    /**\n     * The template for the filter button text\n     */\n    @Input() filterButtonTemplate: any;\n\n    /**\n     * Wether to show the edit button\n     */\n    @Input() enableEdit: boolean = true;\n\n    /**\n     * Wether the edit button is loading\n     */\n    @Input() editButtonLoading: boolean = false;\n\n    /**\n     * The edit button icon\n     */\n    @Input() editButtonIcon: IconVariant = 'pencil';\n\n    /**\n     * The edit button text if changed\n     */\n    @Input() editButtonText?: string;\n\n    /**\n     * The template for the edit button text\n     */\n    @Input() editButtonTemplate: any;\n\n    /**\n     * Event when one of the quick filters is clicked\n     */\n    @Output() quickFilter: EventEmitter<QuickFilter> = new EventEmitter();\n\n    /**\n     * Event when the query changes\n     */\n    @Output() queryChange: EventEmitter<string> = new EventEmitter();\n\n    /**\n     * Event when the filter button is clicked\n     */\n    @Output() filter: EventEmitter<null> = new EventEmitter();\n\n    /**\n     * Event when the edit button is clicked\n     */\n    @Output() edit: EventEmitter<null> = new EventEmitter();\n\n    /** START FOOTER */\n\n    /**\n     * Wether to show the footer\n     */\n    @Input() enableFooter: boolean = true;\n\n    /**\n     * Wether to enable page size select\n     */\n    @Input() enablePageSize: boolean = true;\n\n    /**\n     * Wether to enable pagination\n     */\n    @Input() enablePagination: boolean = true;\n\n    /**\n     * Wether to enable export\n     */\n    @Input() enableExport: boolean = true;\n\n    /**\n     * The current page\n     */\n    @Input() page: number = 1;\n\n    /**\n     * The total amount of items\n     */\n    @Input() total!: number;\n\n    /**\n     * Event whenever the page changes\n     */\n    @Output() pageChange: EventEmitter<number> = new EventEmitter();\n\n    /**\n     * The amount of items per page\n     */\n    @Input() pageSize: number = defaultSize;\n\n    /**\n     * The options for the page size\n     */\n    @Input() pageSizeOptions: number[] = defaultSizeOptions;\n\n    /**\n     * Event whenever the page changes\n     */\n    @Output() pageSizeChange: EventEmitter<number> = new EventEmitter();\n\n    /**\n     * Event whenever the page changes\n     */\n    @Output() export: EventEmitter<number> = new EventEmitter();\n\n    /**\n     * Wether to hide when there is only 1 page available\n     */\n    @Input() hideOnSinglePage: boolean = true;\n\n    /* Empty state start */\n    @Input() emptyStateType: 'no_filter' | 'filtered' = 'no_filter';\n\n    @Input() emptyStateIllustration: IllustrationVariant = 'empty-state-add';\n    @Input() emptyStateHeader!: string;\n    @Input() emptyStateContent!: string;\n    @Input() emptyStateAction!: string;\n\n    @Input() enableEmptyStateAction: boolean = true;\n\n    @Input() emptyStateFilteredIllustration: IllustrationVariant =\n        'empty-state-search';\n    @Input() emptyStateFilteredHeader!: string;\n    @Input() emptyStateFilteredContent!: string;\n\n    /**\n     * Event whenever the empty state is clicked\n     */\n    @Output() emptyStateActionClick: EventEmitter<null> = new EventEmitter();\n\n    /* Empty state end */\n\n    public columns: any[] = [];\n    public parsedItems: any[] = [];\n    public loadingRows = Array.from({\n        length: this.amountOfLoadingRows,\n    });\n    private _ctrlDown = false;\n\n    // Angular stuff\n    // custom filter template\n    @ContentChild(TableCustomFilterDirective, {\n        read: TemplateRef,\n        static: true,\n    })\n    public headerCustomFilterTemplate: TemplateRef<any> | undefined;\n\n    // column templates\n    private _columnDefinitions!: QueryList<TableColumn>;\n\n    @ContentChildren(TableColumn)\n    set columnDefinitions(v: QueryList<TableColumn>) {\n        this._columnDefinitions = v;\n        this._generateColumns();\n    }\n    get columnDefinitions(): QueryList<TableColumn> {\n        return this._columnDefinitions;\n    }\n\n    // filter modal\n    @ContentChild(TableFilterModalDirective, {\n        read: TemplateRef,\n        static: true,\n    })\n    public filterModalTemplate: TemplateRef<any> | undefined;\n\n    public filterModalShow$ = new BehaviorSubject(false);\n\n    @Input() filterModalHeaderText: string = 'Filters';\n    @Input() filterModalSaveText: string = 'Save';\n    @Input() filterModalCancelText: string = 'Cancel';\n    @Input() filterModalResetText: string = 'Reset filters';\n\n    @Input() filterModalShowReset: boolean = false;\n    @Input() filterModalShowResetMobile: boolean = false;\n\n    @Output() filterModalShow: EventEmitter<boolean> = new EventEmitter();\n    @Output() filterModalSave: EventEmitter<void> = new EventEmitter();\n    @Output() filterModalReset: EventEmitter<boolean> = new EventEmitter();\n\n    constructor() {}\n\n    ngOnInit() {\n        this._parseItems(this.items);\n\n        this.loadingRows = Array.from({\n            length: this.amountOfLoadingRows,\n        });\n\n        this.filterModalShow$\n            .pipe(untilDestroyed(this), distinctUntilChanged())\n            .subscribe((value) => this.filterModalShow.next(value));\n        // this._generateColumns();\n    }\n\n    ngOnChanges(changes: SimpleChanges) {\n        if (changes['items']) {\n            this._parseItems(changes['items'].currentValue);\n        }\n\n        if (changes['amountOfLoadingRows']) {\n            this.loadingRows = Array.from({\n                length: changes['amountOfLoadingRows'].currentValue,\n            });\n        }\n    }\n\n    //  @HostListener('body:tableDefinitionChanged', { target: 'body' })\n    //  onTableDefinitionUpdated() {\n    //      this._generateColumns();\n    //  }\n\n    @HostListener('document:keydown', ['$event'])\n    keyDown({ key }: { key: string }) {\n        if (key !== 'Control' || this._ctrlDown === true) {\n            return;\n        }\n\n        this._ctrlDown = true;\n    }\n\n    @HostListener('document:keyup', ['$event'])\n    keyUp({ key }: { key: string }) {\n        if (key !== 'Control' || this._ctrlDown === false) {\n            return;\n        }\n\n        this._ctrlDown = false;\n    }\n\n    @HostListener('document:visibilitychange', ['$event'])\n    visibilityChange() {\n        if (document.visibilityState !== 'hidden' || this._ctrlDown === false) {\n            return;\n        }\n\n        this._ctrlDown = false;\n    }\n\n    onQueryChange({ detail }: any) {\n        this.queryChange.emit(detail);\n    }\n\n    onQuickFilter({ detail }: any) {\n        this.quickFilter.emit(detail);\n    }\n\n    onPageSizeChange({ detail }: any) {\n        this.pageSize = detail;\n        this.pageSizeChange.emit(detail);\n    }\n\n    onPageChange({ detail }: any) {\n        this.page = detail;\n        this.pageChange.emit(detail);\n    }\n\n    onFilterModalSave() {\n        this.filterModalSave.next();\n        this.filterModalShow$.next(false);\n    }\n\n    onFilterModalReset(resetQuickFilter = false) {\n        this.filterModalReset.next(resetQuickFilter);\n        this.filterModalShow$.next(false);\n    }\n\n    emptyStateClicked() {\n        if (!this.enableEmptyStateAction) {\n            return;\n        }\n\n        this.emptyStateActionClick.emit();\n    }\n\n    private _parseItems(items: string) {\n        if (!items) {\n            this.parsedItems = [];\n            return;\n        }\n\n        if (Array.isArray(items)) {\n            this.parsedItems = items;\n            return;\n        }\n\n        this.parsedItems = JSON.parse(items);\n    }\n\n    private _generateColumns() {\n        // const definitions =\n        // \tthis._el.nativeElement.querySelectorAll('p-table-definition');\n        const definitionsArray = Array.from(\n            this._columnDefinitions\n        ) as TableColumn[];\n        definitionsArray[definitionsArray.length - 1].isLast = true;\n\n        this.columns = definitionsArray;\n    }\n\n    //  private _getHeader() {\n    //      return (\n    //          <p-table-row variant=\"header\">\n    //              {this._columns.map((col: TableDefinition, index) => (\n    //                  <p-table-column\n    //                      definition={col}\n    //                      value={col.name}\n    //                      variant=\"header\"\n    //                      checkbox={this._getCheckbox(index, null, 'header')}\n    //                      index={index}\n    //                  ></p-table-column>\n    //              ))}\n    //          </p-table-row>\n    //      );\n    //  }\n\n    //  private _getRows() {\n    //      if (this.loading) {\n    //          return Array.from(\n    //              {\n    //                  length: this.amountOfLoadingRows,\n    //              },\n    //              (_, i) => (\n    //                  <p-table-row\n    //                      enableHover={\n    //                          this.enableRowSelection || this.enableRowClick\n    //                      }\n    //                  >\n    //                      {this._getLoadingColumns(i)}\n    //                  </p-table-row>\n    //              )\n    //          );\n    //      }\n\n    //      return this._items.map((item, index) => (\n    //          <p-table-row\n    //              enableHover={this.enableRowSelection || this.enableRowClick}\n    //              onClick={(ev) => this._rowClick(ev, index)}\n    //          >\n    //              {this._getRowColumns(item, index)}\n    //          </p-table-row>\n    //      ));\n    //  }\n\n    //  private _getRowColumns(item, index) {\n    //      return this._columns.map((col: TableDefinition, colIndex) => {\n    //          return (\n    //              <p-table-column\n    //                  definition={col}\n    //                  item={item}\n    //                  checkbox={this._getCheckbox(colIndex, index)}\n    //                  index={colIndex}\n    //                  rowIndex={index}\n    //              ></p-table-column>\n    //          );\n    //      });\n    //  }\n\n    //  private _getLoadingColumns(index) {\n    //      return this._columns.map((col: TableDefinition, colIndex) => {\n    //          return (\n    //              <p-table-column\n    //                  definition={col}\n    //                  variant=\"loading\"\n    //                  checkbox={this._getCheckbox(colIndex, index, 'loading')}\n    //                  index={colIndex}\n    //                  rowIndex={index}\n    //              ></p-table-column>\n    //          );\n    //      });\n    //  }\n\n    //  private _getCheckbox(\n    //      index,\n    //      rowIndex,\n    //      variant: 'header' | 'default' | 'loading' = 'default'\n    //  ) {\n    //      if (!this.enableRowSelection || !this.selectionKey || index !== 0) {\n    //          return;\n    //      }\n\n    //      if (variant === 'loading') {\n    //          return <p-loader variant=\"ghost\" class=\"rounded w-6 h-6\" />;\n    //      }\n\n    //      if (variant === 'header') {\n    //          return (\n    //              <input\n    //                  class=\"p-input\"\n    //                  type=\"checkbox\"\n    //                  onChange={(ev) => this._selectAllChange(ev)}\n    //                  checked={this._selectionContainsAll()}\n    //                  indeterminate={this._selectionIndeterminate()}\n    //              />\n    //          );\n    //      }\n\n    //      const item = this._items[rowIndex];\n\n    //      return (\n    //          <input\n    //              class=\"p-input\"\n    //              type=\"checkbox\"\n    //              onChange={(ev) => this._checkboxChange(ev?.target, rowIndex)}\n    //              disabled={this.canSelectKey && !item[this.canSelectKey]}\n    //              checked={this._selectionContains(item, rowIndex)}\n    //          />\n    //      );\n    //  }\n\n    public _checkboxDisabled(item: any) {\n        return this.canSelectKey && !item[this.canSelectKey];\n    }\n\n    public _selectAllChange($event: any) {\n        if (!this.enableRowSelection) {\n            return;\n        }\n\n        const value = this._getCheckedValue($event.target);\n        if (value) {\n            const toAdd = [];\n            for (let i = 0; i < this.parsedItems.length; i++) {\n                const row = this.parsedItems[i];\n                if (this.canSelectKey && !row[this.canSelectKey]) {\n                    continue;\n                }\n\n                if (this._selectionContains(row, i)) {\n                    continue;\n                }\n\n                toAdd.push(row);\n                this.rowSelected.emit(row);\n            }\n\n            this.selectedRows = [...this.selectedRows, ...toAdd];\n            this.selectedRowsChange.emit(this.selectedRows);\n            return;\n        }\n\n        for (let i = 0; i < this.selectedRows.length; i++) {\n            const value = this.selectedRows[i];\n            const row = this.parsedItems.find(\n                (d) =>\n                    this._getSelectionValue(d, i) ===\n                    this._getSelectionValue(value, i)\n            );\n\n            if (!row) {\n                continue;\n            }\n\n            this.rowDeselected.emit(row);\n        }\n\n        this.selectedRows = [];\n        this.selectedRowsChange.emit(this.selectedRows);\n    }\n\n    public _checkboxChange(target: any, index: number) {\n        if (!this.enableRowSelection) {\n            return;\n        }\n\n        const row = this.parsedItems[index];\n\n        if (this.canSelectKey && !row[this.canSelectKey]) {\n            target.checked = false;\n            return;\n        }\n\n        const value = this._getCheckedValue(target);\n        if (value) {\n            this.selectedRows = [...this.selectedRows, row];\n            this.selectedRowsChange.emit(this.selectedRows);\n            this.rowSelected.emit(row);\n            return;\n        }\n\n        const indexOfToRemove = this._selectionContains(row, index, true);\n\n        // we need to do this, because splice does not trigger the selection setter.\n        const selection = [...this.selectedRows];\n        selection.splice(indexOfToRemove, 1);\n        this.selectedRows = selection;\n        this.selectedRowsChange.emit(this.selectedRows);\n        this.rowDeselected.emit(row);\n    }\n\n    private _getCheckedValue(target: any) {\n        return target?.checked;\n    }\n\n    private _getSelectionValue(row: any, index: number) {\n        return this.selectionKey ? row?.[this.selectionKey] || index : index;\n    }\n\n    public _selectionContains(\n        row: any,\n        index: number,\n        returnIndex = false\n    ): any {\n        const returnValue = this.selectedRows.findIndex(\n            (item) =>\n                this._getSelectionValue(row, index) ===\n                this._getSelectionValue(item, index)\n        );\n        return !returnIndex ? returnValue >= 0 : returnValue;\n    }\n\n    public _selectionContainsAll() {\n        let returnValue = true;\n        if (!this.parsedItems?.length) {\n            return false;\n        }\n\n        for (let i = 0; i < this.parsedItems?.length; i++) {\n            const item = this.parsedItems[i];\n            const contains = this._selectionContains(item, i);\n\n            if (!contains) {\n                returnValue = false;\n                break;\n            }\n        }\n\n        return returnValue;\n    }\n\n    public _selectionIndeterminate() {\n        if (!this.parsedItems?.length || !this.selectedRows?.length) {\n            return false;\n        }\n\n        let containsCount = 0;\n        for (let i = 0; i < this.parsedItems?.length; i++) {\n            const item = this.parsedItems[i];\n            const contains = this._selectionContains(item, i);\n\n            if (contains) {\n                containsCount++;\n            }\n        }\n\n        return containsCount > 0 && containsCount !== this.parsedItems.length;\n    }\n\n    public _rowClick($event: MouseEvent, index: number) {\n        const target = $event.target as HTMLElement;\n\n        if (\n            target.tagName.toLowerCase() === 'input' ||\n            (target as HTMLInputElement).type === 'checkbox'\n        ) {\n            return;\n        }\n\n        const row = this._findRow(target);\n        const action = this._findRowAction(target);\n\n        if (action) {\n            return;\n        }\n\n        if (this.enableRowClick) {\n            const item = this.parsedItems[index];\n            this.rowClick.emit({\n                item,\n                ctrlDown: this._ctrlDown,\n            });\n            return;\n        }\n\n        if (!this.enableRowSelection) {\n            return;\n        }\n\n        const checkbox = row?.querySelector('input[type=\"checkbox\"]');\n\n        if (!checkbox) {\n            return;\n        }\n\n        checkbox.checked = !checkbox.checked;\n        this._checkboxChange(checkbox, index);\n    }\n\n    private _findRow(el: HTMLElement | null): any {\n        if (!el) {\n            return el;\n        }\n\n        if (el?.tagName?.toLowerCase() === 'p-table-row') {\n            return el;\n        }\n\n        return this._findRow(el?.parentElement);\n    }\n\n    private _findRowAction(el: HTMLElement | null): any {\n        if (!el) {\n            return null;\n        }\n\n        if (\n            el.getAttribute('data-is-action') !== null &&\n            el.getAttribute('data-is-action') !== 'false'\n        ) {\n            return el;\n        }\n\n        if (el?.tagName?.toLowerCase() === 'p-table-row') {\n            return null;\n        }\n\n        return this._findRowAction(el?.parentElement);\n    }\n}\n","<p-table-container>\n    <p-table-header\n        *ngIf=\"enableHeader\"\n        [quickFilters]=\"quickFilters\"\n        [activeQuickFilterIdentifier]=\"activeQuickFilterIdentifier\"\n        (quickFilter)=\"onQuickFilter($event)\"\n        [enableSearch]=\"enableSearch\"\n        [query]=\"query\"\n        (queryChange)=\"onQueryChange($event)\"\n        [enableFilter]=\"enableFilter\"\n        [selectedFiltersAmount]=\"selectedFiltersAmount\"\n        [filterButtonTemplate]=\"filterButtonTemplate\"\n        (filter)=\"filterModalShow$.next(true)\"\n        [enableEdit]=\"enableEdit\"\n        [canEdit]=\"!!selectedRows.length\"\n        [editButtonTemplate]=\"editButtonTemplate\"\n        [editLoading]=\"editButtonLoading\"\n        [editText]=\"editButtonText\"\n        [editIcon]=\"editButtonIcon\"\n        (edit)=\"edit.emit()\"\n        [itemsSelectedAmount]=\"selectedRows.length\"\n        [loading]=\"headerLoading\"\n    >\n        <ng-container *ngIf=\"headerCustomFilterTemplate\">\n            <ng-container\n                *ngTemplateOutlet=\"headerCustomFilterTemplate\"\n            ></ng-container>\n        </ng-container>\n    </p-table-header>\n\n    <p-table-row variant=\"header\">\n        <ng-container *ngFor=\"let col of columns; let index = index\">\n            <p-table-cell-ngx\n                [definition]=\"col\"\n                [value]=\"col.name\"\n                variant=\"header\"\n                [index]=\"index\"\n                [checkbox]=\"\n                    (index === 0 || col.hasCheckbox) && enableRowSelection\n                        ? checkboxTemplate\n                        : undefined\n                \"\n            ></p-table-cell-ngx>\n            <ng-template #checkboxTemplate>\n                <input\n                    class=\"p-input\"\n                    type=\"checkbox\"\n                    (change)=\"_selectAllChange($event)\"\n                    [checked]=\"_selectionContainsAll()\"\n                    [indeterminate]=\"_selectionIndeterminate()\"\n                />\n            </ng-template>\n        </ng-container>\n    </p-table-row>\n\n    <div class=\"flex flex-col\">\n        <ng-container *ngIf=\"loading; else contentTemplate\">\n            <p-table-row\n                *ngFor=\"let r of loadingRows; let rowIndex = index\"\n                [enableHover]=\"enableRowSelection || enableRowClick\"\n            >\n                <ng-container *ngFor=\"let col of columns; let index = index\">\n                    <p-table-cell-ngx\n                        [definition]=\"col\"\n                        variant=\"loading\"\n                        [checkbox]=\"\n                            (index === 0 || col.hasCheckbox) &&\n                            enableRowSelection\n                                ? checkboxTemplate\n                                : undefined\n                        \"\n                        [index]=\"index\"\n                        [rowIndex]=\"rowIndex\"\n                    ></p-table-cell-ngx>\n                    <ng-template #checkboxTemplate>\n                        <p-loader\n                            variant=\"ghost\"\n                            class=\"h-6 w-6 rounded\"\n                        ></p-loader>\n                    </ng-template>\n                </ng-container>\n            </p-table-row>\n        </ng-container>\n\n        <ng-template #contentTemplate>\n            <ng-container *ngIf=\"items?.length; else emptyStateTemplate\">\n                <p-table-row\n                    *ngFor=\"let item of items; let rowIndex = index\"\n                    [enableHover]=\"enableRowSelection || enableRowClick\"\n                    (click)=\"_rowClick($event, rowIndex)\"\n                >\n                    <ng-container\n                        *ngFor=\"let col of columns; let index = index\"\n                    >\n                        <p-table-cell-ngx\n                            [definition]=\"col\"\n                            [item]=\"item\"\n                            [checkbox]=\"\n                                (index === 0 || col.hasCheckbox) &&\n                                enableRowSelection\n                                    ? checkboxTemplate\n                                    : undefined\n                            \"\n                            [index]=\"index\"\n                            [rowIndex]=\"rowIndex\"\n                            [template]=\"col.template\"\n                        ></p-table-cell-ngx>\n\n                        <ng-template #checkboxTemplate>\n                            <input\n                                class=\"p-input\"\n                                type=\"checkbox\"\n                                (change)=\"\n                                    _checkboxChange($event.target, rowIndex)\n                                \"\n                                [disabled]=\"_checkboxDisabled(item)\"\n                                [checked]=\"_selectionContains(item, rowIndex)\"\n                            />\n                        </ng-template>\n                    </ng-container>\n                </p-table-row>\n            </ng-container>\n        </ng-template>\n    </div>\n\n    <p-table-footer\n        *ngIf=\"enableFooter\"\n        [hideOnSinglePage]=\"hideOnSinglePage\"\n        [enablePageSize]=\"enablePageSize\"\n        [pageSize]=\"pageSize\"\n        [pageSizeOptions]=\"pageSizeOptions\"\n        (pageSizeChange)=\"onPageSizeChange($event)\"\n        [enablePagination]=\"enablePagination\"\n        [page]=\"page\"\n        [total]=\"total\"\n        (pageChange)=\"onPageChange($event)\"\n        [enableExport]=\"enableExport\"\n        (export)=\"export.emit()\"\n        [loading]=\"footerLoading\"\n    ></p-table-footer>\n</p-table-container>\n\n<ng-container *ngIf=\"filterModalTemplate\">\n    <p-modal\n        [header]=\"filterModalHeaderText\"\n        [show]=\"filterModalShow$ | async\"\n        (closed)=\"filterModalShow$.next(false)\"\n    >\n        <div slot=\"content\" class=\"flex flex-col gap-6\">\n            <ng-container\n                *ngTemplateOutlet=\"filterModalTemplate\"\n            ></ng-container>\n        </div>\n        <div slot=\"footer\" class=\"flex w-full justify-between gap-4\">\n            <p-button\n                *ngIf=\"filterModalShowResetMobile\"\n                class=\"flex w-full tablet:w-auto desktop-xs:hidden\"\n                variant=\"secondary\"\n                (onClick)=\"onFilterModalReset(true)\"\n            >\n                {{ filterModalResetText }}\n            </p-button>\n            <p-button\n                *ngIf=\"filterModalShowReset\"\n                class=\"hidden w-full tablet:w-auto desktop-xs:flex\"\n                variant=\"secondary\"\n                (onClick)=\"onFilterModalReset()\"\n            >\n                {{ filterModalResetText }}\n            </p-button>\n            <p-button\n                class=\"ml-auto w-full tablet:w-auto\"\n                icon=\"checkmark\"\n                (onClick)=\"onFilterModalSave()\"\n            >\n                {{ filterModalSaveText }}\n            </p-button>\n        </div>\n    </p-modal>\n</ng-container>\n\n<ng-template #emptyStateTemplate>\n    <div\n        *ngIf=\"emptyStateType === 'filtered'; else emptyStateNonFilterTemplate\"\n        class=\"\n            flex\n            max-w-[20rem]\n            flex-col\n            items-center\n            self-center\n            py-24\n            text-center\n        \"\n    >\n        <p-illustration\n            [variant]=\"emptyStateFilteredIllustration\"\n            class=\"mb-6\"\n        ></p-illustration>\n        <p class=\"text-storm-default font-semibold\">\n            {{ emptyStateFilteredHeader }}\n        </p>\n        <p class=\"mb-14 text-sm text-storm-medium\">\n            {{ emptyStateFilteredContent }}\n        </p>\n    </div>\n</ng-template>\n\n<ng-template #emptyStateNonFilterTemplate>\n    <div\n        class=\"\n            flex\n            max-w-[20rem]\n            flex-col\n            items-center\n            self-center\n            py-24\n            text-center\n        \"\n        [class.cursor-pointer]=\"enableEmptyStateAction\"\n        (click)=\"emptyStateClicked()\"\n    >\n        <p-illustration\n            [variant]=\"emptyStateIllustration\"\n            class=\"mb-6\"\n        ></p-illustration>\n        <p class=\"text-storm-default font-semibold\">\n            {{ emptyStateHeader }}\n        </p>\n        <p class=\"mb-6 text-sm text-storm-medium\">\n            {{ emptyStateContent }}\n        </p>\n        <p-button\n            *ngIf=\"enableEmptyStateAction\"\n            variant=\"secondary\"\n            icon=\"plus\"\n            size=\"small\"\n        >\n            {{ emptyStateAction }}\n        </p-button>\n    </div>\n</ng-template>\n"]}
|