@paperless/angular 0.1.0-alpha.22 → 0.1.0-alpha.221

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (94) hide show
  1. package/README.md +9 -1
  2. package/esm2020/lib/animations/index.mjs +2 -0
  3. package/esm2020/lib/animations/slide.mjs +20 -0
  4. package/esm2020/lib/base/index.mjs +2 -1
  5. package/esm2020/lib/base/upload.component.mjs +57 -0
  6. package/esm2020/lib/base/value-accessor.mjs +8 -8
  7. package/esm2020/lib/directives/index.mjs +12 -4
  8. package/esm2020/lib/directives/p-page-size-select.directive.mjs +42 -0
  9. package/esm2020/lib/directives/p-pagination.directive.mjs +42 -0
  10. package/esm2020/lib/directives/p-select.directive.mjs +38 -0
  11. package/esm2020/lib/modules/index.mjs +6 -0
  12. package/esm2020/lib/modules/table/base/form.component.mjs +105 -0
  13. package/esm2020/lib/modules/table/base/index.mjs +3 -0
  14. package/esm2020/lib/modules/table/base/table.component.mjs +162 -0
  15. package/esm2020/lib/modules/table/components/index.mjs +8 -0
  16. package/esm2020/lib/modules/table/components/table/constants.mjs +3 -0
  17. package/esm2020/lib/modules/table/components/table/table.component.mjs +544 -0
  18. package/esm2020/lib/modules/table/components/table-cell/table-cell.component.mjs +167 -0
  19. package/esm2020/lib/modules/table/components/table-column/table-column.component.mjs +37 -0
  20. package/esm2020/lib/modules/table/directives/index.mjs +15 -0
  21. package/esm2020/lib/modules/table/directives/p-table-footer.directive.mjs +52 -0
  22. package/esm2020/lib/modules/table/directives/p-table-header.directive.mjs +60 -0
  23. package/esm2020/lib/modules/table/directives/p-table-ngx.directive.mjs +88 -0
  24. package/esm2020/lib/modules/table/directives/p-table.directive.mjs +78 -0
  25. package/esm2020/lib/modules/table/index.mjs +5 -0
  26. package/esm2020/lib/modules/table/table.module.mjs +27 -0
  27. package/esm2020/lib/modules/toast/components/index.mjs +4 -0
  28. package/esm2020/lib/modules/toast/components/toast-container/toast-container.component.mjs +36 -0
  29. package/esm2020/lib/modules/toast/directives/index.mjs +4 -0
  30. package/esm2020/lib/modules/toast/directives/toast.directive.mjs +44 -0
  31. package/esm2020/lib/modules/toast/index.mjs +6 -0
  32. package/esm2020/lib/modules/toast/services/index.mjs +4 -0
  33. package/esm2020/lib/modules/toast/services/toast.service.mjs +47 -0
  34. package/esm2020/lib/modules/toast/toast.module.mjs +22 -0
  35. package/esm2020/lib/modules/toast/types.mjs +10 -0
  36. package/esm2020/lib/paperless.module.mjs +29 -11
  37. package/esm2020/lib/pipes/currency.pipe.mjs +20 -0
  38. package/esm2020/lib/pipes/date.pipe.mjs +20 -0
  39. package/esm2020/lib/pipes/index.mjs +8 -0
  40. package/esm2020/lib/pipes/safe.pipe.mjs +33 -0
  41. package/esm2020/lib/stencil/components.mjs +976 -70
  42. package/esm2020/lib/stencil/index.mjs +37 -1
  43. package/esm2020/lib/stencil.module.mjs +17 -0
  44. package/esm2020/public-api.mjs +5 -1
  45. package/fesm2015/paperless-angular.mjs +2693 -148
  46. package/fesm2015/paperless-angular.mjs.map +1 -1
  47. package/fesm2020/paperless-angular.mjs +2707 -146
  48. package/fesm2020/paperless-angular.mjs.map +1 -1
  49. package/{paperless-angular.d.ts → index.d.ts} +0 -0
  50. package/lib/animations/index.d.ts +1 -0
  51. package/lib/animations/slide.d.ts +2 -0
  52. package/lib/base/index.d.ts +1 -0
  53. package/lib/base/upload.component.d.ts +16 -0
  54. package/lib/base/value-accessor.d.ts +6 -6
  55. package/lib/directives/index.d.ts +5 -3
  56. package/lib/directives/p-page-size-select.directive.d.ts +10 -0
  57. package/lib/directives/{pagination.directive.d.ts → p-pagination.directive.d.ts} +3 -3
  58. package/lib/directives/p-select.directive.d.ts +9 -0
  59. package/lib/modules/index.d.ts +4 -0
  60. package/lib/modules/table/base/form.component.d.ts +15 -0
  61. package/lib/modules/table/base/index.d.ts +2 -0
  62. package/lib/modules/table/base/table.component.d.ts +45 -0
  63. package/lib/modules/table/components/index.d.ts +7 -0
  64. package/lib/modules/table/components/table/constants.d.ts +2 -0
  65. package/lib/modules/table/components/table/table.component.d.ts +190 -0
  66. package/lib/modules/table/components/table-cell/table-cell.component.d.ts +45 -0
  67. package/lib/modules/table/components/table-column/table-column.component.d.ts +17 -0
  68. package/lib/modules/table/directives/index.d.ts +9 -0
  69. package/lib/modules/table/directives/p-table-footer.directive.d.ts +11 -0
  70. package/lib/modules/table/directives/p-table-header.directive.d.ts +17 -0
  71. package/lib/modules/table/directives/p-table-ngx.directive.d.ts +24 -0
  72. package/lib/modules/table/directives/p-table.directive.d.ts +22 -0
  73. package/lib/modules/table/index.d.ts +4 -0
  74. package/lib/modules/table/table.module.d.ts +15 -0
  75. package/lib/modules/toast/components/index.d.ts +3 -0
  76. package/lib/modules/toast/components/toast-container/toast-container.component.d.ts +17 -0
  77. package/lib/modules/toast/directives/index.d.ts +3 -0
  78. package/lib/modules/toast/directives/toast.directive.d.ts +13 -0
  79. package/lib/modules/toast/index.d.ts +5 -0
  80. package/lib/modules/toast/services/index.d.ts +3 -0
  81. package/lib/modules/toast/services/toast.service.d.ts +12 -0
  82. package/lib/modules/toast/toast.module.d.ts +10 -0
  83. package/lib/modules/toast/types.d.ts +26 -0
  84. package/lib/paperless.module.d.ts +13 -3
  85. package/lib/pipes/currency.pipe.d.ts +10 -0
  86. package/lib/pipes/date.pipe.d.ts +10 -0
  87. package/lib/pipes/index.d.ts +7 -0
  88. package/lib/pipes/safe.pipe.d.ts +10 -0
  89. package/lib/stencil/components.d.ts +403 -14
  90. package/lib/stencil/index.d.ts +1 -1
  91. package/lib/stencil.module.d.ts +7 -0
  92. package/package.json +7 -6
  93. package/public-api.d.ts +4 -0
  94. package/esm2020/lib/directives/pagination.directive.mjs +0 -42
