ngx-material-entity 15.3.1 → 16.0.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/classes/entity.model.d.ts +2 -2
- package/components/confirm-dialog/confirm-dialog-data.d.ts +1 -1
- package/components/edit-page/edit-page.component.d.ts +1 -1
- package/components/edit-page/page-edit-data.builder.d.ts +1 -1
- package/components/input/array/array-string-chips-input/array-string-chips-input.component.d.ts +1 -0
- package/components/input/array/array-table.class.d.ts +1 -1
- package/components/input/base-input.component.d.ts +5 -1
- package/components/input/boolean/boolean-checkbox-input/boolean-checkbox-input.component.d.ts +1 -1
- package/components/input/boolean/boolean-dropdown-input/boolean-dropdown-input.component.d.ts +1 -1
- package/components/input/file/file-input/file-input.component.d.ts +1 -1
- package/components/input/input.component.d.ts +2 -1
- package/components/table/display-column-value/base-display-column-value.component.d.ts +1 -1
- package/components/table/display-column-value/display-column-value.component.d.ts +1 -1
- package/components/table/table-data.builder.d.ts +1 -1
- package/components/table/table-data.d.ts +1 -1
- package/components/table/table.component.d.ts +1 -1
- package/decorators/base/decorator-types.enum.d.ts +1 -1
- package/decorators/base/property-decorator.data.d.ts +1 -1
- package/decorators/file/file-decorator.data.d.ts +1 -1
- package/decorators/number/number-decorator.data.d.ts +1 -1
- package/decorators/string/string-decorator.data.d.ts +1 -1
- package/encapsulation/jszip.utilities.d.ts +1 -1
- package/encapsulation/uuid.utilities.d.ts +11 -0
- package/esm2022/classes/base.builder.mjs +44 -0
- package/esm2022/classes/entity.model.mjs +26 -0
- package/esm2022/components/confirm-dialog/confirm-dialog-data.builder.mjs +58 -0
- package/esm2022/components/confirm-dialog/confirm-dialog.component.mjs +60 -0
- package/esm2022/components/edit-page/edit-page.component.mjs +291 -0
- package/esm2022/components/input/array/array-date-input/array-date-input.component.mjs +23 -0
- package/esm2022/components/input/array/array-date-range-input/array-date-range-input.component.mjs +49 -0
- package/esm2022/components/input/array/array-date-time-input/array-date-time-input.component.mjs +49 -0
- package/esm2022/components/input/array/array-string-autocomplete-chips/array-string-autocomplete-chips.component.mjs +50 -0
- package/esm2022/components/input/array/array-string-chips-input/array-string-chips-input.component.mjs +69 -0
- package/esm2022/components/input/array/array-table.class.mjs +100 -0
- package/esm2022/components/input/base-input.component.mjs +88 -0
- package/esm2022/components/input/boolean/boolean-checkbox-input/boolean-checkbox-input.component.mjs +21 -0
- package/esm2022/components/input/boolean/boolean-dropdown-input/boolean-dropdown-input.component.mjs +17 -0
- package/esm2022/components/input/boolean/boolean-toggle-input/boolean-toggle-input.component.mjs +21 -0
- package/esm2022/components/input/custom/custom.component.mjs +28 -0
- package/esm2022/components/input/date/date-input/date-input.component.mjs +19 -0
- package/esm2022/components/input/date/date-range-input/date-range-input.component.mjs +68 -0
- package/esm2022/components/input/date/date-time-input/date-time-input.component.mjs +69 -0
- package/{esm2020 → esm2022}/components/input/file/file-default-input/file-default-input.component.mjs +4 -4
- package/esm2022/components/input/file/file-image-input/file-image-input.component.mjs +101 -0
- package/esm2022/components/input/file/file-input/dragDrop.directive.mjs +62 -0
- package/esm2022/components/input/file/file-input/file-input.component.mjs +206 -0
- package/esm2022/components/input/input.component.mjs +849 -0
- package/esm2022/components/input/input.module.mjs +172 -0
- package/esm2022/components/input/number/number-dropdown-input/number-dropdown-input.component.mjs +23 -0
- package/esm2022/components/input/number/number-input/number-input.component.mjs +16 -0
- package/esm2022/components/input/number/number-slider-input/number-slider-input.component.mjs +17 -0
- package/esm2022/components/input/relations/references-many-input/references-many-input.component.mjs +102 -0
- package/esm2022/components/input/string/string-autocomplete-input/string-autocomplete-input.component.mjs +36 -0
- package/esm2022/components/input/string/string-dropdown-input/string-dropdown-input.component.mjs +23 -0
- package/esm2022/components/input/string/string-input/string-input.component.mjs +16 -0
- package/esm2022/components/input/string/string-password-input/string-password-input.component.mjs +39 -0
- package/esm2022/components/input/string/string-textbox-input/string-textbox-input.component.mjs +17 -0
- package/esm2022/components/table/create-dialog/create-dialog-data.builder.mjs +42 -0
- package/esm2022/components/table/create-dialog/create-entity-dialog-data.builder.mjs +32 -0
- package/esm2022/components/table/create-dialog/create-entity-dialog.component.mjs +107 -0
- package/esm2022/components/table/display-column-value/base-display-column-value.component.mjs +28 -0
- package/esm2022/components/table/display-column-value/display-column-value.component.mjs +37 -0
- package/esm2022/components/table/edit-dialog/edit-data.builder.mjs +106 -0
- package/esm2022/components/table/edit-dialog/edit-entity-dialog.component.mjs +209 -0
- package/esm2022/components/table/edit-dialog/edit-entity.builder.mjs +39 -0
- package/esm2022/components/table/table-data.builder.mjs +269 -0
- package/esm2022/components/table/table.component.mjs +348 -0
- package/esm2022/decorators/array/array-decorator-internal.data.mjs +286 -0
- package/esm2022/decorators/array/array-decorator.data.mjs +21 -0
- package/esm2022/decorators/base/property-decorator-internal.data.mjs +82 -0
- package/esm2022/decorators/base/property-decorator.data.mjs +56 -0
- package/esm2022/decorators/boolean/boolean-decorator-internal.data.mjs +43 -0
- package/esm2022/decorators/boolean/boolean-decorator.data.mjs +11 -0
- package/esm2022/decorators/custom/custom-decorator-internal.data.mjs +35 -0
- package/{esm2020 → esm2022}/decorators/date/date-decorator-internal.data.mjs +43 -1
- package/esm2022/decorators/date/date-decorator.data.mjs +11 -0
- package/esm2022/decorators/file/file-decorator-internal.data.mjs +143 -0
- package/esm2022/decorators/file/file-decorator.data.mjs +64 -0
- package/esm2022/decorators/has-many/has-many-decorator-internal.data.mjs +42 -0
- package/esm2022/decorators/number/number-decorator-internal.data.mjs +76 -0
- package/esm2022/decorators/number/number-decorator.data.mjs +11 -0
- package/esm2022/decorators/object/object-decorator-internal.data.mjs +20 -0
- package/esm2022/decorators/object/object-decorator.data.mjs +22 -0
- package/esm2022/decorators/references-many/references-many-decorator-internal.data.mjs +48 -0
- package/esm2022/decorators/references-one/references-one-decorator-internal.data.mjs +24 -0
- package/esm2022/decorators/string/string-decorator-internal.data.mjs +114 -0
- package/esm2022/decorators/string/string-decorator.data.mjs +11 -0
- package/esm2022/encapsulation/uuid.utilities.mjs +15 -0
- package/esm2022/services/entity.service.mjs +276 -0
- package/esm2022/utilities/date.utilities.mjs +159 -0
- package/esm2022/utilities/entity.utilities.mjs +905 -0
- package/{fesm2020 → fesm2022}/ngx-material-entity.mjs +1225 -376
- package/fesm2022/ngx-material-entity.mjs.map +1 -0
- package/package.json +11 -17
- package/utilities/date.utilities.d.ts +1 -1
- package/esm2020/classes/base.builder.mjs +0 -42
- package/esm2020/classes/entity.model.mjs +0 -22
- package/esm2020/components/confirm-dialog/confirm-dialog-data.builder.mjs +0 -44
- package/esm2020/components/confirm-dialog/confirm-dialog.component.mjs +0 -57
- package/esm2020/components/edit-page/edit-page.component.mjs +0 -277
- package/esm2020/components/input/array/array-date-input/array-date-input.component.mjs +0 -26
- package/esm2020/components/input/array/array-date-range-input/array-date-range-input.component.mjs +0 -50
- package/esm2020/components/input/array/array-date-time-input/array-date-time-input.component.mjs +0 -49
- package/esm2020/components/input/array/array-string-autocomplete-chips/array-string-autocomplete-chips.component.mjs +0 -49
- package/esm2020/components/input/array/array-string-chips-input/array-string-chips-input.component.mjs +0 -70
- package/esm2020/components/input/array/array-table.class.mjs +0 -96
- package/esm2020/components/input/base-input.component.mjs +0 -64
- package/esm2020/components/input/boolean/boolean-checkbox-input/boolean-checkbox-input.component.mjs +0 -21
- package/esm2020/components/input/boolean/boolean-dropdown-input/boolean-dropdown-input.component.mjs +0 -17
- package/esm2020/components/input/boolean/boolean-toggle-input/boolean-toggle-input.component.mjs +0 -21
- package/esm2020/components/input/custom/custom.component.mjs +0 -26
- package/esm2020/components/input/date/date-input/date-input.component.mjs +0 -22
- package/esm2020/components/input/date/date-range-input/date-range-input.component.mjs +0 -71
- package/esm2020/components/input/date/date-time-input/date-time-input.component.mjs +0 -71
- package/esm2020/components/input/file/file-image-input/file-image-input.component.mjs +0 -100
- package/esm2020/components/input/file/file-input/dragDrop.directive.mjs +0 -63
- package/esm2020/components/input/file/file-input/file-input.component.mjs +0 -198
- package/esm2020/components/input/input.component.mjs +0 -755
- package/esm2020/components/input/input.module.mjs +0 -173
- package/esm2020/components/input/number/number-dropdown-input/number-dropdown-input.component.mjs +0 -26
- package/esm2020/components/input/number/number-input/number-input.component.mjs +0 -16
- package/esm2020/components/input/number/number-slider-input/number-slider-input.component.mjs +0 -17
- package/esm2020/components/input/relations/references-many-input/references-many-input.component.mjs +0 -100
- package/esm2020/components/input/string/string-autocomplete-input/string-autocomplete-input.component.mjs +0 -34
- package/esm2020/components/input/string/string-dropdown-input/string-dropdown-input.component.mjs +0 -26
- package/esm2020/components/input/string/string-input/string-input.component.mjs +0 -16
- package/esm2020/components/input/string/string-password-input/string-password-input.component.mjs +0 -42
- package/esm2020/components/input/string/string-textbox-input/string-textbox-input.component.mjs +0 -17
- package/esm2020/components/table/create-dialog/create-dialog-data.builder.mjs +0 -32
- package/esm2020/components/table/create-dialog/create-entity-dialog-data.builder.mjs +0 -26
- package/esm2020/components/table/create-dialog/create-entity-dialog.component.mjs +0 -100
- package/esm2020/components/table/display-column-value/base-display-column-value.component.mjs +0 -27
- package/esm2020/components/table/display-column-value/display-column-value.component.mjs +0 -33
- package/esm2020/components/table/edit-dialog/edit-data.builder.mjs +0 -76
- package/esm2020/components/table/edit-dialog/edit-entity-dialog.component.mjs +0 -198
- package/esm2020/components/table/edit-dialog/edit-entity.builder.mjs +0 -29
- package/esm2020/components/table/table-data.builder.mjs +0 -205
- package/esm2020/components/table/table.component.mjs +0 -333
- package/esm2020/decorators/array/array-decorator-internal.data.mjs +0 -150
- package/esm2020/decorators/array/array-decorator.data.mjs +0 -7
- package/esm2020/decorators/base/property-decorator-internal.data.mjs +0 -58
- package/esm2020/decorators/base/property-decorator.data.mjs +0 -6
- package/esm2020/decorators/boolean/boolean-decorator-internal.data.mjs +0 -33
- package/esm2020/decorators/boolean/boolean-decorator.data.mjs +0 -7
- package/esm2020/decorators/custom/custom-decorator-internal.data.mjs +0 -27
- package/esm2020/decorators/date/date-decorator.data.mjs +0 -7
- package/esm2020/decorators/file/file-decorator-internal.data.mjs +0 -97
- package/esm2020/decorators/file/file-decorator.data.mjs +0 -7
- package/esm2020/decorators/has-many/has-many-decorator-internal.data.mjs +0 -32
- package/esm2020/decorators/number/number-decorator-internal.data.mjs +0 -54
- package/esm2020/decorators/number/number-decorator.data.mjs +0 -7
- package/esm2020/decorators/object/object-decorator-internal.data.mjs +0 -14
- package/esm2020/decorators/object/object-decorator.data.mjs +0 -7
- package/esm2020/decorators/references-many/references-many-decorator-internal.data.mjs +0 -30
- package/esm2020/decorators/references-one/references-one-decorator-internal.data.mjs +0 -16
- package/esm2020/decorators/string/string-decorator-internal.data.mjs +0 -72
- package/esm2020/decorators/string/string-decorator.data.mjs +0 -7
- package/esm2020/services/entity.service.mjs +0 -274
- package/esm2020/utilities/date.utilities.mjs +0 -159
- package/esm2020/utilities/entity.utilities.mjs +0 -905
- package/fesm2015/ngx-material-entity.mjs +0 -6322
- package/fesm2015/ngx-material-entity.mjs.map +0 -1
- package/fesm2020/ngx-material-entity.mjs.map +0 -1
- /package/{esm2020 → esm2022}/components/confirm-dialog/confirm-dialog-data.mjs +0 -0
- /package/{esm2020 → esm2022}/components/edit-page/edit-data.route.mjs +0 -0
- /package/{esm2020 → esm2022}/components/edit-page/page-edit-data.builder.mjs +0 -0
- /package/{esm2020 → esm2022}/components/get-validation-error-message.function.mjs +0 -0
- /package/{esm2020 → esm2022}/components/table/create-dialog/create-entity-dialog-data.mjs +0 -0
- /package/{esm2020 → esm2022}/components/table/default.actions.mjs +0 -0
- /package/{esm2020 → esm2022}/components/table/edit-dialog/edit-entity-data.mjs +0 -0
- /package/{esm2020 → esm2022}/components/table/table-data.mjs +0 -0
- /package/{esm2020 → esm2022}/decorators/array/array.decorator.mjs +0 -0
- /package/{esm2020 → esm2022}/decorators/base/base-property.decorator.mjs +0 -0
- /package/{esm2020 → esm2022}/decorators/base/decorator-types.enum.mjs +0 -0
- /package/{esm2020 → esm2022}/decorators/base/dropdown-value.interface.mjs +0 -0
- /package/{esm2020 → esm2022}/decorators/boolean/boolean.decorator.mjs +0 -0
- /package/{esm2020 → esm2022}/decorators/custom/custom-decorator.data.mjs +0 -0
- /package/{esm2020 → esm2022}/decorators/custom/custom.decorator.mjs +0 -0
- /package/{esm2020 → esm2022}/decorators/date/date.decorator.mjs +0 -0
- /package/{esm2020 → esm2022}/decorators/file/file.decorator.mjs +0 -0
- /package/{esm2020 → esm2022}/decorators/has-many/has-many-decorator.data.mjs +0 -0
- /package/{esm2020 → esm2022}/decorators/has-many/has-many.decorator.mjs +0 -0
- /package/{esm2020 → esm2022}/decorators/number/number.decorator.mjs +0 -0
- /package/{esm2020 → esm2022}/decorators/object/object.decorator.mjs +0 -0
- /package/{esm2020 → esm2022}/decorators/references-many/references-many-decorator.data.mjs +0 -0
- /package/{esm2020 → esm2022}/decorators/references-many/references-many.decorator.mjs +0 -0
- /package/{esm2020 → esm2022}/decorators/references-one/references-one-decorator.data.mjs +0 -0
- /package/{esm2020 → esm2022}/decorators/references-one/references-one.decorator.mjs +0 -0
- /package/{esm2020 → esm2022}/decorators/string/string.decorator.mjs +0 -0
- /package/{esm2020 → esm2022}/encapsulation/js-2-xml.utilities.mjs +0 -0
- /package/{esm2020 → esm2022}/encapsulation/jszip.utilities.mjs +0 -0
- /package/{esm2020 → esm2022}/encapsulation/lodash.utilities.mjs +0 -0
- /package/{esm2020 → esm2022}/encapsulation/reflect.utilities.mjs +0 -0
- /package/{esm2020 → esm2022}/functions/default-false.function.mjs +0 -0
- /package/{esm2020 → esm2022}/functions/default-true.function.mjs +0 -0
- /package/{esm2020 → esm2022}/functions/is-async-function.function.mjs +0 -0
- /package/{esm2020 → esm2022}/mocks/placeholder-data.png.mjs +0 -0
- /package/{esm2020 → esm2022}/ngx-material-entity.mjs +0 -0
- /package/{esm2020 → esm2022}/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/services/unsaved-changes.guard.mjs +0 -0
- /package/{esm2020 → esm2022}/utilities/file.utilities.mjs +0 -0
- /package/{esm2020 → esm2022}/utilities/selection.utilities.mjs +0 -0
|
@@ -0,0 +1,348 @@
|
|
|
1
|
+
import { SelectionModel } from '@angular/cdk/collections';
|
|
2
|
+
import { NgFor, NgIf } from '@angular/common';
|
|
3
|
+
import { Component, EnvironmentInjector, Input, ViewChild, inject } from '@angular/core';
|
|
4
|
+
import { FormsModule } from '@angular/forms';
|
|
5
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
6
|
+
import { MatCheckboxModule } from '@angular/material/checkbox';
|
|
7
|
+
import { MatDialog, MatDialogModule } from '@angular/material/dialog';
|
|
8
|
+
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
9
|
+
import { MatInputModule } from '@angular/material/input';
|
|
10
|
+
import { MatMenuModule } from '@angular/material/menu';
|
|
11
|
+
import { MatPaginator, MatPaginatorModule } from '@angular/material/paginator';
|
|
12
|
+
import { MatProgressSpinnerModule } from '@angular/material/progress-spinner';
|
|
13
|
+
import { MatSort } from '@angular/material/sort';
|
|
14
|
+
import { MatTableDataSource, MatTableModule } from '@angular/material/table';
|
|
15
|
+
import { Router } from '@angular/router';
|
|
16
|
+
import { Subject, firstValueFrom, takeUntil } from 'rxjs';
|
|
17
|
+
import { SelectionUtilities } from '../../utilities/selection.utilities';
|
|
18
|
+
import { ConfirmDialogDataBuilder } from '../confirm-dialog/confirm-dialog-data.builder';
|
|
19
|
+
import { NgxMatEntityConfirmDialogComponent } from '../confirm-dialog/confirm-dialog.component';
|
|
20
|
+
import { CreateEntityDialogDataBuilder } from './create-dialog/create-entity-dialog-data.builder';
|
|
21
|
+
import { NgxMatEntityCreateDialogComponent } from './create-dialog/create-entity-dialog.component';
|
|
22
|
+
import { DisplayColumnValueComponent } from './display-column-value/display-column-value.component';
|
|
23
|
+
import { NgxMatEntityEditDialogComponent } from './edit-dialog/edit-entity-dialog.component';
|
|
24
|
+
import { EditEntityDataBuilder } from './edit-dialog/edit-entity.builder';
|
|
25
|
+
import { BaseTableActionInternal, TableDataBuilder } from './table-data.builder';
|
|
26
|
+
import * as i0 from "@angular/core";
|
|
27
|
+
import * as i1 from "@angular/material/dialog";
|
|
28
|
+
import * as i2 from "@angular/router";
|
|
29
|
+
import * as i3 from "@angular/material/input";
|
|
30
|
+
import * as i4 from "@angular/material/form-field";
|
|
31
|
+
import * as i5 from "@angular/material/checkbox";
|
|
32
|
+
import * as i6 from "@angular/material/table";
|
|
33
|
+
import * as i7 from "@angular/material/paginator";
|
|
34
|
+
import * as i8 from "@angular/material/button";
|
|
35
|
+
import * as i9 from "@angular/material/menu";
|
|
36
|
+
import * as i10 from "@angular/material/progress-spinner";
|
|
37
|
+
/**
|
|
38
|
+
* Generates a fully functional table for displaying, creating, updating and deleting entities
|
|
39
|
+
* based on the configuration passed in the @Input "tableData".
|
|
40
|
+
*
|
|
41
|
+
* It offers a lot of customization options which can be found in "TableData".
|
|
42
|
+
*/
|
|
43
|
+
export class NgxMatEntityTableComponent {
|
|
44
|
+
dialog;
|
|
45
|
+
injector;
|
|
46
|
+
router;
|
|
47
|
+
/**
|
|
48
|
+
* The configuration for the component.
|
|
49
|
+
*/
|
|
50
|
+
tableData;
|
|
51
|
+
data;
|
|
52
|
+
isLoading = true;
|
|
53
|
+
allowCreate;
|
|
54
|
+
entityService;
|
|
55
|
+
onDestroy = new Subject();
|
|
56
|
+
paginator;
|
|
57
|
+
sort;
|
|
58
|
+
filter;
|
|
59
|
+
displayedColumns;
|
|
60
|
+
dataSource = new MatTableDataSource();
|
|
61
|
+
selection = new SelectionModel(true, []);
|
|
62
|
+
SelectionUtilities = SelectionUtilities;
|
|
63
|
+
importAction;
|
|
64
|
+
constructor(dialog, injector, router) {
|
|
65
|
+
this.dialog = dialog;
|
|
66
|
+
this.injector = injector;
|
|
67
|
+
this.router = router;
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* Sets up all the configuration for the table and the EntityService.
|
|
71
|
+
*/
|
|
72
|
+
ngOnInit() {
|
|
73
|
+
this.data = new TableDataBuilder(this.tableData).getResult();
|
|
74
|
+
this.injector.runInContext(() => {
|
|
75
|
+
this.allowCreate = this.data.baseData.allowCreate();
|
|
76
|
+
});
|
|
77
|
+
this.importAction = new BaseTableActionInternal({
|
|
78
|
+
...this.data.baseData.importActionData,
|
|
79
|
+
action: () => this.startImportJson()
|
|
80
|
+
});
|
|
81
|
+
this.injector.runInContext(() => {
|
|
82
|
+
this.entityService = inject(this.data.baseData.EntityServiceClass);
|
|
83
|
+
});
|
|
84
|
+
const givenDisplayColumns = this.data.baseData.displayColumns.map((v) => v.displayName);
|
|
85
|
+
if (this.data.baseData.tableActions.filter(tA => tA.type === 'multi-select').length) {
|
|
86
|
+
this.displayedColumns = ['select'].concat(givenDisplayColumns);
|
|
87
|
+
}
|
|
88
|
+
else {
|
|
89
|
+
this.displayedColumns = givenDisplayColumns;
|
|
90
|
+
}
|
|
91
|
+
this.dataSource.sortingDataAccessor = (entity, header) => {
|
|
92
|
+
return this.injector.runInContext(() => {
|
|
93
|
+
return this.data.baseData.displayColumns.find((dp) => dp.displayName === header)?.value(entity);
|
|
94
|
+
});
|
|
95
|
+
};
|
|
96
|
+
this.dataSource.sort = this.sort;
|
|
97
|
+
this.dataSource.filterPredicate = (entity, filter) => {
|
|
98
|
+
const searchStr = this.data.baseData.searchString(entity);
|
|
99
|
+
const formattedSearchString = searchStr.toLowerCase();
|
|
100
|
+
const formattedFilterString = filter.toLowerCase();
|
|
101
|
+
return formattedSearchString.includes(formattedFilterString);
|
|
102
|
+
};
|
|
103
|
+
this.dataSource.filter = this.filter;
|
|
104
|
+
this.dataSource.paginator = this.paginator;
|
|
105
|
+
this.entityService.entitiesSubject.pipe(takeUntil(this.onDestroy)).subscribe((entities) => {
|
|
106
|
+
this.dataSource.data = entities;
|
|
107
|
+
this.selection.clear();
|
|
108
|
+
});
|
|
109
|
+
void this.entityService.read().then(() => {
|
|
110
|
+
this.isLoading = false;
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
/**
|
|
114
|
+
* Gets the value to display in the column.
|
|
115
|
+
* Runs in environment context to enable injection.
|
|
116
|
+
*
|
|
117
|
+
* @param entity - The entity to get the value from.
|
|
118
|
+
* @param displayColumn - The display column to get the value from.
|
|
119
|
+
* @returns The value of the display column.
|
|
120
|
+
*/
|
|
121
|
+
getDisplayColumnValue(entity, displayColumn) {
|
|
122
|
+
return this.injector.runInContext(() => {
|
|
123
|
+
return displayColumn.value(entity);
|
|
124
|
+
});
|
|
125
|
+
}
|
|
126
|
+
startImportJson() {
|
|
127
|
+
const input = document.createElement('input');
|
|
128
|
+
input.type = 'file';
|
|
129
|
+
input.accept = 'application/json';
|
|
130
|
+
input.onchange = async () => {
|
|
131
|
+
if (input.files) {
|
|
132
|
+
this.importJson(input.files[0]);
|
|
133
|
+
}
|
|
134
|
+
};
|
|
135
|
+
input.click();
|
|
136
|
+
}
|
|
137
|
+
importJson(file) {
|
|
138
|
+
const dialogData = new ConfirmDialogDataBuilder(this.importAction.confirmDialogData)
|
|
139
|
+
.withDefault('text', this.data.baseData.importActionData.confirmDialogData.text)
|
|
140
|
+
.withDefault('title', this.importAction.displayName)
|
|
141
|
+
.getResult();
|
|
142
|
+
const dialogRef = this.dialog.open(NgxMatEntityConfirmDialogComponent, {
|
|
143
|
+
data: dialogData,
|
|
144
|
+
autoFocus: false,
|
|
145
|
+
restoreFocus: false
|
|
146
|
+
});
|
|
147
|
+
dialogRef.afterClosed().subscribe(res => {
|
|
148
|
+
if (res == true) {
|
|
149
|
+
void this.entityService.import(file);
|
|
150
|
+
}
|
|
151
|
+
});
|
|
152
|
+
}
|
|
153
|
+
/**
|
|
154
|
+
* Edits an entity. This either calls the edit-Method provided by the user or uses a default edit-dialog.
|
|
155
|
+
*
|
|
156
|
+
* @param entity - The entity that should be updated.
|
|
157
|
+
* @param dCol - The display column. Is needed if a custom component was used that handles the click event differently.
|
|
158
|
+
* @throws When no EntityClass was provided, as a new call is needed to initialize metadata.
|
|
159
|
+
*/
|
|
160
|
+
editEntity(entity, dCol) {
|
|
161
|
+
if (dCol.disableClick == true) {
|
|
162
|
+
return;
|
|
163
|
+
}
|
|
164
|
+
if (!(this.allowUpdate(entity) || this.allowRead(entity))) {
|
|
165
|
+
return;
|
|
166
|
+
}
|
|
167
|
+
if (!this.data.baseData.EntityClass) {
|
|
168
|
+
throw new Error('No "EntityClass" specified for this table');
|
|
169
|
+
}
|
|
170
|
+
if (this.data.baseData.edit) {
|
|
171
|
+
this.data.baseData.edit(new this.data.baseData.EntityClass(entity));
|
|
172
|
+
return;
|
|
173
|
+
}
|
|
174
|
+
if (this.data.baseData.defaultEdit == 'page') {
|
|
175
|
+
this.editDefaultPage(new this.data.baseData.EntityClass(entity));
|
|
176
|
+
return;
|
|
177
|
+
}
|
|
178
|
+
void this.editDefaultDialog(new this.data.baseData.EntityClass(entity));
|
|
179
|
+
}
|
|
180
|
+
/**
|
|
181
|
+
* Whether updating the provided entity is allowed.
|
|
182
|
+
*
|
|
183
|
+
* @param entity - The entity that the user wants to edit.
|
|
184
|
+
* @returns True when the user can edit the provided entity and false otherwise.
|
|
185
|
+
*/
|
|
186
|
+
allowUpdate(entity) {
|
|
187
|
+
return this.injector.runInContext(() => {
|
|
188
|
+
return this.data.baseData.allowUpdate(entity);
|
|
189
|
+
});
|
|
190
|
+
}
|
|
191
|
+
/**
|
|
192
|
+
* Whether viewing the provided entity is allowed.
|
|
193
|
+
*
|
|
194
|
+
* @param entity - The entity that the user wants to view.
|
|
195
|
+
* @returns True when the user can view the provided entity and false otherwise.
|
|
196
|
+
*/
|
|
197
|
+
allowRead(entity) {
|
|
198
|
+
return this.injector.runInContext(() => {
|
|
199
|
+
return this.data.baseData.allowRead(entity);
|
|
200
|
+
});
|
|
201
|
+
}
|
|
202
|
+
editDefaultPage(entity) {
|
|
203
|
+
void this.router.navigate(['', this.entityService.editBaseRoute, entity.id]);
|
|
204
|
+
}
|
|
205
|
+
async editDefaultDialog(entity) {
|
|
206
|
+
const inputDialogData = {
|
|
207
|
+
entity: entity,
|
|
208
|
+
EntityServiceClass: this.data.baseData.EntityServiceClass,
|
|
209
|
+
allowUpdate: this.data.baseData.allowUpdate,
|
|
210
|
+
allowDelete: this.data.baseData.allowDelete,
|
|
211
|
+
editData: this.data.editData
|
|
212
|
+
};
|
|
213
|
+
const dialogData = new EditEntityDataBuilder(inputDialogData).getResult();
|
|
214
|
+
const res = await firstValueFrom(this.dialog.open(NgxMatEntityEditDialogComponent, {
|
|
215
|
+
data: dialogData,
|
|
216
|
+
minWidth: '60%',
|
|
217
|
+
autoFocus: false,
|
|
218
|
+
restoreFocus: false
|
|
219
|
+
}).afterClosed());
|
|
220
|
+
if (res === 0) {
|
|
221
|
+
const data = this.dataSource.data;
|
|
222
|
+
data[this.dataSource.data.findIndex((e) => e[this.entityService.idKey] === entity[this.entityService.idKey])] = entity;
|
|
223
|
+
this.dataSource.data = data;
|
|
224
|
+
this.selection.clear();
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
/**
|
|
228
|
+
* Creates a new Entity. This either calls the create-Method provided by the user or uses a default create-dialog.
|
|
229
|
+
*
|
|
230
|
+
* @throws When no EntityClass was provided, as a new call is needed to initialize metadata.
|
|
231
|
+
*/
|
|
232
|
+
createEntity() {
|
|
233
|
+
this.injector.runInContext(() => {
|
|
234
|
+
if (this.data.baseData.allowCreate()) {
|
|
235
|
+
if (!this.data.baseData.EntityClass) {
|
|
236
|
+
throw new Error('No "EntityClass" specified for this table');
|
|
237
|
+
}
|
|
238
|
+
if (this.data.baseData.create) {
|
|
239
|
+
this.data.baseData.create(new this.data.baseData.EntityClass());
|
|
240
|
+
}
|
|
241
|
+
else {
|
|
242
|
+
this.createDefault(new this.data.baseData.EntityClass());
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
});
|
|
246
|
+
}
|
|
247
|
+
createDefault(entity) {
|
|
248
|
+
const dialogData = new CreateEntityDialogDataBuilder({
|
|
249
|
+
entity: entity,
|
|
250
|
+
EntityServiceClass: this.data.baseData.EntityServiceClass,
|
|
251
|
+
createDialogData: this.data.createDialogData
|
|
252
|
+
}).getResult();
|
|
253
|
+
this.dialog.open(NgxMatEntityCreateDialogComponent, {
|
|
254
|
+
data: dialogData,
|
|
255
|
+
minWidth: '60%',
|
|
256
|
+
autoFocus: false,
|
|
257
|
+
restoreFocus: false
|
|
258
|
+
});
|
|
259
|
+
}
|
|
260
|
+
/**
|
|
261
|
+
* Runs the TableAction for all selected entries.
|
|
262
|
+
* Also handles confirmation with an additional dialog if configured.
|
|
263
|
+
*
|
|
264
|
+
* @param action - The TableAction to run.
|
|
265
|
+
*/
|
|
266
|
+
runTableAction(action) {
|
|
267
|
+
const requireConfirmDialog = this.injector.runInContext(() => {
|
|
268
|
+
return action.requireConfirmDialog(this.selection.selected);
|
|
269
|
+
});
|
|
270
|
+
if (!requireConfirmDialog) {
|
|
271
|
+
this.confirmRunTableAction(action);
|
|
272
|
+
return;
|
|
273
|
+
}
|
|
274
|
+
const dialogRef = this.dialog.open(NgxMatEntityConfirmDialogComponent, {
|
|
275
|
+
data: action.confirmDialogData,
|
|
276
|
+
autoFocus: false,
|
|
277
|
+
restoreFocus: false
|
|
278
|
+
});
|
|
279
|
+
dialogRef.afterClosed().subscribe(res => {
|
|
280
|
+
if (res == true) {
|
|
281
|
+
this.confirmRunTableAction(action);
|
|
282
|
+
}
|
|
283
|
+
});
|
|
284
|
+
}
|
|
285
|
+
confirmRunTableAction(action) {
|
|
286
|
+
void this.injector.runInContext(async () => {
|
|
287
|
+
await action.action(this.selection.selected);
|
|
288
|
+
});
|
|
289
|
+
}
|
|
290
|
+
/**
|
|
291
|
+
* Checks if an TableAction is disabled (e.g. Because no entries have been selected).
|
|
292
|
+
*
|
|
293
|
+
* @param action - The TableAction to check.
|
|
294
|
+
* @returns Whether or not the Action can be used.
|
|
295
|
+
*/
|
|
296
|
+
tableActionDisabled(action) {
|
|
297
|
+
return this.injector.runInContext(() => {
|
|
298
|
+
return !action.enabled(this.selection.selected);
|
|
299
|
+
});
|
|
300
|
+
}
|
|
301
|
+
ngOnDestroy() {
|
|
302
|
+
this.onDestroy.next(undefined);
|
|
303
|
+
this.onDestroy.complete();
|
|
304
|
+
}
|
|
305
|
+
/**
|
|
306
|
+
* Applies the search input to filter the table entries.
|
|
307
|
+
*
|
|
308
|
+
* @param event - The keyup-event which contains the search-string of the user.
|
|
309
|
+
*/
|
|
310
|
+
applyFilter(event) {
|
|
311
|
+
const filterValue = event.target.value;
|
|
312
|
+
this.dataSource.filter = filterValue.trim().toLowerCase();
|
|
313
|
+
}
|
|
314
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: NgxMatEntityTableComponent, deps: [{ token: i1.MatDialog }, { token: i0.EnvironmentInjector }, { token: i2.Router }], target: i0.ɵɵFactoryTarget.Component });
|
|
315
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.0", type: NgxMatEntityTableComponent, isStandalone: true, selector: "ngx-mat-entity-table", inputs: { tableData: "tableData" }, viewQueries: [{ propertyName: "paginator", first: true, predicate: MatPaginator, descendants: true, static: true }, { propertyName: "sort", first: true, predicate: MatSort, descendants: true, static: true }, { propertyName: "filter", first: true, predicate: ["filter"], descendants: true, static: true }], ngImport: i0, template: "<h1 class=\"title\">{{data.baseData.title}}</h1>\n\n<div class=\"row\">\n <mat-form-field class=\"col-lg-8 col-md-6 col-sm-12\">\n <mat-label>{{data.baseData.searchLabel}}</mat-label>\n <input matInput (keyup)=\"applyFilter($event)\">\n </mat-form-field>\n <div\n *ngIf=\"data.baseData.tableActions.length\"\n [class.col-lg-2]=\"allowCreate\"\n [class.col-lg-4]=\"!allowCreate\"\n [class.col-md-3]=\"allowCreate\"\n [class.col-md-6]=\"!allowCreate\"\n [class.col-sm-6]=\"allowCreate\"\n [class.col-sm-12]=\"!allowCreate\"\n >\n <button type=\"button\" class=\"actions-button\" [matMenuTriggerFor]=\"menu\" mat-raised-button>\n {{data.baseData.tableActionsLabel}}\n </button>\n </div>\n <mat-menu #menu=\"matMenu\">\n <button *ngIf=\"data.baseData.allowJsonImport\" type=\"button\" [disabled]=\"tableActionDisabled(importAction)\" (click)=\"runTableAction(importAction)\" mat-menu-item>\n {{importAction.displayName}}\n </button>\n <button type=\"button\" *ngFor=\"let action of data.baseData.tableActions\" [disabled]=\"tableActionDisabled(action)\" (click)=\"runTableAction(action)\" mat-menu-item>\n {{action.displayName}}\n </button>\n </mat-menu>\n\n <div\n *ngIf=\"allowCreate\"\n [class.col-lg-2]=\"data.baseData.tableActions.length\"\n [class.col-lg-4]=\"!data.baseData.tableActions.length\"\n [class.col-md-3]=\"data.baseData.tableActions.length\"\n [class.col-md-6]=\"!data.baseData.tableActions.length\"\n [class.col-sm-6]=\"data.baseData.tableActions.length\"\n [class.col-sm-12]=\"!data.baseData.tableActions.length\"\n >\n <button type=\"button\" class=\"create-button\" (click)=\"createEntity()\" mat-raised-button>\n {{data.baseData.createButtonLabel}}\n </button>\n </div>\n</div>\n\n<div class=\"mat-elevation-z8\">\n <mat-table [dataSource]=\"dataSource\" matSort>\n <!-- select Column -->\n <ng-container matColumnDef=\"select\">\n <mat-header-cell *matHeaderCellDef>\n <mat-checkbox (change)=\"$event ? SelectionUtilities.masterToggle(selection, dataSource) : null\"\n [checked]=\"selection.hasValue() && SelectionUtilities.isAllSelected(selection, dataSource)\"\n [indeterminate]=\"selection.hasValue() && !SelectionUtilities.isAllSelected(selection, dataSource)\">\n </mat-checkbox>\n </mat-header-cell>\n <mat-cell class=\"entity\" *matCellDef=\"let entity\">\n <mat-checkbox (click)=\"$event.stopPropagation()\"\n (change)=\"$event ? selection.toggle(entity) : null\"\n [checked]=\"selection.isSelected(entity)\">\n </mat-checkbox>\n </mat-cell>\n </ng-container>\n\n <ng-container *ngFor=\"let dCol of data.baseData.displayColumns\" [matColumnDef]=\"dCol.displayName\">\n <mat-header-cell *matHeaderCellDef mat-sort-header>\n {{dCol.displayName}}\n </mat-header-cell>\n <mat-cell class=\"entity\" [class.enabled]=\"!dCol.disableClick && (allowUpdate(entity) || allowRead(entity))\"\n (click)=\"editEntity(entity, dCol)\"\n *matCellDef=\"let entity\"\n >\n <ng-container *ngIf=\"dCol.Component\">\n <display-column-value [entity]=\"entity\" [ComponentClass]=\"dCol.Component\"></display-column-value>\n </ng-container>\n <ng-container *ngIf=\"!dCol.Component\">\n {{getDisplayColumnValue(entity, dCol)}}\n </ng-container>\n </mat-cell>\n </ng-container>\n\n <mat-header-row *matHeaderRowDef=\"displayedColumns\"></mat-header-row>\n <mat-row *matRowDef=\"let row; columns: displayedColumns\"></mat-row>\n </mat-table>\n\n <mat-spinner *ngIf=\"isLoading && data.baseData.displayLoadingSpinner\">\n </mat-spinner>\n\n <mat-paginator [length]=\"dataSource.filteredData.length\" [pageIndex]=\"0\" [pageSize]=\"10\" [pageSizeOptions]=\"[5, 10, 25, 50]\"></mat-paginator>\n</div>", styles: [".mdc-data-table__row:last-child .mdc-data-table__cell{border-bottom:1px solid rgba(0,0,0,.12)}button{width:100%}mat-spinner{margin:10px auto}.title{text-align:center}.actions-button,.create-button{height:56px;line-height:24px;font-size:16px}.mat-column-select{flex:0 0 75px}.enabled:hover{cursor:pointer}@media (max-width: 767px){.actions-button,.create-button{margin-bottom:15px}}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i3.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLabel, selector: "mat-label" }, { kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: MatCheckboxModule }, { kind: "component", type: i5.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex"], exportAs: ["matCheckbox"] }, { kind: "ngmodule", type: MatTableModule }, { kind: "component", type: i6.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i6.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i6.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i6.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i6.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i6.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i6.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i6.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i6.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i6.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "ngmodule", type: MatPaginatorModule }, { kind: "component", type: i7.MatPaginator, selector: "mat-paginator", inputs: ["disabled"], exportAs: ["matPaginator"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i8.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "ngmodule", type: MatMenuModule }, { kind: "component", type: i9.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i9.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i9.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "ngmodule", type: MatDialogModule }, { kind: "ngmodule", type: MatProgressSpinnerModule }, { kind: "component", type: i10.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "component", type: DisplayColumnValueComponent, selector: "display-column-value", inputs: ["entity", "ComponentClass"] }] });
|
|
316
|
+
}
|
|
317
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: NgxMatEntityTableComponent, decorators: [{
|
|
318
|
+
type: Component,
|
|
319
|
+
args: [{ selector: 'ngx-mat-entity-table', standalone: true, imports: [
|
|
320
|
+
NgIf,
|
|
321
|
+
NgFor,
|
|
322
|
+
MatInputModule,
|
|
323
|
+
FormsModule,
|
|
324
|
+
MatFormFieldModule,
|
|
325
|
+
MatCheckboxModule,
|
|
326
|
+
MatTableModule,
|
|
327
|
+
MatPaginatorModule,
|
|
328
|
+
MatButtonModule,
|
|
329
|
+
MatMenuModule,
|
|
330
|
+
MatDialogModule,
|
|
331
|
+
MatProgressSpinnerModule,
|
|
332
|
+
NgxMatEntityCreateDialogComponent,
|
|
333
|
+
NgxMatEntityEditDialogComponent,
|
|
334
|
+
DisplayColumnValueComponent
|
|
335
|
+
], template: "<h1 class=\"title\">{{data.baseData.title}}</h1>\n\n<div class=\"row\">\n <mat-form-field class=\"col-lg-8 col-md-6 col-sm-12\">\n <mat-label>{{data.baseData.searchLabel}}</mat-label>\n <input matInput (keyup)=\"applyFilter($event)\">\n </mat-form-field>\n <div\n *ngIf=\"data.baseData.tableActions.length\"\n [class.col-lg-2]=\"allowCreate\"\n [class.col-lg-4]=\"!allowCreate\"\n [class.col-md-3]=\"allowCreate\"\n [class.col-md-6]=\"!allowCreate\"\n [class.col-sm-6]=\"allowCreate\"\n [class.col-sm-12]=\"!allowCreate\"\n >\n <button type=\"button\" class=\"actions-button\" [matMenuTriggerFor]=\"menu\" mat-raised-button>\n {{data.baseData.tableActionsLabel}}\n </button>\n </div>\n <mat-menu #menu=\"matMenu\">\n <button *ngIf=\"data.baseData.allowJsonImport\" type=\"button\" [disabled]=\"tableActionDisabled(importAction)\" (click)=\"runTableAction(importAction)\" mat-menu-item>\n {{importAction.displayName}}\n </button>\n <button type=\"button\" *ngFor=\"let action of data.baseData.tableActions\" [disabled]=\"tableActionDisabled(action)\" (click)=\"runTableAction(action)\" mat-menu-item>\n {{action.displayName}}\n </button>\n </mat-menu>\n\n <div\n *ngIf=\"allowCreate\"\n [class.col-lg-2]=\"data.baseData.tableActions.length\"\n [class.col-lg-4]=\"!data.baseData.tableActions.length\"\n [class.col-md-3]=\"data.baseData.tableActions.length\"\n [class.col-md-6]=\"!data.baseData.tableActions.length\"\n [class.col-sm-6]=\"data.baseData.tableActions.length\"\n [class.col-sm-12]=\"!data.baseData.tableActions.length\"\n >\n <button type=\"button\" class=\"create-button\" (click)=\"createEntity()\" mat-raised-button>\n {{data.baseData.createButtonLabel}}\n </button>\n </div>\n</div>\n\n<div class=\"mat-elevation-z8\">\n <mat-table [dataSource]=\"dataSource\" matSort>\n <!-- select Column -->\n <ng-container matColumnDef=\"select\">\n <mat-header-cell *matHeaderCellDef>\n <mat-checkbox (change)=\"$event ? SelectionUtilities.masterToggle(selection, dataSource) : null\"\n [checked]=\"selection.hasValue() && SelectionUtilities.isAllSelected(selection, dataSource)\"\n [indeterminate]=\"selection.hasValue() && !SelectionUtilities.isAllSelected(selection, dataSource)\">\n </mat-checkbox>\n </mat-header-cell>\n <mat-cell class=\"entity\" *matCellDef=\"let entity\">\n <mat-checkbox (click)=\"$event.stopPropagation()\"\n (change)=\"$event ? selection.toggle(entity) : null\"\n [checked]=\"selection.isSelected(entity)\">\n </mat-checkbox>\n </mat-cell>\n </ng-container>\n\n <ng-container *ngFor=\"let dCol of data.baseData.displayColumns\" [matColumnDef]=\"dCol.displayName\">\n <mat-header-cell *matHeaderCellDef mat-sort-header>\n {{dCol.displayName}}\n </mat-header-cell>\n <mat-cell class=\"entity\" [class.enabled]=\"!dCol.disableClick && (allowUpdate(entity) || allowRead(entity))\"\n (click)=\"editEntity(entity, dCol)\"\n *matCellDef=\"let entity\"\n >\n <ng-container *ngIf=\"dCol.Component\">\n <display-column-value [entity]=\"entity\" [ComponentClass]=\"dCol.Component\"></display-column-value>\n </ng-container>\n <ng-container *ngIf=\"!dCol.Component\">\n {{getDisplayColumnValue(entity, dCol)}}\n </ng-container>\n </mat-cell>\n </ng-container>\n\n <mat-header-row *matHeaderRowDef=\"displayedColumns\"></mat-header-row>\n <mat-row *matRowDef=\"let row; columns: displayedColumns\"></mat-row>\n </mat-table>\n\n <mat-spinner *ngIf=\"isLoading && data.baseData.displayLoadingSpinner\">\n </mat-spinner>\n\n <mat-paginator [length]=\"dataSource.filteredData.length\" [pageIndex]=\"0\" [pageSize]=\"10\" [pageSizeOptions]=\"[5, 10, 25, 50]\"></mat-paginator>\n</div>", styles: [".mdc-data-table__row:last-child .mdc-data-table__cell{border-bottom:1px solid rgba(0,0,0,.12)}button{width:100%}mat-spinner{margin:10px auto}.title{text-align:center}.actions-button,.create-button{height:56px;line-height:24px;font-size:16px}.mat-column-select{flex:0 0 75px}.enabled:hover{cursor:pointer}@media (max-width: 767px){.actions-button,.create-button{margin-bottom:15px}}\n"] }]
|
|
336
|
+
}], ctorParameters: function () { return [{ type: i1.MatDialog }, { type: i0.EnvironmentInjector }, { type: i2.Router }]; }, propDecorators: { tableData: [{
|
|
337
|
+
type: Input
|
|
338
|
+
}], paginator: [{
|
|
339
|
+
type: ViewChild,
|
|
340
|
+
args: [MatPaginator, { static: true }]
|
|
341
|
+
}], sort: [{
|
|
342
|
+
type: ViewChild,
|
|
343
|
+
args: [MatSort, { static: true }]
|
|
344
|
+
}], filter: [{
|
|
345
|
+
type: ViewChild,
|
|
346
|
+
args: ['filter', { static: true }]
|
|
347
|
+
}] } });
|
|
348
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-material-entity/src/components/table/table.component.ts","../../../../../projects/ngx-material-entity/src/components/table/table.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC1D,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAE,SAAS,EAAE,mBAAmB,EAAE,KAAK,EAAqB,SAAS,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAC5G,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAC/D,OAAO,EAAE,SAAS,EAAE,eAAe,EAAgB,MAAM,0BAA0B,CAAC;AACpF,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAClE,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,YAAY,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AAC/E,OAAO,EAAE,wBAAwB,EAAE,MAAM,oCAAoC,CAAC;AAC9E,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AACjD,OAAO,EAAE,kBAAkB,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAC7E,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACzC,OAAO,EAAE,OAAO,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAG1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,qCAAqC,CAAC;AACzE,OAAO,EAAE,wBAAwB,EAA6B,MAAM,+CAA+C,CAAC;AACpH,OAAO,EAAE,kCAAkC,EAAE,MAAM,4CAA4C,CAAC;AAChG,OAAO,EAAE,6BAA6B,EAAkC,MAAM,mDAAmD,CAAC;AAClI,OAAO,EAAE,iCAAiC,EAAE,MAAM,gDAAgD,CAAC;AACnG,OAAO,EAAE,2BAA2B,EAAE,MAAM,uDAAuD,CAAC;AAEpG,OAAO,EAAE,+BAA+B,EAAE,MAAM,4CAA4C,CAAC;AAC7F,OAAO,EAAE,qBAAqB,EAA0B,MAAM,mCAAmC,CAAC;AAElG,OAAO,EAAE,uBAAuB,EAAuB,gBAAgB,EAAqB,MAAM,sBAAsB,CAAC;;;;;;;;;;;;AAEzH;;;;;GAKG;AAwBH,MAAM,OAAO,0BAA0B;IA2Bd;IACA;IACA;IA3BrB;;OAEG;IAEH,SAAS,CAAyB;IAElC,IAAI,CAAiC;IAErC,SAAS,GAAY,IAAI,CAAC;IAC1B,WAAW,CAAW;IAEd,aAAa,CAA6B;IACjC,SAAS,GAAkB,IAAI,OAAO,EAAQ,CAAC;IACrB,SAAS,CAAgB;IAC9B,IAAI,CAAW;IACd,MAAM,CAAU;IACvD,gBAAgB,CAAY;IAC5B,UAAU,GAAmC,IAAI,kBAAkB,EAAE,CAAC;IACtE,SAAS,GAA+B,IAAI,cAAc,CAAa,IAAI,EAAE,EAAE,CAAC,CAAC;IAEjF,kBAAkB,GAA8B,kBAAkB,CAAC;IAEnE,YAAY,CAA2B;IAEvC,YACqB,MAAiB,EACjB,QAA6B,EAC7B,MAAc;QAFd,WAAM,GAAN,MAAM,CAAW;QACjB,aAAQ,GAAR,QAAQ,CAAqB;QAC7B,WAAM,GAAN,MAAM,CAAQ;IAChC,CAAC;IAEJ;;OAEG;IACH,QAAQ;QACJ,IAAI,CAAC,IAAI,GAAG,IAAI,gBAAgB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,SAAS,EAAE,CAAC;QAC7D,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,GAAG,EAAE;YAC5B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;QACxD,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,YAAY,GAAG,IAAI,uBAAuB,CAAC;YAC5C,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,gBAAgB;YACtC,MAAM,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,eAAe,EAAE;SACvC,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,GAAG,EAAE;YAC5B,IAAI,CAAC,aAAa,GAAG,MAAM,CAA4B,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,kBAAkB,CAAC,CAAC;QAClG,CAAC,CAAC,CAAC;QAEH,MAAM,mBAAmB,GAAa,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC;QAClG,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,KAAK,cAAc,CAAC,CAAC,MAAM,EAAE;YACjF,IAAI,CAAC,gBAAgB,GAAG,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,mBAAmB,CAAC,CAAC;SAClE;aACI;YACD,IAAI,CAAC,gBAAgB,GAAG,mBAAmB,CAAC;SAC/C;QAED,IAAI,CAAC,UAAU,CAAC,mBAAmB,GAAG,CAAC,MAAkB,EAAE,MAAc,EAAE,EAAE;YACzE,OAAO,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,GAAG,EAAE;gBACnC,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,WAAW,KAAK,MAAM,CAAC,EAAE,KAAK,CAAC,MAAM,CAAW,CAAC;YAC9G,CAAC,CAAC,CAAC;QACP,CAAC,CAAC;QACF,IAAI,CAAC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;QACjC,IAAI,CAAC,UAAU,CAAC,eAAe,GAAG,CAAC,MAAkB,EAAE,MAAc,EAAE,EAAE;YACrE,MAAM,SAAS,GAAW,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;YAClE,MAAM,qBAAqB,GAAW,SAAS,CAAC,WAAW,EAAE,CAAC;YAC9D,MAAM,qBAAqB,GAAW,MAAM,CAAC,WAAW,EAAE,CAAC;YAC3D,OAAO,qBAAqB,CAAC,QAAQ,CAAC,qBAAqB,CAAC,CAAC;QACjE,CAAC,CAAC;QACF,IAAI,CAAC,UAAU,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QACrC,IAAI,CAAC,UAAU,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;QAE3C,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,QAAQ,EAAE,EAAE;YACtF,IAAI,CAAC,UAAU,CAAC,IAAI,GAAG,QAAQ,CAAC;YAChC,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;QAC3B,CAAC,CAAC,CAAC;QACH,KAAK,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;YACrC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QAC3B,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;;;;;OAOG;IACH,qBAAqB,CAAC,MAAkB,EAAE,aAAwC;QAC9E,OAAO,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,GAAG,EAAE;YACnC,OAAO,aAAa,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,eAAe;QACnB,MAAM,KAAK,GAAqB,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;QAChE,KAAK,CAAC,IAAI,GAAG,MAAM,CAAC;QACpB,KAAK,CAAC,MAAM,GAAG,kBAAkB,CAAC;QAClC,KAAK,CAAC,QAAQ,GAAG,KAAK,IAAI,EAAE;YACxB,IAAI,KAAK,CAAC,KAAK,EAAE;gBACb,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;aACnC;QACL,CAAC,CAAC;QACF,KAAK,CAAC,KAAK,EAAE,CAAC;IAClB,CAAC;IAEO,UAAU,CAAC,IAAU;QACzB,MAAM,UAAU,GAA8B,IAAI,wBAAwB,CAAC,IAAI,CAAC,YAAY,CAAC,iBAAiB,CAAC;aAC1G,WAAW,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,IAAI,CAAC;aAC/E,WAAW,CAAC,OAAO,EAAE,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC;aACnD,SAAS,EAAE,CAAC;QACjB,MAAM,SAAS,GAA8D,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,kCAAkC,EAAE;YAC9H,IAAI,EAAE,UAAU;YAChB,SAAS,EAAE,KAAK;YAChB,YAAY,EAAE,KAAK;SACtB,CAAC,CAAC;QACH,SAAS,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;YACpC,IAAI,GAAG,IAAI,IAAI,EAAE;gBACb,KAAK,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;aACxC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;;;;OAMG;IACH,UAAU,CAAC,MAAkB,EAAE,IAA+B;QAC1D,IAAI,IAAI,CAAC,YAAY,IAAI,IAAI,EAAE;YAC3B,OAAO;SACV;QACD,IAAI,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,EAAE;YACvD,OAAO;SACV;QACD,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE;YACjC,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;SAChE;QACD,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE;YACzB,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC;YACpE,OAAO;SACV;QACD,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,IAAI,MAAM,EAAE;YAC1C,IAAI,CAAC,eAAe,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC;YACjE,OAAO;SACV;QACD,KAAK,IAAI,CAAC,iBAAiB,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC;IAC5E,CAAC;IAED;;;;;OAKG;IACH,WAAW,CAAC,MAAkB;QAC1B,OAAO,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,GAAG,EAAE;YACnC,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;QAClD,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;;;OAKG;IACH,SAAS,CAAC,MAAkB;QACxB,OAAO,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,GAAG,EAAE;YACnC,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QAChD,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,eAAe,CAAC,MAAkB;QACtC,KAAK,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,EAAE,EAAE,IAAI,CAAC,aAAa,CAAC,aAAa,EAAE,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;IACjF,CAAC;IAEO,KAAK,CAAC,iBAAiB,CAAC,MAAkB;QAC9C,MAAM,eAAe,GAA+B;YAChD,MAAM,EAAE,MAAM;YACd,kBAAkB,EAAE,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,kBAAkB;YACzD,WAAW,EAAE,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW;YAC3C,WAAW,EAAE,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW;YAC3C,QAAQ,EAAE,IAAI,CAAC,IAAI,CAAC,QAAQ;SAC/B,CAAC;QACF,MAAM,UAAU,GAAuC,IAAI,qBAAqB,CAAC,eAAe,CAAC,CAAC,SAAS,EAAE,CAAC;QAC9G,MAAM,GAAG,GAAW,MAAM,cAAc,CACpC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,+BAA+B,EAAE;YAC9C,IAAI,EAAE,UAAU;YAChB,QAAQ,EAAE,KAAK;YACf,SAAS,EAAE,KAAK;YAChB,YAAY,EAAE,KAAK;SACtB,CAAC,CAAC,WAAW,EAAE,CACT,CAAC;QACZ,IAAI,GAAG,KAAK,CAAC,EAAE;YACX,MAAM,IAAI,GAAiB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;YAChD,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,KAAK,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC;YACvH,IAAI,CAAC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC;YAC5B,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;SAC1B;IACL,CAAC;IAED;;;;OAIG;IACH,YAAY;QACR,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,GAAG,EAAE;YAC5B,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,EAAE;gBAClC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE;oBACjC,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;iBAChE;gBACD,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;oBAC3B,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC,CAAC;iBACnE;qBACI;oBACD,IAAI,CAAC,aAAa,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC,CAAC;iBAC5D;aACJ;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,aAAa,CAAC,MAAkB;QACpC,MAAM,UAAU,GAA+C,IAAI,6BAA6B,CAC5F;YACI,MAAM,EAAE,MAAM;YACd,kBAAkB,EAAE,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,kBAAkB;YACzD,gBAAgB,EAAE,IAAI,CAAC,IAAI,CAAC,gBAAgB;SAC/C,CACJ,CAAC,SAAS,EAAE,CAAC;QACd,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,iCAAiC,EAAE;YAChD,IAAI,EAAE,UAAU;YAChB,QAAQ,EAAE,KAAK;YACf,SAAS,EAAE,KAAK;YAChB,YAAY,EAAE,KAAK;SACtB,CAAC,CAAC;IACP,CAAC;IAED;;;;;OAKG;IACH,cAAc,CAAC,MAAuC;QAClD,MAAM,oBAAoB,GAAY,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,GAAG,EAAE;YAClE,OAAO,MAAM,CAAC,oBAAoB,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QAChE,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,oBAAoB,EAAE;YACvB,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;YACnC,OAAO;SACV;QACD,MAAM,SAAS,GAA8D,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,kCAAkC,EAAE;YAC9H,IAAI,EAAE,MAAM,CAAC,iBAAiB;YAC9B,SAAS,EAAE,KAAK;YAChB,YAAY,EAAE,KAAK;SACtB,CAAC,CAAC;QACH,SAAS,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;YACpC,IAAI,GAAG,IAAI,IAAI,EAAE;gBACb,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;aACtC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,qBAAqB,CAAC,MAAuC;QACjE,KAAK,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,KAAK,IAAI,EAAE;YACvC,MAAM,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QACjD,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;;;OAKG;IACH,mBAAmB,CAAC,MAAuC;QACvD,OAAO,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,GAAG,EAAE;YACnC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QACpD,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW;QACP,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC/B,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IAC9B,CAAC;IAED;;;;OAIG;IACH,WAAW,CAAC,KAAY;QACpB,MAAM,WAAW,GAAY,KAAK,CAAC,MAA2B,CAAC,KAAK,CAAC;QACrE,IAAI,CAAC,UAAU,CAAC,MAAM,GAAG,WAAW,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;IAC9D,CAAC;uGA7SQ,0BAA0B;2FAA1B,0BAA0B,+JAexB,YAAY,qFACZ,OAAO,+JC3EtB,0rIAuFM,ybD7CE,IAAI,6FACJ,KAAK,kHACL,cAAc,snBACd,WAAW,8BACX,kBAAkB,8BAClB,iBAAiB,gLACjB,cAAc,ghCACd,kBAAkB,yJAClB,eAAe,2QACf,aAAa,+YACb,eAAe,8BACf,wBAAwB,oOAGxB,2BAA2B;;2FAGtB,0BAA0B;kBAvBtC,SAAS;+BACI,sBAAsB,cAGpB,IAAI,WACP;wBACL,IAAI;wBACJ,KAAK;wBACL,cAAc;wBACd,WAAW;wBACX,kBAAkB;wBAClB,iBAAiB;wBACjB,cAAc;wBACd,kBAAkB;wBAClB,eAAe;wBACf,aAAa;wBACb,eAAe;wBACf,wBAAwB;wBACxB,iCAAiC;wBACjC,+BAA+B;wBAC/B,2BAA2B;qBAC9B;uJAQD,SAAS;sBADR,KAAK;gBAUqC,SAAS;sBAAnD,SAAS;uBAAC,YAAY,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBACH,IAAI;sBAAzC,SAAS;uBAAC,OAAO,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBACG,MAAM;sBAA5C,SAAS;uBAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["import { SelectionModel } from '@angular/cdk/collections';\nimport { NgFor, NgIf } from '@angular/common';\nimport { Component, EnvironmentInjector, Input, OnDestroy, OnInit, ViewChild, inject } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatCheckboxModule } from '@angular/material/checkbox';\nimport { MatDialog, MatDialogModule, MatDialogRef } from '@angular/material/dialog';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatMenuModule } from '@angular/material/menu';\nimport { MatPaginator, MatPaginatorModule } from '@angular/material/paginator';\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\nimport { MatSort } from '@angular/material/sort';\nimport { MatTableDataSource, MatTableModule } from '@angular/material/table';\nimport { Router } from '@angular/router';\nimport { Subject, firstValueFrom, takeUntil } from 'rxjs';\nimport { BaseEntityType, Entity } from '../../classes/entity.model';\nimport { EntityService } from '../../services/entity.service';\nimport { SelectionUtilities } from '../../utilities/selection.utilities';\nimport { ConfirmDialogDataBuilder, ConfirmDialogDataInternal } from '../confirm-dialog/confirm-dialog-data.builder';\nimport { NgxMatEntityConfirmDialogComponent } from '../confirm-dialog/confirm-dialog.component';\nimport { CreateEntityDialogDataBuilder, CreateEntityDialogDataInternal } from './create-dialog/create-entity-dialog-data.builder';\nimport { NgxMatEntityCreateDialogComponent } from './create-dialog/create-entity-dialog.component';\nimport { DisplayColumnValueComponent } from './display-column-value/display-column-value.component';\nimport { EditEntityData } from './edit-dialog/edit-entity-data';\nimport { NgxMatEntityEditDialogComponent } from './edit-dialog/edit-entity-dialog.component';\nimport { EditEntityDataBuilder, EditEntityDataInternal } from './edit-dialog/edit-entity.builder';\nimport { DisplayColumn, TableData } from './table-data';\nimport { BaseTableActionInternal, TableActionInternal, TableDataBuilder, TableDataInternal } from './table-data.builder';\n\n/**\n * Generates a fully functional table for displaying, creating, updating and deleting entities\n * based on the configuration passed in the @Input \"tableData\".\n *\n * It offers a lot of customization options which can be found in \"TableData\".\n */\n@Component({\n    selector: 'ngx-mat-entity-table',\n    templateUrl: './table.component.html',\n    styleUrls: ['./table.component.scss'],\n    standalone: true,\n    imports: [\n        NgIf,\n        NgFor,\n        MatInputModule,\n        FormsModule,\n        MatFormFieldModule,\n        MatCheckboxModule,\n        MatTableModule,\n        MatPaginatorModule,\n        MatButtonModule,\n        MatMenuModule,\n        MatDialogModule,\n        MatProgressSpinnerModule,\n        NgxMatEntityCreateDialogComponent,\n        NgxMatEntityEditDialogComponent,\n        DisplayColumnValueComponent\n    ]\n})\nexport class NgxMatEntityTableComponent<EntityType extends BaseEntityType<Entity>> implements OnInit, OnDestroy {\n\n    /**\n     * The configuration for the component.\n     */\n    @Input()\n    tableData!: TableData<EntityType>;\n\n    data!: TableDataInternal<EntityType>;\n\n    isLoading: boolean = true;\n    allowCreate!: boolean;\n\n    private entityService!: EntityService<EntityType>;\n    private readonly onDestroy: Subject<void> = new Subject<void>();\n    @ViewChild(MatPaginator, { static: true }) paginator!: MatPaginator;\n    @ViewChild(MatSort, { static: true }) sort!: MatSort;\n    @ViewChild('filter', { static: true }) filter!: string;\n    displayedColumns!: string[];\n    dataSource: MatTableDataSource<EntityType> = new MatTableDataSource();\n    selection: SelectionModel<EntityType> = new SelectionModel<EntityType>(true, []);\n\n    SelectionUtilities: typeof SelectionUtilities = SelectionUtilities;\n\n    importAction!: BaseTableActionInternal;\n\n    constructor(\n        private readonly dialog: MatDialog,\n        private readonly injector: EnvironmentInjector,\n        private readonly router: Router\n    ) {}\n\n    /**\n     * Sets up all the configuration for the table and the EntityService.\n     */\n    ngOnInit(): void {\n        this.data = new TableDataBuilder(this.tableData).getResult();\n        this.injector.runInContext(() => {\n            this.allowCreate = this.data.baseData.allowCreate();\n        });\n\n        this.importAction = new BaseTableActionInternal({\n            ...this.data.baseData.importActionData,\n            action: () => this.startImportJson()\n        });\n\n        this.injector.runInContext(() => {\n            this.entityService = inject<EntityService<EntityType>>(this.data.baseData.EntityServiceClass);\n        });\n\n        const givenDisplayColumns: string[] = this.data.baseData.displayColumns.map((v) => v.displayName);\n        if (this.data.baseData.tableActions.filter(tA => tA.type === 'multi-select').length) {\n            this.displayedColumns = ['select'].concat(givenDisplayColumns);\n        }\n        else {\n            this.displayedColumns = givenDisplayColumns;\n        }\n\n        this.dataSource.sortingDataAccessor = (entity: EntityType, header: string) => {\n            return this.injector.runInContext(() => {\n                return this.data.baseData.displayColumns.find((dp) => dp.displayName === header)?.value(entity) as string;\n            });\n        };\n        this.dataSource.sort = this.sort;\n        this.dataSource.filterPredicate = (entity: EntityType, filter: string) => {\n            const searchStr: string = this.data.baseData.searchString(entity);\n            const formattedSearchString: string = searchStr.toLowerCase();\n            const formattedFilterString: string = filter.toLowerCase();\n            return formattedSearchString.includes(formattedFilterString);\n        };\n        this.dataSource.filter = this.filter;\n        this.dataSource.paginator = this.paginator;\n\n        this.entityService.entitiesSubject.pipe(takeUntil(this.onDestroy)).subscribe((entities) => {\n            this.dataSource.data = entities;\n            this.selection.clear();\n        });\n        void this.entityService.read().then(() => {\n            this.isLoading = false;\n        });\n    }\n\n    /**\n     * Gets the value to display in the column.\n     * Runs in environment context to enable injection.\n     *\n     * @param entity - The entity to get the value from.\n     * @param displayColumn - The display column to get the value from.\n     * @returns The value of the display column.\n     */\n    getDisplayColumnValue(entity: EntityType, displayColumn: DisplayColumn<EntityType>): unknown {\n        return this.injector.runInContext(() => {\n            return displayColumn.value(entity);\n        });\n    }\n\n    private startImportJson(): void {\n        const input: HTMLInputElement = document.createElement('input');\n        input.type = 'file';\n        input.accept = 'application/json';\n        input.onchange = async () => {\n            if (input.files) {\n                this.importJson(input.files[0]);\n            }\n        };\n        input.click();\n    }\n\n    private importJson(file: File): void {\n        const dialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(this.importAction.confirmDialogData)\n            .withDefault('text', this.data.baseData.importActionData.confirmDialogData.text)\n            .withDefault('title', this.importAction.displayName)\n            .getResult();\n        const dialogRef: MatDialogRef<NgxMatEntityConfirmDialogComponent, boolean> = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        dialogRef.afterClosed().subscribe(res => {\n            if (res == true) {\n                void this.entityService.import(file);\n            }\n        });\n    }\n\n    /**\n     * Edits an entity. This either calls the edit-Method provided by the user or uses a default edit-dialog.\n     *\n     * @param entity - The entity that should be updated.\n     * @param dCol - The display column. Is needed if a custom component was used that handles the click event differently.\n     * @throws When no EntityClass was provided, as a new call is needed to initialize metadata.\n     */\n    editEntity(entity: EntityType, dCol: DisplayColumn<EntityType>): void {\n        if (dCol.disableClick == true) {\n            return;\n        }\n        if (!(this.allowUpdate(entity) || this.allowRead(entity))) {\n            return;\n        }\n        if (!this.data.baseData.EntityClass) {\n            throw new Error('No \"EntityClass\" specified for this table');\n        }\n        if (this.data.baseData.edit) {\n            this.data.baseData.edit(new this.data.baseData.EntityClass(entity));\n            return;\n        }\n        if (this.data.baseData.defaultEdit == 'page') {\n            this.editDefaultPage(new this.data.baseData.EntityClass(entity));\n            return;\n        }\n        void this.editDefaultDialog(new this.data.baseData.EntityClass(entity));\n    }\n\n    /**\n     * Whether updating the provided entity is allowed.\n     *\n     * @param entity - The entity that the user wants to edit.\n     * @returns True when the user can edit the provided entity and false otherwise.\n     */\n    allowUpdate(entity: EntityType): boolean {\n        return this.injector.runInContext(() => {\n            return this.data.baseData.allowUpdate(entity);\n        });\n    }\n\n    /**\n     * Whether viewing the provided entity is allowed.\n     *\n     * @param entity - The entity that the user wants to view.\n     * @returns True when the user can view the provided entity and false otherwise.\n     */\n    allowRead(entity: EntityType): boolean {\n        return this.injector.runInContext(() => {\n            return this.data.baseData.allowRead(entity);\n        });\n    }\n\n    private editDefaultPage(entity: EntityType): void {\n        void this.router.navigate(['', this.entityService.editBaseRoute, entity.id]);\n    }\n\n    private async editDefaultDialog(entity: EntityType): Promise<void> {\n        const inputDialogData: EditEntityData<EntityType> = {\n            entity: entity,\n            EntityServiceClass: this.data.baseData.EntityServiceClass,\n            allowUpdate: this.data.baseData.allowUpdate,\n            allowDelete: this.data.baseData.allowDelete,\n            editData: this.data.editData\n        };\n        const dialogData: EditEntityDataInternal<EntityType> = new EditEntityDataBuilder(inputDialogData).getResult();\n        const res: number = await firstValueFrom(\n            this.dialog.open(NgxMatEntityEditDialogComponent, {\n                data: dialogData,\n                minWidth: '60%',\n                autoFocus: false,\n                restoreFocus: false\n            }).afterClosed()\n        ) as number;\n        if (res === 0) {\n            const data: EntityType[] = this.dataSource.data;\n            data[this.dataSource.data.findIndex((e) => e[this.entityService.idKey] === entity[this.entityService.idKey])] = entity;\n            this.dataSource.data = data;\n            this.selection.clear();\n        }\n    }\n\n    /**\n     * Creates a new Entity. This either calls the create-Method provided by the user or uses a default create-dialog.\n     *\n     * @throws When no EntityClass was provided, as a new call is needed to initialize metadata.\n     */\n    createEntity(): void {\n        this.injector.runInContext(() => {\n            if (this.data.baseData.allowCreate()) {\n                if (!this.data.baseData.EntityClass) {\n                    throw new Error('No \"EntityClass\" specified for this table');\n                }\n                if (this.data.baseData.create) {\n                    this.data.baseData.create(new this.data.baseData.EntityClass());\n                }\n                else {\n                    this.createDefault(new this.data.baseData.EntityClass());\n                }\n            }\n        });\n    }\n\n    private createDefault(entity: EntityType): void {\n        const dialogData: CreateEntityDialogDataInternal<EntityType> = new CreateEntityDialogDataBuilder(\n            {\n                entity: entity,\n                EntityServiceClass: this.data.baseData.EntityServiceClass,\n                createDialogData: this.data.createDialogData\n            }\n        ).getResult();\n        this.dialog.open(NgxMatEntityCreateDialogComponent, {\n            data: dialogData,\n            minWidth: '60%',\n            autoFocus: false,\n            restoreFocus: false\n        });\n    }\n\n    /**\n     * Runs the TableAction for all selected entries.\n     * Also handles confirmation with an additional dialog if configured.\n     *\n     * @param action - The TableAction to run.\n     */\n    runTableAction(action: TableActionInternal<EntityType>): void {\n        const requireConfirmDialog: boolean = this.injector.runInContext(() => {\n            return action.requireConfirmDialog(this.selection.selected);\n        });\n\n        if (!requireConfirmDialog) {\n            this.confirmRunTableAction(action);\n            return;\n        }\n        const dialogRef: MatDialogRef<NgxMatEntityConfirmDialogComponent, boolean> = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: action.confirmDialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        dialogRef.afterClosed().subscribe(res => {\n            if (res == true) {\n                this.confirmRunTableAction(action);\n            }\n        });\n    }\n\n    private confirmRunTableAction(action: TableActionInternal<EntityType>): void {\n        void this.injector.runInContext(async () => {\n            await action.action(this.selection.selected);\n        });\n    }\n\n    /**\n     * Checks if an TableAction is disabled (e.g. Because no entries have been selected).\n     *\n     * @param action - The TableAction to check.\n     * @returns Whether or not the Action can be used.\n     */\n    tableActionDisabled(action: TableActionInternal<EntityType>): boolean {\n        return this.injector.runInContext(() => {\n            return !action.enabled(this.selection.selected);\n        });\n    }\n\n    ngOnDestroy(): void {\n        this.onDestroy.next(undefined);\n        this.onDestroy.complete();\n    }\n\n    /**\n     * Applies the search input to filter the table entries.\n     *\n     * @param event - The keyup-event which contains the search-string of the user.\n     */\n    applyFilter(event: Event): void {\n        const filterValue: string = (event.target as HTMLInputElement).value;\n        this.dataSource.filter = filterValue.trim().toLowerCase();\n    }\n\n\n}","<h1 class=\"title\">{{data.baseData.title}}</h1>\n\n<div class=\"row\">\n    <mat-form-field class=\"col-lg-8 col-md-6 col-sm-12\">\n        <mat-label>{{data.baseData.searchLabel}}</mat-label>\n        <input matInput (keyup)=\"applyFilter($event)\">\n    </mat-form-field>\n    <div\n        *ngIf=\"data.baseData.tableActions.length\"\n        [class.col-lg-2]=\"allowCreate\"\n        [class.col-lg-4]=\"!allowCreate\"\n        [class.col-md-3]=\"allowCreate\"\n        [class.col-md-6]=\"!allowCreate\"\n        [class.col-sm-6]=\"allowCreate\"\n        [class.col-sm-12]=\"!allowCreate\"\n    >\n        <button type=\"button\" class=\"actions-button\" [matMenuTriggerFor]=\"menu\" mat-raised-button>\n            {{data.baseData.tableActionsLabel}}\n        </button>\n    </div>\n    <mat-menu #menu=\"matMenu\">\n        <button *ngIf=\"data.baseData.allowJsonImport\" type=\"button\" [disabled]=\"tableActionDisabled(importAction)\" (click)=\"runTableAction(importAction)\" mat-menu-item>\n            {{importAction.displayName}}\n        </button>\n        <button type=\"button\" *ngFor=\"let action of data.baseData.tableActions\" [disabled]=\"tableActionDisabled(action)\" (click)=\"runTableAction(action)\" mat-menu-item>\n            {{action.displayName}}\n        </button>\n    </mat-menu>\n\n    <div\n        *ngIf=\"allowCreate\"\n        [class.col-lg-2]=\"data.baseData.tableActions.length\"\n        [class.col-lg-4]=\"!data.baseData.tableActions.length\"\n        [class.col-md-3]=\"data.baseData.tableActions.length\"\n        [class.col-md-6]=\"!data.baseData.tableActions.length\"\n        [class.col-sm-6]=\"data.baseData.tableActions.length\"\n        [class.col-sm-12]=\"!data.baseData.tableActions.length\"\n    >\n        <button type=\"button\" class=\"create-button\" (click)=\"createEntity()\" mat-raised-button>\n            {{data.baseData.createButtonLabel}}\n        </button>\n    </div>\n</div>\n\n<div class=\"mat-elevation-z8\">\n    <mat-table [dataSource]=\"dataSource\" matSort>\n        <!-- select Column -->\n        <ng-container matColumnDef=\"select\">\n            <mat-header-cell *matHeaderCellDef>\n                <mat-checkbox (change)=\"$event ? SelectionUtilities.masterToggle(selection, dataSource) : null\"\n                    [checked]=\"selection.hasValue() && SelectionUtilities.isAllSelected(selection, dataSource)\"\n                    [indeterminate]=\"selection.hasValue() && !SelectionUtilities.isAllSelected(selection, dataSource)\">\n                </mat-checkbox>\n            </mat-header-cell>\n            <mat-cell class=\"entity\" *matCellDef=\"let entity\">\n                <mat-checkbox (click)=\"$event.stopPropagation()\"\n                    (change)=\"$event ? selection.toggle(entity) : null\"\n                    [checked]=\"selection.isSelected(entity)\">\n                </mat-checkbox>\n            </mat-cell>\n        </ng-container>\n\n        <ng-container *ngFor=\"let dCol of data.baseData.displayColumns\" [matColumnDef]=\"dCol.displayName\">\n            <mat-header-cell *matHeaderCellDef mat-sort-header>\n                {{dCol.displayName}}\n            </mat-header-cell>\n            <mat-cell class=\"entity\" [class.enabled]=\"!dCol.disableClick && (allowUpdate(entity) || allowRead(entity))\"\n                (click)=\"editEntity(entity, dCol)\"\n                *matCellDef=\"let entity\"\n            >\n                <ng-container *ngIf=\"dCol.Component\">\n                    <display-column-value [entity]=\"entity\" [ComponentClass]=\"dCol.Component\"></display-column-value>\n                </ng-container>\n                <ng-container *ngIf=\"!dCol.Component\">\n                    {{getDisplayColumnValue(entity, dCol)}}\n                </ng-container>\n            </mat-cell>\n        </ng-container>\n\n        <mat-header-row *matHeaderRowDef=\"displayedColumns\"></mat-header-row>\n        <mat-row *matRowDef=\"let row; columns: displayedColumns\"></mat-row>\n    </mat-table>\n\n    <mat-spinner *ngIf=\"isLoading && data.baseData.displayLoadingSpinner\">\n    </mat-spinner>\n\n    <mat-paginator [length]=\"dataSource.filteredData.length\" [pageIndex]=\"0\" [pageSize]=\"10\" [pageSizeOptions]=\"[5, 10, 25, 50]\"></mat-paginator>\n</div>"]}
|