@@ -0,0 +1,544 @@
1
+ import { __decorate } from "tslib";
2
+ import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, HostListener, Input, Output, } from '@angular/core';
3
+ import { UntilDestroy } from '@ngneat/until-destroy';
4
+ import { TableColumn } from '../table-column/table-column.component';
5
+ import { defaultSize, defaultSizeOptions } from './constants';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@angular/common";
8
+ import * as i2 from "../../../../stencil/components";
9
+ import * as i3 from "../table-cell/table-cell.component";
10
+ import * as i4 from "../../directives/p-table-footer.directive";
11
+ import * as i5 from "../../directives/p-table-header.directive";
12
+ let Table = class Table {
13
+ constructor() {
14
+ /**
15
+ * Wether data is loading
16
+ */
17
+ this.loading = false;
18
+ /**
19
+ * The amount of loading rows to show
20
+ */
21
+ this.amountOfLoadingRows = 4;
22
+ /**
23
+ * Wether to enable selection
24
+ */
25
+ this.enableRowSelection = true;
26
+ /**
27
+ * Wether to enable row clicking
28
+ */
29
+ this.enableRowClick = true;
30
+ /**
31
+ * The current selection of items
32
+ */
33
+ this.selectedRows = [];
34
+ /**
35
+ * Event whenever the current selection changes
36
+ */
37
+ this.selectedRowsChange = new EventEmitter();
38
+ /**
39
+ * Event whenever a row is clicked
40
+ */
41
+ this.rowClick = new EventEmitter();
42
+ /**
43
+ * Event whenever a row is selected
44
+ */
45
+ this.rowSelected = new EventEmitter();
46
+ /**
47
+ * Event whenever a row is deselected
48
+ */
49
+ this.rowDeselected = new EventEmitter();
50
+ /** START HEADER */
51
+ /**
52
+ * Quick filters to show
53
+ */
54
+ this.quickFilters = [];
55
+ /**
56
+ * Wether to show the search input
57
+ */
58
+ this.enableSearch = true;
59
+ /**
60
+ * Wether to show the filter button
61
+ */
62
+ this.enableFilter = true;
63
+ /**
64
+ * Wether to show the edit button
65
+ */
66
+ this.enableEdit = true;
67
+ /**
68
+ * Event when one of the quick filters is clicked
69
+ */
70
+ this.quickFilter = new EventEmitter();
71
+ /**
72
+ * Event when the query changes
73
+ */
74
+ this.queryChange = new EventEmitter();
75
+ /**
76
+ * Event when the filter button is clicked
77
+ */
78
+ this.filter = new EventEmitter();
79
+ /**
80
+ * Event when the edit button is clicked
81
+ */
82
+ this.edit = new EventEmitter();
83
+ /** START FOOTER */
84
+ /**
85
+ * Wether to enable page size select
86
+ */
87
+ this.enablePageSize = true;
88
+ /**
89
+ * Wether to enable pagination
90
+ */
91
+ this.enablePagination = true;
92
+ /**
93
+ * Wether to enable export
94
+ */
95
+ this.enableExport = true;
96
+ /**
97
+ * The current page
98
+ */
99
+ this.page = 1;
100
+ /**
101
+ * Event whenever the page changes
102
+ */
103
+ this.pageChange = new EventEmitter();
104
+ /**
105
+ * The amount of items per page
106
+ */
107
+ this.pageSize = defaultSize;
108
+ /**
109
+ * The options for the page size
110
+ */
111
+ this.pageSizeOptions = defaultSizeOptions;
112
+ /**
113
+ * Event whenever the page changes
114
+ */
115
+ this.pageSizeChange = new EventEmitter();
116
+ /**
117
+ * Event whenever the page changes
118
+ */
119
+ this.export = new EventEmitter();
120
+ /**
121
+ * Wether to hide when there is only 1 page available
122
+ */
123
+ this.hideOnSinglePage = true;
124
+ this.columns = [];
125
+ this.parsedItems = [];
126
+ this.loadingRows = Array.from({
127
+ length: this.amountOfLoadingRows,
128
+ });
129
+ this._ctrlDown = false;
130
+ }
131
+ set columnDefinitions(v) {
132
+ this._columnDefinitions = v;
133
+ this._generateColumns();
134
+ }
135
+ get columnDefinitions() {
136
+ return this._columnDefinitions;
137
+ }
138
+ ngOnInit() {
139
+ this._parseItems(this.items);
140
+ // this._generateColumns();
141
+ }
142
+ ngOnChanges(changes) {
143
+ if (changes['items']) {
144
+ this._parseItems(changes['items'].currentValue);
145
+ }
146
+ }
147
+ // @HostListener('body:tableDefinitionChanged', { target: 'body' })
148
+ // onTableDefinitionUpdated() {
149
+ // this._generateColumns();
150
+ // }
151
+ keyDown({ key }) {
152
+ if (key !== 'Control' || this._ctrlDown === true) {
153
+ return;
154
+ }
155
+ this._ctrlDown = true;
156
+ }
157
+ keyUp({ key }) {
158
+ if (key !== 'Control' || this._ctrlDown === false) {
159
+ return;
160
+ }
161
+ this._ctrlDown = false;
162
+ }
163
+ visibilityChange() {
164
+ if (document.visibilityState !== 'hidden' || this._ctrlDown === false) {
165
+ return;
166
+ }
167
+ this._ctrlDown = false;
168
+ }
169
+ onQueryChange({ detail }) {
170
+ this.queryChange.emit(detail);
171
+ }
172
+ onQuickFilter({ detail }) {
173
+ this.quickFilter.emit(detail);
174
+ }
175
+ onPageSizeChange({ detail }) {
176
+ this.pageSizeChange.emit(detail);
177
+ }
178
+ onPageChange({ detail }) {
179
+ this.pageChange.emit(detail);
180
+ }
181
+ _parseItems(items) {
182
+ if (!items) {
183
+ this.parsedItems = [];
184
+ return;
185
+ }
186
+ if (Array.isArray(items)) {
187
+ this.parsedItems = items;
188
+ return;
189
+ }
190
+ this.parsedItems = JSON.parse(items);
191
+ }
192
+ _generateColumns() {
193
+ // const definitions =
194
+ // this._el.nativeElement.querySelectorAll('p-table-definition');
195
+ this.columns = Array.from(this._columnDefinitions);
196
+ }
197
+ // private _getHeader() {
198
+ // return (
199
+ // <p-table-row variant="header">
200
+ // {this._columns.map((col: TableDefinition, index) => (
201
+ // <p-table-column
202
+ // definition={col}
203
+ // value={col.name}
204
+ // variant="header"
205
+ // checkbox={this._getCheckbox(index, null, 'header')}
206
+ // index={index}
207
+ // ></p-table-column>
208
+ // ))}
209
+ // </p-table-row>
210
+ // );
211
+ // }
212
+ // private _getRows() {
213
+ // if (this.loading) {
214
+ // return Array.from(
215
+ // {
216
+ // length: this.amountOfLoadingRows,
217
+ // },
218
+ // (_, i) => (
219
+ // <p-table-row
220
+ // enableHover={
221
+ // this.enableRowSelection || this.enableRowClick
222
+ // }
223
+ // >
224
+ // {this._getLoadingColumns(i)}
225
+ // </p-table-row>
226
+ // )
227
+ // );
228
+ // }
229
+ // return this._items.map((item, index) => (
230
+ // <p-table-row
231
+ // enableHover={this.enableRowSelection || this.enableRowClick}
232
+ // onClick={(ev) => this._rowClick(ev, index)}
233
+ // >
234
+ // {this._getRowColumns(item, index)}
235
+ // </p-table-row>
236
+ // ));
237
+ // }
238
+ // private _getRowColumns(item, index) {
239
+ // return this._columns.map((col: TableDefinition, colIndex) => {
240
+ // return (
241
+ // <p-table-column
242
+ // definition={col}
243
+ // item={item}
244
+ // checkbox={this._getCheckbox(colIndex, index)}
245
+ // index={colIndex}
246
+ // rowIndex={index}
247
+ // ></p-table-column>
248
+ // );
249
+ // });
250
+ // }
251
+ // private _getLoadingColumns(index) {
252
+ // return this._columns.map((col: TableDefinition, colIndex) => {
253
+ // return (
254
+ // <p-table-column
255
+ // definition={col}
256
+ // variant="loading"
257
+ // checkbox={this._getCheckbox(colIndex, index, 'loading')}
258
+ // index={colIndex}
259
+ // rowIndex={index}
260
+ // ></p-table-column>
261
+ // );
262
+ // });
263
+ // }
264
+ // private _getCheckbox(
265
+ // index,
266
+ // rowIndex,
267
+ // variant: 'header' | 'default' | 'loading' = 'default'
268
+ // ) {
269
+ // if (!this.enableRowSelection || !this.selectionKey || index !== 0) {
270
+ // return;
271
+ // }
272
+ // if (variant === 'loading') {
273
+ // return <p-loader variant="ghost" class="rounded w-6 h-6" />;
274
+ // }
275
+ // if (variant === 'header') {
276
+ // return (
277
+ // <input
278
+ // class="p-input"
279
+ // type="checkbox"
280
+ // onChange={(ev) => this._selectAllChange(ev)}
281
+ // checked={this._selectionContainsAll()}
282
+ // indeterminate={this._selectionIndeterminate()}
283
+ // />
284
+ // );
285
+ // }
286
+ // const item = this._items[rowIndex];
287
+ // return (
288
+ // <input
289
+ // class="p-input"
290
+ // type="checkbox"
291
+ // onChange={(ev) => this._checkboxChange(ev?.target, rowIndex)}
292
+ // disabled={this.canSelectKey && !item[this.canSelectKey]}
293
+ // checked={this._selectionContains(item, rowIndex)}
294
+ // />
295
+ // );
296
+ // }
297
+ _checkboxDisabled(item) {
298
+ return this.canSelectKey && !item[this.canSelectKey];
299
+ }
300
+ _selectAllChange($event) {
301
+ if (!this.enableRowSelection) {
302
+ return;
303
+ }
304
+ const value = this._getCheckedValue($event.target);
305
+ if (value) {
306
+ const toAdd = [];
307
+ for (let i = 0; i < this.parsedItems.length; i++) {
308
+ const row = this.parsedItems[i];
309
+ if (this.canSelectKey && !row[this.canSelectKey]) {
310
+ continue;
311
+ }
312
+ if (this._selectionContains(row, i)) {
313
+ continue;
314
+ }
315
+ toAdd.push(row);
316
+ this.rowSelected.emit(row);
317
+ }
318
+ this.selectedRows = [...this.selectedRows, ...toAdd];
319
+ this.selectedRowsChange.emit(this.selectedRows);
320
+ return;
321
+ }
322
+ for (let i = 0; i < this.selectedRows.length; i++) {
323
+ const value = this.selectedRows[i];
324
+ const row = this.parsedItems.find((d) => this._getSelectionValue(d, i) ===
325
+ this._getSelectionValue(value, i));
326
+ if (!row) {
327
+ continue;
328
+ }
329
+ this.rowDeselected.emit(row);
330
+ }
331
+ this.selectedRows = [];
332
+ this.selectedRowsChange.emit(this.selectedRows);
333
+ }
334
+ _checkboxChange(target, index) {
335
+ if (!this.enableRowSelection) {
336
+ return;
337
+ }
338
+ const row = this.parsedItems[index];
339
+ if (this.canSelectKey && !row[this.canSelectKey]) {
340
+ target.checked = false;
341
+ return;
342
+ }
343
+ const value = this._getCheckedValue(target);
344
+ if (value) {
345
+ this.selectedRows = [...this.selectedRows, row];
346
+ this.selectedRowsChange.emit(this.selectedRows);
347
+ this.rowSelected.emit(row);
348
+ return;
349
+ }
350
+ const indexOfToRemove = this._selectionContains(row, index, true);
351
+ // we need to do this, because splice does not trigger the selection setter.
352
+ const selection = [...this.selectedRows];
353
+ selection.splice(indexOfToRemove, 1);
354
+ this.selectedRows = selection;
355
+ this.selectedRowsChange.emit(this.selectedRows);
356
+ this.rowDeselected.emit(row);
357
+ }
358
+ _getCheckedValue(target) {
359
+ return target?.checked;
360
+ }
361
+ _getSelectionValue(row, index) {
362
+ return this.selectionKey ? row?.[this.selectionKey] || index : index;
363
+ }
364
+ _selectionContains(row, index, returnIndex = false) {
365
+ const returnValue = this.selectedRows.findIndex((item) => this._getSelectionValue(row, index) ===
366
+ this._getSelectionValue(item, index));
367
+ return !returnIndex ? returnValue >= 0 : returnValue;
368
+ }
369
+ _selectionContainsAll() {
370
+ let returnValue = true;
371
+ if (!this.parsedItems?.length) {
372
+ return false;
373
+ }
374
+ for (let i = 0; i < this.parsedItems?.length; i++) {
375
+ const item = this.parsedItems[i];
376
+ const contains = this._selectionContains(item, i);
377
+ if (!contains) {
378
+ returnValue = false;
379
+ break;
380
+ }
381
+ }
382
+ return returnValue;
383
+ }
384
+ _selectionIndeterminate() {
385
+ if (!this.parsedItems?.length || !this.selectedRows?.length) {
386
+ return false;
387
+ }
388
+ let containsCount = 0;
389
+ for (let i = 0; i < this.parsedItems?.length; i++) {
390
+ const item = this.parsedItems[i];
391
+ const contains = this._selectionContains(item, i);
392
+ if (contains) {
393
+ containsCount++;
394
+ }
395
+ }
396
+ return containsCount > 0 && containsCount !== this.parsedItems.length;
397
+ }
398
+ _rowClick($event, index) {
399
+ const target = $event.target;
400
+ if (target.tagName.toLowerCase() === 'input' ||
401
+ target.type === 'checkbox') {
402
+ return;
403
+ }
404
+ const row = this._findRow($event.target);
405
+ if (this.enableRowClick) {
406
+ const action = this._findRowAction($event.target);
407
+ if (action) {
408
+ return;
409
+ }
410
+ const item = this.parsedItems[index];
411
+ this.rowClick.emit({
412
+ item,
413
+ ctrlDown: this._ctrlDown,
414
+ });
415
+ return;
416
+ }
417
+ if (!this.enableRowSelection) {
418
+ return;
419
+ }
420
+ const checkbox = row?.querySelector('input[type="checkbox"]');
421
+ if (!checkbox) {
422
+ return;
423
+ }
424
+ checkbox.checked = !checkbox.checked;
425
+ this._checkboxChange(checkbox, index);
426
+ }
427
+ _findRow(el) {
428
+ if (!el) {
429
+ return el;
430
+ }
431
+ if (el?.tagName?.toLowerCase() === 'p-table-row') {
432
+ return el;
433
+ }
434
+ return this._findRow(el?.parentElement);
435
+ }
436
+ _findRowAction(el) {
437
+ if (!el) {
438
+ return null;
439
+ }
440
+ if (el.getAttribute('data-is-action') !== null &&
441
+ el.getAttribute('data-is-action') !== 'false') {
442
+ return el;
443
+ }
444
+ if (el?.tagName?.toLowerCase() === 'p-table-row') {
445
+ return null;
446
+ }
447
+ return this._findRowAction(el?.parentElement);
448
+ }
449
+ };
450
+ Table.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.9", ngImport: i0, type: Table, deps: [], target: i0.ɵɵFactoryTarget.Component });
451
+ Table.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.9", type: Table, selector: "p-table-ngx", inputs: { items: "items", loading: "loading", amountOfLoadingRows: "amountOfLoadingRows", enableRowSelection: "enableRowSelection", enableRowClick: "enableRowClick", selectedRows: "selectedRows", selectionKey: "selectionKey", canSelectKey: "canSelectKey", quickFilters: "quickFilters", activeQuickFilterIdentifier: "activeQuickFilterIdentifier", enableSearch: "enableSearch", query: "query", enableFilter: "enableFilter", selectedFiltersAmount: "selectedFiltersAmount", filterButtonTemplate: "filterButtonTemplate", enableEdit: "enableEdit", editButtonTemplate: "editButtonTemplate", enablePageSize: "enablePageSize", enablePagination: "enablePagination", enableExport: "enableExport", page: "page", total: "total", pageSize: "pageSize", pageSizeOptions: "pageSizeOptions", hideOnSinglePage: "hideOnSinglePage" }, outputs: { selectedRowsChange: "selectedRowsChange", rowClick: "rowClick", rowSelected: "rowSelected", rowDeselected: "rowDeselected", quickFilter: "quickFilter", queryChange: "queryChange", filter: "filter", edit: "edit", pageChange: "pageChange", pageSizeChange: "pageSizeChange", export: "export" }, host: { listeners: { "document:keydown": "keyDown($event)", "document:keyup": "keyUp($event)", "document:visibilitychange": "visibilityChange($event)" } }, queries: [{ propertyName: "columnDefinitions", predicate: TableColumn }], usesOnChanges: true, ngImport: i0, template: "<p-table-container>\n <p-table-header\n [quickFilters]=\"quickFilters\"\n [activeQuickFilterIdentifier]=\"activeQuickFilterIdentifier\"\n (onQuickFilter)=\"(onQuickFilter)\"\n [enableSearch]=\"enableSearch\"\n [query]=\"query\"\n (onQueryChange)=\"(onQueryChange)\"\n [enableFilter]=\"enableFilter\"\n [selectedFiltersAmount]=\"selectedFiltersAmount\"\n [filterButtonTemplate]=\"filterButtonTemplate\"\n (onFilter)=\"filter.emit()\"\n [enableEdit]=\"enableEdit\"\n [canEdit]=\"!!selectedRows.length\"\n [editButtonTemplate]=\"editButtonTemplate\"\n (onEdit)=\"edit.emit()\"\n [itemsSelectedAmount]=\"selectedRows.length\"\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 && 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 && 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=\"rounded w-6 h-6\"\n ></p-loader>\n </ng-template>\n </ng-container>\n </p-table-row>\n </ng-container>\n\n <ng-template #contentTemplate>\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 *ngFor=\"let col of columns; let index = index\">\n <p-table-cell-ngx\n [definition]=\"col\"\n [item]=\"item\"\n [checkbox]=\"\n index === 0 && 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)=\"_checkboxChange($event.target, rowIndex)\"\n [disabled]=\"_checkboxDisabled(item)\"\n [checked]=\"_selectionContains(item, rowIndex)\"\n />\n </ng-template>\n </ng-container>\n </p-table-row>\n </ng-template>\n </div>\n\n <p-table-footer\n [hideOnSinglePage]=\"hideOnSinglePage\"\n [enablePageSize]=\"enablePageSize\"\n [pageSize]=\"pageSize\"\n [pageSizeOptions]=\"pageSizeOptions\"\n (onPageSizeChange)=\"(pageSizeChange)\"\n [enablePagination]=\"enablePagination\"\n [page]=\"page\"\n [total]=\"total\"\n (onPageChange)=\"(pageChange)\"\n [enableExport]=\"enableExport\"\n (onExport)=\"export.emit()\"\n ></p-table-footer>\n</p-table-container>\n", styles: [":host{display:flex;flex-direction:column}\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: "component", type: i2.PLoader, selector: "p-loader", inputs: ["color", "modalDescription", "modalTitle", "show", "variant"] }, { kind: "component", type: i2.PTableContainer, selector: "p-table-container" }, { kind: "component", type: i2.PTableFooter, selector: "p-table-footer", inputs: ["enableExport", "enablePageSize", "enablePagination", "hideOnSinglePage", "page", "pageSize", "pageSizeOptions", "total"] }, { kind: "component", type: i2.PTableHeader, selector: "p-table-header", inputs: ["activeQuickFilterIdentifier", "canEdit", "editButtonTemplate", "enableEdit", "enableFilter", "enableSearch", "filterButtonTemplate", "itemsSelectedAmount", "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" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
452
+ Table = __decorate([
453
+ UntilDestroy({ checkProperties: true })
454
+ ], Table);
455
+ export { Table };
456
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.9", ngImport: i0, type: Table, decorators: [{
457
+ type: Component,
458
+ args: [{ selector: 'p-table-ngx', changeDetection: ChangeDetectionStrategy.OnPush, template: "<p-table-container>\n <p-table-header\n [quickFilters]=\"quickFilters\"\n [activeQuickFilterIdentifier]=\"activeQuickFilterIdentifier\"\n (onQuickFilter)=\"(onQuickFilter)\"\n [enableSearch]=\"enableSearch\"\n [query]=\"query\"\n (onQueryChange)=\"(onQueryChange)\"\n [enableFilter]=\"enableFilter\"\n [selectedFiltersAmount]=\"selectedFiltersAmount\"\n [filterButtonTemplate]=\"filterButtonTemplate\"\n (onFilter)=\"filter.emit()\"\n [enableEdit]=\"enableEdit\"\n [canEdit]=\"!!selectedRows.length\"\n [editButtonTemplate]=\"editButtonTemplate\"\n (onEdit)=\"edit.emit()\"\n [itemsSelectedAmount]=\"selectedRows.length\"\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 && 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 && 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=\"rounded w-6 h-6\"\n ></p-loader>\n </ng-template>\n </ng-container>\n </p-table-row>\n </ng-container>\n\n <ng-template #contentTemplate>\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 *ngFor=\"let col of columns; let index = index\">\n <p-table-cell-ngx\n [definition]=\"col\"\n [item]=\"item\"\n [checkbox]=\"\n index === 0 && 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)=\"_checkboxChange($event.target, rowIndex)\"\n [disabled]=\"_checkboxDisabled(item)\"\n [checked]=\"_selectionContains(item, rowIndex)\"\n />\n </ng-template>\n </ng-container>\n </p-table-row>\n </ng-template>\n </div>\n\n <p-table-footer\n [hideOnSinglePage]=\"hideOnSinglePage\"\n [enablePageSize]=\"enablePageSize\"\n [pageSize]=\"pageSize\"\n [pageSizeOptions]=\"pageSizeOptions\"\n (onPageSizeChange)=\"(pageSizeChange)\"\n [enablePagination]=\"enablePagination\"\n [page]=\"page\"\n [total]=\"total\"\n (onPageChange)=\"(pageChange)\"\n [enableExport]=\"enableExport\"\n (onExport)=\"export.emit()\"\n ></p-table-footer>\n</p-table-container>\n", styles: [":host{display:flex;flex-direction:column}\n"] }]
459
+ }], ctorParameters: function () { return []; }, propDecorators: { items: [{
460
+ type: Input
461
+ }], loading: [{
462
+ type: Input
463
+ }], amountOfLoadingRows: [{
464
+ type: Input
465
+ }], enableRowSelection: [{
466
+ type: Input
467
+ }], enableRowClick: [{
468
+ type: Input
469
+ }], selectedRows: [{
470
+ type: Input
471
+ }], selectedRowsChange: [{
472
+ type: Output
473
+ }], selectionKey: [{
474
+ type: Input
475
+ }], canSelectKey: [{
476
+ type: Input
477
+ }], rowClick: [{
478
+ type: Output
479
+ }], rowSelected: [{
480
+ type: Output
481
+ }], rowDeselected: [{
482
+ type: Output
483
+ }], quickFilters: [{
484
+ type: Input
485
+ }], activeQuickFilterIdentifier: [{
486
+ type: Input
487
+ }], enableSearch: [{
488
+ type: Input
489
+ }], query: [{
490
+ type: Input
491
+ }], enableFilter: [{
492
+ type: Input
493
+ }], selectedFiltersAmount: [{
494
+ type: Input
495
+ }], filterButtonTemplate: [{
496
+ type: Input
497
+ }], enableEdit: [{
498
+ type: Input
499
+ }], editButtonTemplate: [{
500
+ type: Input
501
+ }], quickFilter: [{
502
+ type: Output
503
+ }], queryChange: [{
504
+ type: Output
505
+ }], filter: [{
506
+ type: Output
507
+ }], edit: [{
508
+ type: Output
509
+ }], enablePageSize: [{
510
+ type: Input
511
+ }], enablePagination: [{
512
+ type: Input
513
+ }], enableExport: [{
514
+ type: Input
515
+ }], page: [{
516
+ type: Input
517
+ }], total: [{
518
+ type: Input
519
+ }], pageChange: [{
520
+ type: Output
521
+ }], pageSize: [{
522
+ type: Input
523
+ }], pageSizeOptions: [{
524
+ type: Input
525
+ }], pageSizeChange: [{
526
+ type: Output
527
+ }], export: [{
528
+ type: Output
529
+ }], hideOnSinglePage: [{
530
+ type: Input
531
+ }], columnDefinitions: [{
532
+ type: ContentChildren,
533
+ args: [TableColumn]
534
+ }], keyDown: [{
535
+ type: HostListener,
536
+ args: ['document:keydown', ['$event']]
537
+ }], keyUp: [{
538
+ type: HostListener,
539
+ args: ['document:keyup', ['$event']]
540
+ }], visibilityChange: [{
541
+ type: HostListener,
542
+ args: ['document:visibilitychange', ['$event']]
543
+ }] } });
544
+ //# 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":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    EventEmitter,\n    HostListener,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    QueryList,\n    SimpleChanges,\n} from '@angular/core';\nimport { UntilDestroy } from '@ngneat/until-destroy';\nimport { QuickFilter, RowClickEvent } from '@paperless/core';\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     * The amount of loading rows to show\n     */\n    @Input() amountOfLoadingRows: number = 4;\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     * 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     * 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 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    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    // 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    constructor() {}\n\n    ngOnInit() {\n        this._parseItems(this.items);\n        // this._generateColumns();\n    }\n\n    ngOnChanges(changes: SimpleChanges) {\n        if (changes['items']) {\n            this._parseItems(changes['items'].currentValue);\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 }: CustomEvent<string>) {\n        this.queryChange.emit(detail);\n    }\n\n    onQuickFilter({ detail }: CustomEvent<any>) {\n        this.quickFilter.emit(detail);\n    }\n\n    onPageSizeChange({ detail }: CustomEvent<number>) {\n        this.pageSizeChange.emit(detail);\n    }\n\n    onPageChange({ detail }: CustomEvent<number>) {\n        this.pageChange.emit(detail);\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        this.columns = Array.from(this._columnDefinitions);\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: { target: any }, index: number) {\n        const target = $event.target;\n\n        if (\n            target.tagName.toLowerCase() === 'input' ||\n            target.type === 'checkbox'\n        ) {\n            return;\n        }\n\n        const row = this._findRow($event.target);\n\n        if (this.enableRowClick) {\n            const action = this._findRowAction($event.target);\n\n            if (action) {\n                return;\n            }\n\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        [quickFilters]=\"quickFilters\"\n        [activeQuickFilterIdentifier]=\"activeQuickFilterIdentifier\"\n        (onQuickFilter)=\"(onQuickFilter)\"\n        [enableSearch]=\"enableSearch\"\n        [query]=\"query\"\n        (onQueryChange)=\"(onQueryChange)\"\n        [enableFilter]=\"enableFilter\"\n        [selectedFiltersAmount]=\"selectedFiltersAmount\"\n        [filterButtonTemplate]=\"filterButtonTemplate\"\n        (onFilter)=\"filter.emit()\"\n        [enableEdit]=\"enableEdit\"\n        [canEdit]=\"!!selectedRows.length\"\n        [editButtonTemplate]=\"editButtonTemplate\"\n        (onEdit)=\"edit.emit()\"\n        [itemsSelectedAmount]=\"selectedRows.length\"\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 && 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 && 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=\"rounded w-6 h-6\"\n                        ></p-loader>\n                    </ng-template>\n                </ng-container>\n            </p-table-row>\n        </ng-container>\n\n        <ng-template #contentTemplate>\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 *ngFor=\"let col of columns; let index = index\">\n                    <p-table-cell-ngx\n                        [definition]=\"col\"\n                        [item]=\"item\"\n                        [checkbox]=\"\n                            index === 0 && 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)=\"_checkboxChange($event.target, rowIndex)\"\n                            [disabled]=\"_checkboxDisabled(item)\"\n                            [checked]=\"_selectionContains(item, rowIndex)\"\n                        />\n                    </ng-template>\n                </ng-container>\n            </p-table-row>\n        </ng-template>\n    </div>\n\n    <p-table-footer\n        [hideOnSinglePage]=\"hideOnSinglePage\"\n        [enablePageSize]=\"enablePageSize\"\n        [pageSize]=\"pageSize\"\n        [pageSizeOptions]=\"pageSizeOptions\"\n        (onPageSizeChange)=\"(pageSizeChange)\"\n        [enablePagination]=\"enablePagination\"\n        [page]=\"page\"\n        [total]=\"total\"\n        (onPageChange)=\"(pageChange)\"\n        [enableExport]=\"enableExport\"\n        (onExport)=\"export.emit()\"\n    ></p-table-footer>\n</p-table-container>\n"]}