ngx-material-entity 18.0.1 → 18.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +10 -13
- package/components/create-page/create-page.component.d.ts +3 -0
- package/components/custom-table/custom-table-configuration.model.d.ts +65 -0
- package/components/custom-table/custom-table.component.d.ts +111 -0
- package/components/edit-page/edit-page.component.d.ts +8 -1
- package/components/input/array/array-date-input/array-date-input.component.d.ts +2 -2
- package/components/input/array/array-date-range-input/array-date-range-input.component.d.ts +3 -3
- package/components/input/array/array-date-time-input/array-date-time-input.component.d.ts +3 -3
- package/components/input/array/array-table.class.d.ts +25 -19
- package/components/input/file/file-default-input/file-default-input.component.d.ts +1 -1
- package/components/input/file/file-image-input/file-image-input.component.d.ts +3 -0
- package/components/input/file/file-input/file-input.component.d.ts +8 -2
- package/components/input/input.component.d.ts +101 -80
- package/components/input/number/number-dropdown-input/number-dropdown-input.component.d.ts +2 -0
- package/components/input/relations/references-many-input/references-many-input.component.d.ts +14 -17
- package/components/input/string/string-dropdown-input/string-dropdown-input.component.d.ts +2 -0
- package/components/input/string/string-password-input/string-password-input.component.d.ts +3 -0
- package/components/table/edit-dialog/edit-entity-dialog.component.d.ts +5 -5
- package/components/table/table-data.d.ts +9 -4
- package/components/table/table.component.d.ts +15 -37
- package/components/tooltip/tooltip.component.d.ts +2 -0
- package/decorators/array/array-decorator-internal.data.d.ts +8 -3
- package/decorators/array/array-decorator.data.d.ts +45 -88
- package/decorators/base/property-decorator.data.d.ts +2 -2
- package/decorators/file/file-decorator-internal.data.d.ts +3 -2
- package/decorators/file/file-decorator.data.d.ts +4 -3
- package/decorators/references-many/references-many-decorator-internal.data.d.ts +3 -1
- package/decorators/references-many/references-many-decorator.data.d.ts +13 -1
- package/directives/dynamic-style-class.directive.d.ts +4 -5
- package/esm2022/components/confirm-dialog/confirm-dialog.component.mjs +7 -8
- package/esm2022/components/create-page/create-page.component.mjs +17 -11
- package/esm2022/components/custom-table/custom-table-configuration.model.mjs +37 -0
- package/esm2022/components/custom-table/custom-table.component.mjs +213 -0
- package/esm2022/components/edit-page/edit-page.component.mjs +29 -12
- package/esm2022/components/form/form.component.mjs +7 -8
- package/esm2022/components/input/array/array-date-input/array-date-input.component.mjs +17 -21
- package/esm2022/components/input/array/array-date-range-input/array-date-range-input.component.mjs +28 -27
- package/esm2022/components/input/array/array-date-time-input/array-date-time-input.component.mjs +18 -22
- package/esm2022/components/input/array/array-string-autocomplete-chips/array-string-autocomplete-chips.component.mjs +9 -7
- package/esm2022/components/input/array/array-string-chips-input/array-string-chips-input.component.mjs +9 -7
- package/esm2022/components/input/array/array-table.class.mjs +53 -45
- package/esm2022/components/input/base-input.component.mjs +3 -3
- package/esm2022/components/input/boolean/boolean-checkbox-input/boolean-checkbox-input.component.mjs +4 -4
- package/esm2022/components/input/boolean/boolean-dropdown-input/boolean-dropdown-input.component.mjs +3 -3
- package/esm2022/components/input/boolean/boolean-toggle-input/boolean-toggle-input.component.mjs +4 -4
- package/esm2022/components/input/custom/custom.component.mjs +3 -3
- package/esm2022/components/input/date/date-input/date-input.component.mjs +3 -3
- package/esm2022/components/input/date/date-range-input/date-range-input.component.mjs +7 -8
- package/esm2022/components/input/date/date-time-input/date-time-input.component.mjs +6 -6
- package/esm2022/components/input/file/file-default-input/file-default-input.component.mjs +5 -5
- package/esm2022/components/input/file/file-image-input/file-image-input.component.mjs +10 -9
- package/esm2022/components/input/file/file-input/file-input.component.mjs +27 -15
- package/esm2022/components/input/input.component.mjs +162 -114
- package/esm2022/components/input/number/number-dropdown-input/number-dropdown-input.component.mjs +11 -8
- package/esm2022/components/input/number/number-input/number-input.component.mjs +3 -3
- package/esm2022/components/input/number/number-slider-input/number-slider-input.component.mjs +4 -4
- package/esm2022/components/input/relations/references-many-input/references-many-input.component.mjs +46 -57
- package/esm2022/components/input/string/string-autocomplete-input/string-autocomplete-input.component.mjs +6 -7
- package/esm2022/components/input/string/string-dropdown-input/string-dropdown-input.component.mjs +11 -8
- package/esm2022/components/input/string/string-input/string-input.component.mjs +3 -3
- package/esm2022/components/input/string/string-password-input/string-password-input.component.mjs +13 -8
- package/esm2022/components/input/string/string-textbox-input/string-textbox-input.component.mjs +3 -3
- package/esm2022/components/table/create-dialog/create-entity-dialog.component.mjs +9 -10
- package/esm2022/components/table/display-column-value/base-display-column-value.component.mjs +3 -3
- package/esm2022/components/table/display-column-value/display-column-value.component.mjs +3 -3
- package/esm2022/components/table/edit-dialog/edit-data.builder.mjs +1 -1
- package/esm2022/components/table/edit-dialog/edit-entity-dialog.component.mjs +21 -16
- package/esm2022/components/table/table-data.builder.mjs +3 -1
- package/esm2022/components/table/table-data.mjs +1 -1
- package/esm2022/components/table/table.component.mjs +41 -114
- package/esm2022/components/tooltip/tooltip.component.mjs +9 -5
- package/esm2022/decorators/array/array-decorator-internal.data.mjs +18 -3
- package/esm2022/decorators/array/array-decorator.data.mjs +33 -2
- package/esm2022/decorators/array/array.decorator.mjs +15 -8
- package/esm2022/decorators/base/property-decorator.data.mjs +2 -2
- package/esm2022/decorators/file/file-decorator-internal.data.mjs +4 -3
- package/esm2022/decorators/file/file-decorator.data.mjs +3 -3
- package/esm2022/decorators/file/file.decorator.mjs +7 -4
- package/esm2022/decorators/has-many/has-many-decorator-internal.data.mjs +1 -1
- package/esm2022/decorators/number/number.decorator.mjs +7 -4
- package/esm2022/decorators/object/object.decorator.mjs +5 -3
- package/esm2022/decorators/references-many/references-many-decorator-internal.data.mjs +8 -1
- package/esm2022/decorators/references-many/references-many-decorator.data.mjs +1 -1
- package/esm2022/decorators/string/string-decorator-internal.data.mjs +2 -1
- package/esm2022/decorators/string/string.decorator.mjs +11 -6
- package/esm2022/directives/drag-drop.directive.mjs +3 -3
- package/esm2022/directives/dynamic-style-class.directive.mjs +7 -7
- package/esm2022/directives/included-in.directive.mjs +3 -3
- package/esm2022/directives/number.directive.mjs +3 -3
- package/esm2022/directives/password-match.directive.mjs +3 -3
- package/esm2022/directives/tooltip.directive.mjs +7 -4
- package/esm2022/functions/dropdown-values-to-function.function.mjs +2 -1
- package/esm2022/functions/get-changes-tooltip-content.function.mjs +23 -0
- package/esm2022/functions/get-validation-errors-tooltip-content.function.mjs +23 -0
- package/esm2022/functions/table-column-value-to-sort-value.function.mjs +33 -0
- package/esm2022/public-api.mjs +3 -2
- package/esm2022/utilities/date.utilities.mjs +7 -6
- package/esm2022/utilities/entity.utilities.mjs +58 -27
- package/esm2022/utilities/file.utilities.mjs +7 -4
- package/esm2022/utilities/validation.utilities.mjs +41 -21
- package/fesm2022/ngx-material-entity.mjs +2767 -2336
- package/fesm2022/ngx-material-entity.mjs.map +1 -1
- package/functions/get-changes-tooltip-content.function.d.ts +13 -0
- package/functions/table-column-value-to-sort-value.function.d.ts +9 -0
- package/package.json +4 -2
- package/public-api.d.ts +2 -1
- package/utilities/entity.utilities.d.ts +11 -7
- package/esm2022/functions/get-validation-errors-tooltip-content.function.ts.mjs +0 -23
- /package/functions/{get-validation-errors-tooltip-content.function.ts.d.ts → get-validation-errors-tooltip-content.function.d.ts} +0 -0
|
@@ -10,13 +10,15 @@ import { MatDialog, MatDialogModule } from '@angular/material/dialog';
|
|
|
10
10
|
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
11
11
|
import { MatInputModule } from '@angular/material/input';
|
|
12
12
|
import { MatMenuModule } from '@angular/material/menu';
|
|
13
|
-
import {
|
|
13
|
+
import { MatPaginatorModule } from '@angular/material/paginator';
|
|
14
14
|
import { MatProgressSpinnerModule } from '@angular/material/progress-spinner';
|
|
15
15
|
import { MatSelectModule } from '@angular/material/select';
|
|
16
|
-
import { MatSort } from '@angular/material/sort';
|
|
16
|
+
import { MatSort, MatSortModule } from '@angular/material/sort';
|
|
17
17
|
import { MatTableDataSource, MatTableModule } from '@angular/material/table';
|
|
18
18
|
import { MatTabsModule } from '@angular/material/tabs';
|
|
19
19
|
import { Router } from '@angular/router';
|
|
20
|
+
import { FaIconComponent } from '@fortawesome/angular-fontawesome';
|
|
21
|
+
import { faSearch } from '@fortawesome/free-solid-svg-icons';
|
|
20
22
|
import { firstValueFrom } from 'rxjs';
|
|
21
23
|
import { ArrayDateInputComponent } from './array/array-date-input/array-date-input.component';
|
|
22
24
|
import { ArrayDateRangeInputComponent } from './array/array-date-range-input/array-date-range-input.component';
|
|
@@ -44,12 +46,15 @@ import { StringTextboxInputComponent } from './string/string-textbox-input/strin
|
|
|
44
46
|
import { EntityArrayDecoratorConfigInternal } from '../../decorators/array/array-decorator-internal.data';
|
|
45
47
|
import { DecoratorTypes } from '../../decorators/base/decorator-types.enum';
|
|
46
48
|
import { HasManyDecoratorConfigInternal } from '../../decorators/has-many/has-many-decorator-internal.data';
|
|
49
|
+
import { DynamicStyleClassDirective } from '../../directives/dynamic-style-class.directive';
|
|
47
50
|
import { LodashUtilities } from '../../encapsulation/lodash.utilities';
|
|
48
51
|
import { ReflectUtilities } from '../../encapsulation/reflect.utilities';
|
|
49
52
|
import { UUIDUtilities } from '../../encapsulation/uuid.utilities';
|
|
50
53
|
import { defaultFalse } from '../../functions/default-false.function';
|
|
54
|
+
import { getChangesTooltipContent } from '../../functions/get-changes-tooltip-content.function';
|
|
51
55
|
import { NGX_GET_VALIDATION_ERROR_MESSAGE } from '../../functions/get-validation-error-message.function';
|
|
52
|
-
import { getValidationErrorsTooltipContent } from '../../functions/get-validation-errors-tooltip-content.function
|
|
56
|
+
import { getValidationErrorsTooltipContent } from '../../functions/get-validation-errors-tooltip-content.function';
|
|
57
|
+
import { tableColumnValueToSortValue } from '../../functions/table-column-value-to-sort-value.function';
|
|
53
58
|
import { NGX_COMPLETE_GLOBAL_DEFAULT_VALUES } from '../../global-configuration-values';
|
|
54
59
|
import { DateUtilities } from '../../utilities/date.utilities';
|
|
55
60
|
import { EntityUtilities } from '../../utilities/entity.utilities';
|
|
@@ -57,6 +62,7 @@ import { SelectionUtilities } from '../../utilities/selection.utilities';
|
|
|
57
62
|
import { ValidationUtilities } from '../../utilities/validation.utilities';
|
|
58
63
|
import { ConfirmDialogDataBuilder } from '../confirm-dialog/confirm-dialog-data.builder';
|
|
59
64
|
import { NgxMatEntityConfirmDialogComponent } from '../confirm-dialog/confirm-dialog.component';
|
|
65
|
+
import { InternalCustomTableConfiguration } from '../custom-table/custom-table-configuration.model';
|
|
60
66
|
import { CreateDataBuilder } from '../table/create-dialog/create-data.builder';
|
|
61
67
|
import { DisplayColumnValueComponent } from '../table/display-column-value/display-column-value.component';
|
|
62
68
|
import { BaseTableActionInternal } from '../table/table-data.builder';
|
|
@@ -79,6 +85,7 @@ import * as i14 from "@angular/material/progress-spinner";
|
|
|
79
85
|
import * as i15 from "@angular/material/table";
|
|
80
86
|
import * as i16 from "@angular/material/checkbox";
|
|
81
87
|
import * as i17 from "@angular/material/button";
|
|
88
|
+
import * as i18 from "@angular/material/sort";
|
|
82
89
|
/**
|
|
83
90
|
* The default input component. It gets the metadata of the property from the given @Input "entity" and @Input "propertyKey"
|
|
84
91
|
* and displays the input field accordingly.
|
|
@@ -94,6 +101,8 @@ export class NgxMatEntityInputComponent {
|
|
|
94
101
|
defaultGetValidationErrorMessage;
|
|
95
102
|
globalConfig;
|
|
96
103
|
http;
|
|
104
|
+
// eslint-disable-next-line jsdoc/require-jsdoc
|
|
105
|
+
faSearch = faSearch;
|
|
97
106
|
/**
|
|
98
107
|
* The entity on which the property exists. Used in conjunction with the "propertyKey"
|
|
99
108
|
* to determine the property for which the input should be generated.
|
|
@@ -139,6 +148,21 @@ export class NgxMatEntityInputComponent {
|
|
|
139
148
|
* Emits when the input value has been changed.
|
|
140
149
|
*/
|
|
141
150
|
inputChangeEvent = new EventEmitter();
|
|
151
|
+
/**
|
|
152
|
+
* A setter for the has many sort.
|
|
153
|
+
* Is needed because the sort is inside a switch case,
|
|
154
|
+
* which means that at ngOnInit it can't be initialized.
|
|
155
|
+
*/
|
|
156
|
+
set sort(sort) {
|
|
157
|
+
// eslint-disable-next-line typescript/strict-boolean-expressions
|
|
158
|
+
if (this.hasManyTableContext) {
|
|
159
|
+
this.hasManyTableContext.$implicit.dataSource.sort = this.hasManyTableContext.$implicit.dataSource.sort ?? sort;
|
|
160
|
+
}
|
|
161
|
+
// eslint-disable-next-line typescript/strict-boolean-expressions
|
|
162
|
+
if (this.entityArrayTableContext) {
|
|
163
|
+
this.entityArrayTableContext.$implicit.dataSource.sort = this.entityArrayTableContext.$implicit.dataSource.sort ?? sort;
|
|
164
|
+
}
|
|
165
|
+
}
|
|
142
166
|
/**
|
|
143
167
|
* The type of the decorator for this input.
|
|
144
168
|
*/
|
|
@@ -201,9 +225,9 @@ export class NgxMatEntityInputComponent {
|
|
|
201
225
|
*/
|
|
202
226
|
metadataEntityArray;
|
|
203
227
|
/**
|
|
204
|
-
* The entity array
|
|
228
|
+
* The table context for the entity array input.
|
|
205
229
|
*/
|
|
206
|
-
|
|
230
|
+
entityArrayTableContext;
|
|
207
231
|
/**
|
|
208
232
|
* The current array item to be added or updated.
|
|
209
233
|
*/
|
|
@@ -220,18 +244,6 @@ export class NgxMatEntityInputComponent {
|
|
|
220
244
|
* The form context for editing an array item.
|
|
221
245
|
*/
|
|
222
246
|
editArrayItemFormContext;
|
|
223
|
-
/**
|
|
224
|
-
* The dataSource for the entity array.
|
|
225
|
-
*/
|
|
226
|
-
entityArrayDataSource;
|
|
227
|
-
/**
|
|
228
|
-
* The selection for the entity array.
|
|
229
|
-
*/
|
|
230
|
-
entityArraySelection = new SelectionModel(true, []);
|
|
231
|
-
/**
|
|
232
|
-
* The columns to display in the entity array table.
|
|
233
|
-
*/
|
|
234
|
-
entityArrayDisplayedColumns;
|
|
235
247
|
/**
|
|
236
248
|
* Whether or not the array item is valid.
|
|
237
249
|
*/
|
|
@@ -256,6 +268,10 @@ export class NgxMatEntityInputComponent {
|
|
|
256
268
|
* All validation errors for the array item.
|
|
257
269
|
*/
|
|
258
270
|
arrayItemValidationErrors = [];
|
|
271
|
+
/**
|
|
272
|
+
* All the changes that have been done to the array item.
|
|
273
|
+
*/
|
|
274
|
+
arrayItemChanges = [];
|
|
259
275
|
/**
|
|
260
276
|
* What to display inside the array item tooltip.
|
|
261
277
|
*/
|
|
@@ -265,42 +281,9 @@ export class NgxMatEntityInputComponent {
|
|
|
265
281
|
*/
|
|
266
282
|
metadataHasMany;
|
|
267
283
|
/**
|
|
268
|
-
*
|
|
269
|
-
*/
|
|
270
|
-
hasManyIsLoading = true;
|
|
271
|
-
/**
|
|
272
|
-
* A setter for the has many paginator.
|
|
273
|
-
* Is needed because the paginator is inside a switch case,
|
|
274
|
-
* which means that at ngOnInit it can't be initialized.
|
|
275
|
-
*/
|
|
276
|
-
set hasManyPaginator(paginator) {
|
|
277
|
-
if (!this.hasManyDataSource.paginator) {
|
|
278
|
-
this.hasManyDataSource.paginator = paginator;
|
|
279
|
-
}
|
|
280
|
-
}
|
|
281
|
-
/**
|
|
282
|
-
* A setter for the has many sort.
|
|
283
|
-
* Is needed because the sort is inside a switch case,
|
|
284
|
-
* which means that at ngOnInit it can't be initialized.
|
|
285
|
-
*/
|
|
286
|
-
set hasManySort(sort) {
|
|
287
|
-
if (!this.hasManyDataSource.sort) {
|
|
288
|
-
this.hasManyDataSource.sort = sort;
|
|
289
|
-
}
|
|
290
|
-
}
|
|
291
|
-
hasManyFilter;
|
|
292
|
-
/**
|
|
293
|
-
* The columns of the has many table.
|
|
294
|
-
*/
|
|
295
|
-
displayedHasManyColumns;
|
|
296
|
-
/**
|
|
297
|
-
* The data source of the has many table.
|
|
298
|
-
*/
|
|
299
|
-
hasManyDataSource = new MatTableDataSource();
|
|
300
|
-
/**
|
|
301
|
-
* The selection of the has many table.
|
|
284
|
+
* The table context for the has many input.
|
|
302
285
|
*/
|
|
303
|
-
|
|
286
|
+
hasManyTableContext;
|
|
304
287
|
/**
|
|
305
288
|
* The has many import action.
|
|
306
289
|
*/
|
|
@@ -326,6 +309,10 @@ export class NgxMatEntityInputComponent {
|
|
|
326
309
|
* All validation errors of the has many entity.
|
|
327
310
|
*/
|
|
328
311
|
hasManyValidationErrors = [];
|
|
312
|
+
/**
|
|
313
|
+
* All the changes that have been done to the has many entity.
|
|
314
|
+
*/
|
|
315
|
+
hasManyChanges = [];
|
|
329
316
|
/**
|
|
330
317
|
* What to display inside the has many tooltip.
|
|
331
318
|
*/
|
|
@@ -442,6 +429,18 @@ export class NgxMatEntityInputComponent {
|
|
|
442
429
|
getDisplayColumnValue(entity, displayColumn) {
|
|
443
430
|
return runInInjectionContext(this.injector, () => displayColumn.value(entity));
|
|
444
431
|
}
|
|
432
|
+
/**
|
|
433
|
+
* Emits a cellClicked event when the clicked column is enabled and clicking is allowed by the configuration.
|
|
434
|
+
* @param value - The value of the row that was clicked.
|
|
435
|
+
* @param dCol - The display column of the row that was clicked.
|
|
436
|
+
* @param context - The context of the table where the cell was clicked.
|
|
437
|
+
*/
|
|
438
|
+
clickCell(value, dCol, context) {
|
|
439
|
+
if (dCol.disableClick == true || !context.allowClick(value)) {
|
|
440
|
+
return;
|
|
441
|
+
}
|
|
442
|
+
context.clickCell(value, dCol);
|
|
443
|
+
}
|
|
445
444
|
ngOnInit() {
|
|
446
445
|
this.internalGetValidationErrorMessage = this.getValidationErrorMessage ?? this.defaultGetValidationErrorMessage;
|
|
447
446
|
this.internalIsReadOnly = this.isReadOnly ?? false;
|
|
@@ -460,23 +459,29 @@ export class NgxMatEntityInputComponent {
|
|
|
460
459
|
}
|
|
461
460
|
this.metadata = foundMetadata;
|
|
462
461
|
switch (this.type) {
|
|
463
|
-
case DecoratorTypes.OBJECT_DROPDOWN:
|
|
462
|
+
case DecoratorTypes.OBJECT_DROPDOWN: {
|
|
464
463
|
void this.initDropdownObjectInput();
|
|
465
464
|
break;
|
|
466
|
-
|
|
465
|
+
}
|
|
466
|
+
case DecoratorTypes.OBJECT: {
|
|
467
467
|
this.initObjectInput();
|
|
468
468
|
break;
|
|
469
|
-
|
|
469
|
+
}
|
|
470
|
+
case DecoratorTypes.ARRAY: {
|
|
470
471
|
this.initEntityArray();
|
|
471
472
|
break;
|
|
472
|
-
|
|
473
|
+
}
|
|
474
|
+
case DecoratorTypes.HAS_MANY: {
|
|
473
475
|
this.initHasMany();
|
|
474
476
|
break;
|
|
475
|
-
|
|
477
|
+
}
|
|
478
|
+
case DecoratorTypes.REFERENCES_ONE: {
|
|
476
479
|
void this.initReferencesOne();
|
|
477
480
|
break;
|
|
478
|
-
|
|
481
|
+
}
|
|
482
|
+
default: {
|
|
479
483
|
break;
|
|
484
|
+
}
|
|
480
485
|
}
|
|
481
486
|
}
|
|
482
487
|
async initReferencesOne() {
|
|
@@ -513,35 +518,55 @@ export class NgxMatEntityInputComponent {
|
|
|
513
518
|
this.hasManyCreateBaseUrl = this.metadataHasMany.createBaseUrl(this.entity, this.metadataHasMany);
|
|
514
519
|
});
|
|
515
520
|
const givenDisplayColumns = this.metadataHasMany.tableData.baseData.displayColumns.map((v) => v.displayName);
|
|
516
|
-
|
|
517
|
-
|
|
518
|
-
|
|
519
|
-
}
|
|
520
|
-
else {
|
|
521
|
-
this.displayedHasManyColumns = givenDisplayColumns;
|
|
521
|
+
if (givenDisplayColumns.find(s => s === 'select')) {
|
|
522
|
+
throw new Error(`The name "select" for a display column is reserved.
|
|
523
|
+
Please choose a different name.`);
|
|
522
524
|
}
|
|
523
|
-
this.
|
|
525
|
+
this.hasManyTableContext = {
|
|
526
|
+
$implicit: {
|
|
527
|
+
...new InternalCustomTableConfiguration(this.globalConfig, {
|
|
528
|
+
displayColumns: this.metadataHasMany.tableData.baseData.displayColumns,
|
|
529
|
+
withSelection: !this.internalIsReadOnly,
|
|
530
|
+
// eslint-disable-next-line stylistic/max-len
|
|
531
|
+
dynamicRowStyleClasses: this.metadataHasMany.tableData.baseData.dynamicRowStyleClasses,
|
|
532
|
+
allowClick: ((entity) => {
|
|
533
|
+
return this.metadataHasMany.tableData.baseData.allowRead(entity)
|
|
534
|
+
|| this.metadataHasMany.tableData.baseData.allowUpdate(entity);
|
|
535
|
+
}),
|
|
536
|
+
displayLoadingSpinner: this.metadataHasMany.tableData.baseData.displayLoadingSpinner,
|
|
537
|
+
searchStringForRow: this.metadataHasMany.tableData.baseData.searchString
|
|
538
|
+
}),
|
|
539
|
+
displayedColumns: !this.metadataHasMany.tableData.baseData.tableActions.filter(tA => tA.type === 'multi-select').length
|
|
540
|
+
? givenDisplayColumns
|
|
541
|
+
: ['select'].concat(givenDisplayColumns),
|
|
542
|
+
dataSource: new MatTableDataSource(),
|
|
543
|
+
isLoading: true,
|
|
544
|
+
shouldShowMissingError: false,
|
|
545
|
+
selection: new SelectionModel(true, []),
|
|
546
|
+
clickCell: (entity, dCol) => this.editHasManyEntity(entity, dCol)
|
|
547
|
+
}
|
|
548
|
+
};
|
|
549
|
+
this.hasManyTableContext.$implicit.dataSource.sortingDataAccessor = (entity, header) => {
|
|
524
550
|
return runInInjectionContext(this.injector, () => {
|
|
525
|
-
|
|
526
|
-
.find((dp) => dp.displayName === header)
|
|
527
|
-
|
|
551
|
+
const displayColumn = this.metadataHasMany.tableData.baseData.displayColumns
|
|
552
|
+
.find((dp) => dp.displayName === header);
|
|
553
|
+
return tableColumnValueToSortValue(displayColumn.value(entity));
|
|
528
554
|
});
|
|
529
555
|
};
|
|
530
|
-
this.
|
|
556
|
+
this.hasManyTableContext.$implicit.dataSource.filterPredicate = (entity, filter) => {
|
|
531
557
|
const searchStr = this.metadataHasMany.tableData.baseData.searchString(entity);
|
|
532
558
|
const formattedSearchString = searchStr.toLowerCase();
|
|
533
559
|
const formattedFilterString = filter.toLowerCase();
|
|
534
560
|
return formattedSearchString.includes(formattedFilterString);
|
|
535
561
|
};
|
|
536
|
-
this.hasManyDataSource.filter = this.hasManyFilter;
|
|
537
562
|
this.hasManyEntityService.entitiesSubject.subscribe((entities) => {
|
|
538
|
-
this.
|
|
539
|
-
this.
|
|
563
|
+
this.hasManyTableContext.$implicit.dataSource.data = entities;
|
|
564
|
+
this.hasManyTableContext.$implicit.selection.clear();
|
|
540
565
|
});
|
|
541
566
|
void runInInjectionContext(this.injector, async () => {
|
|
542
567
|
const readBaseUrl = this.metadataHasMany.readBaseUrl(this.entity, this.metadataHasMany);
|
|
543
568
|
await this.hasManyEntityService.read(readBaseUrl);
|
|
544
|
-
this.
|
|
569
|
+
this.hasManyTableContext.$implicit.isLoading = false;
|
|
545
570
|
});
|
|
546
571
|
}
|
|
547
572
|
initEntityArray() {
|
|
@@ -551,7 +576,6 @@ export class NgxMatEntityInputComponent {
|
|
|
551
576
|
if (this.entity[this.propertyKey] == undefined) {
|
|
552
577
|
this.entity[this.propertyKey] = [];
|
|
553
578
|
}
|
|
554
|
-
this.entityArrayValues = this.entity[this.propertyKey];
|
|
555
579
|
if (!this.metadataEntityArray.createInline && !this.metadataEntityArray.createDialogData) {
|
|
556
580
|
this.metadataEntityArray.createDialogData = {
|
|
557
581
|
title: 'Add'
|
|
@@ -562,9 +586,24 @@ export class NgxMatEntityInputComponent {
|
|
|
562
586
|
throw new Error(`The name "select" for a display column is reserved.
|
|
563
587
|
Please choose a different name.`);
|
|
564
588
|
}
|
|
565
|
-
this.
|
|
566
|
-
|
|
567
|
-
|
|
589
|
+
this.entityArrayTableContext = {
|
|
590
|
+
$implicit: {
|
|
591
|
+
...new InternalCustomTableConfiguration(this.globalConfig, {
|
|
592
|
+
displayColumns: this.metadataEntityArray.displayColumns,
|
|
593
|
+
withSelection: !this.internalIsReadOnly,
|
|
594
|
+
dynamicRowStyleClasses: this.metadataEntityArray.dynamicRowStyleClasses,
|
|
595
|
+
emptyErrorMessage: this.metadataEntityArray.missingErrorMessage
|
|
596
|
+
}),
|
|
597
|
+
displayedColumns: this.internalIsReadOnly ? givenDisplayColumns : ['select'].concat(givenDisplayColumns),
|
|
598
|
+
dataSource: new MatTableDataSource(),
|
|
599
|
+
isLoading: false,
|
|
600
|
+
shouldShowMissingError: true,
|
|
601
|
+
selection: new SelectionModel(true, []),
|
|
602
|
+
// eslint-disable-next-line typescript/no-misused-promises
|
|
603
|
+
clickCell: (entity, dCol) => this.editArrayItem(entity, dCol)
|
|
604
|
+
}
|
|
605
|
+
};
|
|
606
|
+
this.entityArrayTableContext.$implicit.dataSource.data = this.entity[this.propertyKey];
|
|
568
607
|
this.arrayItem = new this.metadataEntityArray.EntityClass();
|
|
569
608
|
this.arrayItemPriorChanges = LodashUtilities.cloneDeep(this.arrayItem);
|
|
570
609
|
EntityUtilities.setDefaultValues(this.arrayItem);
|
|
@@ -807,11 +846,11 @@ export class NgxMatEntityInputComponent {
|
|
|
807
846
|
});
|
|
808
847
|
const res = await firstValueFrom(this.editHasManyDialogRef.afterClosed());
|
|
809
848
|
if (res === 0) {
|
|
810
|
-
const data = this.
|
|
849
|
+
const data = this.hasManyTableContext.$implicit.dataSource.data;
|
|
811
850
|
// eslint-disable-next-line stylistic/max-len
|
|
812
|
-
data[this.
|
|
813
|
-
this.
|
|
814
|
-
this.
|
|
851
|
+
data[this.hasManyTableContext.$implicit.dataSource.data.findIndex((e) => e[this.hasManyEntityService.idKey] === entity[this.hasManyEntityService.idKey])] = entity;
|
|
852
|
+
this.hasManyTableContext.$implicit.dataSource.data = data;
|
|
853
|
+
this.hasManyTableContext.$implicit.selection.clear();
|
|
815
854
|
}
|
|
816
855
|
}
|
|
817
856
|
/**
|
|
@@ -976,13 +1015,13 @@ export class NgxMatEntityInputComponent {
|
|
|
976
1015
|
* @param action - The TableAction to run.
|
|
977
1016
|
*/
|
|
978
1017
|
async runHasManyTableAction(action) {
|
|
979
|
-
const requireConfirmDialog = runInInjectionContext(this.injector, () => action.requireConfirmDialog(this.
|
|
1018
|
+
const requireConfirmDialog = runInInjectionContext(this.injector, () => action.requireConfirmDialog(this.hasManyTableContext.$implicit.selection.selected));
|
|
980
1019
|
if (!requireConfirmDialog) {
|
|
981
1020
|
await this.confirmRunHasManyTableAction(action);
|
|
982
1021
|
return;
|
|
983
1022
|
}
|
|
984
1023
|
const defaultText = action.type === 'multi-select'
|
|
985
|
-
? this.globalConfig.confirmMultiSelectActionText(this.
|
|
1024
|
+
? this.globalConfig.confirmMultiSelectActionText(this.hasManyTableContext.$implicit.selection.selected)
|
|
986
1025
|
: this.globalConfig.confirmBaseActionText;
|
|
987
1026
|
const dialogData = new ConfirmDialogDataBuilder(this.globalConfig, action.confirmDialogData)
|
|
988
1027
|
.withDefault('text', defaultText)
|
|
@@ -1000,7 +1039,7 @@ export class NgxMatEntityInputComponent {
|
|
|
1000
1039
|
}
|
|
1001
1040
|
async confirmRunHasManyTableAction(action) {
|
|
1002
1041
|
await runInInjectionContext(this.injector, async () => {
|
|
1003
|
-
await action.action(this.
|
|
1042
|
+
await action.action(this.hasManyTableContext.$implicit.selection.selected);
|
|
1004
1043
|
this.emitChange();
|
|
1005
1044
|
});
|
|
1006
1045
|
}
|
|
@@ -1011,7 +1050,7 @@ export class NgxMatEntityInputComponent {
|
|
|
1011
1050
|
*/
|
|
1012
1051
|
hasManyTableActionDisabled(action) {
|
|
1013
1052
|
return runInInjectionContext(this.injector, () => {
|
|
1014
|
-
return !action.enabled(this.
|
|
1053
|
+
return !action.enabled(this.hasManyTableContext.$implicit.selection.selected);
|
|
1015
1054
|
});
|
|
1016
1055
|
}
|
|
1017
1056
|
/**
|
|
@@ -1020,14 +1059,18 @@ export class NgxMatEntityInputComponent {
|
|
|
1020
1059
|
*/
|
|
1021
1060
|
applyHasManyFilter(event) {
|
|
1022
1061
|
const filterValue = event.target.value;
|
|
1023
|
-
this.
|
|
1062
|
+
this.hasManyTableContext.$implicit.dataSource.filter = filterValue.trim().toLowerCase();
|
|
1024
1063
|
}
|
|
1025
1064
|
/**
|
|
1026
1065
|
* Checks if the entity is valid for updating and if it is dirty.
|
|
1027
1066
|
*/
|
|
1028
1067
|
async checkHasManyEntity() {
|
|
1029
1068
|
await this.checkIsHasManyEntityValid('update');
|
|
1030
|
-
this.
|
|
1069
|
+
this.hasManyChanges = await EntityUtilities.getDifferencesBetweenEntities(this.hasManyEntity, this.hasManyEntityPriorChanges, this.http, this.injector);
|
|
1070
|
+
if (!this.hasManyValidationErrors.length && this.hasManyChanges.length) {
|
|
1071
|
+
this.hasManyTooltipContent = runInInjectionContext(this.injector, () => getChangesTooltipContent(this.hasManyChanges));
|
|
1072
|
+
}
|
|
1073
|
+
this.isHasManyEntityDirty = !!this.hasManyChanges.length;
|
|
1031
1074
|
}
|
|
1032
1075
|
/**
|
|
1033
1076
|
* Checks if the entity is valid.
|
|
@@ -1035,7 +1078,9 @@ export class NgxMatEntityInputComponent {
|
|
|
1035
1078
|
*/
|
|
1036
1079
|
async checkIsHasManyEntityValid(omit) {
|
|
1037
1080
|
this.hasManyValidationErrors = await ValidationUtilities.getEntityValidationErrors(this.hasManyEntity, this.injector, omit);
|
|
1038
|
-
|
|
1081
|
+
if (this.hasManyValidationErrors.length) {
|
|
1082
|
+
this.hasManyTooltipContent = runInInjectionContext(this.injector, () => getValidationErrorsTooltipContent(this.hasManyValidationErrors));
|
|
1083
|
+
}
|
|
1039
1084
|
this.isHasManyEntityValid = this.hasManyValidationErrors.length === 0;
|
|
1040
1085
|
}
|
|
1041
1086
|
/**
|
|
@@ -1049,14 +1094,20 @@ export class NgxMatEntityInputComponent {
|
|
|
1049
1094
|
* Checks if the array item is dirty.
|
|
1050
1095
|
*/
|
|
1051
1096
|
async checkIsArrayItemDirty() {
|
|
1052
|
-
this.
|
|
1097
|
+
this.arrayItemChanges = await EntityUtilities.getDifferencesBetweenEntities(this.arrayItem, this.arrayItemPriorChanges, this.http, this.injector);
|
|
1098
|
+
if (!this.arrayItemValidationErrors.length && this.arrayItemChanges.length) {
|
|
1099
|
+
this.arrayItemTooltipContent = runInInjectionContext(this.injector, () => getChangesTooltipContent(this.arrayItemChanges));
|
|
1100
|
+
}
|
|
1101
|
+
this.isArrayItemDirty = !!this.arrayItemChanges.length;
|
|
1053
1102
|
}
|
|
1054
1103
|
/**
|
|
1055
1104
|
* Checks if the arrayItem is valid.
|
|
1056
1105
|
*/
|
|
1057
1106
|
async checkIsArrayItemValid() {
|
|
1058
1107
|
this.arrayItemValidationErrors = await ValidationUtilities.getEntityValidationErrors(this.arrayItem, this.injector, 'create');
|
|
1059
|
-
|
|
1108
|
+
if (this.arrayItemValidationErrors.length) {
|
|
1109
|
+
this.arrayItemTooltipContent = runInInjectionContext(this.injector, () => getValidationErrorsTooltipContent(this.arrayItemValidationErrors));
|
|
1110
|
+
}
|
|
1060
1111
|
this.isArrayItemValid = this.arrayItemValidationErrors.length === 0;
|
|
1061
1112
|
}
|
|
1062
1113
|
/**
|
|
@@ -1081,7 +1132,7 @@ export class NgxMatEntityInputComponent {
|
|
|
1081
1132
|
return;
|
|
1082
1133
|
}
|
|
1083
1134
|
if (!this.metadataEntityArray.allowDuplicates) {
|
|
1084
|
-
for (const v of this.
|
|
1135
|
+
for (const v of this.entityArrayTableContext.$implicit.dataSource.data) {
|
|
1085
1136
|
if (await EntityUtilities.isEqual(this.arrayItem, v, this.metadata, this.metadataEntityArray.itemType, this.http)) {
|
|
1086
1137
|
this.dialog.open(NgxMatEntityConfirmDialogComponent, {
|
|
1087
1138
|
data: this.metadataEntityArray.duplicatesErrorDialog,
|
|
@@ -1092,8 +1143,8 @@ export class NgxMatEntityInputComponent {
|
|
|
1092
1143
|
}
|
|
1093
1144
|
}
|
|
1094
1145
|
}
|
|
1095
|
-
this.
|
|
1096
|
-
this.
|
|
1146
|
+
this.entity[this.propertyKey].push(LodashUtilities.cloneDeep(this.arrayItem));
|
|
1147
|
+
this.entityArrayTableContext.$implicit.dataSource.data = this.entity[this.propertyKey];
|
|
1097
1148
|
EntityUtilities.resetChangesOnEntity(this.arrayItem, this.arrayItemPriorChanges);
|
|
1098
1149
|
EntityUtilities.setDefaultValues(this.arrayItem);
|
|
1099
1150
|
await this.checkIsArrayItemValid();
|
|
@@ -1106,8 +1157,8 @@ export class NgxMatEntityInputComponent {
|
|
|
1106
1157
|
if (!this.isArrayItemValid) {
|
|
1107
1158
|
return;
|
|
1108
1159
|
}
|
|
1109
|
-
this.
|
|
1110
|
-
this.
|
|
1160
|
+
this.entity[this.propertyKey].push(LodashUtilities.cloneDeep(this.arrayItem));
|
|
1161
|
+
this.entityArrayTableContext.$implicit.dataSource.data = this.entity[this.propertyKey];
|
|
1111
1162
|
await this.closeAddArrayItemDialog();
|
|
1112
1163
|
}
|
|
1113
1164
|
/**
|
|
@@ -1128,7 +1179,7 @@ export class NgxMatEntityInputComponent {
|
|
|
1128
1179
|
if (dCol.disableClick === true) {
|
|
1129
1180
|
return;
|
|
1130
1181
|
}
|
|
1131
|
-
this.indexOfEditedArrayItem = this.
|
|
1182
|
+
this.indexOfEditedArrayItem = this.entityArrayTableContext.$implicit.dataSource.data.indexOf(entity);
|
|
1132
1183
|
this.arrayItem = new this.metadataEntityArray.EntityClass(entity);
|
|
1133
1184
|
this.arrayItemPriorChanges = LodashUtilities.cloneDeep(this.arrayItem);
|
|
1134
1185
|
await this.checkArrayItem();
|
|
@@ -1142,8 +1193,8 @@ export class NgxMatEntityInputComponent {
|
|
|
1142
1193
|
* Saves changes on the array item in the dialog.
|
|
1143
1194
|
*/
|
|
1144
1195
|
saveArrayItem() {
|
|
1145
|
-
this.
|
|
1146
|
-
this.
|
|
1196
|
+
this.entity[this.propertyKey][this.indexOfEditedArrayItem] = LodashUtilities.cloneDeep(this.arrayItem);
|
|
1197
|
+
this.entityArrayTableContext.$implicit.dataSource.data = this.entity[this.propertyKey];
|
|
1147
1198
|
void this.closeEditArrayItemDialog();
|
|
1148
1199
|
}
|
|
1149
1200
|
/**
|
|
@@ -1160,13 +1211,13 @@ export class NgxMatEntityInputComponent {
|
|
|
1160
1211
|
* Removes all selected entries from the entity array.
|
|
1161
1212
|
*/
|
|
1162
1213
|
removeFromEntityArray() {
|
|
1163
|
-
SelectionUtilities.remove(this.
|
|
1214
|
+
SelectionUtilities.remove(this.entityArrayTableContext.$implicit.selection, this.entity[this.propertyKey], this.entityArrayTableContext.$implicit.dataSource);
|
|
1164
1215
|
this.emitChange();
|
|
1165
1216
|
}
|
|
1166
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.
|
|
1167
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: NgxMatEntityInputComponent, isStandalone: true, selector: "ngx-mat-entity-input", inputs: { entity: "entity", propertyKey: "propertyKey", getValidationErrorMessage: "getValidationErrorMessage", hideOmitForCreate: "hideOmitForCreate", hideOmitForEdit: "hideOmitForEdit", validEmpty: "validEmpty", isReadOnly: "isReadOnly" }, outputs: { inputChangeEvent: "inputChangeEvent" }, viewQueries: [{ propertyName: "addArrayItemDialog", first: true, predicate: ["addArrayItemDialog"], descendants: true }, { propertyName: "editArrayItemDialog", first: true, predicate: ["editArrayItemDialog"], descendants: true }, { propertyName: "hasManyPaginator", first: true, predicate: MatPaginator, descendants: true }, { propertyName: "hasManySort", first: true, predicate: MatSort, descendants: true }, { propertyName: "hasManyFilter", first: true, predicate: ["filter"], descendants: true, static: true }, { propertyName: "createHasManyDialog", first: true, predicate: ["createHasManyDialog"], descendants: true }, { propertyName: "editHasManyDialog", first: true, predicate: ["editHasManyDialog"], descendants: true }], ngImport: i0, template: "<!-- eslint-disable angular/no-call-expression -->\n \n@if(!(hideOmitForCreate && metadata.omitForCreate) && !(hideOmitForEdit && metadata.omitForUpdate)) {\n @switch (type) {\n <!-------------------------------------------->\n <!-----------------Strings-------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.STRING) {\n <string-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </string-input>\n }\n @case (DecoratorTypes.STRING_TEXTBOX) {\n <string-textbox-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </string-textbox-input>\n }\n @case (DecoratorTypes.STRING_AUTOCOMPLETE) {\n <string-autocomplete-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </string-autocomplete-input>\n }\n @case (DecoratorTypes.STRING_DROPDOWN) {\n <string-dropdown-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </string-dropdown-input>\n }\n @case (DecoratorTypes.STRING_PASSWORD) {\n <string-password-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </string-password-input>\n }\n <!-------------------------------------------->\n <!-----------------Booleans------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.BOOLEAN_CHECKBOX) {\n <boolean-checkbox-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </boolean-checkbox-input>\n }\n @case (DecoratorTypes.BOOLEAN_TOGGLE) {\n <boolean-toggle-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </boolean-toggle-input>\n }\n @case (DecoratorTypes.BOOLEAN_DROPDOWN) {\n <boolean-dropdown-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </boolean-dropdown-input>\n }\n <!-------------------------------------------->\n <!------------------Numbers------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.NUMBER) {\n <number-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </number-input>\n }\n @case (DecoratorTypes.NUMBER_DROPDOWN) {\n <number-dropdown-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </number-dropdown-input>\n }\n @case (DecoratorTypes.NUMBER_SLIDER) {\n <number-slider-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </number-slider-input>\n }\n <!-------------------------------------------->\n <!-------------------Array-------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.ARRAY_DATE) {\n <array-date-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </array-date-input>\n }\n @case (DecoratorTypes.ARRAY_DATE_TIME) {\n <array-date-time-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </array-date-time-input>\n }\n @case (DecoratorTypes.ARRAY_DATE_RANGE) {\n <array-date-range-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </array-date-range-input>\n }\n @case (DecoratorTypes.ARRAY_STRING_CHIPS) {\n <array-string-chips-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </array-string-chips-input>\n }\n @case (DecoratorTypes.ARRAY_STRING_AUTOCOMPLETE_CHIPS) {\n <array-string-autocomplete-chips\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </array-string-autocomplete-chips>\n }\n <!-------------------------------------------->\n <!-------------------Dates-------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.DATE) {\n <date-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </date-input>\n }\n @case (DecoratorTypes.DATE_RANGE) {\n <date-range-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </date-range-input>\n }\n @case (DecoratorTypes.DATE_TIME) {\n <date-time-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </date-time-input>\n }\n <!-------------------------------------------->\n <!-------------------Files-------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.FILE_DEFAULT) {\n <file-default-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </file-default-input>\n }\n @case (DecoratorTypes.FILE_IMAGE) {\n <file-image-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </file-image-input>\n }\n <!-------------------------------------------->\n <!-------------- references many ------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.REFERENCES_MANY) {\n <references-many-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </references-many-input>\n }\n <!-------------------------------------------->\n <!-------------------Custom------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.CUSTOM) {\n <custom-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </custom-input>\n }\n <!-------------------------------------------->\n <!-------------------Object------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.OBJECT) {\n <b>{{metadataDefaultObject.displayName}}</b>\n <!-- iterates over the object properties -->\n <ng-container *ngTemplateOutlet=\"form; context: objectFormContext\"></ng-container>\n }\n <!-------------------------------------------->\n <!---------------Object Dropdown-------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.OBJECT_DROPDOWN) {\n <mat-form-field class=\"object-dropdown\">\n <mat-label>{{metadata.displayName}}</mat-label>\n <mat-select #model=\"ngModel\"\n [name]=\"objectDropdownName\"\n [required]=\"metadata.required(entity)\"\n [disabled]=\"internalIsReadOnly\"\n [compareWith]=\"compareObjectsBound\"\n [(ngModel)]=\"entity[propertyKey]\"\n (selectionChange)=\"emitChange()\"\n (opened)=\"selectSearchInput.focus()\"\n >\n <mat-form-field class=\"select-search-input\">\n <!-- eslint-disable-next-line angular/no-any -->\n <input #selectSearchInput matInput (keyup)=\"filterObjectDropdownValues($any($event.target).value)\">\n <i matSuffix class=\"fas fa-search\"></i>\n </mat-form-field>\n @if (!metadata.required(entity)) {\n <mat-option>-</mat-option>\n }\n @if (shouldDisplayCurrentObjectDropdownValue) {\n <mat-option [value]=\"currentObjectDropdownValue?.value\">{{currentObjectDropdownValue?.displayName}}</mat-option>\n }\n @for (value of filteredObjectDropdownValues; track $index) {\n <mat-option [value]=\"value.value\">{{value.displayName}}</mat-option>\n }\n </mat-select>\n <mat-error>{{internalGetValidationErrorMessage(model)}}</mat-error>\n </mat-form-field>\n }\n <!-------------------------------------------->\n <!-------------- references one -------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.REFERENCES_ONE) {\n <mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <mat-select #inputModel=\"ngModel\"\n [name]=\"referencesOneName\"\n [disabled]=\"internalIsReadOnly\"\n [required]=\"metadata.required(entity)\"\n [(ngModel)]=\"entity[propertyKey]\"\n (selectionChange)=\"setReferencesOneObject()\"\n (opened)=\"selectSearchInput.focus()\"\n >\n <mat-form-field class=\"select-search-input\">\n <!-- eslint-disable-next-line angular/no-any -->\n <input #selectSearchInput matInput (keyup)=\"filterReferencesOneValues($any($event.target).value)\">\n <i matSuffix class=\"fas fa-search\"></i>\n </mat-form-field>\n @if (!metadata.required(entity)) {\n <mat-option>-</mat-option>\n }\n @if (shouldDisplayCurrentReferencesOneDropdownValue) {\n <mat-option [value]=\"currentReferencesOneDropdownValue?.value\">{{currentReferencesOneDropdownValue?.displayName}}</mat-option>\n }\n @for (value of filteredReferencesOneDropdownValues; track $index) {\n <mat-option [value]=\"value.value\">{{value.displayName}}</mat-option>\n }\n </mat-select>\n <mat-error>{{internalGetValidationErrorMessage(inputModel)}}</mat-error>\n </mat-form-field>\n <!-- iterates over the references one properties -->\n @if (referencesOneFormContext) {\n <ng-container *ngTemplateOutlet=\"form; context: referencesOneFormContext\"></ng-container>\n }\n }\n <!-------------------------------------------->\n <!-------------------Array-------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.ARRAY) {\n <div class=\"entityArray\">\n <div class=\"mat-elevation-z8 elevation-container\">\n <div class=\"array-headline\">\n <b>{{metadataEntityArray.displayName}}</b>\n </div>\n @if (metadataEntityArray.createInline && !internalIsReadOnly && addArrayItemFormContext) {\n <ng-container *ngTemplateOutlet=\"form; context: addArrayItemFormContext\"></ng-container>\n }\n @if (!internalIsReadOnly) {\n <div class=\"buttons\">\n <button type=\"button\" mat-raised-button\n [disabled]=\"metadataEntityArray.createInline && !isArrayItemValid\"\n (click)=\"addEntity()\">\n {{metadataEntityArray.addButtonLabel}}\n </button>\n <button type=\"button\" mat-raised-button\n [disabled]=\"!entityArraySelection.selected.length\"\n (click)=\"removeFromEntityArray()\">\n {{metadataEntityArray.removeButtonLabel}}\n </button>\n </div>\n }\n <mat-table [dataSource]=\"entityArrayDataSource\">\n @if (!internalIsReadOnly) {\n <ng-container matColumnDef=\"select\">\n <mat-header-cell *matHeaderCellDef>\n <mat-checkbox\n [disabled]=\"!entityArrayDataSource.data.length\" [checked]=\"entityArraySelection.hasValue() && SelectionUtilities.isAllSelected(entityArraySelection, entityArrayDataSource)\"\n [indeterminate]=\"entityArraySelection.hasValue() && !SelectionUtilities.isAllSelected(entityArraySelection, entityArrayDataSource)\"\n (change)=\"$event ? SelectionUtilities.masterToggle(entityArraySelection, entityArrayDataSource) : null\">\n </mat-checkbox>\n </mat-header-cell>\n <mat-cell *matCellDef=\"let entity\">\n <mat-checkbox [checked]=\"entityArraySelection.isSelected(entity)\" (click)=\"$event.stopPropagation()\" (change)=\"$event ? entityArraySelection.toggle(entity) : null\"></mat-checkbox>\n </mat-cell>\n </ng-container>\n }\n @for (dCol of metadataEntityArray.displayColumns; track $index) {\n <ng-container [matColumnDef]=\"dCol.displayName\">\n <mat-header-cell *matHeaderCellDef>\n {{dCol.displayName}}\n </mat-header-cell>\n <mat-cell *matCellDef=\"let entity\" [class.enabled]=\"!dCol.disableClick\" (click)=\"editArrayItem(entity, dCol)\">\n @if (dCol.Component) {\n <display-column-value [entity]=\"entity\" [ComponentClass]=\"dCol.Component\"></display-column-value>\n }\n @else {\n {{getDisplayColumnValue(entity, dCol)}}\n }\n </mat-cell>\n </ng-container>\n }\n <mat-header-row *matHeaderRowDef=\"entityArrayDisplayedColumns\"></mat-header-row>\n <mat-row *matRowDef=\"let row; columns: entityArrayDisplayedColumns\"></mat-row>\n </mat-table>\n \n @if (metadataEntityArray.required(entity) && !entityArrayDataSource.data.length) {\n <div class=\"array-error\">{{metadataEntityArray.missingErrorMessage}}</div>\n }\n </div>\n </div>\n }\n <!-------------------------------------------->\n <!------------------ has many ---------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.HAS_MANY) {\n <div class=\"hasMany\">\n <h2 class=\"title\">{{metadataHasMany.tableData.baseData.title}}</h2>\n <div class=\"row\">\n <mat-form-field class=\"col-lg-8 col-md-6 col-sm-12\">\n <mat-label>{{metadataHasMany.tableData.baseData.searchLabel}}</mat-label>\n <input matInput (keyup)=\"applyHasManyFilter($event)\">\n </mat-form-field>\n @if (metadataHasMany.tableData.baseData.tableActions.length) {\n <div\n [class.col-lg-2]=\"hasManyAllowCreate\"\n [class.col-lg-4]=\"!hasManyAllowCreate\"\n [class.col-md-3]=\"hasManyAllowCreate\"\n [class.col-md-6]=\"!hasManyAllowCreate\"\n [class.col-sm-6]=\"hasManyAllowCreate\"\n [class.col-sm-12]=\"!hasManyAllowCreate\"\n >\n <button type=\"button\" class=\"actions-button\" mat-raised-button [matMenuTriggerFor]=\"menu\">\n {{metadataHasMany.tableData.baseData.tableActionsLabel}}\n </button>\n </div>\n }\n <mat-menu #menu=\"matMenu\">\n @if (metadataHasMany.tableData.baseData.allowJsonImport) {\n <button type=\"button\" mat-menu-item [disabled]=\"hasManyTableActionDisabled(hasManyImportAction)\" (click)=\"runHasManyTableAction(hasManyImportAction)\">\n {{hasManyImportAction.displayName}}\n </button>\n }\n @for (action of metadataHasMany.tableData.baseData.tableActions; track $index) {\n <button type=\"button\" mat-menu-item [disabled]=\"hasManyTableActionDisabled(action)\" (click)=\"runHasManyTableAction(action)\">\n {{action.displayName}}\n </button>\n }\n </mat-menu>\n @if (hasManyAllowCreate) {\n <div\n [class.col-lg-2]=\"metadataHasMany.tableData.baseData.tableActions.length\"\n [class.col-lg-4]=\"!metadataHasMany.tableData.baseData.tableActions.length\"\n [class.col-md-3]=\"metadataHasMany.tableData.baseData.tableActions.length\"\n [class.col-md-6]=\"!metadataHasMany.tableData.baseData.tableActions.length\"\n [class.col-sm-6]=\"metadataHasMany.tableData.baseData.tableActions.length\"\n [class.col-sm-12]=\"!metadataHasMany.tableData.baseData.tableActions.length\"\n >\n <button type=\"button\" class=\"create-button\" mat-raised-button (click)=\"createHasManyEntity()\">\n {{metadataHasMany.tableData.baseData.createButtonLabel}}\n </button>\n </div>\n }\n </div>\n \n <div class=\"mat-elevation-z8 elevation-container\">\n <mat-table matSort [dataSource]=\"hasManyDataSource\">\n <!-- select Column -->\n <ng-container matColumnDef=\"select\">\n <mat-header-cell *matHeaderCellDef>\n <mat-checkbox [checked]=\"hasManySelection.hasValue() && SelectionUtilities.isAllSelected(hasManySelection, hasManyDataSource)\"\n [indeterminate]=\"hasManySelection.hasValue() && !SelectionUtilities.isAllSelected(hasManySelection, hasManyDataSource)\"\n (change)=\"$event ? SelectionUtilities.masterToggle(hasManySelection, hasManyDataSource) : null\">\n </mat-checkbox>\n </mat-header-cell>\n <mat-cell *matCellDef=\"let entity\" class=\"enabled\">\n <mat-checkbox [checked]=\"hasManySelection.isSelected(entity)\"\n (click)=\"$event.stopPropagation()\"\n (change)=\"$event ? hasManySelection.toggle(entity) : null\">\n </mat-checkbox>\n </mat-cell>\n </ng-container>\n \n @for (dCol of metadataHasMany.tableData.baseData.displayColumns; track $index) {\n <ng-container [matColumnDef]=\"dCol.displayName\">\n <mat-header-cell *matHeaderCellDef mat-sort-header>\n {{dCol.displayName}}\n </mat-header-cell>\n <mat-cell *matCellDef=\"let entity\"\n [class.enabled]=\"!dCol.disableClick && (hasManyAllowUpdate(entity) || hasManyAllowRead(entity))\"\n (click)=\"editHasManyEntity(entity, dCol)\"\n >\n @if (dCol.Component) {\n <display-column-value [entity]=\"entity\" [ComponentClass]=\"dCol.Component\"></display-column-value>\n }\n @else {\n {{getDisplayColumnValue(entity, dCol)}}\n }\n </mat-cell>\n </ng-container>\n }\n <mat-header-row *matHeaderRowDef=\"displayedHasManyColumns\"></mat-header-row>\n <mat-row *matRowDef=\"let row; columns: displayedHasManyColumns\"></mat-row>\n </mat-table>\n \n @if (hasManyIsLoading && metadataHasMany.tableData.baseData.displayLoadingSpinner) {\n <mat-spinner></mat-spinner>\n }\n <mat-paginator style=\"padding-top: 10px; padding-bottom: 10px;\" [length]=\"hasManyDataSource.filteredData.length\" [pageIndex]=\"0\" [pageSize]=\"10\" [pageSizeOptions]=\"[5, 10, 25, 50]\"></mat-paginator>\n </div>\n </div>\n }\n \n @default {\n <div>ERROR: The type {{type}} is not known.</div>\n }\n }\n}\n\n\n\n\n<!--------------------------------------------------------->\n<!---------------------------Form-------------------------->\n<!--------------------------------------------------------->\n<ng-template #form let-context>\n <!-- eslint-disable angular/no-call-expression -->\n @if (context.tabs.length > 1) {\n <mat-tab-group preserveContent>\n @for (tab of context.tabs; track $index) {\n <mat-tab [label]=\"tab.tabName\">\n @for (row of tab.rows; track $index) {\n <div class=\"row\">\n @for (key of row.keys; track key) {\n <ngx-mat-entity-input\n [entity]=\"context.entity\"\n [propertyKey]=\"key\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [validEmpty]=\"context.validEmpty?.()\"\n [isReadOnly]=\"context.isReadOnly?.(context.entity, key)\"\n [class]=\"EntityUtilities.getWidthClasses(context.entity, key)\"\n [hideOmitForEdit]=\"context.hideOmitForEdit\"\n [hideOmitForCreate]=\"context.hideOmitForCreate\"\n (inputChangeEvent)=\"context.inputChangeEvent()\"\n >\n </ngx-mat-entity-input>\n }\n </div>\n }\n </mat-tab>\n }\n </mat-tab-group>\n }\n @else {\n @if (!context.tabs.length) {\n <span class=\"no-entity-tabs\">\n ERROR: No Inputs. Did you correctly assign all values in the model constructor?\n </span>\n }\n @else {\n @for (row of context.tabs[0].rows; track $index) {\n <div class=\"row\">\n @for (key of row.keys; track key) {\n <ngx-mat-entity-input\n [entity]=\"context.entity\"\n [propertyKey]=\"key\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [validEmpty]=\"context.validEmpty?.()\"\n [isReadOnly]=\"context.isReadOnly?.(context.entity, key)\"\n [class]=\"EntityUtilities.getWidthClasses(context.entity, key)\"\n [hideOmitForEdit]=\"context.hideOmitForEdit\"\n [hideOmitForCreate]=\"context.hideOmitForCreate\"\n (inputChangeEvent)=\"context.inputChangeEvent()\"\n >\n </ngx-mat-entity-input>\n }\n </div>\n }\n }\n }\n</ng-template>\n\n<!--------------------------------------------------------->\n<!--------------------Add Array Item Dialog---------------->\n<!--------------------------------------------------------->\n<ng-template #addArrayItemDialog>\n <div class=\"mat-dialog-title\">\n <div>{{addArrayItemDialogData.title}}</div>\n </div>\n\n <form>\n <mat-dialog-content>\n @if (addArrayItemFormContext) {\n <ng-container *ngTemplateOutlet=\"form; context: addArrayItemFormContext\"></ng-container>\n }\n </mat-dialog-content>\n \n <mat-dialog-actions>\n <div class=\"d-flex align-items-center gap-3\" style=\"margin-top: 10px;\">\n <button type=\"submit\" mat-raised-button matBadgeColor=\"warn\"\n [disabled]=\"!isArrayItemValid\"\n [matBadge]=\"arrayItemValidationErrors.length\"\n [matBadgeHidden]=\"!arrayItemValidationErrors.length\"\n (click)=\"addArrayItem()\"\n >\n {{addArrayItemDialogData.createButtonLabel}}\n </button>\n @if (arrayItemValidationErrors.length) {\n <ngx-mat-entity-tooltip [tooltipContent]=\"arrayItemTooltipContent\"></ngx-mat-entity-tooltip>\n }\n </div>\n <button type=\"button\" mat-raised-button class=\"cancel-button\" (click)=\"closeAddArrayItemDialog()\">\n {{addArrayItemDialogData.cancelButtonLabel}}\n </button>\n </mat-dialog-actions>\n </form>\n\n</ng-template>\n\n<!--------------------------------------------------------->\n<!--------------------Edit Array Item Dialog---------------->\n<!--------------------------------------------------------->\n<ng-template #editArrayItemDialog>\n <div class=\"mat-dialog-title\">\n <div>{{editArrayItemDialogData.title(arrayItemPriorChanges)}}</div>\n </div>\n \n <form>\n <mat-dialog-content>\n @if (editArrayItemFormContext) {\n <ng-container *ngTemplateOutlet=\"form; context: editArrayItemFormContext\"></ng-container>\n }\n </mat-dialog-content>\n \n <mat-dialog-actions>\n <div class=\"d-flex align-items-center gap-3\" style=\"margin-top: 10px;\">\n <button type=\"submit\" mat-raised-button matBadgeColor=\"warn\"\n [disabled]=\"internalIsReadOnly || !isArrayItemValid || !isArrayItemDirty\"\n [matBadge]=\"arrayItemValidationErrors.length\"\n [matBadgeHidden]=\"!arrayItemValidationErrors.length\"\n (click)=\"saveArrayItem()\"\n >\n {{editArrayItemDialogData.confirmButtonLabel}}\n </button>\n @if (arrayItemValidationErrors.length) {\n <ngx-mat-entity-tooltip [tooltipContent]=\"arrayItemTooltipContent\"></ngx-mat-entity-tooltip>\n }\n </div>\n <button type=\"button\" mat-raised-button class=\"cancel-button\" (click)=\"closeEditArrayItemDialog()\">\n {{editArrayItemDialogData.cancelButtonLabel}}\n </button>\n </mat-dialog-actions>\n </form>\n</ng-template>\n\n<!--------------------------------------------------------->\n<!--------------------Create Has Many Dialog---------------->\n<!--------------------------------------------------------->\n<ng-template #createHasManyDialog>\n <div class=\"mat-dialog-title\">\n <div>{{metadataHasMany.tableData.createData.title}}</div>\n </div>\n \n <form>\n <mat-dialog-content>\n @if (hasManyCreateFormContext) {\n <ng-container *ngTemplateOutlet=\"form; context: hasManyCreateFormContext\"></ng-container>\n }\n </mat-dialog-content>\n \n <mat-dialog-actions>\n <div class=\"d-flex align-items-center gap-3\" style=\"margin-top: 10px;\">\n <button type=\"submit\" mat-raised-button matBadgeColor=\"warn\"\n [disabled]=\"!isHasManyEntityValid\"\n [matBadge]=\"hasManyValidationErrors.length\"\n [matBadgeHidden]=\"!hasManyValidationErrors.length\"\n (click)=\"dialogCreateHasMany()\"\n >\n {{metadataHasMany.tableData.createData.createButtonLabel}}\n </button>\n @if (hasManyValidationErrors.length) {\n <ngx-mat-entity-tooltip [tooltipContent]=\"hasManyTooltipContent\"></ngx-mat-entity-tooltip>\n }\n </div>\n <button type=\"button\" mat-raised-button class=\"cancel-button\" (click)=\"dialogCancelCreateHasMany()\">\n {{metadataHasMany.tableData.createData.cancelButtonLabel}}\n </button>\n </mat-dialog-actions>\n </form>\n \n</ng-template>\n\n<!--------------------------------------------------------->\n<!--------------------Edit Has Many Dialog----------------->\n<!--------------------------------------------------------->\n<ng-template #editHasManyDialog>\n <div class=\"mat-dialog-title\">\n <div>{{metadataHasMany.tableData.editData.title(hasManyEntityPriorChanges)}}</div>\n\n <div class=\"actions-container\">\n @if (metadataHasMany.tableData.editData.actions.length) {\n <button type=\"button\" mat-raised-button [matMenuTriggerFor]=\"menu\">\n {{metadataHasMany.tableData.editData.actionsLabel}}\n </button>\n }\n <mat-menu #menu=\"matMenu\">\n @for (action of metadataHasMany.tableData.editData.actions; track $index) {\n <button type=\"button\" mat-menu-item [disabled]=\"hasManyEditActionDisabled(action)\" (click)=\"hasManyRunEditAction(action)\">\n {{action.displayName}}\n </button>\n }\n </mat-menu>\n \n @if (hasManyAllowDelete(hasManyEntity)) {\n <button type=\"button\" mat-raised-button color=\"warn\" class=\"delete-button\" tabindex=\"-1\" (click)=\"deleteHasManyEntity()\">\n {{metadataHasMany.tableData.editData.deleteButtonLabel}}\n </button>\n }\n </div>\n </div>\n \n <form>\n <mat-dialog-content>\n @if (hasManyEditFormContext) {\n <ng-container *ngTemplateOutlet=\"form; context: hasManyEditFormContext\"></ng-container>\n }\n </mat-dialog-content>\n \n <mat-dialog-actions>\n <div class=\"d-flex align-items-center gap-3\" style=\"margin-top: 10px;\">\n <button type=\"submit\" mat-raised-button matBadgeColor=\"warn\"\n [disabled]=\"internalIsReadOnly || !isHasManyEntityValid || !isHasManyEntityDirty\"\n [matBadge]=\"hasManyValidationErrors.length\"\n [matBadgeHidden]=\"!hasManyValidationErrors.length\"\n (click)=\"dialogEditHasMany()\"\n >\n {{metadataHasMany.tableData.editData.confirmButtonLabel}}\n </button>\n @if (hasManyValidationErrors.length) {\n <ngx-mat-entity-tooltip [tooltipContent]=\"hasManyTooltipContent\"></ngx-mat-entity-tooltip>\n }\n </div>\n <button type=\"button\" mat-raised-button class=\"cancel-button\" (click)=\"dialogCancelEditHasMany()\">\n {{metadataHasMany.tableData.editData.cancelButtonLabel}}\n </button>\n </mat-dialog-actions>\n </form>\n</ng-template>", styles: ["::ng-deep mat-tab-body{padding-top:10px;padding-left:12px;padding-right:12px}::ng-deep mat-tab-body .mat-mdc-tab-body-content{overflow:initial}::ng-deep .mat-mdc-form-field-has-icon-suffix .mat-mdc-text-field-wrapper{padding-right:16px}::ng-deep .select-search-input{width:100%;margin-top:-8px;margin-bottom:8px}::ng-deep .select-search-input .mat-mdc-form-field-subscript-wrapper{display:none}::ng-deep .mdc-dialog .mdc-dialog__content{padding:6px 20px!important}::ng-deep .mat-mdc-tab-body-wrapper{margin-left:-12px;margin-right:-12px}::ng-deep .mat-mdc-form-field.mat-form-field-disabled label{color:#0009}::ng-deep .mat-mdc-form-field.mat-form-field-disabled input,::ng-deep .mat-mdc-form-field.mat-form-field-disabled textarea,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mat-mdc-select-disabled,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mat-mdc-select-value{color:#000!important}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-checkbox .mdc-checkbox__native-control[disabled]:not(:checked):not(:indeterminate):not([data-indeterminate=true])~.mdc-checkbox__background{border-color:#707070}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-checkbox .mdc-checkbox__native-control[disabled]:checked~.mdc-checkbox__background,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-checkbox .mdc-checkbox__native-control[disabled]:indeterminate~.mdc-checkbox__background,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-checkbox .mdc-checkbox__native-control[data-indeterminate=true][disabled]~.mdc-checkbox__background{background-color:#000}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mat-mdc-chip.mat-mdc-standard-chip.mat-mdc-chip-disabled{opacity:1}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mat-mdc-chip.mat-mdc-standard-chip.mat-mdc-chip-disabled button{opacity:.2}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-switch.mdc-switch--selected:disabled .mdc-switch__icons,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-switch.mdc-switch--unselected:disabled .mdc-switch__icons{opacity:1}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-switch.mdc-switch--selected:disabled .mdc-switch__handle:after,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-switch.mdc-switch--unselected:disabled .mdc-switch__handle:after{opacity:1;background:#000}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-switch.mdc-switch--selected:disabled .mdc-switch__track,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-switch.mdc-switch--unselected:disabled .mdc-switch__track{opacity:.3}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mat-date-range-input-inner:disabled{color:#000}::ng-deep #slider.mat-mdc-slider.mdc-slider--disabled{opacity:1}::ng-deep #slider.mat-mdc-slider.mdc-slider--disabled .mdc-slider__input{cursor:default}::ng-deep #slider.mat-mdc-slider.mdc-slider--disabled mat-slider-visual-thumb .mat-mdc-slider,::ng-deep #slider.mat-mdc-slider.mdc-slider--disabled mat-slider-visual-thumb .mdc-slider__thumb:hover,::ng-deep #slider.mat-mdc-slider.mdc-slider--disabled mat-slider-visual-thumb .mdc-slider__thumb-knob{background-color:#000;border-color:#000}::ng-deep .mat-mdc-form-field .mat-mdc-slide-toggle{opacity:1}mat-dialog-actions{justify-content:space-between;align-items:center;padding-left:20px;padding-right:20px}mat-spinner{margin:10px auto}.mdc-data-table__row:last-child .mdc-data-table__cell{border-bottom:1px solid rgba(0,0,0,.12)}.mat-dialog-title{padding:12px 20px;display:flex;justify-content:space-between;align-items:center}.mat-dialog-title div{font-size:var(--mdc-dialog-subhead-size, 14px);font-weight:var(--mdc-dialog-subhead-weight, 500)}.actions-container{display:flex;gap:10px}.object-dropdown{width:100%}.entityArray .elevation-container{border-radius:5px;padding:15px;margin-bottom:15px;margin-top:15px}.entityArray .array-headline{padding-bottom:10px}.entityArray .buttons{display:flex;justify-content:space-between;margin-bottom:10px;margin-top:5px;flex-wrap:wrap;gap:10px}.entityArray .buttons button{flex-grow:1}.entityArray mat-table{border:1px solid #E0E0E0;border-radius:5px;padding-top:5px;padding-bottom:5px}.entityArray .mat-column-select{flex:0 0 48px;padding-left:0;padding-right:0;justify-content:center}.entityArray .enabled:hover{cursor:pointer}.entityArray .array-error{display:flex;align-items:center;justify-content:center;margin-top:-6px;border:1px solid #E0E0E0;background-color:#f8d3d7;color:#721c24;height:fit-content;padding-left:4px;padding-right:4px;border-bottom-left-radius:5px;border-bottom-right-radius:5px}.hasMany button{width:100%;height:56px;line-height:24px;font-size:16px}.hasMany .title{text-align:center}.hasMany .elevation-container{border-radius:5px;padding:5px;margin-bottom:15px}.hasMany .mat-column-select{flex:0 0 48px;padding-left:0;padding-right:0;justify-content:center}.hasMany .enabled:hover{cursor:pointer}\n"], dependencies: [{ kind: "component", type: NgxMatEntityInputComponent, selector: "ngx-mat-entity-input", inputs: ["entity", "propertyKey", "getValidationErrorMessage", "hideOmitForCreate", "hideOmitForEdit", "validEmpty", "isReadOnly"], outputs: ["inputChangeEvent"] }, { kind: "component", type: DisplayColumnValueComponent, selector: "display-column-value", inputs: ["entity", "ComponentClass"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: MatTabsModule }, { kind: "component", type: i5.MatTab, selector: "mat-tab", inputs: ["disabled", "label", "aria-label", "aria-labelledby", "labelClass", "bodyClass"], exportAs: ["matTab"] }, { kind: "component", type: i5.MatTabGroup, selector: "mat-tab-group", inputs: ["color", "fitInkBarToContent", "mat-stretch-tabs", "dynamicHeight", "selectedIndex", "headerPosition", "animationDuration", "contentTabIndex", "disablePagination", "disableRipple", "preserveContent", "backgroundColor"], outputs: ["selectedIndexChange", "focusChange", "animationDone", "selectedTabChange"], exportAs: ["matTabGroup"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i6.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i6.MatLabel, selector: "mat-label" }, { kind: "directive", type: i6.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i6.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatSelectModule }, { kind: "component", type: i7.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "component", type: i8.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i9.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i9.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i9.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i9.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i9.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: MatDialogModule }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "ngmodule", type: MatBadgeModule }, { kind: "directive", type: i10.MatBadge, selector: "[matBadge]", inputs: ["matBadgeColor", "matBadgeOverlap", "matBadgeDisabled", "matBadgePosition", "matBadge", "matBadgeDescription", "matBadgeSize", "matBadgeHidden"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i11.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: "ngmodule", type: MatMenuModule }, { kind: "component", type: i12.MatMenu, selector: "mat-menu", inputs: ["backdropClass", "aria-label", "aria-labelledby", "aria-describedby", "xPosition", "yPosition", "overlapTrigger", "hasBackdrop", "class", "classList"], outputs: ["closed", "close"], exportAs: ["matMenu"] }, { kind: "component", type: i12.MatMenuItem, selector: "[mat-menu-item]", inputs: ["role", "disabled", "disableRipple"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i12.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData", "matMenuTriggerRestoreFocus"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }, { kind: "ngmodule", type: MatPaginatorModule }, { kind: "component", type: i13.MatPaginator, selector: "mat-paginator", inputs: ["color", "pageIndex", "length", "pageSize", "pageSizeOptions", "hidePageSize", "showFirstLastButtons", "selectConfig", "disabled"], outputs: ["page"], exportAs: ["matPaginator"] }, { kind: "ngmodule", type: MatProgressSpinnerModule }, { kind: "component", type: i14.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "ngmodule", type: MatTableModule }, { kind: "component", type: i15.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i15.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i15.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i15.MatColumnDef, selector: "[matColumnDef]", inputs: ["matColumnDef"] }, { kind: "directive", type: i15.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i15.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i15.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i15.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i15.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i15.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "ngmodule", type: MatCheckboxModule }, { kind: "component", type: i16.MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i17.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: TooltipComponent, selector: "ngx-mat-entity-tooltip", inputs: ["tooltipContent"] }, { kind: "component", type: StringInputComponent, selector: "string-input" }, { kind: "component", type: StringTextboxInputComponent, selector: "string-textbox-input" }, { kind: "component", type: StringAutocompleteInputComponent, selector: "string-autocomplete-input" }, { kind: "component", type: StringDropdownInputComponent, selector: "string-dropdown-input" }, { kind: "component", type: StringPasswordInputComponent, selector: "string-password-input" }, { kind: "component", type: BooleanCheckboxInputComponent, selector: "boolean-checkbox-input" }, { kind: "component", type: BooleanToggleInputComponent, selector: "boolean-toggle-input" }, { kind: "component", type: BooleanDropdownInputComponent, selector: "boolean-dropdown-input" }, { kind: "component", type: NumberInputComponent, selector: "number-input" }, { kind: "component", type: NumberDropdownInputComponent, selector: "number-dropdown-input" }, { kind: "component", type: NumberSliderInputComponent, selector: "number-slider-input" }, { kind: "component", type: ArrayDateInputComponent, selector: "array-date-input" }, { kind: "component", type: ArrayDateRangeInputComponent, selector: "array-date-range-input" }, { kind: "component", type: ArrayDateTimeInputComponent, selector: "array-date-time-input" }, { kind: "component", type: ArrayStringAutocompleteChipsComponent, selector: "array-string-autocomplete-chips" }, { kind: "component", type: ArrayStringChipsInputComponent, selector: "array-string-chips-input" }, { kind: "component", type: DateInputComponent, selector: "date-input" }, { kind: "component", type: DateRangeInputComponent, selector: "date-range-input" }, { kind: "component", type: DateTimeInputComponent, selector: "date-time-input" }, { kind: "component", type: FileDefaultInputComponent, selector: "file-default-input" }, { kind: "component", type: FileImageInputComponent, selector: "file-image-input" }, { kind: "component", type: ReferencesManyInputComponent, selector: "references-many-input" }, { kind: "component", type: CustomInputComponent, selector: "custom-input" }] });
|
|
1217
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.7", ngImport: i0, type: NgxMatEntityInputComponent, deps: [{ token: i1.MatDialog }, { token: i0.EnvironmentInjector }, { token: i2.Router }, { token: NGX_GET_VALIDATION_ERROR_MESSAGE }, { token: NGX_COMPLETE_GLOBAL_DEFAULT_VALUES }, { token: i3.HttpClient }], target: i0.ɵɵFactoryTarget.Component });
|
|
1218
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.7", type: NgxMatEntityInputComponent, isStandalone: true, selector: "ngx-mat-entity-input", inputs: { entity: "entity", propertyKey: "propertyKey", getValidationErrorMessage: "getValidationErrorMessage", hideOmitForCreate: "hideOmitForCreate", hideOmitForEdit: "hideOmitForEdit", validEmpty: "validEmpty", isReadOnly: "isReadOnly" }, outputs: { inputChangeEvent: "inputChangeEvent" }, viewQueries: [{ propertyName: "sort", first: true, predicate: MatSort, descendants: true }, { propertyName: "addArrayItemDialog", first: true, predicate: ["addArrayItemDialog"], descendants: true }, { propertyName: "editArrayItemDialog", first: true, predicate: ["editArrayItemDialog"], descendants: true }, { propertyName: "createHasManyDialog", first: true, predicate: ["createHasManyDialog"], descendants: true }, { propertyName: "editHasManyDialog", first: true, predicate: ["editHasManyDialog"], descendants: true }], ngImport: i0, template: "<!-- eslint-disable angular/no-call-expression -->\n \n@if(!(hideOmitForCreate && metadata.omitForCreate) && !(hideOmitForEdit && metadata.omitForUpdate)) {\n @switch (type) {\n <!-------------------------------------------->\n <!-----------------Strings-------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.STRING) {\n <string-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </string-input>\n }\n @case (DecoratorTypes.STRING_TEXTBOX) {\n <string-textbox-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </string-textbox-input>\n }\n @case (DecoratorTypes.STRING_AUTOCOMPLETE) {\n <string-autocomplete-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </string-autocomplete-input>\n }\n @case (DecoratorTypes.STRING_DROPDOWN) {\n <string-dropdown-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </string-dropdown-input>\n }\n @case (DecoratorTypes.STRING_PASSWORD) {\n <string-password-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </string-password-input>\n }\n <!-------------------------------------------->\n <!-----------------Booleans------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.BOOLEAN_CHECKBOX) {\n <boolean-checkbox-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </boolean-checkbox-input>\n }\n @case (DecoratorTypes.BOOLEAN_TOGGLE) {\n <boolean-toggle-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </boolean-toggle-input>\n }\n @case (DecoratorTypes.BOOLEAN_DROPDOWN) {\n <boolean-dropdown-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </boolean-dropdown-input>\n }\n <!-------------------------------------------->\n <!------------------Numbers------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.NUMBER) {\n <number-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </number-input>\n }\n @case (DecoratorTypes.NUMBER_DROPDOWN) {\n <number-dropdown-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </number-dropdown-input>\n }\n @case (DecoratorTypes.NUMBER_SLIDER) {\n <number-slider-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </number-slider-input>\n }\n <!-------------------------------------------->\n <!-------------------Array-------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.ARRAY_DATE) {\n <array-date-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </array-date-input>\n }\n @case (DecoratorTypes.ARRAY_DATE_TIME) {\n <array-date-time-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </array-date-time-input>\n }\n @case (DecoratorTypes.ARRAY_DATE_RANGE) {\n <array-date-range-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </array-date-range-input>\n }\n @case (DecoratorTypes.ARRAY_STRING_CHIPS) {\n <array-string-chips-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </array-string-chips-input>\n }\n @case (DecoratorTypes.ARRAY_STRING_AUTOCOMPLETE_CHIPS) {\n <array-string-autocomplete-chips\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </array-string-autocomplete-chips>\n }\n <!-------------------------------------------->\n <!-------------------Dates-------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.DATE) {\n <date-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </date-input>\n }\n @case (DecoratorTypes.DATE_RANGE) {\n <date-range-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </date-range-input>\n }\n @case (DecoratorTypes.DATE_TIME) {\n <date-time-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </date-time-input>\n }\n <!-------------------------------------------->\n <!-------------------Files-------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.FILE_DEFAULT) {\n <file-default-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </file-default-input>\n }\n @case (DecoratorTypes.FILE_IMAGE) {\n <file-image-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </file-image-input>\n }\n <!-------------------------------------------->\n <!-------------- references many ------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.REFERENCES_MANY) {\n <references-many-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </references-many-input>\n }\n <!-------------------------------------------->\n <!-------------------Custom------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.CUSTOM) {\n <custom-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </custom-input>\n }\n <!-------------------------------------------->\n <!-------------------Object------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.OBJECT) {\n <b>{{metadataDefaultObject.displayName}}</b>\n <!-- iterates over the object properties -->\n <ng-container *ngTemplateOutlet=\"form; context: objectFormContext\"></ng-container>\n }\n <!-------------------------------------------->\n <!---------------Object Dropdown-------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.OBJECT_DROPDOWN) {\n <mat-form-field class=\"object-dropdown\">\n <mat-label>{{metadata.displayName}}</mat-label>\n <mat-select #model=\"ngModel\"\n [name]=\"objectDropdownName\"\n [required]=\"metadata.required(entity)\"\n [disabled]=\"internalIsReadOnly\"\n [compareWith]=\"compareObjectsBound\"\n [(ngModel)]=\"entity[propertyKey]\"\n (selectionChange)=\"emitChange()\"\n (opened)=\"selectSearchInput.focus()\"\n >\n <mat-form-field class=\"select-search-input\">\n <!-- eslint-disable-next-line angular/no-any -->\n <input #selectSearchInput matInput (keyup)=\"filterObjectDropdownValues($any($event.target).value)\">\n <fa-icon matSuffix [icon]=\"faSearch\"></fa-icon>\n </mat-form-field>\n @if (!metadata.required(entity)) {\n <mat-option>-</mat-option>\n }\n @if (shouldDisplayCurrentObjectDropdownValue) {\n <mat-option [value]=\"currentObjectDropdownValue?.value\">{{currentObjectDropdownValue?.displayName}}</mat-option>\n }\n @for (value of filteredObjectDropdownValues; track $index) {\n <mat-option [value]=\"value.value\">{{value.displayName}}</mat-option>\n }\n </mat-select>\n <mat-error>{{internalGetValidationErrorMessage(model)}}</mat-error>\n </mat-form-field>\n }\n <!-------------------------------------------->\n <!-------------- references one -------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.REFERENCES_ONE) {\n <mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <mat-select #inputModel=\"ngModel\"\n [name]=\"referencesOneName\"\n [disabled]=\"internalIsReadOnly\"\n [required]=\"metadata.required(entity)\"\n [(ngModel)]=\"entity[propertyKey]\"\n (selectionChange)=\"setReferencesOneObject()\"\n (opened)=\"selectSearchInput.focus()\"\n >\n <mat-form-field class=\"select-search-input\">\n <!-- eslint-disable-next-line angular/no-any -->\n <input #selectSearchInput matInput (keyup)=\"filterReferencesOneValues($any($event.target).value)\">\n <fa-icon matSuffix [icon]=\"faSearch\"></fa-icon>\n </mat-form-field>\n @if (!metadata.required(entity)) {\n <mat-option>-</mat-option>\n }\n @if (shouldDisplayCurrentReferencesOneDropdownValue) {\n <mat-option [value]=\"currentReferencesOneDropdownValue?.value\">{{currentReferencesOneDropdownValue?.displayName}}</mat-option>\n }\n @for (value of filteredReferencesOneDropdownValues; track $index) {\n <mat-option [value]=\"value.value\">{{value.displayName}}</mat-option>\n }\n </mat-select>\n <mat-error>{{internalGetValidationErrorMessage(inputModel)}}</mat-error>\n </mat-form-field>\n <!-- iterates over the references one properties -->\n @if (referencesOneFormContext) {\n <ng-container *ngTemplateOutlet=\"form; context: referencesOneFormContext\"></ng-container>\n }\n }\n <!-------------------------------------------->\n <!-------------------Array-------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.ARRAY) {\n <div class=\"entityArray\">\n <div class=\"mat-elevation-z8 elevation-container\">\n <div class=\"array-headline\">\n <b>{{metadataEntityArray.displayName}}</b>\n </div>\n @if (metadataEntityArray.createInline && !internalIsReadOnly && addArrayItemFormContext) {\n <ng-container *ngTemplateOutlet=\"form; context: addArrayItemFormContext\"></ng-container>\n }\n @if (!internalIsReadOnly && entityArrayTableContext) {\n <div class=\"buttons\">\n <button type=\"button\" mat-raised-button\n [disabled]=\"metadataEntityArray.createInline && !isArrayItemValid\"\n (click)=\"addEntity()\">\n {{metadataEntityArray.addButtonLabel}}\n </button>\n <button type=\"button\" mat-raised-button\n [disabled]=\"!entityArrayTableContext.$implicit.selection.selected.length\"\n (click)=\"removeFromEntityArray()\">\n {{metadataEntityArray.removeButtonLabel}}\n </button>\n </div>\n }\n @if (entityArrayTableContext) {\n <ng-container *ngTemplateOutlet=\"table; context: entityArrayTableContext\"></ng-container>\n }\n </div>\n </div>\n }\n <!-------------------------------------------->\n <!------------------ has many ---------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.HAS_MANY) {\n <div class=\"hasMany\">\n <h2 class=\"title\">{{metadataHasMany.tableData.baseData.title}}</h2>\n <div class=\"grid grid-cols-12\" style=\"column-gap: 24px;\">\n <mat-form-field class=\"lg:col-span-8 md:col-span-6 col-span-12\">\n <mat-label>{{metadataHasMany.tableData.baseData.searchLabel}}</mat-label>\n <input matInput (keyup)=\"applyHasManyFilter($event)\">\n </mat-form-field>\n @if (metadataHasMany.tableData.baseData.tableActions.length) {\n <div\n [class.lg:col-span-2]=\"hasManyAllowCreate\"\n [class.lg:col-span-4]=\"!hasManyAllowCreate\"\n [class.md:col-span-3]=\"hasManyAllowCreate\"\n [class.md:col-span-6]=\"!hasManyAllowCreate\"\n [class.col-span-6]=\"hasManyAllowCreate\"\n [class.col-span-12]=\"!hasManyAllowCreate\"\n >\n <button type=\"button\" class=\"actions-button\" mat-raised-button [matMenuTriggerFor]=\"menu\">\n {{metadataHasMany.tableData.baseData.tableActionsLabel}}\n </button>\n </div>\n }\n <mat-menu #menu=\"matMenu\">\n @if (metadataHasMany.tableData.baseData.allowJsonImport) {\n <button type=\"button\" mat-menu-item [disabled]=\"hasManyTableActionDisabled(hasManyImportAction)\" (click)=\"runHasManyTableAction(hasManyImportAction)\">\n {{hasManyImportAction.displayName}}\n </button>\n }\n @for (action of metadataHasMany.tableData.baseData.tableActions; track $index) {\n <button type=\"button\" mat-menu-item [disabled]=\"hasManyTableActionDisabled(action)\" (click)=\"runHasManyTableAction(action)\">\n {{action.displayName}}\n </button>\n }\n </mat-menu>\n @if (hasManyAllowCreate) {\n <div\n [class.lg:col-span-2]=\"metadataHasMany.tableData.baseData.tableActions.length\"\n [class.lg:col-span-4]=\"!metadataHasMany.tableData.baseData.tableActions.length\"\n [class.md:col-span-3]=\"metadataHasMany.tableData.baseData.tableActions.length\"\n [class.md:col-span-6]=\"!metadataHasMany.tableData.baseData.tableActions.length\"\n [class.col-span-6]=\"metadataHasMany.tableData.baseData.tableActions.length\"\n [class.col-span-12]=\"!metadataHasMany.tableData.baseData.tableActions.length\"\n >\n <button type=\"button\" class=\"create-button\" mat-raised-button (click)=\"createHasManyEntity()\">\n {{metadataHasMany.tableData.baseData.createButtonLabel}}\n </button>\n </div>\n }\n </div>\n \n <div class=\"mat-elevation-z8 elevation-container\">\n @if (hasManyTableContext) {\n <ng-container *ngTemplateOutlet=\"table; context: hasManyTableContext\"></ng-container>\n }\n </div>\n </div>\n }\n \n @default {\n <div>ERROR: The type {{type}} is not known.</div>\n }\n }\n}\n\n\n<ng-template #table let-context>\n <mat-table matSort [dataSource]=\"context.dataSource\" [class.table-with-error-slot]=\"context.shouldShowMissingError\">\n <!-- select Column -->\n <ng-container matColumnDef=\"select\">\n <mat-header-cell *matHeaderCellDef>\n <mat-checkbox [checked]=\"context.selection.hasValue() && SelectionUtilities.isAllSelected(context.selection, context.dataSource)\"\n [indeterminate]=\"context.selection.hasValue() && !SelectionUtilities.isAllSelected(context.selection, context.dataSource)\"\n (change)=\"$event ? SelectionUtilities.masterToggle(context.selection, context.dataSource) : null\">\n </mat-checkbox>\n </mat-header-cell>\n <mat-cell *matCellDef=\"let value\" [dynamicStyleClasses]=\"context.dynamicRowStyleClasses\" [value]=\"value\">\n <mat-checkbox [checked]=\"context.selection.isSelected(value)\"\n (click)=\"$event.stopPropagation()\"\n (change)=\"$event ? context.selection.toggle(value) : null\">\n </mat-checkbox>\n </mat-cell>\n </ng-container>\n\n @for (dCol of context.displayColumns; track $index) {\n <ng-container [matColumnDef]=\"dCol.displayName\">\n <mat-header-cell *matHeaderCellDef mat-sort-header>\n {{dCol.displayName}}\n </mat-header-cell>\n <mat-cell *matCellDef=\"let value\" [class.enabled]=\"!dCol.disableClick && context.allowClick(value)\"\n [dynamicStyleClasses]=\"context.dynamicRowStyleClasses\" [value]=\"value\"\n (click)=\"clickCell(value, dCol, context)\"\n >\n @if (dCol.Component) {\n <display-column-value [entity]=\"value\" [ComponentClass]=\"dCol.Component\"></display-column-value>\n }\n @else {\n {{getDisplayColumnValue(value, dCol)}}\n }\n </mat-cell>\n </ng-container>\n }\n\n <mat-header-row *matHeaderRowDef=\"context.displayedColumns\"></mat-header-row>\n <mat-row *matRowDef=\"let row; columns: context.displayedColumns\"></mat-row>\n </mat-table>\n\n @if (context.displayLoadingSpinner && context.isLoading) {\n <mat-spinner>\n </mat-spinner>\n }\n @else if (context.shouldShowMissingError && !context.dataSource.data.length) {\n <div class=\"table-error\">{{context.emptyErrorMessage}}</div>\n }\n\n <mat-paginator [length]=\"context.dataSource.filteredData.length\" [pageIndex]=\"0\" [pageSize]=\"10\" [pageSizeOptions]=\"[5, 10, 25, 50]\"></mat-paginator>\n</ng-template>\n\n<!--------------------------------------------------------->\n<!---------------------------Form-------------------------->\n<!--------------------------------------------------------->\n<ng-template #form let-context>\n <!-- eslint-disable angular/no-call-expression -->\n @if (context.tabs.length > 1) {\n <mat-tab-group preserveContent>\n @for (tab of context.tabs; track $index) {\n <mat-tab [label]=\"tab.tabName\">\n @for (row of tab.rows; track $index) {\n <div class=\"grid grid-cols-12\" style=\"column-gap: 24px;\">\n @for (key of row.keys; track key) {\n <ngx-mat-entity-input\n [entity]=\"context.entity\"\n [propertyKey]=\"key\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [validEmpty]=\"context.validEmpty?.()\"\n [isReadOnly]=\"context.isReadOnly?.(context.entity, key)\"\n [class]=\"EntityUtilities.getWidthClasses(context.entity, key)\"\n [hideOmitForEdit]=\"context.hideOmitForEdit\"\n [hideOmitForCreate]=\"context.hideOmitForCreate\"\n (inputChangeEvent)=\"context.inputChangeEvent()\"\n >\n </ngx-mat-entity-input>\n }\n </div>\n }\n </mat-tab>\n }\n </mat-tab-group>\n }\n @else {\n @if (!context.tabs.length) {\n <span class=\"no-entity-tabs\">\n ERROR: No Inputs. Did you correctly assign all values in the model constructor?\n </span>\n }\n @else {\n @for (row of context.tabs[0].rows; track $index) {\n <div class=\"grid grid-cols-12\" style=\"column-gap: 24px;\">\n @for (key of row.keys; track key) {\n <ngx-mat-entity-input\n [entity]=\"context.entity\"\n [propertyKey]=\"key\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [validEmpty]=\"context.validEmpty?.()\"\n [isReadOnly]=\"context.isReadOnly?.(context.entity, key)\"\n [class]=\"EntityUtilities.getWidthClasses(context.entity, key)\"\n [hideOmitForEdit]=\"context.hideOmitForEdit\"\n [hideOmitForCreate]=\"context.hideOmitForCreate\"\n (inputChangeEvent)=\"context.inputChangeEvent()\"\n >\n </ngx-mat-entity-input>\n }\n </div>\n }\n }\n }\n</ng-template>\n\n<!--------------------------------------------------------->\n<!--------------------Add Array Item Dialog---------------->\n<!--------------------------------------------------------->\n<ng-template #addArrayItemDialog>\n <div class=\"mat-dialog-title\">\n <div>{{addArrayItemDialogData.title}}</div>\n </div>\n\n <form>\n <mat-dialog-content>\n @if (addArrayItemFormContext) {\n <ng-container *ngTemplateOutlet=\"form; context: addArrayItemFormContext\"></ng-container>\n }\n </mat-dialog-content>\n \n <mat-dialog-actions>\n <div class=\"dialog-button-with-info-icon\">\n <button type=\"submit\" mat-raised-button matBadgeColor=\"warn\"\n [disabled]=\"!isArrayItemValid\"\n [matBadge]=\"arrayItemValidationErrors.length\"\n [matBadgeHidden]=\"!arrayItemValidationErrors.length\"\n (click)=\"addArrayItem()\"\n >\n {{addArrayItemDialogData.createButtonLabel}}\n </button>\n @if (arrayItemValidationErrors.length) {\n <ngx-mat-entity-tooltip [tooltipContent]=\"arrayItemTooltipContent\"></ngx-mat-entity-tooltip>\n }\n </div>\n <button type=\"button\" mat-raised-button class=\"cancel-button\" (click)=\"closeAddArrayItemDialog()\">\n {{addArrayItemDialogData.cancelButtonLabel}}\n </button>\n </mat-dialog-actions>\n </form>\n\n</ng-template>\n\n<!--------------------------------------------------------->\n<!--------------------Edit Array Item Dialog---------------->\n<!--------------------------------------------------------->\n<ng-template #editArrayItemDialog>\n <div class=\"mat-dialog-title\">\n <div>{{editArrayItemDialogData.title(arrayItemPriorChanges)}}</div>\n </div>\n \n <form>\n <mat-dialog-content>\n @if (editArrayItemFormContext) {\n <ng-container *ngTemplateOutlet=\"form; context: editArrayItemFormContext\"></ng-container>\n }\n </mat-dialog-content>\n \n <mat-dialog-actions>\n <div class=\"dialog-button-with-info-icon\">\n <button type=\"submit\" mat-raised-button matBadgeColor=\"warn\"\n [class.badge-changes]=\"!arrayItemValidationErrors.length\"\n [disabled]=\"internalIsReadOnly || !isArrayItemValid || !isArrayItemDirty\"\n [matBadge]=\"arrayItemValidationErrors.length > 0 ? arrayItemValidationErrors.length : arrayItemChanges.length\"\n [matBadgeHidden]=\"!arrayItemValidationErrors.length && !arrayItemChanges.length\"\n (click)=\"saveArrayItem()\"\n >\n {{editArrayItemDialogData.confirmButtonLabel}}\n </button>\n @if (arrayItemValidationErrors.length || arrayItemChanges.length) {\n <ngx-mat-entity-tooltip [tooltipContent]=\"arrayItemTooltipContent\"></ngx-mat-entity-tooltip>\n }\n </div>\n <button type=\"button\" mat-raised-button class=\"cancel-button\" (click)=\"closeEditArrayItemDialog()\">\n {{editArrayItemDialogData.cancelButtonLabel}}\n </button>\n </mat-dialog-actions>\n </form>\n</ng-template>\n\n<!--------------------------------------------------------->\n<!--------------------Create Has Many Dialog---------------->\n<!--------------------------------------------------------->\n<ng-template #createHasManyDialog>\n <div class=\"mat-dialog-title\">\n <div>{{metadataHasMany.tableData.createData.title}}</div>\n </div>\n \n <form>\n <mat-dialog-content>\n @if (hasManyCreateFormContext) {\n <ng-container *ngTemplateOutlet=\"form; context: hasManyCreateFormContext\"></ng-container>\n }\n </mat-dialog-content>\n \n <mat-dialog-actions>\n <div class=\"dialog-button-with-info-icon\">\n <button type=\"submit\" mat-raised-button matBadgeColor=\"warn\"\n [disabled]=\"!isHasManyEntityValid\"\n [matBadge]=\"hasManyValidationErrors.length\"\n [matBadgeHidden]=\"!hasManyValidationErrors.length\"\n (click)=\"dialogCreateHasMany()\"\n >\n {{metadataHasMany.tableData.createData.createButtonLabel}}\n </button>\n @if (hasManyValidationErrors.length) {\n <ngx-mat-entity-tooltip [tooltipContent]=\"hasManyTooltipContent\"></ngx-mat-entity-tooltip>\n }\n </div>\n <button type=\"button\" mat-raised-button class=\"cancel-button\" (click)=\"dialogCancelCreateHasMany()\">\n {{metadataHasMany.tableData.createData.cancelButtonLabel}}\n </button>\n </mat-dialog-actions>\n </form>\n \n</ng-template>\n\n<!--------------------------------------------------------->\n<!--------------------Edit Has Many Dialog----------------->\n<!--------------------------------------------------------->\n<ng-template #editHasManyDialog>\n <div class=\"mat-dialog-title\">\n <div>{{metadataHasMany.tableData.editData.title(hasManyEntityPriorChanges)}}</div>\n\n <div class=\"actions-container\">\n @if (metadataHasMany.tableData.editData.actions.length) {\n <button type=\"button\" mat-raised-button [matMenuTriggerFor]=\"menu\">\n {{metadataHasMany.tableData.editData.actionsLabel}}\n </button>\n }\n <mat-menu #menu=\"matMenu\">\n @for (action of metadataHasMany.tableData.editData.actions; track $index) {\n <button type=\"button\" mat-menu-item [disabled]=\"hasManyEditActionDisabled(action)\" (click)=\"hasManyRunEditAction(action)\">\n {{action.displayName}}\n </button>\n }\n </mat-menu>\n \n @if (hasManyAllowDelete(hasManyEntity)) {\n <button type=\"button\" mat-raised-button color=\"warn\" class=\"delete-button\" tabindex=\"-1\" (click)=\"deleteHasManyEntity()\">\n {{metadataHasMany.tableData.editData.deleteButtonLabel}}\n </button>\n }\n </div>\n </div>\n \n <form>\n <mat-dialog-content>\n @if (hasManyEditFormContext) {\n <ng-container *ngTemplateOutlet=\"form; context: hasManyEditFormContext\"></ng-container>\n }\n </mat-dialog-content>\n \n <mat-dialog-actions>\n <div class=\"dialog-button-with-info-icon\">\n <button type=\"submit\" mat-raised-button matBadgeColor=\"warn\"\n [class.badge-changes]=\"!hasManyValidationErrors.length\"\n [disabled]=\"internalIsReadOnly || !isHasManyEntityValid || !isHasManyEntityDirty\"\n [matBadge]=\"hasManyValidationErrors.length > 0 ? hasManyValidationErrors.length : hasManyChanges.length\"\n [matBadgeHidden]=\"!hasManyValidationErrors.length && !hasManyChanges.length\"\n (click)=\"dialogEditHasMany()\"\n >\n {{metadataHasMany.tableData.editData.confirmButtonLabel}}\n </button>\n @if (hasManyValidationErrors.length || hasManyChanges.length) {\n <ngx-mat-entity-tooltip [tooltipContent]=\"hasManyTooltipContent\"></ngx-mat-entity-tooltip>\n }\n </div>\n <button type=\"button\" mat-raised-button class=\"cancel-button\" (click)=\"dialogCancelEditHasMany()\">\n {{metadataHasMany.tableData.editData.cancelButtonLabel}}\n </button>\n </mat-dialog-actions>\n </form>\n</ng-template>", styles: ["::ng-deep mat-tab-body{padding-top:10px;padding-left:12px;padding-right:12px}::ng-deep mat-tab-body .mat-mdc-tab-body-content{overflow:initial}::ng-deep .mat-mdc-tab-body-wrapper{margin-left:-12px;margin-right:-12px}::ng-deep .mat-mdc-form-field-has-icon-suffix .mat-mdc-text-field-wrapper{padding-right:16px}::ng-deep .select-search-input{width:100%;margin-top:-8px;margin-bottom:8px}::ng-deep .select-search-input .mat-mdc-form-field-subscript-wrapper{display:none}::ng-deep .mat-mdc-form-field.mat-form-field-disabled label{color:#0009}::ng-deep .mat-mdc-form-field.mat-form-field-disabled input,::ng-deep .mat-mdc-form-field.mat-form-field-disabled textarea,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mat-mdc-select-disabled,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mat-mdc-select-value{color:#000!important}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-checkbox .mdc-checkbox__native-control[disabled]:not(:checked):not(:indeterminate):not([data-indeterminate=true])~.mdc-checkbox__background{border-color:#707070}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-checkbox .mdc-checkbox__native-control[disabled]:checked~.mdc-checkbox__background,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-checkbox .mdc-checkbox__native-control[disabled]:indeterminate~.mdc-checkbox__background,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-checkbox .mdc-checkbox__native-control[data-indeterminate=true][disabled]~.mdc-checkbox__background{background-color:#000}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mat-mdc-chip.mat-mdc-standard-chip.mat-mdc-chip-disabled{opacity:1}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mat-mdc-chip.mat-mdc-standard-chip.mat-mdc-chip-disabled button{opacity:.2}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-switch.mdc-switch--selected:disabled .mdc-switch__icons,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-switch.mdc-switch--unselected:disabled .mdc-switch__icons{opacity:1}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-switch.mdc-switch--selected:disabled .mdc-switch__handle:after,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-switch.mdc-switch--unselected:disabled .mdc-switch__handle:after{opacity:1;background:#000}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-switch.mdc-switch--selected:disabled .mdc-switch__track,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-switch.mdc-switch--unselected:disabled .mdc-switch__track{opacity:.3}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mat-date-range-input-inner:disabled{color:#000}::ng-deep #slider.mat-mdc-slider.mdc-slider--disabled{opacity:1}::ng-deep #slider.mat-mdc-slider.mdc-slider--disabled .mdc-slider__input{cursor:default}::ng-deep #slider.mat-mdc-slider.mdc-slider--disabled mat-slider-visual-thumb .mat-mdc-slider,::ng-deep #slider.mat-mdc-slider.mdc-slider--disabled mat-slider-visual-thumb .mdc-slider__thumb:hover,::ng-deep #slider.mat-mdc-slider.mdc-slider--disabled mat-slider-visual-thumb .mdc-slider__thumb-knob{background-color:#000;border-color:#000}::ng-deep .mat-mdc-form-field .mat-mdc-slide-toggle{opacity:1}::ng-deep .badge-changes .mat-badge-content{background-color:orange;color:#fff}mat-spinner{margin:10px auto}.mdc-data-table__row:last-child .mdc-data-table__cell{border-bottom:1px solid rgba(0,0,0,.12)}mat-paginator{padding-top:10px;padding-bottom:10px}.dialog-button-with-info-icon{margin-top:10px;gap:12px;display:flex;align-items:center}.actions-container{display:flex;gap:10px}.object-dropdown{width:100%}.table-with-error-slot{border:1px solid #E0E0E0;border-radius:5px;padding-top:5px;padding-bottom:5px}.mat-column-select{flex:0 0 48px;padding-left:0;padding-right:0;justify-content:center}.enabled:hover{cursor:pointer}.table-error{display:flex;align-items:center;justify-content:center;margin-top:-6px;border:1px solid #E0E0E0;background-color:#f8d3d7;color:#721c24;height:fit-content;padding-left:4px;padding-right:4px;border-bottom-left-radius:5px;border-bottom-right-radius:5px}.entityArray .elevation-container{border-radius:5px;padding:15px 15px 0;margin-bottom:15px;margin-top:15px}.entityArray .array-headline{padding-bottom:10px}.entityArray .buttons{display:flex;justify-content:space-between;margin-bottom:10px;margin-top:5px;flex-wrap:wrap;gap:10px}.entityArray .buttons button{flex-grow:1}.hasMany button{width:100%;height:56px;line-height:24px;font-size:16px}.hasMany .title{text-align:center}.hasMany .elevation-container{margin-bottom:15px}\n", "::ng-deep .mdc-dialog .mdc-dialog__content{padding:6px 20px!important}mat-dialog-actions{justify-content:space-between;align-items:center;padding-left:20px;padding-right:20px}.mat-dialog-title{padding:12px 20px;display:flex;justify-content:space-between;align-items:center}.mat-dialog-title div{font-size:var(--mdc-dialog-subhead-size, 14px);font-weight:var(--mdc-dialog-subhead-weight, 500)}\n", ".grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.grid{display:grid}@media (min-width: 1024px){.lg\\:col-span-12{grid-column:span 12/span 12!important}.lg\\:col-span-11{grid-column:span 11/span 11!important}.lg\\:col-span-10{grid-column:span 10/span 10!important}.lg\\:col-span-9{grid-column:span 9/span 9!important}.lg\\:col-span-8{grid-column:span 8/span 8!important}.lg\\:col-span-7{grid-column:span 7/span 7!important}.lg\\:col-span-6{grid-column:span 6/span 6!important}.lg\\:col-span-5{grid-column:span 5/span 5!important}.lg\\:col-span-4{grid-column:span 4/span 4!important}.lg\\:col-span-3{grid-column:span 3/span 3!important}.lg\\:col-span-2{grid-column:span 2/span 2!important}.lg\\:col-span-1{grid-column:span 1/span 1!important}}@media (min-width: 768px) and (max-width: 1023px){.md\\:col-span-12{grid-column:span 12/span 12!important}.md\\:col-span-11{grid-column:span 11/span 11!important}.md\\:col-span-10{grid-column:span 10/span 10!important}.md\\:col-span-9{grid-column:span 9/span 9!important}.md\\:col-span-8{grid-column:span 8/span 8!important}.md\\:col-span-7{grid-column:span 7/span 7!important}.md\\:col-span-6{grid-column:span 6/span 6!important}.md\\:col-span-5{grid-column:span 5/span 5!important}.md\\:col-span-4{grid-column:span 4/span 4!important}.md\\:col-span-3{grid-column:span 3/span 3!important}.md\\:col-span-2{grid-column:span 2/span 2!important}.md\\:col-span-1{grid-column:span 1/span 1!important}}.col-span-12{grid-column:span 12/span 12}.col-span-11{grid-column:span 11/span 11}.col-span-10{grid-column:span 10/span 10}.col-span-9{grid-column:span 9/span 9}.col-span-8{grid-column:span 8/span 8}.col-span-7{grid-column:span 7/span 7}.col-span-6{grid-column:span 6/span 6}.col-span-5{grid-column:span 5/span 5}.col-span-4{grid-column:span 4/span 4}.col-span-3{grid-column:span 3/span 3}.col-span-2{grid-column:span 2/span 2}.col-span-1{grid-column:span 1/span 1}\n"], dependencies: [{ kind: "component", type: NgxMatEntityInputComponent, selector: "ngx-mat-entity-input", inputs: ["entity", "propertyKey", "getValidationErrorMessage", "hideOmitForCreate", "hideOmitForEdit", "validEmpty", "isReadOnly"], outputs: ["inputChangeEvent"] }, { kind: "component", type: DisplayColumnValueComponent, selector: "display-column-value", inputs: ["entity", "ComponentClass"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: MatTabsModule }, { kind: "component", type: i5.MatTab, selector: "mat-tab", inputs: ["disabled", "label", "aria-label", "aria-labelledby", "labelClass", "bodyClass"], exportAs: ["matTab"] }, { kind: "component", type: i5.MatTabGroup, selector: "mat-tab-group", inputs: ["color", "fitInkBarToContent", "mat-stretch-tabs", "dynamicHeight", "selectedIndex", "headerPosition", "animationDuration", "contentTabIndex", "disablePagination", "disableRipple", "preserveContent", "backgroundColor", "aria-label", "aria-labelledby"], outputs: ["selectedIndexChange", "focusChange", "animationDone", "selectedTabChange"], exportAs: ["matTabGroup"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i6.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i6.MatLabel, selector: "mat-label" }, { kind: "directive", type: i6.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i6.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatSelectModule }, { kind: "component", type: i7.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "component", type: i8.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i9.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i9.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i9.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i9.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i9.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: MatDialogModule }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "ngmodule", type: MatBadgeModule }, { kind: "directive", type: i10.MatBadge, selector: "[matBadge]", inputs: ["matBadgeColor", "matBadgeOverlap", "matBadgeDisabled", "matBadgePosition", "matBadge", "matBadgeDescription", "matBadgeSize", "matBadgeHidden"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i11.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: "ngmodule", type: MatMenuModule }, { kind: "component", type: i12.MatMenu, selector: "mat-menu", inputs: ["backdropClass", "aria-label", "aria-labelledby", "aria-describedby", "xPosition", "yPosition", "overlapTrigger", "hasBackdrop", "class", "classList"], outputs: ["closed", "close"], exportAs: ["matMenu"] }, { kind: "component", type: i12.MatMenuItem, selector: "[mat-menu-item]", inputs: ["role", "disabled", "disableRipple"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i12.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData", "matMenuTriggerRestoreFocus"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }, { kind: "ngmodule", type: MatPaginatorModule }, { kind: "component", type: i13.MatPaginator, selector: "mat-paginator", inputs: ["color", "pageIndex", "length", "pageSize", "pageSizeOptions", "hidePageSize", "showFirstLastButtons", "selectConfig", "disabled"], outputs: ["page"], exportAs: ["matPaginator"] }, { kind: "ngmodule", type: MatProgressSpinnerModule }, { kind: "component", type: i14.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "ngmodule", type: MatTableModule }, { kind: "component", type: i15.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i15.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i15.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i15.MatColumnDef, selector: "[matColumnDef]", inputs: ["matColumnDef"] }, { kind: "directive", type: i15.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i15.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i15.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i15.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i15.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i15.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "ngmodule", type: MatCheckboxModule }, { kind: "component", type: i16.MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "disabledInteractive", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i17.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: TooltipComponent, selector: "ngx-mat-entity-tooltip", inputs: ["tooltipContent"] }, { kind: "component", type: StringInputComponent, selector: "string-input" }, { kind: "component", type: StringTextboxInputComponent, selector: "string-textbox-input" }, { kind: "component", type: StringAutocompleteInputComponent, selector: "string-autocomplete-input" }, { kind: "component", type: StringDropdownInputComponent, selector: "string-dropdown-input" }, { kind: "component", type: StringPasswordInputComponent, selector: "string-password-input" }, { kind: "component", type: BooleanCheckboxInputComponent, selector: "boolean-checkbox-input" }, { kind: "component", type: BooleanToggleInputComponent, selector: "boolean-toggle-input" }, { kind: "component", type: BooleanDropdownInputComponent, selector: "boolean-dropdown-input" }, { kind: "component", type: NumberInputComponent, selector: "number-input" }, { kind: "component", type: NumberDropdownInputComponent, selector: "number-dropdown-input" }, { kind: "component", type: NumberSliderInputComponent, selector: "number-slider-input" }, { kind: "component", type: ArrayDateInputComponent, selector: "array-date-input" }, { kind: "component", type: ArrayDateRangeInputComponent, selector: "array-date-range-input" }, { kind: "component", type: ArrayDateTimeInputComponent, selector: "array-date-time-input" }, { kind: "component", type: ArrayStringAutocompleteChipsComponent, selector: "array-string-autocomplete-chips" }, { kind: "component", type: ArrayStringChipsInputComponent, selector: "array-string-chips-input" }, { kind: "component", type: DateInputComponent, selector: "date-input" }, { kind: "component", type: DateRangeInputComponent, selector: "date-range-input" }, { kind: "component", type: DateTimeInputComponent, selector: "date-time-input" }, { kind: "component", type: FileDefaultInputComponent, selector: "file-default-input" }, { kind: "component", type: FileImageInputComponent, selector: "file-image-input" }, { kind: "component", type: ReferencesManyInputComponent, selector: "references-many-input" }, { kind: "component", type: CustomInputComponent, selector: "custom-input" }, { kind: "directive", type: DynamicStyleClassDirective, selector: "[dynamicStyleClasses]", inputs: ["dynamicStyleClasses", "value"] }, { kind: "ngmodule", type: MatSortModule }, { kind: "directive", type: i18.MatSort, selector: "[matSort]", inputs: ["matSortActive", "matSortStart", "matSortDirection", "matSortDisableClear", "matSortDisabled"], outputs: ["matSortChange"], exportAs: ["matSort"] }, { kind: "component", type: i18.MatSortHeader, selector: "[mat-sort-header]", inputs: ["mat-sort-header", "arrowPosition", "start", "disabled", "sortActionDescription", "disableClear"], exportAs: ["matSortHeader"] }, { kind: "component", type: FaIconComponent, selector: "fa-icon", inputs: ["icon", "title", "animation", "mask", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "transform", "a11yRole"] }] });
|
|
1168
1219
|
}
|
|
1169
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.
|
|
1220
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.7", ngImport: i0, type: NgxMatEntityInputComponent, decorators: [{
|
|
1170
1221
|
type: Component,
|
|
1171
1222
|
args: [{ selector: 'ngx-mat-entity-input', standalone: true, imports: [
|
|
1172
1223
|
DisplayColumnValueComponent,
|
|
@@ -1207,8 +1258,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
|
|
|
1207
1258
|
FileDefaultInputComponent,
|
|
1208
1259
|
FileImageInputComponent,
|
|
1209
1260
|
ReferencesManyInputComponent,
|
|
1210
|
-
CustomInputComponent
|
|
1211
|
-
], template: "<!-- eslint-disable angular/no-call-expression -->\n \n@if(!(hideOmitForCreate && metadata.omitForCreate) && !(hideOmitForEdit && metadata.omitForUpdate)) {\n @switch (type) {\n <!-------------------------------------------->\n <!-----------------Strings-------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.STRING) {\n <string-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </string-input>\n }\n @case (DecoratorTypes.STRING_TEXTBOX) {\n <string-textbox-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </string-textbox-input>\n }\n @case (DecoratorTypes.STRING_AUTOCOMPLETE) {\n <string-autocomplete-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </string-autocomplete-input>\n }\n @case (DecoratorTypes.STRING_DROPDOWN) {\n <string-dropdown-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </string-dropdown-input>\n }\n @case (DecoratorTypes.STRING_PASSWORD) {\n <string-password-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </string-password-input>\n }\n <!-------------------------------------------->\n <!-----------------Booleans------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.BOOLEAN_CHECKBOX) {\n <boolean-checkbox-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </boolean-checkbox-input>\n }\n @case (DecoratorTypes.BOOLEAN_TOGGLE) {\n <boolean-toggle-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </boolean-toggle-input>\n }\n @case (DecoratorTypes.BOOLEAN_DROPDOWN) {\n <boolean-dropdown-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </boolean-dropdown-input>\n }\n <!-------------------------------------------->\n <!------------------Numbers------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.NUMBER) {\n <number-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </number-input>\n }\n @case (DecoratorTypes.NUMBER_DROPDOWN) {\n <number-dropdown-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </number-dropdown-input>\n }\n @case (DecoratorTypes.NUMBER_SLIDER) {\n <number-slider-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </number-slider-input>\n }\n <!-------------------------------------------->\n <!-------------------Array-------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.ARRAY_DATE) {\n <array-date-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </array-date-input>\n }\n @case (DecoratorTypes.ARRAY_DATE_TIME) {\n <array-date-time-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </array-date-time-input>\n }\n @case (DecoratorTypes.ARRAY_DATE_RANGE) {\n <array-date-range-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </array-date-range-input>\n }\n @case (DecoratorTypes.ARRAY_STRING_CHIPS) {\n <array-string-chips-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </array-string-chips-input>\n }\n @case (DecoratorTypes.ARRAY_STRING_AUTOCOMPLETE_CHIPS) {\n <array-string-autocomplete-chips\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </array-string-autocomplete-chips>\n }\n <!-------------------------------------------->\n <!-------------------Dates-------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.DATE) {\n <date-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </date-input>\n }\n @case (DecoratorTypes.DATE_RANGE) {\n <date-range-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </date-range-input>\n }\n @case (DecoratorTypes.DATE_TIME) {\n <date-time-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </date-time-input>\n }\n <!-------------------------------------------->\n <!-------------------Files-------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.FILE_DEFAULT) {\n <file-default-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </file-default-input>\n }\n @case (DecoratorTypes.FILE_IMAGE) {\n <file-image-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </file-image-input>\n }\n <!-------------------------------------------->\n <!-------------- references many ------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.REFERENCES_MANY) {\n <references-many-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </references-many-input>\n }\n <!-------------------------------------------->\n <!-------------------Custom------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.CUSTOM) {\n <custom-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </custom-input>\n }\n <!-------------------------------------------->\n <!-------------------Object------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.OBJECT) {\n <b>{{metadataDefaultObject.displayName}}</b>\n <!-- iterates over the object properties -->\n <ng-container *ngTemplateOutlet=\"form; context: objectFormContext\"></ng-container>\n }\n <!-------------------------------------------->\n <!---------------Object Dropdown-------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.OBJECT_DROPDOWN) {\n <mat-form-field class=\"object-dropdown\">\n <mat-label>{{metadata.displayName}}</mat-label>\n <mat-select #model=\"ngModel\"\n [name]=\"objectDropdownName\"\n [required]=\"metadata.required(entity)\"\n [disabled]=\"internalIsReadOnly\"\n [compareWith]=\"compareObjectsBound\"\n [(ngModel)]=\"entity[propertyKey]\"\n (selectionChange)=\"emitChange()\"\n (opened)=\"selectSearchInput.focus()\"\n >\n <mat-form-field class=\"select-search-input\">\n <!-- eslint-disable-next-line angular/no-any -->\n <input #selectSearchInput matInput (keyup)=\"filterObjectDropdownValues($any($event.target).value)\">\n <i matSuffix class=\"fas fa-search\"></i>\n </mat-form-field>\n @if (!metadata.required(entity)) {\n <mat-option>-</mat-option>\n }\n @if (shouldDisplayCurrentObjectDropdownValue) {\n <mat-option [value]=\"currentObjectDropdownValue?.value\">{{currentObjectDropdownValue?.displayName}}</mat-option>\n }\n @for (value of filteredObjectDropdownValues; track $index) {\n <mat-option [value]=\"value.value\">{{value.displayName}}</mat-option>\n }\n </mat-select>\n <mat-error>{{internalGetValidationErrorMessage(model)}}</mat-error>\n </mat-form-field>\n }\n <!-------------------------------------------->\n <!-------------- references one -------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.REFERENCES_ONE) {\n <mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <mat-select #inputModel=\"ngModel\"\n [name]=\"referencesOneName\"\n [disabled]=\"internalIsReadOnly\"\n [required]=\"metadata.required(entity)\"\n [(ngModel)]=\"entity[propertyKey]\"\n (selectionChange)=\"setReferencesOneObject()\"\n (opened)=\"selectSearchInput.focus()\"\n >\n <mat-form-field class=\"select-search-input\">\n <!-- eslint-disable-next-line angular/no-any -->\n <input #selectSearchInput matInput (keyup)=\"filterReferencesOneValues($any($event.target).value)\">\n <i matSuffix class=\"fas fa-search\"></i>\n </mat-form-field>\n @if (!metadata.required(entity)) {\n <mat-option>-</mat-option>\n }\n @if (shouldDisplayCurrentReferencesOneDropdownValue) {\n <mat-option [value]=\"currentReferencesOneDropdownValue?.value\">{{currentReferencesOneDropdownValue?.displayName}}</mat-option>\n }\n @for (value of filteredReferencesOneDropdownValues; track $index) {\n <mat-option [value]=\"value.value\">{{value.displayName}}</mat-option>\n }\n </mat-select>\n <mat-error>{{internalGetValidationErrorMessage(inputModel)}}</mat-error>\n </mat-form-field>\n <!-- iterates over the references one properties -->\n @if (referencesOneFormContext) {\n <ng-container *ngTemplateOutlet=\"form; context: referencesOneFormContext\"></ng-container>\n }\n }\n <!-------------------------------------------->\n <!-------------------Array-------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.ARRAY) {\n <div class=\"entityArray\">\n <div class=\"mat-elevation-z8 elevation-container\">\n <div class=\"array-headline\">\n <b>{{metadataEntityArray.displayName}}</b>\n </div>\n @if (metadataEntityArray.createInline && !internalIsReadOnly && addArrayItemFormContext) {\n <ng-container *ngTemplateOutlet=\"form; context: addArrayItemFormContext\"></ng-container>\n }\n @if (!internalIsReadOnly) {\n <div class=\"buttons\">\n <button type=\"button\" mat-raised-button\n [disabled]=\"metadataEntityArray.createInline && !isArrayItemValid\"\n (click)=\"addEntity()\">\n {{metadataEntityArray.addButtonLabel}}\n </button>\n <button type=\"button\" mat-raised-button\n [disabled]=\"!entityArraySelection.selected.length\"\n (click)=\"removeFromEntityArray()\">\n {{metadataEntityArray.removeButtonLabel}}\n </button>\n </div>\n }\n <mat-table [dataSource]=\"entityArrayDataSource\">\n @if (!internalIsReadOnly) {\n <ng-container matColumnDef=\"select\">\n <mat-header-cell *matHeaderCellDef>\n <mat-checkbox\n [disabled]=\"!entityArrayDataSource.data.length\" [checked]=\"entityArraySelection.hasValue() && SelectionUtilities.isAllSelected(entityArraySelection, entityArrayDataSource)\"\n [indeterminate]=\"entityArraySelection.hasValue() && !SelectionUtilities.isAllSelected(entityArraySelection, entityArrayDataSource)\"\n (change)=\"$event ? SelectionUtilities.masterToggle(entityArraySelection, entityArrayDataSource) : null\">\n </mat-checkbox>\n </mat-header-cell>\n <mat-cell *matCellDef=\"let entity\">\n <mat-checkbox [checked]=\"entityArraySelection.isSelected(entity)\" (click)=\"$event.stopPropagation()\" (change)=\"$event ? entityArraySelection.toggle(entity) : null\"></mat-checkbox>\n </mat-cell>\n </ng-container>\n }\n @for (dCol of metadataEntityArray.displayColumns; track $index) {\n <ng-container [matColumnDef]=\"dCol.displayName\">\n <mat-header-cell *matHeaderCellDef>\n {{dCol.displayName}}\n </mat-header-cell>\n <mat-cell *matCellDef=\"let entity\" [class.enabled]=\"!dCol.disableClick\" (click)=\"editArrayItem(entity, dCol)\">\n @if (dCol.Component) {\n <display-column-value [entity]=\"entity\" [ComponentClass]=\"dCol.Component\"></display-column-value>\n }\n @else {\n {{getDisplayColumnValue(entity, dCol)}}\n }\n </mat-cell>\n </ng-container>\n }\n <mat-header-row *matHeaderRowDef=\"entityArrayDisplayedColumns\"></mat-header-row>\n <mat-row *matRowDef=\"let row; columns: entityArrayDisplayedColumns\"></mat-row>\n </mat-table>\n \n @if (metadataEntityArray.required(entity) && !entityArrayDataSource.data.length) {\n <div class=\"array-error\">{{metadataEntityArray.missingErrorMessage}}</div>\n }\n </div>\n </div>\n }\n <!-------------------------------------------->\n <!------------------ has many ---------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.HAS_MANY) {\n <div class=\"hasMany\">\n <h2 class=\"title\">{{metadataHasMany.tableData.baseData.title}}</h2>\n <div class=\"row\">\n <mat-form-field class=\"col-lg-8 col-md-6 col-sm-12\">\n <mat-label>{{metadataHasMany.tableData.baseData.searchLabel}}</mat-label>\n <input matInput (keyup)=\"applyHasManyFilter($event)\">\n </mat-form-field>\n @if (metadataHasMany.tableData.baseData.tableActions.length) {\n <div\n [class.col-lg-2]=\"hasManyAllowCreate\"\n [class.col-lg-4]=\"!hasManyAllowCreate\"\n [class.col-md-3]=\"hasManyAllowCreate\"\n [class.col-md-6]=\"!hasManyAllowCreate\"\n [class.col-sm-6]=\"hasManyAllowCreate\"\n [class.col-sm-12]=\"!hasManyAllowCreate\"\n >\n <button type=\"button\" class=\"actions-button\" mat-raised-button [matMenuTriggerFor]=\"menu\">\n {{metadataHasMany.tableData.baseData.tableActionsLabel}}\n </button>\n </div>\n }\n <mat-menu #menu=\"matMenu\">\n @if (metadataHasMany.tableData.baseData.allowJsonImport) {\n <button type=\"button\" mat-menu-item [disabled]=\"hasManyTableActionDisabled(hasManyImportAction)\" (click)=\"runHasManyTableAction(hasManyImportAction)\">\n {{hasManyImportAction.displayName}}\n </button>\n }\n @for (action of metadataHasMany.tableData.baseData.tableActions; track $index) {\n <button type=\"button\" mat-menu-item [disabled]=\"hasManyTableActionDisabled(action)\" (click)=\"runHasManyTableAction(action)\">\n {{action.displayName}}\n </button>\n }\n </mat-menu>\n @if (hasManyAllowCreate) {\n <div\n [class.col-lg-2]=\"metadataHasMany.tableData.baseData.tableActions.length\"\n [class.col-lg-4]=\"!metadataHasMany.tableData.baseData.tableActions.length\"\n [class.col-md-3]=\"metadataHasMany.tableData.baseData.tableActions.length\"\n [class.col-md-6]=\"!metadataHasMany.tableData.baseData.tableActions.length\"\n [class.col-sm-6]=\"metadataHasMany.tableData.baseData.tableActions.length\"\n [class.col-sm-12]=\"!metadataHasMany.tableData.baseData.tableActions.length\"\n >\n <button type=\"button\" class=\"create-button\" mat-raised-button (click)=\"createHasManyEntity()\">\n {{metadataHasMany.tableData.baseData.createButtonLabel}}\n </button>\n </div>\n }\n </div>\n \n <div class=\"mat-elevation-z8 elevation-container\">\n <mat-table matSort [dataSource]=\"hasManyDataSource\">\n <!-- select Column -->\n <ng-container matColumnDef=\"select\">\n <mat-header-cell *matHeaderCellDef>\n <mat-checkbox [checked]=\"hasManySelection.hasValue() && SelectionUtilities.isAllSelected(hasManySelection, hasManyDataSource)\"\n [indeterminate]=\"hasManySelection.hasValue() && !SelectionUtilities.isAllSelected(hasManySelection, hasManyDataSource)\"\n (change)=\"$event ? SelectionUtilities.masterToggle(hasManySelection, hasManyDataSource) : null\">\n </mat-checkbox>\n </mat-header-cell>\n <mat-cell *matCellDef=\"let entity\" class=\"enabled\">\n <mat-checkbox [checked]=\"hasManySelection.isSelected(entity)\"\n (click)=\"$event.stopPropagation()\"\n (change)=\"$event ? hasManySelection.toggle(entity) : null\">\n </mat-checkbox>\n </mat-cell>\n </ng-container>\n \n @for (dCol of metadataHasMany.tableData.baseData.displayColumns; track $index) {\n <ng-container [matColumnDef]=\"dCol.displayName\">\n <mat-header-cell *matHeaderCellDef mat-sort-header>\n {{dCol.displayName}}\n </mat-header-cell>\n <mat-cell *matCellDef=\"let entity\"\n [class.enabled]=\"!dCol.disableClick && (hasManyAllowUpdate(entity) || hasManyAllowRead(entity))\"\n (click)=\"editHasManyEntity(entity, dCol)\"\n >\n @if (dCol.Component) {\n <display-column-value [entity]=\"entity\" [ComponentClass]=\"dCol.Component\"></display-column-value>\n }\n @else {\n {{getDisplayColumnValue(entity, dCol)}}\n }\n </mat-cell>\n </ng-container>\n }\n <mat-header-row *matHeaderRowDef=\"displayedHasManyColumns\"></mat-header-row>\n <mat-row *matRowDef=\"let row; columns: displayedHasManyColumns\"></mat-row>\n </mat-table>\n \n @if (hasManyIsLoading && metadataHasMany.tableData.baseData.displayLoadingSpinner) {\n <mat-spinner></mat-spinner>\n }\n <mat-paginator style=\"padding-top: 10px; padding-bottom: 10px;\" [length]=\"hasManyDataSource.filteredData.length\" [pageIndex]=\"0\" [pageSize]=\"10\" [pageSizeOptions]=\"[5, 10, 25, 50]\"></mat-paginator>\n </div>\n </div>\n }\n \n @default {\n <div>ERROR: The type {{type}} is not known.</div>\n }\n }\n}\n\n\n\n\n<!--------------------------------------------------------->\n<!---------------------------Form-------------------------->\n<!--------------------------------------------------------->\n<ng-template #form let-context>\n <!-- eslint-disable angular/no-call-expression -->\n @if (context.tabs.length > 1) {\n <mat-tab-group preserveContent>\n @for (tab of context.tabs; track $index) {\n <mat-tab [label]=\"tab.tabName\">\n @for (row of tab.rows; track $index) {\n <div class=\"row\">\n @for (key of row.keys; track key) {\n <ngx-mat-entity-input\n [entity]=\"context.entity\"\n [propertyKey]=\"key\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [validEmpty]=\"context.validEmpty?.()\"\n [isReadOnly]=\"context.isReadOnly?.(context.entity, key)\"\n [class]=\"EntityUtilities.getWidthClasses(context.entity, key)\"\n [hideOmitForEdit]=\"context.hideOmitForEdit\"\n [hideOmitForCreate]=\"context.hideOmitForCreate\"\n (inputChangeEvent)=\"context.inputChangeEvent()\"\n >\n </ngx-mat-entity-input>\n }\n </div>\n }\n </mat-tab>\n }\n </mat-tab-group>\n }\n @else {\n @if (!context.tabs.length) {\n <span class=\"no-entity-tabs\">\n ERROR: No Inputs. Did you correctly assign all values in the model constructor?\n </span>\n }\n @else {\n @for (row of context.tabs[0].rows; track $index) {\n <div class=\"row\">\n @for (key of row.keys; track key) {\n <ngx-mat-entity-input\n [entity]=\"context.entity\"\n [propertyKey]=\"key\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [validEmpty]=\"context.validEmpty?.()\"\n [isReadOnly]=\"context.isReadOnly?.(context.entity, key)\"\n [class]=\"EntityUtilities.getWidthClasses(context.entity, key)\"\n [hideOmitForEdit]=\"context.hideOmitForEdit\"\n [hideOmitForCreate]=\"context.hideOmitForCreate\"\n (inputChangeEvent)=\"context.inputChangeEvent()\"\n >\n </ngx-mat-entity-input>\n }\n </div>\n }\n }\n }\n</ng-template>\n\n<!--------------------------------------------------------->\n<!--------------------Add Array Item Dialog---------------->\n<!--------------------------------------------------------->\n<ng-template #addArrayItemDialog>\n <div class=\"mat-dialog-title\">\n <div>{{addArrayItemDialogData.title}}</div>\n </div>\n\n <form>\n <mat-dialog-content>\n @if (addArrayItemFormContext) {\n <ng-container *ngTemplateOutlet=\"form; context: addArrayItemFormContext\"></ng-container>\n }\n </mat-dialog-content>\n \n <mat-dialog-actions>\n <div class=\"d-flex align-items-center gap-3\" style=\"margin-top: 10px;\">\n <button type=\"submit\" mat-raised-button matBadgeColor=\"warn\"\n [disabled]=\"!isArrayItemValid\"\n [matBadge]=\"arrayItemValidationErrors.length\"\n [matBadgeHidden]=\"!arrayItemValidationErrors.length\"\n (click)=\"addArrayItem()\"\n >\n {{addArrayItemDialogData.createButtonLabel}}\n </button>\n @if (arrayItemValidationErrors.length) {\n <ngx-mat-entity-tooltip [tooltipContent]=\"arrayItemTooltipContent\"></ngx-mat-entity-tooltip>\n }\n </div>\n <button type=\"button\" mat-raised-button class=\"cancel-button\" (click)=\"closeAddArrayItemDialog()\">\n {{addArrayItemDialogData.cancelButtonLabel}}\n </button>\n </mat-dialog-actions>\n </form>\n\n</ng-template>\n\n<!--------------------------------------------------------->\n<!--------------------Edit Array Item Dialog---------------->\n<!--------------------------------------------------------->\n<ng-template #editArrayItemDialog>\n <div class=\"mat-dialog-title\">\n <div>{{editArrayItemDialogData.title(arrayItemPriorChanges)}}</div>\n </div>\n \n <form>\n <mat-dialog-content>\n @if (editArrayItemFormContext) {\n <ng-container *ngTemplateOutlet=\"form; context: editArrayItemFormContext\"></ng-container>\n }\n </mat-dialog-content>\n \n <mat-dialog-actions>\n <div class=\"d-flex align-items-center gap-3\" style=\"margin-top: 10px;\">\n <button type=\"submit\" mat-raised-button matBadgeColor=\"warn\"\n [disabled]=\"internalIsReadOnly || !isArrayItemValid || !isArrayItemDirty\"\n [matBadge]=\"arrayItemValidationErrors.length\"\n [matBadgeHidden]=\"!arrayItemValidationErrors.length\"\n (click)=\"saveArrayItem()\"\n >\n {{editArrayItemDialogData.confirmButtonLabel}}\n </button>\n @if (arrayItemValidationErrors.length) {\n <ngx-mat-entity-tooltip [tooltipContent]=\"arrayItemTooltipContent\"></ngx-mat-entity-tooltip>\n }\n </div>\n <button type=\"button\" mat-raised-button class=\"cancel-button\" (click)=\"closeEditArrayItemDialog()\">\n {{editArrayItemDialogData.cancelButtonLabel}}\n </button>\n </mat-dialog-actions>\n </form>\n</ng-template>\n\n<!--------------------------------------------------------->\n<!--------------------Create Has Many Dialog---------------->\n<!--------------------------------------------------------->\n<ng-template #createHasManyDialog>\n <div class=\"mat-dialog-title\">\n <div>{{metadataHasMany.tableData.createData.title}}</div>\n </div>\n \n <form>\n <mat-dialog-content>\n @if (hasManyCreateFormContext) {\n <ng-container *ngTemplateOutlet=\"form; context: hasManyCreateFormContext\"></ng-container>\n }\n </mat-dialog-content>\n \n <mat-dialog-actions>\n <div class=\"d-flex align-items-center gap-3\" style=\"margin-top: 10px;\">\n <button type=\"submit\" mat-raised-button matBadgeColor=\"warn\"\n [disabled]=\"!isHasManyEntityValid\"\n [matBadge]=\"hasManyValidationErrors.length\"\n [matBadgeHidden]=\"!hasManyValidationErrors.length\"\n (click)=\"dialogCreateHasMany()\"\n >\n {{metadataHasMany.tableData.createData.createButtonLabel}}\n </button>\n @if (hasManyValidationErrors.length) {\n <ngx-mat-entity-tooltip [tooltipContent]=\"hasManyTooltipContent\"></ngx-mat-entity-tooltip>\n }\n </div>\n <button type=\"button\" mat-raised-button class=\"cancel-button\" (click)=\"dialogCancelCreateHasMany()\">\n {{metadataHasMany.tableData.createData.cancelButtonLabel}}\n </button>\n </mat-dialog-actions>\n </form>\n \n</ng-template>\n\n<!--------------------------------------------------------->\n<!--------------------Edit Has Many Dialog----------------->\n<!--------------------------------------------------------->\n<ng-template #editHasManyDialog>\n <div class=\"mat-dialog-title\">\n <div>{{metadataHasMany.tableData.editData.title(hasManyEntityPriorChanges)}}</div>\n\n <div class=\"actions-container\">\n @if (metadataHasMany.tableData.editData.actions.length) {\n <button type=\"button\" mat-raised-button [matMenuTriggerFor]=\"menu\">\n {{metadataHasMany.tableData.editData.actionsLabel}}\n </button>\n }\n <mat-menu #menu=\"matMenu\">\n @for (action of metadataHasMany.tableData.editData.actions; track $index) {\n <button type=\"button\" mat-menu-item [disabled]=\"hasManyEditActionDisabled(action)\" (click)=\"hasManyRunEditAction(action)\">\n {{action.displayName}}\n </button>\n }\n </mat-menu>\n \n @if (hasManyAllowDelete(hasManyEntity)) {\n <button type=\"button\" mat-raised-button color=\"warn\" class=\"delete-button\" tabindex=\"-1\" (click)=\"deleteHasManyEntity()\">\n {{metadataHasMany.tableData.editData.deleteButtonLabel}}\n </button>\n }\n </div>\n </div>\n \n <form>\n <mat-dialog-content>\n @if (hasManyEditFormContext) {\n <ng-container *ngTemplateOutlet=\"form; context: hasManyEditFormContext\"></ng-container>\n }\n </mat-dialog-content>\n \n <mat-dialog-actions>\n <div class=\"d-flex align-items-center gap-3\" style=\"margin-top: 10px;\">\n <button type=\"submit\" mat-raised-button matBadgeColor=\"warn\"\n [disabled]=\"internalIsReadOnly || !isHasManyEntityValid || !isHasManyEntityDirty\"\n [matBadge]=\"hasManyValidationErrors.length\"\n [matBadgeHidden]=\"!hasManyValidationErrors.length\"\n (click)=\"dialogEditHasMany()\"\n >\n {{metadataHasMany.tableData.editData.confirmButtonLabel}}\n </button>\n @if (hasManyValidationErrors.length) {\n <ngx-mat-entity-tooltip [tooltipContent]=\"hasManyTooltipContent\"></ngx-mat-entity-tooltip>\n }\n </div>\n <button type=\"button\" mat-raised-button class=\"cancel-button\" (click)=\"dialogCancelEditHasMany()\">\n {{metadataHasMany.tableData.editData.cancelButtonLabel}}\n </button>\n </mat-dialog-actions>\n </form>\n</ng-template>", styles: ["::ng-deep mat-tab-body{padding-top:10px;padding-left:12px;padding-right:12px}::ng-deep mat-tab-body .mat-mdc-tab-body-content{overflow:initial}::ng-deep .mat-mdc-form-field-has-icon-suffix .mat-mdc-text-field-wrapper{padding-right:16px}::ng-deep .select-search-input{width:100%;margin-top:-8px;margin-bottom:8px}::ng-deep .select-search-input .mat-mdc-form-field-subscript-wrapper{display:none}::ng-deep .mdc-dialog .mdc-dialog__content{padding:6px 20px!important}::ng-deep .mat-mdc-tab-body-wrapper{margin-left:-12px;margin-right:-12px}::ng-deep .mat-mdc-form-field.mat-form-field-disabled label{color:#0009}::ng-deep .mat-mdc-form-field.mat-form-field-disabled input,::ng-deep .mat-mdc-form-field.mat-form-field-disabled textarea,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mat-mdc-select-disabled,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mat-mdc-select-value{color:#000!important}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-checkbox .mdc-checkbox__native-control[disabled]:not(:checked):not(:indeterminate):not([data-indeterminate=true])~.mdc-checkbox__background{border-color:#707070}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-checkbox .mdc-checkbox__native-control[disabled]:checked~.mdc-checkbox__background,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-checkbox .mdc-checkbox__native-control[disabled]:indeterminate~.mdc-checkbox__background,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-checkbox .mdc-checkbox__native-control[data-indeterminate=true][disabled]~.mdc-checkbox__background{background-color:#000}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mat-mdc-chip.mat-mdc-standard-chip.mat-mdc-chip-disabled{opacity:1}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mat-mdc-chip.mat-mdc-standard-chip.mat-mdc-chip-disabled button{opacity:.2}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-switch.mdc-switch--selected:disabled .mdc-switch__icons,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-switch.mdc-switch--unselected:disabled .mdc-switch__icons{opacity:1}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-switch.mdc-switch--selected:disabled .mdc-switch__handle:after,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-switch.mdc-switch--unselected:disabled .mdc-switch__handle:after{opacity:1;background:#000}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-switch.mdc-switch--selected:disabled .mdc-switch__track,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-switch.mdc-switch--unselected:disabled .mdc-switch__track{opacity:.3}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mat-date-range-input-inner:disabled{color:#000}::ng-deep #slider.mat-mdc-slider.mdc-slider--disabled{opacity:1}::ng-deep #slider.mat-mdc-slider.mdc-slider--disabled .mdc-slider__input{cursor:default}::ng-deep #slider.mat-mdc-slider.mdc-slider--disabled mat-slider-visual-thumb .mat-mdc-slider,::ng-deep #slider.mat-mdc-slider.mdc-slider--disabled mat-slider-visual-thumb .mdc-slider__thumb:hover,::ng-deep #slider.mat-mdc-slider.mdc-slider--disabled mat-slider-visual-thumb .mdc-slider__thumb-knob{background-color:#000;border-color:#000}::ng-deep .mat-mdc-form-field .mat-mdc-slide-toggle{opacity:1}mat-dialog-actions{justify-content:space-between;align-items:center;padding-left:20px;padding-right:20px}mat-spinner{margin:10px auto}.mdc-data-table__row:last-child .mdc-data-table__cell{border-bottom:1px solid rgba(0,0,0,.12)}.mat-dialog-title{padding:12px 20px;display:flex;justify-content:space-between;align-items:center}.mat-dialog-title div{font-size:var(--mdc-dialog-subhead-size, 14px);font-weight:var(--mdc-dialog-subhead-weight, 500)}.actions-container{display:flex;gap:10px}.object-dropdown{width:100%}.entityArray .elevation-container{border-radius:5px;padding:15px;margin-bottom:15px;margin-top:15px}.entityArray .array-headline{padding-bottom:10px}.entityArray .buttons{display:flex;justify-content:space-between;margin-bottom:10px;margin-top:5px;flex-wrap:wrap;gap:10px}.entityArray .buttons button{flex-grow:1}.entityArray mat-table{border:1px solid #E0E0E0;border-radius:5px;padding-top:5px;padding-bottom:5px}.entityArray .mat-column-select{flex:0 0 48px;padding-left:0;padding-right:0;justify-content:center}.entityArray .enabled:hover{cursor:pointer}.entityArray .array-error{display:flex;align-items:center;justify-content:center;margin-top:-6px;border:1px solid #E0E0E0;background-color:#f8d3d7;color:#721c24;height:fit-content;padding-left:4px;padding-right:4px;border-bottom-left-radius:5px;border-bottom-right-radius:5px}.hasMany button{width:100%;height:56px;line-height:24px;font-size:16px}.hasMany .title{text-align:center}.hasMany .elevation-container{border-radius:5px;padding:5px;margin-bottom:15px}.hasMany .mat-column-select{flex:0 0 48px;padding-left:0;padding-right:0;justify-content:center}.hasMany .enabled:hover{cursor:pointer}\n"] }]
|
|
1261
|
+
CustomInputComponent,
|
|
1262
|
+
DynamicStyleClassDirective,
|
|
1263
|
+
MatSortModule,
|
|
1264
|
+
FaIconComponent
|
|
1265
|
+
], template: "<!-- eslint-disable angular/no-call-expression -->\n \n@if(!(hideOmitForCreate && metadata.omitForCreate) && !(hideOmitForEdit && metadata.omitForUpdate)) {\n @switch (type) {\n <!-------------------------------------------->\n <!-----------------Strings-------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.STRING) {\n <string-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </string-input>\n }\n @case (DecoratorTypes.STRING_TEXTBOX) {\n <string-textbox-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </string-textbox-input>\n }\n @case (DecoratorTypes.STRING_AUTOCOMPLETE) {\n <string-autocomplete-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </string-autocomplete-input>\n }\n @case (DecoratorTypes.STRING_DROPDOWN) {\n <string-dropdown-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </string-dropdown-input>\n }\n @case (DecoratorTypes.STRING_PASSWORD) {\n <string-password-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </string-password-input>\n }\n <!-------------------------------------------->\n <!-----------------Booleans------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.BOOLEAN_CHECKBOX) {\n <boolean-checkbox-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </boolean-checkbox-input>\n }\n @case (DecoratorTypes.BOOLEAN_TOGGLE) {\n <boolean-toggle-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </boolean-toggle-input>\n }\n @case (DecoratorTypes.BOOLEAN_DROPDOWN) {\n <boolean-dropdown-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </boolean-dropdown-input>\n }\n <!-------------------------------------------->\n <!------------------Numbers------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.NUMBER) {\n <number-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </number-input>\n }\n @case (DecoratorTypes.NUMBER_DROPDOWN) {\n <number-dropdown-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </number-dropdown-input>\n }\n @case (DecoratorTypes.NUMBER_SLIDER) {\n <number-slider-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </number-slider-input>\n }\n <!-------------------------------------------->\n <!-------------------Array-------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.ARRAY_DATE) {\n <array-date-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </array-date-input>\n }\n @case (DecoratorTypes.ARRAY_DATE_TIME) {\n <array-date-time-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </array-date-time-input>\n }\n @case (DecoratorTypes.ARRAY_DATE_RANGE) {\n <array-date-range-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </array-date-range-input>\n }\n @case (DecoratorTypes.ARRAY_STRING_CHIPS) {\n <array-string-chips-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </array-string-chips-input>\n }\n @case (DecoratorTypes.ARRAY_STRING_AUTOCOMPLETE_CHIPS) {\n <array-string-autocomplete-chips\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </array-string-autocomplete-chips>\n }\n <!-------------------------------------------->\n <!-------------------Dates-------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.DATE) {\n <date-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </date-input>\n }\n @case (DecoratorTypes.DATE_RANGE) {\n <date-range-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </date-range-input>\n }\n @case (DecoratorTypes.DATE_TIME) {\n <date-time-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </date-time-input>\n }\n <!-------------------------------------------->\n <!-------------------Files-------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.FILE_DEFAULT) {\n <file-default-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </file-default-input>\n }\n @case (DecoratorTypes.FILE_IMAGE) {\n <file-image-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </file-image-input>\n }\n <!-------------------------------------------->\n <!-------------- references many ------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.REFERENCES_MANY) {\n <references-many-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </references-many-input>\n }\n <!-------------------------------------------->\n <!-------------------Custom------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.CUSTOM) {\n <custom-input\n [entity]=\"entity\"\n [key]=\"propertyKey\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [isReadOnly]=\"internalIsReadOnly\"\n (inputChangeEvent)=\"emitChange()\"\n >\n </custom-input>\n }\n <!-------------------------------------------->\n <!-------------------Object------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.OBJECT) {\n <b>{{metadataDefaultObject.displayName}}</b>\n <!-- iterates over the object properties -->\n <ng-container *ngTemplateOutlet=\"form; context: objectFormContext\"></ng-container>\n }\n <!-------------------------------------------->\n <!---------------Object Dropdown-------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.OBJECT_DROPDOWN) {\n <mat-form-field class=\"object-dropdown\">\n <mat-label>{{metadata.displayName}}</mat-label>\n <mat-select #model=\"ngModel\"\n [name]=\"objectDropdownName\"\n [required]=\"metadata.required(entity)\"\n [disabled]=\"internalIsReadOnly\"\n [compareWith]=\"compareObjectsBound\"\n [(ngModel)]=\"entity[propertyKey]\"\n (selectionChange)=\"emitChange()\"\n (opened)=\"selectSearchInput.focus()\"\n >\n <mat-form-field class=\"select-search-input\">\n <!-- eslint-disable-next-line angular/no-any -->\n <input #selectSearchInput matInput (keyup)=\"filterObjectDropdownValues($any($event.target).value)\">\n <fa-icon matSuffix [icon]=\"faSearch\"></fa-icon>\n </mat-form-field>\n @if (!metadata.required(entity)) {\n <mat-option>-</mat-option>\n }\n @if (shouldDisplayCurrentObjectDropdownValue) {\n <mat-option [value]=\"currentObjectDropdownValue?.value\">{{currentObjectDropdownValue?.displayName}}</mat-option>\n }\n @for (value of filteredObjectDropdownValues; track $index) {\n <mat-option [value]=\"value.value\">{{value.displayName}}</mat-option>\n }\n </mat-select>\n <mat-error>{{internalGetValidationErrorMessage(model)}}</mat-error>\n </mat-form-field>\n }\n <!-------------------------------------------->\n <!-------------- references one -------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.REFERENCES_ONE) {\n <mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <mat-select #inputModel=\"ngModel\"\n [name]=\"referencesOneName\"\n [disabled]=\"internalIsReadOnly\"\n [required]=\"metadata.required(entity)\"\n [(ngModel)]=\"entity[propertyKey]\"\n (selectionChange)=\"setReferencesOneObject()\"\n (opened)=\"selectSearchInput.focus()\"\n >\n <mat-form-field class=\"select-search-input\">\n <!-- eslint-disable-next-line angular/no-any -->\n <input #selectSearchInput matInput (keyup)=\"filterReferencesOneValues($any($event.target).value)\">\n <fa-icon matSuffix [icon]=\"faSearch\"></fa-icon>\n </mat-form-field>\n @if (!metadata.required(entity)) {\n <mat-option>-</mat-option>\n }\n @if (shouldDisplayCurrentReferencesOneDropdownValue) {\n <mat-option [value]=\"currentReferencesOneDropdownValue?.value\">{{currentReferencesOneDropdownValue?.displayName}}</mat-option>\n }\n @for (value of filteredReferencesOneDropdownValues; track $index) {\n <mat-option [value]=\"value.value\">{{value.displayName}}</mat-option>\n }\n </mat-select>\n <mat-error>{{internalGetValidationErrorMessage(inputModel)}}</mat-error>\n </mat-form-field>\n <!-- iterates over the references one properties -->\n @if (referencesOneFormContext) {\n <ng-container *ngTemplateOutlet=\"form; context: referencesOneFormContext\"></ng-container>\n }\n }\n <!-------------------------------------------->\n <!-------------------Array-------------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.ARRAY) {\n <div class=\"entityArray\">\n <div class=\"mat-elevation-z8 elevation-container\">\n <div class=\"array-headline\">\n <b>{{metadataEntityArray.displayName}}</b>\n </div>\n @if (metadataEntityArray.createInline && !internalIsReadOnly && addArrayItemFormContext) {\n <ng-container *ngTemplateOutlet=\"form; context: addArrayItemFormContext\"></ng-container>\n }\n @if (!internalIsReadOnly && entityArrayTableContext) {\n <div class=\"buttons\">\n <button type=\"button\" mat-raised-button\n [disabled]=\"metadataEntityArray.createInline && !isArrayItemValid\"\n (click)=\"addEntity()\">\n {{metadataEntityArray.addButtonLabel}}\n </button>\n <button type=\"button\" mat-raised-button\n [disabled]=\"!entityArrayTableContext.$implicit.selection.selected.length\"\n (click)=\"removeFromEntityArray()\">\n {{metadataEntityArray.removeButtonLabel}}\n </button>\n </div>\n }\n @if (entityArrayTableContext) {\n <ng-container *ngTemplateOutlet=\"table; context: entityArrayTableContext\"></ng-container>\n }\n </div>\n </div>\n }\n <!-------------------------------------------->\n <!------------------ has many ---------------->\n <!-------------------------------------------->\n @case (DecoratorTypes.HAS_MANY) {\n <div class=\"hasMany\">\n <h2 class=\"title\">{{metadataHasMany.tableData.baseData.title}}</h2>\n <div class=\"grid grid-cols-12\" style=\"column-gap: 24px;\">\n <mat-form-field class=\"lg:col-span-8 md:col-span-6 col-span-12\">\n <mat-label>{{metadataHasMany.tableData.baseData.searchLabel}}</mat-label>\n <input matInput (keyup)=\"applyHasManyFilter($event)\">\n </mat-form-field>\n @if (metadataHasMany.tableData.baseData.tableActions.length) {\n <div\n [class.lg:col-span-2]=\"hasManyAllowCreate\"\n [class.lg:col-span-4]=\"!hasManyAllowCreate\"\n [class.md:col-span-3]=\"hasManyAllowCreate\"\n [class.md:col-span-6]=\"!hasManyAllowCreate\"\n [class.col-span-6]=\"hasManyAllowCreate\"\n [class.col-span-12]=\"!hasManyAllowCreate\"\n >\n <button type=\"button\" class=\"actions-button\" mat-raised-button [matMenuTriggerFor]=\"menu\">\n {{metadataHasMany.tableData.baseData.tableActionsLabel}}\n </button>\n </div>\n }\n <mat-menu #menu=\"matMenu\">\n @if (metadataHasMany.tableData.baseData.allowJsonImport) {\n <button type=\"button\" mat-menu-item [disabled]=\"hasManyTableActionDisabled(hasManyImportAction)\" (click)=\"runHasManyTableAction(hasManyImportAction)\">\n {{hasManyImportAction.displayName}}\n </button>\n }\n @for (action of metadataHasMany.tableData.baseData.tableActions; track $index) {\n <button type=\"button\" mat-menu-item [disabled]=\"hasManyTableActionDisabled(action)\" (click)=\"runHasManyTableAction(action)\">\n {{action.displayName}}\n </button>\n }\n </mat-menu>\n @if (hasManyAllowCreate) {\n <div\n [class.lg:col-span-2]=\"metadataHasMany.tableData.baseData.tableActions.length\"\n [class.lg:col-span-4]=\"!metadataHasMany.tableData.baseData.tableActions.length\"\n [class.md:col-span-3]=\"metadataHasMany.tableData.baseData.tableActions.length\"\n [class.md:col-span-6]=\"!metadataHasMany.tableData.baseData.tableActions.length\"\n [class.col-span-6]=\"metadataHasMany.tableData.baseData.tableActions.length\"\n [class.col-span-12]=\"!metadataHasMany.tableData.baseData.tableActions.length\"\n >\n <button type=\"button\" class=\"create-button\" mat-raised-button (click)=\"createHasManyEntity()\">\n {{metadataHasMany.tableData.baseData.createButtonLabel}}\n </button>\n </div>\n }\n </div>\n \n <div class=\"mat-elevation-z8 elevation-container\">\n @if (hasManyTableContext) {\n <ng-container *ngTemplateOutlet=\"table; context: hasManyTableContext\"></ng-container>\n }\n </div>\n </div>\n }\n \n @default {\n <div>ERROR: The type {{type}} is not known.</div>\n }\n }\n}\n\n\n<ng-template #table let-context>\n <mat-table matSort [dataSource]=\"context.dataSource\" [class.table-with-error-slot]=\"context.shouldShowMissingError\">\n <!-- select Column -->\n <ng-container matColumnDef=\"select\">\n <mat-header-cell *matHeaderCellDef>\n <mat-checkbox [checked]=\"context.selection.hasValue() && SelectionUtilities.isAllSelected(context.selection, context.dataSource)\"\n [indeterminate]=\"context.selection.hasValue() && !SelectionUtilities.isAllSelected(context.selection, context.dataSource)\"\n (change)=\"$event ? SelectionUtilities.masterToggle(context.selection, context.dataSource) : null\">\n </mat-checkbox>\n </mat-header-cell>\n <mat-cell *matCellDef=\"let value\" [dynamicStyleClasses]=\"context.dynamicRowStyleClasses\" [value]=\"value\">\n <mat-checkbox [checked]=\"context.selection.isSelected(value)\"\n (click)=\"$event.stopPropagation()\"\n (change)=\"$event ? context.selection.toggle(value) : null\">\n </mat-checkbox>\n </mat-cell>\n </ng-container>\n\n @for (dCol of context.displayColumns; track $index) {\n <ng-container [matColumnDef]=\"dCol.displayName\">\n <mat-header-cell *matHeaderCellDef mat-sort-header>\n {{dCol.displayName}}\n </mat-header-cell>\n <mat-cell *matCellDef=\"let value\" [class.enabled]=\"!dCol.disableClick && context.allowClick(value)\"\n [dynamicStyleClasses]=\"context.dynamicRowStyleClasses\" [value]=\"value\"\n (click)=\"clickCell(value, dCol, context)\"\n >\n @if (dCol.Component) {\n <display-column-value [entity]=\"value\" [ComponentClass]=\"dCol.Component\"></display-column-value>\n }\n @else {\n {{getDisplayColumnValue(value, dCol)}}\n }\n </mat-cell>\n </ng-container>\n }\n\n <mat-header-row *matHeaderRowDef=\"context.displayedColumns\"></mat-header-row>\n <mat-row *matRowDef=\"let row; columns: context.displayedColumns\"></mat-row>\n </mat-table>\n\n @if (context.displayLoadingSpinner && context.isLoading) {\n <mat-spinner>\n </mat-spinner>\n }\n @else if (context.shouldShowMissingError && !context.dataSource.data.length) {\n <div class=\"table-error\">{{context.emptyErrorMessage}}</div>\n }\n\n <mat-paginator [length]=\"context.dataSource.filteredData.length\" [pageIndex]=\"0\" [pageSize]=\"10\" [pageSizeOptions]=\"[5, 10, 25, 50]\"></mat-paginator>\n</ng-template>\n\n<!--------------------------------------------------------->\n<!---------------------------Form-------------------------->\n<!--------------------------------------------------------->\n<ng-template #form let-context>\n <!-- eslint-disable angular/no-call-expression -->\n @if (context.tabs.length > 1) {\n <mat-tab-group preserveContent>\n @for (tab of context.tabs; track $index) {\n <mat-tab [label]=\"tab.tabName\">\n @for (row of tab.rows; track $index) {\n <div class=\"grid grid-cols-12\" style=\"column-gap: 24px;\">\n @for (key of row.keys; track key) {\n <ngx-mat-entity-input\n [entity]=\"context.entity\"\n [propertyKey]=\"key\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [validEmpty]=\"context.validEmpty?.()\"\n [isReadOnly]=\"context.isReadOnly?.(context.entity, key)\"\n [class]=\"EntityUtilities.getWidthClasses(context.entity, key)\"\n [hideOmitForEdit]=\"context.hideOmitForEdit\"\n [hideOmitForCreate]=\"context.hideOmitForCreate\"\n (inputChangeEvent)=\"context.inputChangeEvent()\"\n >\n </ngx-mat-entity-input>\n }\n </div>\n }\n </mat-tab>\n }\n </mat-tab-group>\n }\n @else {\n @if (!context.tabs.length) {\n <span class=\"no-entity-tabs\">\n ERROR: No Inputs. Did you correctly assign all values in the model constructor?\n </span>\n }\n @else {\n @for (row of context.tabs[0].rows; track $index) {\n <div class=\"grid grid-cols-12\" style=\"column-gap: 24px;\">\n @for (key of row.keys; track key) {\n <ngx-mat-entity-input\n [entity]=\"context.entity\"\n [propertyKey]=\"key\"\n [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n [validEmpty]=\"context.validEmpty?.()\"\n [isReadOnly]=\"context.isReadOnly?.(context.entity, key)\"\n [class]=\"EntityUtilities.getWidthClasses(context.entity, key)\"\n [hideOmitForEdit]=\"context.hideOmitForEdit\"\n [hideOmitForCreate]=\"context.hideOmitForCreate\"\n (inputChangeEvent)=\"context.inputChangeEvent()\"\n >\n </ngx-mat-entity-input>\n }\n </div>\n }\n }\n }\n</ng-template>\n\n<!--------------------------------------------------------->\n<!--------------------Add Array Item Dialog---------------->\n<!--------------------------------------------------------->\n<ng-template #addArrayItemDialog>\n <div class=\"mat-dialog-title\">\n <div>{{addArrayItemDialogData.title}}</div>\n </div>\n\n <form>\n <mat-dialog-content>\n @if (addArrayItemFormContext) {\n <ng-container *ngTemplateOutlet=\"form; context: addArrayItemFormContext\"></ng-container>\n }\n </mat-dialog-content>\n \n <mat-dialog-actions>\n <div class=\"dialog-button-with-info-icon\">\n <button type=\"submit\" mat-raised-button matBadgeColor=\"warn\"\n [disabled]=\"!isArrayItemValid\"\n [matBadge]=\"arrayItemValidationErrors.length\"\n [matBadgeHidden]=\"!arrayItemValidationErrors.length\"\n (click)=\"addArrayItem()\"\n >\n {{addArrayItemDialogData.createButtonLabel}}\n </button>\n @if (arrayItemValidationErrors.length) {\n <ngx-mat-entity-tooltip [tooltipContent]=\"arrayItemTooltipContent\"></ngx-mat-entity-tooltip>\n }\n </div>\n <button type=\"button\" mat-raised-button class=\"cancel-button\" (click)=\"closeAddArrayItemDialog()\">\n {{addArrayItemDialogData.cancelButtonLabel}}\n </button>\n </mat-dialog-actions>\n </form>\n\n</ng-template>\n\n<!--------------------------------------------------------->\n<!--------------------Edit Array Item Dialog---------------->\n<!--------------------------------------------------------->\n<ng-template #editArrayItemDialog>\n <div class=\"mat-dialog-title\">\n <div>{{editArrayItemDialogData.title(arrayItemPriorChanges)}}</div>\n </div>\n \n <form>\n <mat-dialog-content>\n @if (editArrayItemFormContext) {\n <ng-container *ngTemplateOutlet=\"form; context: editArrayItemFormContext\"></ng-container>\n }\n </mat-dialog-content>\n \n <mat-dialog-actions>\n <div class=\"dialog-button-with-info-icon\">\n <button type=\"submit\" mat-raised-button matBadgeColor=\"warn\"\n [class.badge-changes]=\"!arrayItemValidationErrors.length\"\n [disabled]=\"internalIsReadOnly || !isArrayItemValid || !isArrayItemDirty\"\n [matBadge]=\"arrayItemValidationErrors.length > 0 ? arrayItemValidationErrors.length : arrayItemChanges.length\"\n [matBadgeHidden]=\"!arrayItemValidationErrors.length && !arrayItemChanges.length\"\n (click)=\"saveArrayItem()\"\n >\n {{editArrayItemDialogData.confirmButtonLabel}}\n </button>\n @if (arrayItemValidationErrors.length || arrayItemChanges.length) {\n <ngx-mat-entity-tooltip [tooltipContent]=\"arrayItemTooltipContent\"></ngx-mat-entity-tooltip>\n }\n </div>\n <button type=\"button\" mat-raised-button class=\"cancel-button\" (click)=\"closeEditArrayItemDialog()\">\n {{editArrayItemDialogData.cancelButtonLabel}}\n </button>\n </mat-dialog-actions>\n </form>\n</ng-template>\n\n<!--------------------------------------------------------->\n<!--------------------Create Has Many Dialog---------------->\n<!--------------------------------------------------------->\n<ng-template #createHasManyDialog>\n <div class=\"mat-dialog-title\">\n <div>{{metadataHasMany.tableData.createData.title}}</div>\n </div>\n \n <form>\n <mat-dialog-content>\n @if (hasManyCreateFormContext) {\n <ng-container *ngTemplateOutlet=\"form; context: hasManyCreateFormContext\"></ng-container>\n }\n </mat-dialog-content>\n \n <mat-dialog-actions>\n <div class=\"dialog-button-with-info-icon\">\n <button type=\"submit\" mat-raised-button matBadgeColor=\"warn\"\n [disabled]=\"!isHasManyEntityValid\"\n [matBadge]=\"hasManyValidationErrors.length\"\n [matBadgeHidden]=\"!hasManyValidationErrors.length\"\n (click)=\"dialogCreateHasMany()\"\n >\n {{metadataHasMany.tableData.createData.createButtonLabel}}\n </button>\n @if (hasManyValidationErrors.length) {\n <ngx-mat-entity-tooltip [tooltipContent]=\"hasManyTooltipContent\"></ngx-mat-entity-tooltip>\n }\n </div>\n <button type=\"button\" mat-raised-button class=\"cancel-button\" (click)=\"dialogCancelCreateHasMany()\">\n {{metadataHasMany.tableData.createData.cancelButtonLabel}}\n </button>\n </mat-dialog-actions>\n </form>\n \n</ng-template>\n\n<!--------------------------------------------------------->\n<!--------------------Edit Has Many Dialog----------------->\n<!--------------------------------------------------------->\n<ng-template #editHasManyDialog>\n <div class=\"mat-dialog-title\">\n <div>{{metadataHasMany.tableData.editData.title(hasManyEntityPriorChanges)}}</div>\n\n <div class=\"actions-container\">\n @if (metadataHasMany.tableData.editData.actions.length) {\n <button type=\"button\" mat-raised-button [matMenuTriggerFor]=\"menu\">\n {{metadataHasMany.tableData.editData.actionsLabel}}\n </button>\n }\n <mat-menu #menu=\"matMenu\">\n @for (action of metadataHasMany.tableData.editData.actions; track $index) {\n <button type=\"button\" mat-menu-item [disabled]=\"hasManyEditActionDisabled(action)\" (click)=\"hasManyRunEditAction(action)\">\n {{action.displayName}}\n </button>\n }\n </mat-menu>\n \n @if (hasManyAllowDelete(hasManyEntity)) {\n <button type=\"button\" mat-raised-button color=\"warn\" class=\"delete-button\" tabindex=\"-1\" (click)=\"deleteHasManyEntity()\">\n {{metadataHasMany.tableData.editData.deleteButtonLabel}}\n </button>\n }\n </div>\n </div>\n \n <form>\n <mat-dialog-content>\n @if (hasManyEditFormContext) {\n <ng-container *ngTemplateOutlet=\"form; context: hasManyEditFormContext\"></ng-container>\n }\n </mat-dialog-content>\n \n <mat-dialog-actions>\n <div class=\"dialog-button-with-info-icon\">\n <button type=\"submit\" mat-raised-button matBadgeColor=\"warn\"\n [class.badge-changes]=\"!hasManyValidationErrors.length\"\n [disabled]=\"internalIsReadOnly || !isHasManyEntityValid || !isHasManyEntityDirty\"\n [matBadge]=\"hasManyValidationErrors.length > 0 ? hasManyValidationErrors.length : hasManyChanges.length\"\n [matBadgeHidden]=\"!hasManyValidationErrors.length && !hasManyChanges.length\"\n (click)=\"dialogEditHasMany()\"\n >\n {{metadataHasMany.tableData.editData.confirmButtonLabel}}\n </button>\n @if (hasManyValidationErrors.length || hasManyChanges.length) {\n <ngx-mat-entity-tooltip [tooltipContent]=\"hasManyTooltipContent\"></ngx-mat-entity-tooltip>\n }\n </div>\n <button type=\"button\" mat-raised-button class=\"cancel-button\" (click)=\"dialogCancelEditHasMany()\">\n {{metadataHasMany.tableData.editData.cancelButtonLabel}}\n </button>\n </mat-dialog-actions>\n </form>\n</ng-template>", styles: ["::ng-deep mat-tab-body{padding-top:10px;padding-left:12px;padding-right:12px}::ng-deep mat-tab-body .mat-mdc-tab-body-content{overflow:initial}::ng-deep .mat-mdc-tab-body-wrapper{margin-left:-12px;margin-right:-12px}::ng-deep .mat-mdc-form-field-has-icon-suffix .mat-mdc-text-field-wrapper{padding-right:16px}::ng-deep .select-search-input{width:100%;margin-top:-8px;margin-bottom:8px}::ng-deep .select-search-input .mat-mdc-form-field-subscript-wrapper{display:none}::ng-deep .mat-mdc-form-field.mat-form-field-disabled label{color:#0009}::ng-deep .mat-mdc-form-field.mat-form-field-disabled input,::ng-deep .mat-mdc-form-field.mat-form-field-disabled textarea,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mat-mdc-select-disabled,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mat-mdc-select-value{color:#000!important}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-checkbox .mdc-checkbox__native-control[disabled]:not(:checked):not(:indeterminate):not([data-indeterminate=true])~.mdc-checkbox__background{border-color:#707070}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-checkbox .mdc-checkbox__native-control[disabled]:checked~.mdc-checkbox__background,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-checkbox .mdc-checkbox__native-control[disabled]:indeterminate~.mdc-checkbox__background,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-checkbox .mdc-checkbox__native-control[data-indeterminate=true][disabled]~.mdc-checkbox__background{background-color:#000}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mat-mdc-chip.mat-mdc-standard-chip.mat-mdc-chip-disabled{opacity:1}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mat-mdc-chip.mat-mdc-standard-chip.mat-mdc-chip-disabled button{opacity:.2}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-switch.mdc-switch--selected:disabled .mdc-switch__icons,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-switch.mdc-switch--unselected:disabled .mdc-switch__icons{opacity:1}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-switch.mdc-switch--selected:disabled .mdc-switch__handle:after,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-switch.mdc-switch--unselected:disabled .mdc-switch__handle:after{opacity:1;background:#000}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-switch.mdc-switch--selected:disabled .mdc-switch__track,::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mdc-switch.mdc-switch--unselected:disabled .mdc-switch__track{opacity:.3}::ng-deep .mat-mdc-form-field.mat-form-field-disabled .mat-date-range-input-inner:disabled{color:#000}::ng-deep #slider.mat-mdc-slider.mdc-slider--disabled{opacity:1}::ng-deep #slider.mat-mdc-slider.mdc-slider--disabled .mdc-slider__input{cursor:default}::ng-deep #slider.mat-mdc-slider.mdc-slider--disabled mat-slider-visual-thumb .mat-mdc-slider,::ng-deep #slider.mat-mdc-slider.mdc-slider--disabled mat-slider-visual-thumb .mdc-slider__thumb:hover,::ng-deep #slider.mat-mdc-slider.mdc-slider--disabled mat-slider-visual-thumb .mdc-slider__thumb-knob{background-color:#000;border-color:#000}::ng-deep .mat-mdc-form-field .mat-mdc-slide-toggle{opacity:1}::ng-deep .badge-changes .mat-badge-content{background-color:orange;color:#fff}mat-spinner{margin:10px auto}.mdc-data-table__row:last-child .mdc-data-table__cell{border-bottom:1px solid rgba(0,0,0,.12)}mat-paginator{padding-top:10px;padding-bottom:10px}.dialog-button-with-info-icon{margin-top:10px;gap:12px;display:flex;align-items:center}.actions-container{display:flex;gap:10px}.object-dropdown{width:100%}.table-with-error-slot{border:1px solid #E0E0E0;border-radius:5px;padding-top:5px;padding-bottom:5px}.mat-column-select{flex:0 0 48px;padding-left:0;padding-right:0;justify-content:center}.enabled:hover{cursor:pointer}.table-error{display:flex;align-items:center;justify-content:center;margin-top:-6px;border:1px solid #E0E0E0;background-color:#f8d3d7;color:#721c24;height:fit-content;padding-left:4px;padding-right:4px;border-bottom-left-radius:5px;border-bottom-right-radius:5px}.entityArray .elevation-container{border-radius:5px;padding:15px 15px 0;margin-bottom:15px;margin-top:15px}.entityArray .array-headline{padding-bottom:10px}.entityArray .buttons{display:flex;justify-content:space-between;margin-bottom:10px;margin-top:5px;flex-wrap:wrap;gap:10px}.entityArray .buttons button{flex-grow:1}.hasMany button{width:100%;height:56px;line-height:24px;font-size:16px}.hasMany .title{text-align:center}.hasMany .elevation-container{margin-bottom:15px}\n", "::ng-deep .mdc-dialog .mdc-dialog__content{padding:6px 20px!important}mat-dialog-actions{justify-content:space-between;align-items:center;padding-left:20px;padding-right:20px}.mat-dialog-title{padding:12px 20px;display:flex;justify-content:space-between;align-items:center}.mat-dialog-title div{font-size:var(--mdc-dialog-subhead-size, 14px);font-weight:var(--mdc-dialog-subhead-weight, 500)}\n", ".grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.grid{display:grid}@media (min-width: 1024px){.lg\\:col-span-12{grid-column:span 12/span 12!important}.lg\\:col-span-11{grid-column:span 11/span 11!important}.lg\\:col-span-10{grid-column:span 10/span 10!important}.lg\\:col-span-9{grid-column:span 9/span 9!important}.lg\\:col-span-8{grid-column:span 8/span 8!important}.lg\\:col-span-7{grid-column:span 7/span 7!important}.lg\\:col-span-6{grid-column:span 6/span 6!important}.lg\\:col-span-5{grid-column:span 5/span 5!important}.lg\\:col-span-4{grid-column:span 4/span 4!important}.lg\\:col-span-3{grid-column:span 3/span 3!important}.lg\\:col-span-2{grid-column:span 2/span 2!important}.lg\\:col-span-1{grid-column:span 1/span 1!important}}@media (min-width: 768px) and (max-width: 1023px){.md\\:col-span-12{grid-column:span 12/span 12!important}.md\\:col-span-11{grid-column:span 11/span 11!important}.md\\:col-span-10{grid-column:span 10/span 10!important}.md\\:col-span-9{grid-column:span 9/span 9!important}.md\\:col-span-8{grid-column:span 8/span 8!important}.md\\:col-span-7{grid-column:span 7/span 7!important}.md\\:col-span-6{grid-column:span 6/span 6!important}.md\\:col-span-5{grid-column:span 5/span 5!important}.md\\:col-span-4{grid-column:span 4/span 4!important}.md\\:col-span-3{grid-column:span 3/span 3!important}.md\\:col-span-2{grid-column:span 2/span 2!important}.md\\:col-span-1{grid-column:span 1/span 1!important}}.col-span-12{grid-column:span 12/span 12}.col-span-11{grid-column:span 11/span 11}.col-span-10{grid-column:span 10/span 10}.col-span-9{grid-column:span 9/span 9}.col-span-8{grid-column:span 8/span 8}.col-span-7{grid-column:span 7/span 7}.col-span-6{grid-column:span 6/span 6}.col-span-5{grid-column:span 5/span 5}.col-span-4{grid-column:span 4/span 4}.col-span-3{grid-column:span 3/span 3}.col-span-2{grid-column:span 2/span 2}.col-span-1{grid-column:span 1/span 1}\n"] }]
|
|
1212
1266
|
}], ctorParameters: () => [{ type: i1.MatDialog }, { type: i0.EnvironmentInjector }, { type: i2.Router }, { type: undefined, decorators: [{
|
|
1213
1267
|
type: Inject,
|
|
1214
1268
|
args: [NGX_GET_VALIDATION_ERROR_MESSAGE]
|
|
@@ -1233,21 +1287,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
|
|
|
1233
1287
|
type: Input
|
|
1234
1288
|
}], inputChangeEvent: [{
|
|
1235
1289
|
type: Output
|
|
1290
|
+
}], sort: [{
|
|
1291
|
+
type: ViewChild,
|
|
1292
|
+
args: [MatSort]
|
|
1236
1293
|
}], addArrayItemDialog: [{
|
|
1237
1294
|
type: ViewChild,
|
|
1238
1295
|
args: ['addArrayItemDialog']
|
|
1239
1296
|
}], editArrayItemDialog: [{
|
|
1240
1297
|
type: ViewChild,
|
|
1241
1298
|
args: ['editArrayItemDialog']
|
|
1242
|
-
}], hasManyPaginator: [{
|
|
1243
|
-
type: ViewChild,
|
|
1244
|
-
args: [MatPaginator]
|
|
1245
|
-
}], hasManySort: [{
|
|
1246
|
-
type: ViewChild,
|
|
1247
|
-
args: [MatSort]
|
|
1248
|
-
}], hasManyFilter: [{
|
|
1249
|
-
type: ViewChild,
|
|
1250
|
-
args: ['filter', { static: true }]
|
|
1251
1299
|
}], createHasManyDialog: [{
|
|
1252
1300
|
type: ViewChild,
|
|
1253
1301
|
args: ['createHasManyDialog']
|
|
@@ -1255,4 +1303,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
|
|
|
1255
1303
|
type: ViewChild,
|
|
1256
1304
|
args: ['editHasManyDialog']
|
|
1257
1305
|
}] } });
|
|
1258
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-material-entity/src/components/input/input.component.ts","../../../../../projects/ngx-material-entity/src/components/input/input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { SelectionModel } from '@angular/cdk/collections';\nimport { CommonModule } from '@angular/common';\nimport { HttpClient } from '@angular/common/http';\nimport { Component, EnvironmentInjector, EventEmitter, Inject, Input, OnInit, Output, TemplateRef, ViewChild, inject, runInInjectionContext } from '@angular/core';\nimport { FormsModule, NgModel } from '@angular/forms';\nimport { MatBadgeModule } from '@angular/material/badge';\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 { MatSelectModule } from '@angular/material/select';\nimport { MatSort } from '@angular/material/sort';\nimport { MatTableDataSource, MatTableModule } from '@angular/material/table';\nimport { MatTabsModule } from '@angular/material/tabs';\nimport { Router } from '@angular/router';\nimport { firstValueFrom } from 'rxjs';\n\nimport { ArrayDateInputComponent } from './array/array-date-input/array-date-input.component';\nimport { ArrayDateRangeInputComponent } from './array/array-date-range-input/array-date-range-input.component';\nimport { ArrayDateTimeInputComponent } from './array/array-date-time-input/array-date-time-input.component';\nimport { ArrayStringAutocompleteChipsComponent } from './array/array-string-autocomplete-chips/array-string-autocomplete-chips.component';\nimport { ArrayStringChipsInputComponent } from './array/array-string-chips-input/array-string-chips-input.component';\nimport { BooleanCheckboxInputComponent } from './boolean/boolean-checkbox-input/boolean-checkbox-input.component';\nimport { BooleanDropdownInputComponent } from './boolean/boolean-dropdown-input/boolean-dropdown-input.component';\nimport { BooleanToggleInputComponent } from './boolean/boolean-toggle-input/boolean-toggle-input.component';\nimport { CustomInputComponent } from './custom/custom.component';\nimport { DateInputComponent } from './date/date-input/date-input.component';\nimport { DateRangeInputComponent } from './date/date-range-input/date-range-input.component';\nimport { DateTimeInputComponent } from './date/date-time-input/date-time-input.component';\nimport { FileDefaultInputComponent } from './file/file-default-input/file-default-input.component';\nimport { FileImageInputComponent } from './file/file-image-input/file-image-input.component';\nimport { NumberDropdownInputComponent } from './number/number-dropdown-input/number-dropdown-input.component';\nimport { NumberInputComponent } from './number/number-input/number-input.component';\nimport { NumberSliderInputComponent } from './number/number-slider-input/number-slider-input.component';\nimport { ReferencesManyInputComponent } from './relations/references-many-input/references-many-input.component';\nimport { StringAutocompleteInputComponent } from './string/string-autocomplete-input/string-autocomplete-input.component';\nimport { StringDropdownInputComponent } from './string/string-dropdown-input/string-dropdown-input.component';\nimport { StringInputComponent } from './string/string-input/string-input.component';\nimport { StringPasswordInputComponent } from './string/string-password-input/string-password-input.component';\nimport { StringTextboxInputComponent } from './string/string-textbox-input/string-textbox-input.component';\nimport { BaseEntityType } from '../../classes/entity.model';\nimport { EditArrayItemDialogDataInternal, EntityArrayDecoratorConfigInternal } from '../../decorators/array/array-decorator-internal.data';\nimport { DecoratorTypes } from '../../decorators/base/decorator-types.enum';\nimport { DropdownValue } from '../../decorators/base/dropdown-value.interface';\nimport { PropertyDecoratorConfigInternal } from '../../decorators/base/property-decorator-internal.data';\nimport { HasManyDecoratorConfigInternal } from '../../decorators/has-many/has-many-decorator-internal.data';\nimport { DefaultObjectDecoratorConfigInternal, DropdownObjectDecoratorConfigInternal } from '../../decorators/object/object-decorator-internal.data';\nimport { ReferencesOneDecoratorConfigInternal } from '../../decorators/references-one/references-one-decorator-internal.data';\nimport { LodashUtilities } from '../../encapsulation/lodash.utilities';\nimport { ReflectUtilities } from '../../encapsulation/reflect.utilities';\nimport { UUIDUtilities } from '../../encapsulation/uuid.utilities';\nimport { defaultFalse } from '../../functions/default-false.function';\nimport { NGX_GET_VALIDATION_ERROR_MESSAGE } from '../../functions/get-validation-error-message.function';\nimport { getValidationErrorsTooltipContent } from '../../functions/get-validation-errors-tooltip-content.function.ts';\nimport { NGX_COMPLETE_GLOBAL_DEFAULT_VALUES, NgxGlobalDefaultValues } from '../../global-configuration-values';\nimport { EntityService } from '../../services/entity.service';\nimport { DateUtilities } from '../../utilities/date.utilities';\nimport { EntityTab, EntityUtilities } from '../../utilities/entity.utilities';\nimport { SelectionUtilities } from '../../utilities/selection.utilities';\nimport { ValidationError, ValidationUtilities } from '../../utilities/validation.utilities';\nimport { ConfirmDialogDataBuilder, ConfirmDialogDataInternal } from '../confirm-dialog/confirm-dialog-data.builder';\nimport { NgxMatEntityConfirmDialogComponent } from '../confirm-dialog/confirm-dialog.component';\nimport { CreateDataBuilder, CreateDataInternal } from '../table/create-dialog/create-data.builder';\nimport { DisplayColumnValueComponent } from '../table/display-column-value/display-column-value.component';\nimport { EditActionInternal } from '../table/edit-dialog/edit-data.builder';\nimport { DisplayColumn } from '../table/table-data';\nimport { BaseTableActionInternal, TableActionInternal } from '../table/table-data.builder';\nimport { TooltipComponent } from '../tooltip/tooltip.component';\n\n// TODO: 4 context where the tabs are not set by the form component: hasManyEdit, hasManyCreate, addArrayItem, editArrayItem\n/**\n * A form context that is used to fill an inline template.\n * This is used to go around the limitations of having everything in the same file due to circular dependencies.\n * The forms are used for object, hasMany, referencesMany and the dialogs.\n */\ntype FormContext<EntityType extends BaseEntityType<EntityType>> = {\n    /**\n     * The actual value. The $implicit is needed so that we don't need to specify a key when writing \"let-context\" in the html template.\n     */\n    $implicit: {\n        /**\n         * The entity to build the form for.\n         */\n        entity: EntityType,\n        /**\n         * The tabs to display.\n         */\n        tabs: EntityTab<EntityType>[],\n        /**\n         * Whether or not edit values should be omitted.\n         */\n        hideOmitForEdit?: boolean,\n        /**\n         * Whether or not create values should be omitted.\n         */\n        hideOmitForCreate?: boolean,\n        /**\n         * What happens when the input changes.\n         */\n        inputChangeEvent: () => void | Promise<void>,\n        /**\n         * Whether or not the input is readonly.\n         */\n        isReadOnly?: (property: EntityType, key: keyof EntityType) => boolean,\n        /**\n         * Whether or not the input is valid empty.\n         */\n        validEmpty?: () => boolean\n    }\n};\n\n/**\n * The default input component. It gets the metadata of the property from the given @Input \"entity\" and @Input \"propertyKey\"\n * and displays the input field accordingly.\n *\n * You can also define a method that generates error-messages and if the input should be hidden when its metadata says\n * that it should be omitted for creating or updating.\n * The last part being mostly relevant if you want to use this component inside an ngFor.\n */\n@Component({\n    selector: 'ngx-mat-entity-input',\n    templateUrl: './input.component.html',\n    styleUrls: ['./input.component.scss'],\n    standalone: true,\n    imports: [\n        DisplayColumnValueComponent,\n        CommonModule,\n        MatTabsModule,\n        MatFormFieldModule,\n        MatSelectModule,\n        FormsModule,\n        MatDialogModule,\n        MatBadgeModule,\n        MatInputModule,\n        MatMenuModule,\n        MatPaginatorModule,\n        MatProgressSpinnerModule,\n        MatTableModule,\n        MatCheckboxModule,\n        MatButtonModule,\n        TooltipComponent,\n        StringInputComponent,\n        StringTextboxInputComponent,\n        StringAutocompleteInputComponent,\n        StringDropdownInputComponent,\n        StringPasswordInputComponent,\n        BooleanCheckboxInputComponent,\n        BooleanToggleInputComponent,\n        BooleanDropdownInputComponent,\n        NumberInputComponent,\n        NumberDropdownInputComponent,\n        NumberSliderInputComponent,\n        ArrayDateInputComponent,\n        ArrayDateRangeInputComponent,\n        ArrayDateTimeInputComponent,\n        ArrayStringAutocompleteChipsComponent,\n        ArrayStringChipsInputComponent,\n        DateInputComponent,\n        DateRangeInputComponent,\n        DateTimeInputComponent,\n        FileDefaultInputComponent,\n        FileImageInputComponent,\n        ReferencesManyInputComponent,\n        CustomInputComponent\n    ]\n})\nexport class NgxMatEntityInputComponent<EntityType extends BaseEntityType<EntityType>> implements OnInit {\n    /**\n     * The entity on which the property exists. Used in conjunction with the \"propertyKey\"\n     * to determine the property for which the input should be generated.\n     */\n    @Input({ required: true })\n    entity!: EntityType;\n\n    /**\n     * The name of the property to generate the input for. Used in conjunction with the \"entity\".\n     */\n    @Input({ required: true })\n    propertyKey!: keyof EntityType;\n\n    /**\n     * (optional) A custom function to generate the error-message for invalid inputs.\n     */\n    @Input()\n    getValidationErrorMessage?: (model: NgModel) => string;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    internalGetValidationErrorMessage!: (model: NgModel) => string;\n\n    /**\n     * Whether to hide a value if it is omitted for creation.\n     * Is used internally for the object property.\n     * @default false\n     */\n    @Input()\n    hideOmitForCreate?: boolean;\n\n    /**\n     * Whether to hide a value if it is omitted for editing.\n     * Is used internally for the object property.\n     * @default false\n     */\n    @Input()\n    hideOmitForEdit?: boolean;\n\n    /**\n     * Whether or not an empty value should be valid.\n     * Is used internally for the object property.\n     * @default undefined\n     */\n    @Input()\n    validEmpty?: boolean; // TODO\n\n    /**\n     * Whether or not the input should be readonly.\n     * In that case it is disabled, but most of the default styling is overwritten.\n     * @default false\n     */\n    @Input()\n    isReadOnly?: boolean;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    internalIsReadOnly!: boolean;\n\n    /**\n     * Emits when the input value has been changed.\n     */\n    @Output()\n    readonly inputChangeEvent: EventEmitter<void> = new EventEmitter<void>();\n\n    /**\n     * The type of the decorator for this input.\n     */\n    type!: DecoratorTypes;\n    /**\n     * The property metadata received from the decorator.\n     */\n    metadata!: PropertyDecoratorConfigInternal<unknown>;\n\n    /**\n     * The metadata of an object property.\n     */\n    metadataDefaultObject!: DefaultObjectDecoratorConfigInternal<EntityType>;\n    /**\n     * The form context for an object property.\n     */\n    objectFormContext!: FormContext<EntityType>;\n\n    /**\n     * The metadata of an dropdown object property.\n     */\n    metadataDropdownObject!: DropdownObjectDecoratorConfigInternal<EntityType>;\n    /**\n     * All possible dropdown values for the object property.\n     */\n    private objectDropdownValues: DropdownValue<EntityType | undefined>[] = [];\n    /**\n     * A unique input name for the references one property.\n     */\n    objectDropdownName!: string;\n    /**\n     * All currently shown dropdown values for the object property.\n     */\n    filteredObjectDropdownValues: DropdownValue<EntityType | undefined>[] = [];\n    // eslint-disable-next-line jsdoc/require-returns\n    /**\n     * The currently selected object as a drop down value.\n     */\n    get currentObjectDropdownValue(): DropdownValue<EntityType | undefined> | undefined {\n        const value: DropdownValue<EntityType | undefined>[] = LodashUtilities.cloneDeep(this.objectDropdownValues ?? []);\n        return value.find(v => LodashUtilities.isEqual(v.value, this.entity[this.propertyKey]));\n    }\n    // eslint-disable-next-line jsdoc/require-returns\n    /**\n     * Whether or not the current object dropdown value should be shown in the dropdown.\n     */\n    get shouldDisplayCurrentObjectDropdownValue(): boolean {\n        return !!this.currentObjectDropdownValue\n            && !this.filteredObjectDropdownValues.find(v => LodashUtilities.isEqual(v.value, this.currentObjectDropdownValue?.value));\n    }\n    /**\n     * A compareWith method for the select.\n     * Uses bind.\n     */\n    compareObjectsBound: (value1?: EntityType, value2?: EntityType) => boolean = this.compareObjects.bind(this);\n\n    @ViewChild('addArrayItemDialog')\n    private readonly addArrayItemDialog!: TemplateRef<unknown>;\n    private addArrayItemDialogRef!: MatDialogRef<unknown>;\n    @ViewChild('editArrayItemDialog')\n    private readonly editArrayItemDialog!: TemplateRef<unknown>;\n    private editArrayItemDialogRef!: MatDialogRef<unknown>;\n    /**\n     * The metadata of an entity array property.\n     */\n    metadataEntityArray!: EntityArrayDecoratorConfigInternal<EntityType>;\n    /**\n     * The entity array property value.\n     */\n    entityArrayValues!: EntityType[];\n    /**\n     * The current array item to be added or updated.\n     */\n    arrayItem!: EntityType;\n    /**\n     * The array item before any changes have been made. Used to check if the form is dirty.\n     */\n    arrayItemPriorChanges!: EntityType;\n    /**\n     * The form context for adding an array item.\n     */\n    addArrayItemFormContext!: FormContext<EntityType>;\n    /**\n     * The form context for editing an array item.\n     */\n    editArrayItemFormContext!: FormContext<EntityType>;\n    /**\n     * The dataSource for the entity array.\n     */\n    entityArrayDataSource!: MatTableDataSource<EntityType>;\n    /**\n     * The selection for the entity array.\n     */\n    entityArraySelection: SelectionModel<EntityType> = new SelectionModel<EntityType>(true, []);\n    /**\n     * The columns to display in the entity array table.\n     */\n    entityArrayDisplayedColumns!: string[];\n    /**\n     * Whether or not the array item is valid.\n     */\n    isArrayItemValid: boolean = false;\n    /**\n     * Whether or not the array item is dirty.\n     */\n    isArrayItemDirty: boolean = false;\n    /**\n     * The index of the array item that is being edited.\n     */\n    private indexOfEditedArrayItem!: number;\n    /**\n     * Config for the dialog that adds a new array item.\n     */\n    addArrayItemDialogData!: CreateDataInternal;\n    /**\n     * The tabs to display inside the edit array item dialog.\n     */\n    editArrayItemDialogData!: EditArrayItemDialogDataInternal<EntityType>;\n    /**\n     * All validation errors for the array item.\n     */\n    arrayItemValidationErrors: ValidationError[] = [];\n    /**\n     * What to display inside the array item tooltip.\n     */\n    arrayItemTooltipContent: string = '';\n\n    /**\n     * Metadata of a has many property.\n     */\n    metadataHasMany!: HasManyDecoratorConfigInternal<EntityType, EntityType>;\n    /**\n     * Whether or not has many is currently loading.\n     */\n    hasManyIsLoading: boolean = true;\n    /**\n     * A setter for the has many paginator.\n     * Is needed because the paginator is inside a switch case,\n     * which means that at ngOnInit it can't be initialized.\n     */\n    @ViewChild(MatPaginator)\n    set hasManyPaginator(paginator: MatPaginator) {\n        if (!this.hasManyDataSource.paginator) {\n            this.hasManyDataSource.paginator = paginator;\n        }\n    }\n    /**\n     * A setter for the has many sort.\n     * Is needed because the sort is inside a switch case,\n     * which means that at ngOnInit it can't be initialized.\n     */\n    @ViewChild(MatSort)\n    private set hasManySort(sort: MatSort) {\n        if (!this.hasManyDataSource.sort) {\n            this.hasManyDataSource.sort = sort;\n        }\n    }\n    @ViewChild('filter', { static: true })\n    private readonly hasManyFilter!: string;\n    /**\n     * The columns of the has many table.\n     */\n    displayedHasManyColumns!: string[];\n    /**\n     * The data source of the has many table.\n     */\n    hasManyDataSource: MatTableDataSource<EntityType> = new MatTableDataSource();\n    /**\n     * The selection of the has many table.\n     */\n    hasManySelection: SelectionModel<EntityType> = new SelectionModel<EntityType>(true, []);\n    /**\n     * The has many import action.\n     */\n    hasManyImportAction!: BaseTableActionInternal;\n    private hasManyEntityService!: EntityService<EntityType>;\n    @ViewChild('createHasManyDialog')\n    private readonly createHasManyDialog!: TemplateRef<unknown>;\n    private createHasManyDialogRef!: MatDialogRef<unknown>;\n    @ViewChild('editHasManyDialog')\n    private readonly editHasManyDialog!: TemplateRef<unknown>;\n    private editHasManyDialogRef!: MatDialogRef<unknown>;\n    /**\n     * A single has many entity.\n     */\n    hasManyEntity!: EntityType;\n    /**\n     * The single has many entity before any changes have been made. Is used to determine if the form is dirty.\n     */\n    hasManyEntityPriorChanges!: EntityType;\n    /**\n     * Whether or not the has many entity is valid.\n     */\n    isHasManyEntityValid: boolean = false;\n    /**\n     * All validation errors of the has many entity.\n     */\n    hasManyValidationErrors: ValidationError[] = [];\n    /**\n     * What to display inside the has many tooltip.\n     */\n    hasManyTooltipContent: string = '';\n    /**\n     * Whether or not the has many entity is dirty.\n     */\n    isHasManyEntityDirty: boolean = false;\n    /**\n     * Whether or not the current user is allowed to create a has many entity.\n     */\n    hasManyAllowCreate!: boolean;\n    /**\n     * The form context for creating an has many entity.\n     */\n    hasManyCreateFormContext!: FormContext<EntityType>;\n    /**\n     * The form context for editing an has many entity.\n     */\n    hasManyEditFormContext!: FormContext<EntityType>;\n    private hasManyCreateBaseUrl!: string;\n\n    /**\n     * The metadata for a references one property.\n     */\n    metadataReferencesOne!: ReferencesOneDecoratorConfigInternal<EntityType>;\n    /**\n     * The values that can be possibly referenced.\n     */\n    private referencesOneAllReferencedEntities!: EntityType[];\n    /**\n     * The possible references one dropdown values.\n     */\n    private referencesOneDropdownValues!: DropdownValue<string>[];\n    /**\n     * The filtered dropdown values that get displayed in the references one dropdown input.\n     */\n    filteredReferencesOneDropdownValues!: DropdownValue<string>[];\n    /**\n     * A unique input name for the references one property.\n     */\n    referencesOneName!: string;\n    /**\n     * The form context for an object property.\n     */\n    referencesOneFormContext!: FormContext<EntityType>;\n\n    /**\n     * The enum Values for all the different DecoratorTypes.\n     */\n    readonly DecoratorTypes: typeof DecoratorTypes = DecoratorTypes;\n    /**\n     * Contains HelperMethods around handling Entities and their property-metadata.\n     */\n    EntityUtilities: typeof EntityUtilities = EntityUtilities;\n    /**\n     * Contains Helper Functions for handling date properties.\n     */\n    DateUtilities: typeof DateUtilities = DateUtilities;\n    /**\n     * Provides functionality around material selections inside of tables.\n     */\n    SelectionUtilities: typeof SelectionUtilities = SelectionUtilities;\n\n    // eslint-disable-next-line jsdoc/require-returns\n    /**\n     * Gets the currently selected dropdown value for references one.\n     * Is needed so that the dropdown value will still be displayed,\n     * even when the filter method removes the value from the selectable dropdown values.\n     */\n    get currentReferencesOneDropdownValue(): DropdownValue<string> | undefined {\n        return LodashUtilities.cloneDeep(this.referencesOneDropdownValues ?? [])\n            .find(v => v.value === this.entity[this.propertyKey]);\n    }\n\n    // eslint-disable-next-line jsdoc/require-returns\n    /**\n     * Whether or not the currently selected references one value should be shown,\n     * although it would have been filtered out by the search.\n     */\n    get shouldDisplayCurrentReferencesOneDropdownValue(): boolean {\n        return !!this.currentReferencesOneDropdownValue\n            && !this.filteredReferencesOneDropdownValues.find(v => v.value === this.currentReferencesOneDropdownValue?.value);\n    }\n\n    constructor(\n        private readonly dialog: MatDialog,\n        private readonly injector: EnvironmentInjector,\n        private readonly router: Router,\n        @Inject(NGX_GET_VALIDATION_ERROR_MESSAGE)\n        protected readonly defaultGetValidationErrorMessage: (model: NgModel) => string,\n        @Inject(NGX_COMPLETE_GLOBAL_DEFAULT_VALUES)\n        protected readonly globalConfig: NgxGlobalDefaultValues,\n        private readonly http: HttpClient\n    ) {}\n\n    /**\n     * Checks if the input with the given key on the given property is readonly.\n     * @param property - The property on which to check the input.\n     * @param key - The key for the input to check.\n     * @returns Whether or not the input is readonly.\n     */\n    isPropertyReadOnly(property: EntityType, key: keyof EntityType): boolean {\n        return runInInjectionContext(this.injector, () => {\n            if (this.internalIsReadOnly || this.metadataDefaultObject?.isReadOnly(property)) {\n                return true;\n            }\n            const metadata: PropertyDecoratorConfigInternal<unknown> | undefined = EntityUtilities.getPropertyMetadata(property, key);\n            if (!metadata) {\n                throw new Error(`No metadata was found for the key \"${String(key)}\"`);\n            }\n            return metadata.isReadOnly(property);\n        });\n    }\n\n    /**\n     * Gets the value to display in the column.\n     * Runs in environment context to enable injection.\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 runInInjectionContext(this.injector, () => displayColumn.value(entity));\n    }\n\n    ngOnInit(): void {\n        this.internalGetValidationErrorMessage = this.getValidationErrorMessage ?? this.defaultGetValidationErrorMessage;\n        this.internalIsReadOnly = this.isReadOnly ?? false;\n\n        const foundType: DecoratorTypes | undefined = EntityUtilities.getPropertyType(this.entity, this.propertyKey);\n        if (foundType == undefined) {\n            throw new Error(`No type was found for the key \"${String(this.propertyKey)}\"`);\n        }\n        this.type = foundType;\n        if (this.validEmpty === true) {\n            const currentMetadata: PropertyDecoratorConfigInternal<unknown> = ReflectUtilities.getMetadata(\n                'metadata',\n                this.entity,\n                this.propertyKey\n            ) as PropertyDecoratorConfigInternal<unknown>;\n            ReflectUtilities.defineMetadata('metadata', { ...currentMetadata, required: defaultFalse }, this.entity, this.propertyKey);\n        }\n\n        const foundMetadata: PropertyDecoratorConfigInternal<unknown> | undefined = EntityUtilities.getPropertyMetadata(\n            this.entity,\n            this.propertyKey,\n            this.type\n        );\n        if (!foundMetadata) {\n            throw new Error(`No metadata was found for the key \"${String(this.propertyKey)}\"`);\n        }\n        this.metadata = foundMetadata;\n\n        switch (this.type) {\n            case DecoratorTypes.OBJECT_DROPDOWN:\n                void this.initDropdownObjectInput();\n                break;\n            case DecoratorTypes.OBJECT:\n                this.initObjectInput();\n                break;\n            case DecoratorTypes.ARRAY:\n                this.initEntityArray();\n                break;\n            case DecoratorTypes.HAS_MANY:\n                this.initHasMany();\n                break;\n            case DecoratorTypes.REFERENCES_ONE:\n                void this.initReferencesOne();\n                break;\n            default:\n                break;\n        }\n    }\n\n    private async initReferencesOne(): Promise<void> {\n        this.metadataReferencesOne = this.metadata as ReferencesOneDecoratorConfigInternal<EntityType>;\n        this.referencesOneName = this.propertyKey.toString() + 'input' + UUIDUtilities.create();\n\n        await runInInjectionContext(\n            this.injector,\n            async () => {\n                this.referencesOneAllReferencedEntities = await this.metadataReferencesOne.getReferencedEntities();\n                this.referencesOneDropdownValues = this.metadataReferencesOne.getDropdownValues(\n                    LodashUtilities.cloneDeep(this.referencesOneAllReferencedEntities)\n                );\n                this.filteredReferencesOneDropdownValues = LodashUtilities.cloneDeep(this.referencesOneDropdownValues);\n                this.setReferencesOneObject();\n            }\n        );\n    }\n\n    /**\n     * Filters the references one dropdown values.\n     * @param searchInput - The search input to filter for.\n     */\n    filterReferencesOneValues(searchInput: string): void {\n        const filter: string = searchInput.toLowerCase();\n        this.filteredReferencesOneDropdownValues = LodashUtilities.cloneDeep(this.referencesOneDropdownValues).filter(option => {\n            return option.displayName.toLowerCase().includes(filter) || option.value.toLowerCase().includes(filter);\n        });\n    }\n\n    private initHasMany(): void {\n        this.metadata = new HasManyDecoratorConfigInternal(\n            this.metadata as HasManyDecoratorConfigInternal<EntityType, EntityType>,\n            this.globalConfig\n        );\n        ReflectUtilities.defineMetadata('metadata', this.metadata, this.entity, this.propertyKey);\n        this.metadataHasMany = this.metadata as HasManyDecoratorConfigInternal<EntityType, EntityType>;\n        this.hasManyImportAction = new BaseTableActionInternal({\n            ...this.metadataHasMany.tableData.baseData.importActionData,\n            action: () => this.startImportJson()\n        }, this.globalConfig);\n\n        runInInjectionContext(this.injector, () => {\n            this.hasManyAllowCreate = this.metadataHasMany.tableData.baseData.allowCreate();\n            this.hasManyEntityService = inject<EntityService<EntityType>>(this.metadataHasMany.tableData.baseData.EntityServiceClass);\n            this.hasManyCreateBaseUrl = this.metadataHasMany.createBaseUrl(this.entity, this.metadataHasMany);\n        });\n\n        const givenDisplayColumns: string[] = this.metadataHasMany.tableData.baseData.displayColumns.map((v) => v.displayName);\n        // eslint-disable-next-line unicorn/prefer-ternary\n        if (this.metadataHasMany.tableData.baseData.tableActions.filter(tA => tA.type === 'multi-select').length) {\n            this.displayedHasManyColumns = ['select'].concat(givenDisplayColumns);\n        }\n        else {\n            this.displayedHasManyColumns = givenDisplayColumns;\n        }\n\n        this.hasManyDataSource.sortingDataAccessor = (entity: EntityType, header: string) => {\n            return runInInjectionContext(this.injector, () => {\n                return this.metadataHasMany.tableData.baseData.displayColumns\n                    .find((dp) => dp.displayName === header)\n                    ?.value(entity) as string;\n            });\n        };\n        this.hasManyDataSource.filterPredicate = (entity: EntityType, filter: string) => {\n            const searchStr: string = this.metadataHasMany.tableData.baseData.searchString(entity);\n            const formattedSearchString: string = searchStr.toLowerCase();\n            const formattedFilterString: string = filter.toLowerCase();\n            return formattedSearchString.includes(formattedFilterString);\n        };\n        this.hasManyDataSource.filter = this.hasManyFilter;\n\n        this.hasManyEntityService.entitiesSubject.subscribe((entities) => {\n            this.hasManyDataSource.data = entities;\n            this.hasManySelection.clear();\n        });\n        void runInInjectionContext(this.injector, async () => {\n            const readBaseUrl: string = this.metadataHasMany.readBaseUrl(this.entity, this.metadataHasMany);\n            await this.hasManyEntityService.read(readBaseUrl);\n            this.hasManyIsLoading = false;\n        });\n    }\n\n    private initEntityArray(): void {\n        this.metadata = new EntityArrayDecoratorConfigInternal(\n            this.metadata as EntityArrayDecoratorConfigInternal<EntityType>,\n            this.globalConfig\n        );\n        ReflectUtilities.defineMetadata('metadata', this.metadata, this.entity, this.propertyKey);\n        this.metadataEntityArray = this.metadata as EntityArrayDecoratorConfigInternal<EntityType>;\n        if (this.entity[this.propertyKey] == undefined) {\n            (this.entity[this.propertyKey] as EntityType[]) = [];\n        }\n        this.entityArrayValues = this.entity[this.propertyKey] as EntityType[];\n        if (!this.metadataEntityArray.createInline && !this.metadataEntityArray.createDialogData) {\n            this.metadataEntityArray.createDialogData = {\n                title: 'Add'\n            };\n        }\n        const givenDisplayColumns: string[] = this.metadataEntityArray.displayColumns.map((v) => v.displayName);\n        if (givenDisplayColumns.find(s => s === 'select')) {\n            throw new Error(\n                `The name \"select\" for a display column is reserved.\n                Please choose a different name.`\n            );\n        }\n        this.entityArrayDisplayedColumns = this.internalIsReadOnly ? givenDisplayColumns : ['select'].concat(givenDisplayColumns);\n        this.entityArrayDataSource = new MatTableDataSource();\n        this.entityArrayDataSource.data = this.entityArrayValues;\n        this.arrayItem = new this.metadataEntityArray.EntityClass();\n        this.arrayItemPriorChanges = LodashUtilities.cloneDeep(this.arrayItem);\n        EntityUtilities.setDefaultValues(this.arrayItem);\n\n        this.addArrayItemFormContext = {\n            $implicit: {\n                entity: this.arrayItem,\n                tabs: EntityUtilities.getEntityTabs(this.arrayItem, this.injector, true),\n                inputChangeEvent: () => {\n                    void this.checkIsArrayItemValid();\n                    this.addArrayItemFormContext.$implicit.tabs = EntityUtilities.getEntityTabs(this.arrayItem, this.injector, true);\n                },\n                hideOmitForCreate: true\n            }\n        };\n        this.addArrayItemDialogData = new CreateDataBuilder(this.globalConfig, this.metadataEntityArray.createDialogData)\n            .withDefault('createButtonLabel', this.globalConfig.addLabel)\n            .withDefault('title', this.globalConfig.addArrayItemTitle)\n            .getResult();\n\n        this.editArrayItemFormContext = {\n            $implicit: {\n                entity: this.arrayItem,\n                tabs: EntityUtilities.getEntityTabs(this.arrayItem, this.injector, true),\n                isReadOnly: (property, key) => this.isPropertyReadOnly(property, key),\n                inputChangeEvent: () => {\n                    void this.checkArrayItem();\n                    this.editArrayItemFormContext.$implicit.tabs = EntityUtilities.getEntityTabs(this.arrayItem, this.injector, true);\n                },\n                hideOmitForEdit: true\n            }\n        };\n        this.editArrayItemDialogData = this.metadataEntityArray.editDialogData;\n    }\n\n    private async initDropdownObjectInput(): Promise<void> {\n        this.metadataDropdownObject = this.metadata as DropdownObjectDecoratorConfigInternal<EntityType>;\n        this.objectDropdownName = this.propertyKey.toString() + 'input' + UUIDUtilities.create();\n\n        await runInInjectionContext(this.injector, async () => {\n            this.objectDropdownValues = await this.metadataDropdownObject.dropdownValues(this.entity);\n            this.filteredObjectDropdownValues = LodashUtilities.cloneDeep(this.objectDropdownValues);\n        });\n    }\n\n    private initObjectInput(): void {\n        this.metadataDefaultObject = this.metadata as DefaultObjectDecoratorConfigInternal<EntityType>;\n        const objectProperty: EntityType = this.entity[this.propertyKey] as EntityType;\n        const objectPropertyTabs: EntityTab<EntityType>[] = EntityUtilities.getEntityTabs(\n            objectProperty,\n            this.injector,\n            this.hideOmitForCreate,\n            this.hideOmitForEdit,\n            this.metadataDefaultObject.omit\n        );\n        this.objectFormContext = {\n            $implicit: {\n                entity: objectProperty,\n                tabs: objectPropertyTabs,\n                hideOmitForCreate: this.hideOmitForCreate,\n                hideOmitForEdit: this.hideOmitForEdit,\n                isReadOnly: (property, key) => this.isPropertyReadOnly(property, key),\n                inputChangeEvent: () => this.emitChange(),\n                validEmpty: () => !this.metadata.required(this.entity)\n            }\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                await this.importJson(input.files[0]);\n            }\n        };\n        input.click();\n    }\n\n    private async importJson(file: File): Promise<void> {\n        // eslint-disable-next-line stylistic/max-len\n        const dialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(this.globalConfig, this.hasManyImportAction.confirmDialogData)\n            .withDefault('text', this.metadataHasMany.tableData.baseData.importActionData.confirmDialogData?.text)\n            .withDefault('title', this.hasManyImportAction.displayName)\n            .getResult();\n        const dialogRef: MatDialogRef<NgxMatEntityConfirmDialogComponent, boolean> = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        const res: boolean | undefined = await firstValueFrom(dialogRef.afterClosed());\n        if (res == true) {\n            await this.hasManyEntityService.import(file);\n        }\n    }\n\n    /**\n     * Checks if two objects are equal. Is needed for the dropdown.\n     * @param value1 - The first object to compare.\n     * @param value2 - The second object to compare.\n     * @returns Whether or not the objects are the same.\n     */\n    private compareObjects(value1?: EntityType, value2?: EntityType): boolean {\n        const valueObject1: EntityType = new this.metadataDropdownObject.EntityClass(value1);\n        const valueObject2: EntityType = new this.metadataDropdownObject.EntityClass(value2);\n        return LodashUtilities.isEqual(valueObject1, valueObject2);\n    }\n\n    /**\n     * Filters the dropdown values.\n     * @param searchInput - The search input to filter for.\n     */\n    filterObjectDropdownValues(searchInput: string): void {\n        const filter: string = searchInput.toLowerCase();\n        this.filteredObjectDropdownValues = LodashUtilities.cloneDeep(this.objectDropdownValues).filter(option => {\n            return option.displayName.toLowerCase().includes(filter) || JSON.stringify(option.value).toLowerCase()\n                .includes(filter);\n        });\n    }\n\n    /**\n     * Sets the references one object using the input id.\n     */\n    setReferencesOneObject(): void {\n        const foundEntity: EntityType | undefined = this.metadataReferencesOne.getEntityForId(\n            this.entity[this.propertyKey] as string,\n            this.referencesOneAllReferencedEntities\n        );\n        const referencesOneObject: EntityType = new this.metadataReferencesOne.EntityClass(foundEntity);\n        const referencesOnePropertyTabs: EntityTab<EntityType>[] = EntityUtilities.getEntityTabs(referencesOneObject, this.injector);\n\n        this.referencesOneFormContext = {\n            $implicit: {\n                entity: referencesOneObject,\n                tabs: referencesOnePropertyTabs,\n                hideOmitForCreate: this.hideOmitForCreate,\n                hideOmitForEdit: this.hideOmitForEdit,\n                isReadOnly: () => true,\n                inputChangeEvent: () => this.emitChange(),\n                validEmpty: () => !this.metadata.required(this.entity)\n            }\n        };\n\n        this.emitChange();\n    }\n\n    /**\n     * Edits an entity. This either calls the edit-Method provided by the user or uses a default edit-dialog.\n     * @param entity - The entity that should be updated.\n     * @param dCol - The display column that was clicked on.\n     * @throws When no EntityClass was provided, as a new call is needed to initialize metadata.\n     */\n    editHasManyEntity(entity: EntityType, dCol: DisplayColumn<EntityType>): void {\n        if ((dCol.disableClick === true) || (!this.hasManyAllowUpdate(entity) && !this.hasManyAllowRead(entity))) {\n            return;\n        }\n        if (!this.metadataHasMany.tableData.baseData.EntityClass) {\n            throw new Error('No \"EntityClass\" specified for this table');\n        }\n        if (this.metadataHasMany.tableData.baseData.edit) {\n            this.metadataHasMany.tableData.baseData.edit(new this.metadataHasMany.tableData.baseData.EntityClass(entity));\n            return;\n        }\n        if (this.metadataHasMany.tableData.baseData.defaultEdit == 'page') {\n            this.editHasManyDefaultPage(new this.metadataHasMany.tableData.baseData.EntityClass(entity));\n            return;\n        }\n        void this.editHasManyDefaultDialog(new this.metadataHasMany.tableData.baseData.EntityClass(entity));\n    }\n\n    /**\n     * Whether updating the provided entity from the has many property is allowed.\n     * @param entity - A single value of the has many property that the user wants to edit.\n     * @returns True when the user can edit the provided entity and false otherwise.\n     */\n    hasManyAllowUpdate(entity: EntityType): boolean {\n        return runInInjectionContext(this.injector, () => {\n            return this.metadataHasMany.tableData.baseData.allowUpdate(entity);\n        });\n    }\n\n    /**\n     * Whether viewing the provided entity from the has many property is allowed.\n     * @param entity - A single value of the has many property that the user wants to view.\n     * @returns True when the user can view the provided entity and false otherwise.\n     */\n    hasManyAllowRead(entity: EntityType): boolean {\n        return runInInjectionContext(this.injector, () => {\n            return this.metadataHasMany.tableData.baseData.allowRead(entity);\n        });\n    }\n\n    /**\n     * Whether deleting the provided entity from the has many property is allowed.\n     * @param entity - A single value of the has many property that the user wants to delete.\n     * @returns True when the user can delete the provided entity and false otherwise.\n     */\n    hasManyAllowDelete(entity: EntityType): boolean {\n        return runInInjectionContext(this.injector, () => {\n            return this.metadataHasMany.tableData.baseData.allowDelete(entity);\n        });\n    }\n\n    /**\n     * Checks if an EditAction is disabled (e.g. Because the current entry doesn't fullfil the requirements).\n     * @param action - The EditAction to check.\n     * @returns Whether or not the Action can be used.\n     */\n    hasManyEditActionDisabled(action: EditActionInternal<EntityType>): boolean {\n        return runInInjectionContext(this.injector, () => {\n            return !action.enabled(this.hasManyEntityPriorChanges);\n        });\n    }\n\n    /**\n     * Runs the edit action on the entity.\n     * @param action - The action to run.\n     */\n    async hasManyRunEditAction(action: EditActionInternal<EntityType>): Promise<void> {\n        const requireConfirmDialog: boolean = runInInjectionContext(this.injector, () => {\n            return action.requireConfirmDialog(this.hasManyEntityPriorChanges);\n        });\n\n        if (!requireConfirmDialog) {\n            await this.confirmHasManyRunEditAction(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        const res: boolean | undefined = await firstValueFrom(dialogRef.afterClosed());\n        if (res == true) {\n            await this.confirmHasManyRunEditAction(action);\n        }\n    }\n\n    private async confirmHasManyRunEditAction(action: EditActionInternal<EntityType>): Promise<void> {\n        await runInInjectionContext(this.injector, async () => {\n            await action.action(this.hasManyEntity, this.hasManyEntityPriorChanges);\n            await this.checkHasManyEntity();\n        });\n    }\n\n    private editHasManyDefaultPage(entity: EntityType): void {\n        void this.router.navigate(['', this.hasManyEntityService.editBaseRoute, entity[this.hasManyEntityService.idKey]]);\n    }\n\n    private async editHasManyDefaultDialog(entity: EntityType): Promise<void> {\n        this.hasManyEntity = LodashUtilities.cloneDeep(entity);\n        this.hasManyEntityPriorChanges = LodashUtilities.cloneDeep(this.hasManyEntity);\n        this.hasManyEditFormContext = {\n            $implicit: {\n                entity: this.hasManyEntity,\n                hideOmitForEdit: true,\n                isReadOnly: (property, key) => this.isPropertyReadOnly(property, key),\n                inputChangeEvent: () => {\n                    void this.checkHasManyEntity();\n                    this.hasManyEditFormContext.$implicit.tabs = EntityUtilities.getEntityTabs(\n                        this.hasManyEntity,\n                        this.injector,\n                        false,\n                        true\n                    );\n                },\n                tabs: EntityUtilities.getEntityTabs(this.hasManyEntity, this.injector, false, true)\n            }\n        };\n        await this.checkHasManyEntity();\n        this.editHasManyDialogRef = this.dialog.open(\n            this.editHasManyDialog,\n            {\n                minWidth: '60%',\n                autoFocus: false,\n                restoreFocus: false\n            }\n        );\n        const res: number = await firstValueFrom(this.editHasManyDialogRef.afterClosed()) as number;\n        if (res === 0) {\n            const data: EntityType[] = this.hasManyDataSource.data;\n            // eslint-disable-next-line stylistic/max-len\n            data[this.hasManyDataSource.data.findIndex((e) => e[this.hasManyEntityService.idKey] === entity[this.hasManyEntityService.idKey])] = entity;\n            this.hasManyDataSource.data = data;\n            this.hasManySelection.clear();\n        }\n    }\n\n    /**\n     * Tries to save the changes and close the dialog afterwards.\n     * Also handles the confirmation if required.\n     */\n    async dialogEditHasMany(): Promise<void> {\n        if (this.internalIsReadOnly || !this.isHasManyEntityValid || !this.isHasManyEntityDirty) {\n            return;\n        }\n        if (!this.metadataHasMany.tableData.editData.editRequiresConfirmDialog) {\n            await this.dialogConfirmEditHasMany();\n            return;\n        }\n\n        // eslint-disable-next-line stylistic/max-len\n        const dialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(this.globalConfig, this.metadataHasMany.tableData.editData.confirmEditDialogData)\n            .withDefault('text', this.globalConfig.confirmSaveText)\n            .withDefault('confirmButtonLabel', this.globalConfig.saveLabel)\n            .withDefault('title', this.globalConfig.editLabel)\n            .getResult();\n        const dialogRef: MatDialogRef<NgxMatEntityConfirmDialogComponent, boolean> = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        const res: boolean | undefined = await firstValueFrom(dialogRef.afterClosed());\n        if (res == true) {\n            await this.dialogConfirmEditHasMany();\n        }\n    }\n    private async dialogConfirmEditHasMany(): Promise<void> {\n        await this.hasManyEntityService.update(this.hasManyEntity, this.hasManyEntityPriorChanges);\n        this.editHasManyDialogRef.close(1);\n        this.emitChange();\n    }\n\n    /**\n     * Tries to delete the entity and close the dialog afterwards.\n     * Also handles the confirmation if required.\n     */\n    async deleteHasManyEntity(): Promise<void> {\n        if (!this.metadataHasMany.tableData.editData.deleteRequiresConfirmDialog) {\n            await this.confirmDeleteHasManyEntity();\n            return;\n        }\n\n        // eslint-disable-next-line stylistic/max-len\n        const dialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(this.globalConfig, this.metadataHasMany.tableData.editData.confirmDeleteDialogData)\n            .withDefault('text', this.globalConfig.confirmDeleteText)\n            .withDefault('type', 'delete')\n            .withDefault('confirmButtonLabel', this.globalConfig.deleteLabel)\n            .withDefault('title', this.globalConfig.deleteLabel)\n            .getResult();\n        const dialogRef: MatDialogRef<NgxMatEntityConfirmDialogComponent, boolean> = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        const res: boolean | undefined = await firstValueFrom(dialogRef.afterClosed());\n        if (res == true) {\n            await this.confirmDeleteHasManyEntity();\n        }\n    }\n\n    private async confirmDeleteHasManyEntity(): Promise<void> {\n        await this.hasManyEntityService.delete(this.hasManyEntityPriorChanges);\n        this.editHasManyDialogRef.close(2);\n        this.emitChange();\n    }\n\n    /**\n     * Cancels the editing of the has many entity and closes the dialog.\n     */\n    dialogCancelEditHasMany(): void {\n        EntityUtilities.resetChangesOnEntity(this.hasManyEntity, this.hasManyEntityPriorChanges);\n        this.editHasManyDialogRef.close(0);\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     * @throws When no EntityClass was provided, as a new call is needed to initialize metadata.\n     */\n    createHasManyEntity(): void {\n        void runInInjectionContext(this.injector, async () => {\n            if (this.metadataHasMany.tableData.baseData.allowCreate()) {\n                if (!this.metadataHasMany.tableData.baseData.EntityClass) {\n                    throw new Error('No \"EntityClass\" specified for this table');\n                }\n                if (this.metadataHasMany.tableData.baseData.create) {\n                    this.metadataHasMany.tableData.baseData.create(new this.metadataHasMany.tableData.baseData.EntityClass());\n                    return;\n                }\n                const entity: EntityType = new this.metadataHasMany.tableData.baseData.EntityClass();\n                EntityUtilities.setDefaultValues(entity);\n                if (this.metadataHasMany.tableData.baseData.defaultCreate == 'page') {\n                    this.createHasManyDefaultPage();\n                    return;\n                }\n                await this.createHasManyDefaultDialog(entity);\n            }\n        });\n    }\n\n    private createHasManyDefaultPage(): void {\n        void this.router.navigateByUrl(this.hasManyEntityService.createBaseRoute);\n    }\n\n    private async createHasManyDefaultDialog(entity: EntityType): Promise<void> {\n        this.hasManyEntity = entity;\n        this.hasManyCreateFormContext = {\n            $implicit: {\n                entity: this.hasManyEntity,\n                hideOmitForCreate: true,\n                inputChangeEvent: () => {\n                    void this.checkIsHasManyEntityValid('create');\n                    this.hasManyCreateFormContext.$implicit.tabs = EntityUtilities.getEntityTabs(this.hasManyEntity, this.injector, true);\n                },\n                tabs: EntityUtilities.getEntityTabs(this.hasManyEntity, this.injector, true)\n            }\n        };\n        await this.checkIsHasManyEntityValid('create');\n        this.createHasManyDialogRef = this.dialog.open(\n            this.createHasManyDialog,\n            {\n                minWidth: '60%',\n                autoFocus: false,\n                restoreFocus: false\n            }\n        );\n    }\n\n    /**\n     * Creates the has many entity over the dialog.\n     */\n    async dialogCreateHasMany(): Promise<void> {\n        if (!this.isHasManyEntityValid) {\n            return;\n        }\n        if (!this.metadataHasMany.tableData.createData.createRequiresConfirmDialog) {\n            await this.dialogConfirmCreateHasMany();\n            return;\n        }\n\n        // eslint-disable-next-line stylistic/max-len\n        const dialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(this.globalConfig, this.metadataHasMany.tableData.createData.confirmCreateDialogData)\n            .withDefault('text', this.globalConfig.confirmCreateText)\n            .withDefault('confirmButtonLabel', this.globalConfig.createLabel)\n            .withDefault('title', this.globalConfig.createLabel)\n            .getResult();\n        const dialogRef: MatDialogRef<NgxMatEntityConfirmDialogComponent, boolean> = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        const res: boolean | undefined = await firstValueFrom(dialogRef.afterClosed());\n        if (res == true) {\n            await this.dialogConfirmCreateHasMany();\n        }\n    }\n    private async dialogConfirmCreateHasMany(): Promise<void> {\n        await this.hasManyEntityService.create(this.hasManyEntity, this.hasManyCreateBaseUrl);\n        this.createHasManyDialogRef.close();\n        this.emitChange();\n    }\n\n    /**\n     * Cancels the creating of the has many entity and closes the dialog.\n     */\n    dialogCancelCreateHasMany(): void {\n        this.createHasManyDialogRef.close();\n    }\n\n    /**\n     * Runs the TableAction for all selected entries.\n     * Also handles confirmation with an additional dial#og if configured.\n     * @param action - The TableAction to run.\n     */\n    async runHasManyTableAction(action: TableActionInternal<EntityType>): Promise<void> {\n        const requireConfirmDialog: boolean = runInInjectionContext(\n            this.injector,\n            () => action.requireConfirmDialog(this.hasManySelection.selected)\n        );\n        if (!requireConfirmDialog) {\n            await this.confirmRunHasManyTableAction(action);\n            return;\n        }\n\n        const defaultText: string[] = action.type === 'multi-select'\n            ? this.globalConfig.confirmMultiSelectActionText(this.hasManySelection.selected)\n            : this.globalConfig.confirmBaseActionText;\n        const dialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(this.globalConfig, action.confirmDialogData)\n            .withDefault('text', defaultText)\n            .withDefault('title', action.displayName)\n            .getResult();\n        const dialogRef: MatDialogRef<NgxMatEntityConfirmDialogComponent, boolean> = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        const res: boolean | undefined = await firstValueFrom(dialogRef.afterClosed());\n        if (res == true) {\n            await this.confirmRunHasManyTableAction(action);\n        }\n    }\n\n    private async confirmRunHasManyTableAction(action: TableActionInternal<EntityType>): Promise<void> {\n        await runInInjectionContext(this.injector, async () => {\n            await action.action(this.hasManySelection.selected);\n            this.emitChange();\n        });\n    }\n\n    /**\n     * Checks if an TableAction is disabled (e.g. Because no entries have been selected).\n     * @param action - The TableAction to check.\n     * @returns Whether or not the Action can be used.\n     */\n    hasManyTableActionDisabled(action: TableActionInternal<EntityType>): boolean {\n        return runInInjectionContext(this.injector, () => {\n            return !action.enabled(this.hasManySelection.selected);\n        });\n    }\n\n    /**\n     * Applies the search input to filter the table entries.\n     * @param event - The keyup-event which contains the search-string of the user.\n     */\n    applyHasManyFilter(event: Event): void {\n        const filterValue: string = (event.target as HTMLInputElement).value;\n        this.hasManyDataSource.filter = filterValue.trim().toLowerCase();\n    }\n\n    /**\n     * Checks if the entity is valid for updating and if it is dirty.\n     */\n    async checkHasManyEntity(): Promise<void> {\n        await this.checkIsHasManyEntityValid('update');\n        this.isHasManyEntityDirty = await EntityUtilities.isDirty(this.hasManyEntity, this.hasManyEntityPriorChanges, this.http);\n    }\n\n    /**\n     * Checks if the entity is valid.\n     * @param omit - Whether values omitted for create or update should be left out.\n     */\n    async checkIsHasManyEntityValid(omit: 'create' | 'update'): Promise<void> {\n        this.hasManyValidationErrors = await ValidationUtilities.getEntityValidationErrors(this.hasManyEntity, this.injector, omit);\n\n        this.hasManyTooltipContent = runInInjectionContext(\n            this.injector,\n            () => getValidationErrorsTooltipContent(this.hasManyValidationErrors)\n        );\n        this.isHasManyEntityValid = this.hasManyValidationErrors.length === 0;\n    }\n\n    /**\n     * Checks whether the array item is valid and if the array item is dirty.\n     */\n    async checkArrayItem(): Promise<void> {\n        await this.checkIsArrayItemValid();\n        await this.checkIsArrayItemDirty();\n    }\n\n    /**\n     * Checks if the array item is dirty.\n     */\n    async checkIsArrayItemDirty(): Promise<void> {\n        this.isArrayItemDirty = await EntityUtilities.isDirty(this.arrayItem, this.arrayItemPriorChanges, this.http);\n    }\n\n    /**\n     * Checks if the arrayItem is valid.\n     */\n    async checkIsArrayItemValid(): Promise<void> {\n        this.arrayItemValidationErrors = await ValidationUtilities.getEntityValidationErrors(this.arrayItem, this.injector, 'create');\n\n        this.arrayItemTooltipContent = runInInjectionContext(\n            this.injector,\n            () => getValidationErrorsTooltipContent(this.arrayItemValidationErrors)\n        );\n        this.isArrayItemValid = this.arrayItemValidationErrors.length === 0;\n    }\n\n    /**\n     * Emits that a the value has been changed.\n     */\n    emitChange(): void {\n        this.inputChangeEvent.emit();\n    }\n\n    /**\n     * Tries to add an item to the entity array.\n     * Does this either inline if the \"createInline\"-metadata is set to true\n     * or in a separate dialog if it is set to false.\n     */\n    async addEntity(): Promise<void> {\n        await this.checkIsArrayItemValid();\n        if (!this.metadataEntityArray.createInline) {\n            this.addArrayItemDialogRef = this.dialog.open(\n                this.addArrayItemDialog,\n                {\n                    minWidth: '60%',\n                    autoFocus: false,\n                    restoreFocus: false\n                }\n            );\n            return;\n        }\n        if (!this.metadataEntityArray.allowDuplicates) {\n            for (const v of this.entityArrayValues) {\n                if (await EntityUtilities.isEqual(this.arrayItem, v, this.metadata, this.metadataEntityArray.itemType, this.http)) {\n                    this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n                        data: this.metadataEntityArray.duplicatesErrorDialog,\n                        autoFocus: false,\n                        restoreFocus: false\n                    });\n                    return;\n                }\n            }\n        }\n        this.entityArrayValues.push(LodashUtilities.cloneDeep(this.arrayItem));\n        this.entityArrayDataSource.data = this.entityArrayValues;\n        EntityUtilities.resetChangesOnEntity(this.arrayItem, this.arrayItemPriorChanges);\n        EntityUtilities.setDefaultValues(this.arrayItem);\n        await this.checkIsArrayItemValid();\n        this.emitChange();\n    }\n\n    /**\n     * Adds the array item defined in the dialog.\n     */\n    async addArrayItem(): Promise<void> {\n        if (!this.isArrayItemValid) {\n            return;\n        }\n        this.entityArrayValues.push(LodashUtilities.cloneDeep(this.arrayItem));\n        this.entityArrayDataSource.data = this.entityArrayValues;\n\n        await this.closeAddArrayItemDialog();\n    }\n\n    /**\n     * Cancels adding the array item defined in the dialog.\n     */\n    async closeAddArrayItemDialog(): Promise<void> {\n        this.addArrayItemDialogRef.close();\n        EntityUtilities.resetChangesOnEntity(this.arrayItem, this.arrayItemPriorChanges);\n        await this.checkIsArrayItemValid();\n        this.emitChange();\n    }\n\n    /**\n     * Edits an entity array item.\n     * @param entity - The entity that has been clicked.\n     * @param dCol - The display column that was clicked on.\n     */\n    async editArrayItem(entity: EntityType, dCol: DisplayColumn<EntityType>): Promise<void> {\n        if (dCol.disableClick === true) {\n            return;\n        }\n        this.indexOfEditedArrayItem = this.entityArrayValues.indexOf(entity);\n        this.arrayItem = new this.metadataEntityArray.EntityClass(entity);\n        this.arrayItemPriorChanges = LodashUtilities.cloneDeep(this.arrayItem);\n\n        await this.checkArrayItem();\n\n        this.editArrayItemDialogRef = this.dialog.open(\n            this.editArrayItemDialog,\n            {\n                minWidth: '60%',\n                autoFocus: false,\n                restoreFocus: false\n            }\n        );\n    }\n\n    /**\n     * Saves changes on the array item in the dialog.\n     */\n    saveArrayItem(): void {\n        this.entityArrayValues[this.indexOfEditedArrayItem] = LodashUtilities.cloneDeep(this.arrayItem);\n        this.entityArrayDataSource.data = this.entityArrayValues;\n\n        void this.closeEditArrayItemDialog();\n    }\n\n    /**\n     * Closes the edit array item dialog and resets changes.\n     */\n    async closeEditArrayItemDialog(): Promise<void> {\n        this.editArrayItemDialogRef.close();\n        this.arrayItem = new this.metadataEntityArray.EntityClass();\n        this.arrayItemPriorChanges = LodashUtilities.cloneDeep(this.arrayItem);\n        await this.checkArrayItem();\n        this.emitChange();\n    }\n\n    /**\n     * Removes all selected entries from the entity array.\n     */\n    removeFromEntityArray(): void {\n        SelectionUtilities.remove(this.entityArraySelection, this.entityArrayValues, this.entityArrayDataSource);\n        this.emitChange();\n    }\n}","<!-- eslint-disable angular/no-call-expression -->\n \n@if(!(hideOmitForCreate && metadata.omitForCreate) && !(hideOmitForEdit && metadata.omitForUpdate)) {\n    @switch (type) {\n        <!-------------------------------------------->\n        <!-----------------Strings-------------------->\n        <!-------------------------------------------->\n        @case (DecoratorTypes.STRING) {\n            <string-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </string-input>\n        }\n        @case (DecoratorTypes.STRING_TEXTBOX) {\n            <string-textbox-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </string-textbox-input>\n        }\n        @case (DecoratorTypes.STRING_AUTOCOMPLETE) {\n            <string-autocomplete-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </string-autocomplete-input>\n        }\n        @case (DecoratorTypes.STRING_DROPDOWN) {\n            <string-dropdown-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </string-dropdown-input>\n        }\n        @case (DecoratorTypes.STRING_PASSWORD) {\n            <string-password-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </string-password-input>\n        }\n        <!-------------------------------------------->\n        <!-----------------Booleans------------------->\n        <!-------------------------------------------->\n        @case (DecoratorTypes.BOOLEAN_CHECKBOX) {\n            <boolean-checkbox-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </boolean-checkbox-input>\n        }\n        @case (DecoratorTypes.BOOLEAN_TOGGLE) {\n            <boolean-toggle-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </boolean-toggle-input>\n        }\n        @case (DecoratorTypes.BOOLEAN_DROPDOWN) {\n            <boolean-dropdown-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </boolean-dropdown-input>\n        }\n        <!-------------------------------------------->\n        <!------------------Numbers------------------->\n        <!-------------------------------------------->\n        @case (DecoratorTypes.NUMBER) {\n            <number-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </number-input>\n        }\n        @case (DecoratorTypes.NUMBER_DROPDOWN) {\n            <number-dropdown-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </number-dropdown-input>\n        }\n        @case (DecoratorTypes.NUMBER_SLIDER) {\n            <number-slider-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </number-slider-input>\n        }\n        <!-------------------------------------------->\n        <!-------------------Array-------------------->\n        <!-------------------------------------------->\n        @case (DecoratorTypes.ARRAY_DATE) {\n            <array-date-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </array-date-input>\n        }\n        @case (DecoratorTypes.ARRAY_DATE_TIME) {\n            <array-date-time-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </array-date-time-input>\n        }\n        @case (DecoratorTypes.ARRAY_DATE_RANGE) {\n            <array-date-range-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </array-date-range-input>\n        }\n        @case (DecoratorTypes.ARRAY_STRING_CHIPS) {\n            <array-string-chips-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </array-string-chips-input>\n        }\n        @case (DecoratorTypes.ARRAY_STRING_AUTOCOMPLETE_CHIPS) {\n            <array-string-autocomplete-chips\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </array-string-autocomplete-chips>\n        }\n        <!-------------------------------------------->\n        <!-------------------Dates-------------------->\n        <!-------------------------------------------->\n        @case (DecoratorTypes.DATE) {\n            <date-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </date-input>\n        }\n        @case (DecoratorTypes.DATE_RANGE) {\n            <date-range-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </date-range-input>\n        }\n        @case (DecoratorTypes.DATE_TIME) {\n            <date-time-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </date-time-input>\n        }\n        <!-------------------------------------------->\n        <!-------------------Files-------------------->\n        <!-------------------------------------------->\n        @case (DecoratorTypes.FILE_DEFAULT) {\n            <file-default-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </file-default-input>\n        }\n        @case (DecoratorTypes.FILE_IMAGE) {\n            <file-image-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </file-image-input>\n        }\n        <!-------------------------------------------->\n        <!-------------- references many ------------->\n        <!-------------------------------------------->\n        @case (DecoratorTypes.REFERENCES_MANY) {\n            <references-many-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </references-many-input>\n        }\n        <!-------------------------------------------->\n        <!-------------------Custom------------------->\n        <!-------------------------------------------->\n        @case (DecoratorTypes.CUSTOM) {\n            <custom-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </custom-input>\n        }\n        <!-------------------------------------------->\n        <!-------------------Object------------------->\n        <!-------------------------------------------->\n        @case (DecoratorTypes.OBJECT) {\n            <b>{{metadataDefaultObject.displayName}}</b>\n            <!-- iterates over the object properties -->\n            <ng-container *ngTemplateOutlet=\"form; context: objectFormContext\"></ng-container>\n        }\n        <!-------------------------------------------->\n        <!---------------Object Dropdown-------------->\n        <!-------------------------------------------->\n        @case (DecoratorTypes.OBJECT_DROPDOWN) {\n            <mat-form-field class=\"object-dropdown\">\n                <mat-label>{{metadata.displayName}}</mat-label>\n                <mat-select #model=\"ngModel\"\n                    [name]=\"objectDropdownName\"\n                    [required]=\"metadata.required(entity)\"\n                    [disabled]=\"internalIsReadOnly\"\n                    [compareWith]=\"compareObjectsBound\"\n                    [(ngModel)]=\"entity[propertyKey]\"\n                    (selectionChange)=\"emitChange()\"\n                    (opened)=\"selectSearchInput.focus()\"\n                >\n                    <mat-form-field class=\"select-search-input\">\n                        <!-- eslint-disable-next-line angular/no-any -->\n                        <input #selectSearchInput matInput (keyup)=\"filterObjectDropdownValues($any($event.target).value)\">\n                        <i matSuffix class=\"fas fa-search\"></i>\n                    </mat-form-field>\n                    @if (!metadata.required(entity)) {\n                        <mat-option>-</mat-option>\n                    }\n                    @if (shouldDisplayCurrentObjectDropdownValue) {\n                        <mat-option [value]=\"currentObjectDropdownValue?.value\">{{currentObjectDropdownValue?.displayName}}</mat-option>\n                    }\n                    @for (value of filteredObjectDropdownValues; track $index) {\n                        <mat-option [value]=\"value.value\">{{value.displayName}}</mat-option>\n                    }\n                </mat-select>\n                <mat-error>{{internalGetValidationErrorMessage(model)}}</mat-error>\n            </mat-form-field>\n        }\n        <!-------------------------------------------->\n        <!-------------- references one -------------->\n        <!-------------------------------------------->\n        @case (DecoratorTypes.REFERENCES_ONE) {\n            <mat-form-field>\n                <mat-label>{{metadata.displayName}}</mat-label>\n                <mat-select #inputModel=\"ngModel\"\n                    [name]=\"referencesOneName\"\n                    [disabled]=\"internalIsReadOnly\"\n                    [required]=\"metadata.required(entity)\"\n                    [(ngModel)]=\"entity[propertyKey]\"\n                    (selectionChange)=\"setReferencesOneObject()\"\n                    (opened)=\"selectSearchInput.focus()\"\n                >\n                    <mat-form-field class=\"select-search-input\">\n                        <!-- eslint-disable-next-line angular/no-any -->\n                        <input #selectSearchInput matInput (keyup)=\"filterReferencesOneValues($any($event.target).value)\">\n                        <i matSuffix class=\"fas fa-search\"></i>\n                    </mat-form-field>\n                    @if (!metadata.required(entity)) {\n                        <mat-option>-</mat-option>\n                    }\n                    @if (shouldDisplayCurrentReferencesOneDropdownValue) {\n                        <mat-option [value]=\"currentReferencesOneDropdownValue?.value\">{{currentReferencesOneDropdownValue?.displayName}}</mat-option>\n                    }\n                    @for (value of filteredReferencesOneDropdownValues; track $index) {\n                        <mat-option [value]=\"value.value\">{{value.displayName}}</mat-option>\n                    }\n                </mat-select>\n                <mat-error>{{internalGetValidationErrorMessage(inputModel)}}</mat-error>\n            </mat-form-field>\n            <!-- iterates over the references one properties -->\n            @if (referencesOneFormContext) {\n                <ng-container *ngTemplateOutlet=\"form; context: referencesOneFormContext\"></ng-container>\n            }\n        }\n        <!-------------------------------------------->\n        <!-------------------Array-------------------->\n        <!-------------------------------------------->\n        @case (DecoratorTypes.ARRAY) {\n            <div class=\"entityArray\">\n                <div class=\"mat-elevation-z8 elevation-container\">\n                    <div class=\"array-headline\">\n                        <b>{{metadataEntityArray.displayName}}</b>\n                    </div>\n                    @if (metadataEntityArray.createInline && !internalIsReadOnly && addArrayItemFormContext) {\n                        <ng-container *ngTemplateOutlet=\"form; context: addArrayItemFormContext\"></ng-container>\n                    }\n                    @if (!internalIsReadOnly) {\n                        <div class=\"buttons\">\n                            <button type=\"button\" mat-raised-button\n                                [disabled]=\"metadataEntityArray.createInline && !isArrayItemValid\"\n                                (click)=\"addEntity()\">\n                                {{metadataEntityArray.addButtonLabel}}\n                            </button>\n                            <button type=\"button\" mat-raised-button\n                                [disabled]=\"!entityArraySelection.selected.length\"\n                                (click)=\"removeFromEntityArray()\">\n                                {{metadataEntityArray.removeButtonLabel}}\n                            </button>\n                        </div>\n                    }\n                    <mat-table [dataSource]=\"entityArrayDataSource\">\n                        @if (!internalIsReadOnly) {\n                            <ng-container matColumnDef=\"select\">\n                                <mat-header-cell *matHeaderCellDef>\n                                    <mat-checkbox\n                                        [disabled]=\"!entityArrayDataSource.data.length\" [checked]=\"entityArraySelection.hasValue() && SelectionUtilities.isAllSelected(entityArraySelection, entityArrayDataSource)\"\n                                        [indeterminate]=\"entityArraySelection.hasValue() && !SelectionUtilities.isAllSelected(entityArraySelection, entityArrayDataSource)\"\n                                        (change)=\"$event ? SelectionUtilities.masterToggle(entityArraySelection, entityArrayDataSource) : null\">\n                                    </mat-checkbox>\n                                </mat-header-cell>\n                                <mat-cell *matCellDef=\"let entity\">\n                                    <mat-checkbox [checked]=\"entityArraySelection.isSelected(entity)\" (click)=\"$event.stopPropagation()\" (change)=\"$event ? entityArraySelection.toggle(entity) : null\"></mat-checkbox>\n                                </mat-cell>\n                            </ng-container>\n                        }\n                        @for (dCol of metadataEntityArray.displayColumns; track $index) {\n                            <ng-container [matColumnDef]=\"dCol.displayName\">\n                                <mat-header-cell *matHeaderCellDef>\n                                    {{dCol.displayName}}\n                                </mat-header-cell>\n                                <mat-cell *matCellDef=\"let entity\" [class.enabled]=\"!dCol.disableClick\" (click)=\"editArrayItem(entity, dCol)\">\n                                    @if (dCol.Component) {\n                                        <display-column-value [entity]=\"entity\" [ComponentClass]=\"dCol.Component\"></display-column-value>\n                                    }\n                                    @else {\n                                        {{getDisplayColumnValue(entity, dCol)}}\n                                    }\n                                </mat-cell>\n                            </ng-container>\n                        }\n                        <mat-header-row *matHeaderRowDef=\"entityArrayDisplayedColumns\"></mat-header-row>\n                        <mat-row *matRowDef=\"let row; columns: entityArrayDisplayedColumns\"></mat-row>\n                    </mat-table>\n                \n                    @if (metadataEntityArray.required(entity) && !entityArrayDataSource.data.length) {\n                        <div class=\"array-error\">{{metadataEntityArray.missingErrorMessage}}</div>\n                    }\n                </div>\n            </div>\n        }\n        <!-------------------------------------------->\n        <!------------------ has many ---------------->\n        <!-------------------------------------------->\n        @case (DecoratorTypes.HAS_MANY) {\n            <div class=\"hasMany\">\n                <h2 class=\"title\">{{metadataHasMany.tableData.baseData.title}}</h2>\n                <div class=\"row\">\n                    <mat-form-field class=\"col-lg-8 col-md-6 col-sm-12\">\n                        <mat-label>{{metadataHasMany.tableData.baseData.searchLabel}}</mat-label>\n                        <input matInput (keyup)=\"applyHasManyFilter($event)\">\n                    </mat-form-field>\n                    @if (metadataHasMany.tableData.baseData.tableActions.length) {\n                        <div\n                            [class.col-lg-2]=\"hasManyAllowCreate\"\n                            [class.col-lg-4]=\"!hasManyAllowCreate\"\n                            [class.col-md-3]=\"hasManyAllowCreate\"\n                            [class.col-md-6]=\"!hasManyAllowCreate\"\n                            [class.col-sm-6]=\"hasManyAllowCreate\"\n                            [class.col-sm-12]=\"!hasManyAllowCreate\"\n                        >\n                            <button type=\"button\" class=\"actions-button\" mat-raised-button [matMenuTriggerFor]=\"menu\">\n                                {{metadataHasMany.tableData.baseData.tableActionsLabel}}\n                            </button>\n                        </div>\n                    }\n                    <mat-menu #menu=\"matMenu\">\n                        @if (metadataHasMany.tableData.baseData.allowJsonImport) {\n                            <button type=\"button\" mat-menu-item [disabled]=\"hasManyTableActionDisabled(hasManyImportAction)\" (click)=\"runHasManyTableAction(hasManyImportAction)\">\n                                {{hasManyImportAction.displayName}}\n                            </button>\n                        }\n                        @for (action of metadataHasMany.tableData.baseData.tableActions; track $index) {\n                            <button type=\"button\" mat-menu-item [disabled]=\"hasManyTableActionDisabled(action)\" (click)=\"runHasManyTableAction(action)\">\n                                {{action.displayName}}\n                            </button>\n                        }\n                    </mat-menu>\n                    @if (hasManyAllowCreate) {\n                        <div\n                            [class.col-lg-2]=\"metadataHasMany.tableData.baseData.tableActions.length\"\n                            [class.col-lg-4]=\"!metadataHasMany.tableData.baseData.tableActions.length\"\n                            [class.col-md-3]=\"metadataHasMany.tableData.baseData.tableActions.length\"\n                            [class.col-md-6]=\"!metadataHasMany.tableData.baseData.tableActions.length\"\n                            [class.col-sm-6]=\"metadataHasMany.tableData.baseData.tableActions.length\"\n                            [class.col-sm-12]=\"!metadataHasMany.tableData.baseData.tableActions.length\"\n                        >\n                            <button type=\"button\" class=\"create-button\" mat-raised-button (click)=\"createHasManyEntity()\">\n                                {{metadataHasMany.tableData.baseData.createButtonLabel}}\n                            </button>\n                        </div>\n                    }\n                </div>\n        \n                <div class=\"mat-elevation-z8 elevation-container\">\n                    <mat-table matSort [dataSource]=\"hasManyDataSource\">\n                        <!-- select Column -->\n                        <ng-container matColumnDef=\"select\">\n                            <mat-header-cell *matHeaderCellDef>\n                                <mat-checkbox [checked]=\"hasManySelection.hasValue() && SelectionUtilities.isAllSelected(hasManySelection, hasManyDataSource)\"\n                                    [indeterminate]=\"hasManySelection.hasValue() && !SelectionUtilities.isAllSelected(hasManySelection, hasManyDataSource)\"\n                                    (change)=\"$event ? SelectionUtilities.masterToggle(hasManySelection, hasManyDataSource) : null\">\n                                </mat-checkbox>\n                            </mat-header-cell>\n                            <mat-cell *matCellDef=\"let entity\" class=\"enabled\">\n                                <mat-checkbox [checked]=\"hasManySelection.isSelected(entity)\"\n                                    (click)=\"$event.stopPropagation()\"\n                                    (change)=\"$event ? hasManySelection.toggle(entity) : null\">\n                                </mat-checkbox>\n                            </mat-cell>\n                        </ng-container>\n                        \n                        @for (dCol of metadataHasMany.tableData.baseData.displayColumns; track $index) {\n                            <ng-container [matColumnDef]=\"dCol.displayName\">\n                                <mat-header-cell *matHeaderCellDef mat-sort-header>\n                                    {{dCol.displayName}}\n                                </mat-header-cell>\n                                <mat-cell *matCellDef=\"let entity\"\n                                    [class.enabled]=\"!dCol.disableClick && (hasManyAllowUpdate(entity) || hasManyAllowRead(entity))\"\n                                    (click)=\"editHasManyEntity(entity, dCol)\"\n                                >\n                                    @if (dCol.Component) {\n                                        <display-column-value [entity]=\"entity\" [ComponentClass]=\"dCol.Component\"></display-column-value>\n                                    }\n                                    @else {\n                                        {{getDisplayColumnValue(entity, dCol)}}\n                                    }\n                                </mat-cell>\n                            </ng-container>\n                        }\n                        <mat-header-row *matHeaderRowDef=\"displayedHasManyColumns\"></mat-header-row>\n                        <mat-row *matRowDef=\"let row; columns: displayedHasManyColumns\"></mat-row>\n                    </mat-table>\n        \n                    @if (hasManyIsLoading && metadataHasMany.tableData.baseData.displayLoadingSpinner) {\n                        <mat-spinner></mat-spinner>\n                    }\n                    <mat-paginator style=\"padding-top: 10px; padding-bottom: 10px;\" [length]=\"hasManyDataSource.filteredData.length\" [pageIndex]=\"0\" [pageSize]=\"10\" [pageSizeOptions]=\"[5, 10, 25, 50]\"></mat-paginator>\n                </div>\n            </div>\n        }\n        \n        @default {\n            <div>ERROR: The type {{type}} is not known.</div>\n        }\n    }\n}\n\n\n\n\n<!--------------------------------------------------------->\n<!---------------------------Form-------------------------->\n<!--------------------------------------------------------->\n<ng-template #form let-context>\n     <!-- eslint-disable angular/no-call-expression -->\n    @if (context.tabs.length > 1) {\n        <mat-tab-group preserveContent>\n            @for (tab of context.tabs; track $index) {\n                <mat-tab [label]=\"tab.tabName\">\n                    @for (row of tab.rows; track $index) {\n                        <div class=\"row\">\n                            @for (key of row.keys; track key) {\n                                <ngx-mat-entity-input\n                                    [entity]=\"context.entity\"\n                                    [propertyKey]=\"key\"\n                                    [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                                    [validEmpty]=\"context.validEmpty?.()\"\n                                    [isReadOnly]=\"context.isReadOnly?.(context.entity, key)\"\n                                    [class]=\"EntityUtilities.getWidthClasses(context.entity, key)\"\n                                    [hideOmitForEdit]=\"context.hideOmitForEdit\"\n                                    [hideOmitForCreate]=\"context.hideOmitForCreate\"\n                                    (inputChangeEvent)=\"context.inputChangeEvent()\"\n                                >\n                                </ngx-mat-entity-input>\n                            }\n                        </div>\n                    }\n                </mat-tab>\n            }\n        </mat-tab-group>\n    }\n    @else {\n        @if (!context.tabs.length) {\n            <span class=\"no-entity-tabs\">\n                ERROR: No Inputs. Did you correctly assign all values in the model constructor?\n            </span>\n        }\n        @else {\n            @for (row of context.tabs[0].rows; track $index) {\n                <div class=\"row\">\n                    @for (key of row.keys; track key) {\n                        <ngx-mat-entity-input\n                            [entity]=\"context.entity\"\n                            [propertyKey]=\"key\"\n                            [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                            [validEmpty]=\"context.validEmpty?.()\"\n                            [isReadOnly]=\"context.isReadOnly?.(context.entity, key)\"\n                            [class]=\"EntityUtilities.getWidthClasses(context.entity, key)\"\n                            [hideOmitForEdit]=\"context.hideOmitForEdit\"\n                            [hideOmitForCreate]=\"context.hideOmitForCreate\"\n                            (inputChangeEvent)=\"context.inputChangeEvent()\"\n                        >\n                        </ngx-mat-entity-input>\n                    }\n                </div>\n            }\n        }\n    }\n</ng-template>\n\n<!--------------------------------------------------------->\n<!--------------------Add Array Item Dialog---------------->\n<!--------------------------------------------------------->\n<ng-template #addArrayItemDialog>\n    <div class=\"mat-dialog-title\">\n        <div>{{addArrayItemDialogData.title}}</div>\n    </div>\n\n    <form>\n        <mat-dialog-content>\n            @if (addArrayItemFormContext) {\n                <ng-container *ngTemplateOutlet=\"form; context: addArrayItemFormContext\"></ng-container>\n            }\n        </mat-dialog-content>\n    \n        <mat-dialog-actions>\n            <div class=\"d-flex align-items-center gap-3\" style=\"margin-top: 10px;\">\n                <button type=\"submit\" mat-raised-button matBadgeColor=\"warn\"\n                    [disabled]=\"!isArrayItemValid\"\n                    [matBadge]=\"arrayItemValidationErrors.length\"\n                    [matBadgeHidden]=\"!arrayItemValidationErrors.length\"\n                    (click)=\"addArrayItem()\"\n                >\n                    {{addArrayItemDialogData.createButtonLabel}}\n                </button>\n                @if (arrayItemValidationErrors.length) {\n                    <ngx-mat-entity-tooltip [tooltipContent]=\"arrayItemTooltipContent\"></ngx-mat-entity-tooltip>\n                }\n            </div>\n            <button type=\"button\" mat-raised-button class=\"cancel-button\" (click)=\"closeAddArrayItemDialog()\">\n                {{addArrayItemDialogData.cancelButtonLabel}}\n            </button>\n        </mat-dialog-actions>\n    </form>\n\n</ng-template>\n\n<!--------------------------------------------------------->\n<!--------------------Edit Array Item Dialog---------------->\n<!--------------------------------------------------------->\n<ng-template #editArrayItemDialog>\n    <div class=\"mat-dialog-title\">\n        <div>{{editArrayItemDialogData.title(arrayItemPriorChanges)}}</div>\n    </div>\n    \n    <form>\n        <mat-dialog-content>\n            @if (editArrayItemFormContext) {\n                <ng-container *ngTemplateOutlet=\"form; context: editArrayItemFormContext\"></ng-container>\n            }\n        </mat-dialog-content>\n        \n        <mat-dialog-actions>\n            <div class=\"d-flex align-items-center gap-3\" style=\"margin-top: 10px;\">\n                <button type=\"submit\" mat-raised-button matBadgeColor=\"warn\"\n                    [disabled]=\"internalIsReadOnly || !isArrayItemValid || !isArrayItemDirty\"\n                    [matBadge]=\"arrayItemValidationErrors.length\"\n                    [matBadgeHidden]=\"!arrayItemValidationErrors.length\"\n                    (click)=\"saveArrayItem()\"\n                >\n                    {{editArrayItemDialogData.confirmButtonLabel}}\n                </button>\n                @if (arrayItemValidationErrors.length) {\n                    <ngx-mat-entity-tooltip [tooltipContent]=\"arrayItemTooltipContent\"></ngx-mat-entity-tooltip>\n                }\n            </div>\n            <button type=\"button\" mat-raised-button class=\"cancel-button\" (click)=\"closeEditArrayItemDialog()\">\n                {{editArrayItemDialogData.cancelButtonLabel}}\n            </button>\n        </mat-dialog-actions>\n    </form>\n</ng-template>\n\n<!--------------------------------------------------------->\n<!--------------------Create Has Many Dialog---------------->\n<!--------------------------------------------------------->\n<ng-template #createHasManyDialog>\n    <div class=\"mat-dialog-title\">\n        <div>{{metadataHasMany.tableData.createData.title}}</div>\n    </div>\n    \n    <form>\n        <mat-dialog-content>\n            @if (hasManyCreateFormContext) {\n                <ng-container *ngTemplateOutlet=\"form; context: hasManyCreateFormContext\"></ng-container>\n            }\n        </mat-dialog-content>\n        \n        <mat-dialog-actions>\n            <div class=\"d-flex align-items-center gap-3\" style=\"margin-top: 10px;\">\n                <button type=\"submit\" mat-raised-button matBadgeColor=\"warn\"\n                    [disabled]=\"!isHasManyEntityValid\"\n                    [matBadge]=\"hasManyValidationErrors.length\"\n                    [matBadgeHidden]=\"!hasManyValidationErrors.length\"\n                    (click)=\"dialogCreateHasMany()\"\n                >\n                    {{metadataHasMany.tableData.createData.createButtonLabel}}\n                </button>\n                @if (hasManyValidationErrors.length) {\n                    <ngx-mat-entity-tooltip [tooltipContent]=\"hasManyTooltipContent\"></ngx-mat-entity-tooltip>\n                }\n            </div>\n            <button type=\"button\" mat-raised-button class=\"cancel-button\" (click)=\"dialogCancelCreateHasMany()\">\n                {{metadataHasMany.tableData.createData.cancelButtonLabel}}\n            </button>\n        </mat-dialog-actions>\n    </form>\n    \n</ng-template>\n\n<!--------------------------------------------------------->\n<!--------------------Edit Has Many Dialog----------------->\n<!--------------------------------------------------------->\n<ng-template #editHasManyDialog>\n    <div class=\"mat-dialog-title\">\n        <div>{{metadataHasMany.tableData.editData.title(hasManyEntityPriorChanges)}}</div>\n\n        <div class=\"actions-container\">\n            @if (metadataHasMany.tableData.editData.actions.length) {\n                <button type=\"button\" mat-raised-button [matMenuTriggerFor]=\"menu\">\n                    {{metadataHasMany.tableData.editData.actionsLabel}}\n                </button>\n            }\n            <mat-menu #menu=\"matMenu\">\n                @for (action of metadataHasMany.tableData.editData.actions; track $index) {\n                    <button type=\"button\" mat-menu-item [disabled]=\"hasManyEditActionDisabled(action)\" (click)=\"hasManyRunEditAction(action)\">\n                        {{action.displayName}}\n                    </button>\n                }\n            </mat-menu>\n        \n            @if (hasManyAllowDelete(hasManyEntity)) {\n                <button type=\"button\" mat-raised-button color=\"warn\" class=\"delete-button\" tabindex=\"-1\" (click)=\"deleteHasManyEntity()\">\n                    {{metadataHasMany.tableData.editData.deleteButtonLabel}}\n                </button>\n            }\n        </div>\n    </div>\n    \n    <form>\n        <mat-dialog-content>\n            @if (hasManyEditFormContext) {\n                <ng-container *ngTemplateOutlet=\"form; context: hasManyEditFormContext\"></ng-container>\n            }\n        </mat-dialog-content>\n        \n        <mat-dialog-actions>\n            <div class=\"d-flex align-items-center gap-3\" style=\"margin-top: 10px;\">\n                <button type=\"submit\" mat-raised-button matBadgeColor=\"warn\"\n                    [disabled]=\"internalIsReadOnly || !isHasManyEntityValid || !isHasManyEntityDirty\"\n                    [matBadge]=\"hasManyValidationErrors.length\"\n                    [matBadgeHidden]=\"!hasManyValidationErrors.length\"\n                    (click)=\"dialogEditHasMany()\"\n                >\n                    {{metadataHasMany.tableData.editData.confirmButtonLabel}}\n                </button>\n                @if (hasManyValidationErrors.length) {\n                    <ngx-mat-entity-tooltip [tooltipContent]=\"hasManyTooltipContent\"></ngx-mat-entity-tooltip>\n                }\n            </div>\n            <button type=\"button\" mat-raised-button class=\"cancel-button\" (click)=\"dialogCancelEditHasMany()\">\n                {{metadataHasMany.tableData.editData.cancelButtonLabel}}\n            </button>\n        </mat-dialog-actions>\n    </form>\n</ng-template>"]}
|
|
1306
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-material-entity/src/components/input/input.component.ts","../../../../../projects/ngx-material-entity/src/components/input/input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { SelectionModel } from '@angular/cdk/collections';\nimport { CommonModule } from '@angular/common';\nimport { HttpClient } from '@angular/common/http';\nimport { Component, EnvironmentInjector, EventEmitter, Inject, Input, OnInit, Output, TemplateRef, ViewChild, inject, runInInjectionContext } from '@angular/core';\nimport { FormsModule, NgModel } from '@angular/forms';\nimport { MatBadgeModule } from '@angular/material/badge';\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 { MatPaginatorModule } from '@angular/material/paginator';\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\nimport { MatSelectModule } from '@angular/material/select';\nimport { MatSort, MatSortModule } from '@angular/material/sort';\nimport { MatTableDataSource, MatTableModule } from '@angular/material/table';\nimport { MatTabsModule } from '@angular/material/tabs';\nimport { Router } from '@angular/router';\nimport { FaIconComponent, IconDefinition } from '@fortawesome/angular-fontawesome';\nimport { faSearch } from '@fortawesome/free-solid-svg-icons';\nimport { firstValueFrom } from 'rxjs';\n\nimport { ArrayDateInputComponent } from './array/array-date-input/array-date-input.component';\nimport { ArrayDateRangeInputComponent } from './array/array-date-range-input/array-date-range-input.component';\nimport { ArrayDateTimeInputComponent } from './array/array-date-time-input/array-date-time-input.component';\nimport { ArrayStringAutocompleteChipsComponent } from './array/array-string-autocomplete-chips/array-string-autocomplete-chips.component';\nimport { ArrayStringChipsInputComponent } from './array/array-string-chips-input/array-string-chips-input.component';\nimport { BooleanCheckboxInputComponent } from './boolean/boolean-checkbox-input/boolean-checkbox-input.component';\nimport { BooleanDropdownInputComponent } from './boolean/boolean-dropdown-input/boolean-dropdown-input.component';\nimport { BooleanToggleInputComponent } from './boolean/boolean-toggle-input/boolean-toggle-input.component';\nimport { CustomInputComponent } from './custom/custom.component';\nimport { DateInputComponent } from './date/date-input/date-input.component';\nimport { DateRangeInputComponent } from './date/date-range-input/date-range-input.component';\nimport { DateTimeInputComponent } from './date/date-time-input/date-time-input.component';\nimport { FileDefaultInputComponent } from './file/file-default-input/file-default-input.component';\nimport { FileImageInputComponent } from './file/file-image-input/file-image-input.component';\nimport { NumberDropdownInputComponent } from './number/number-dropdown-input/number-dropdown-input.component';\nimport { NumberInputComponent } from './number/number-input/number-input.component';\nimport { NumberSliderInputComponent } from './number/number-slider-input/number-slider-input.component';\nimport { ReferencesManyInputComponent } from './relations/references-many-input/references-many-input.component';\nimport { StringAutocompleteInputComponent } from './string/string-autocomplete-input/string-autocomplete-input.component';\nimport { StringDropdownInputComponent } from './string/string-dropdown-input/string-dropdown-input.component';\nimport { StringInputComponent } from './string/string-input/string-input.component';\nimport { StringPasswordInputComponent } from './string/string-password-input/string-password-input.component';\nimport { StringTextboxInputComponent } from './string/string-textbox-input/string-textbox-input.component';\nimport { BaseEntityType } from '../../classes/entity.model';\nimport { EditArrayItemDialogDataInternal, EntityArrayDecoratorConfigInternal } from '../../decorators/array/array-decorator-internal.data';\nimport { DecoratorTypes } from '../../decorators/base/decorator-types.enum';\nimport { DropdownValue } from '../../decorators/base/dropdown-value.interface';\nimport { PropertyDecoratorConfigInternal } from '../../decorators/base/property-decorator-internal.data';\nimport { HasManyDecoratorConfigInternal } from '../../decorators/has-many/has-many-decorator-internal.data';\nimport { DefaultObjectDecoratorConfigInternal, DropdownObjectDecoratorConfigInternal } from '../../decorators/object/object-decorator-internal.data';\nimport { ReferencesOneDecoratorConfigInternal } from '../../decorators/references-one/references-one-decorator-internal.data';\nimport { DynamicStyleClassDirective } from '../../directives/dynamic-style-class.directive';\nimport { LodashUtilities } from '../../encapsulation/lodash.utilities';\nimport { ReflectUtilities } from '../../encapsulation/reflect.utilities';\nimport { UUIDUtilities } from '../../encapsulation/uuid.utilities';\nimport { defaultFalse } from '../../functions/default-false.function';\nimport { getChangesTooltipContent } from '../../functions/get-changes-tooltip-content.function';\nimport { NGX_GET_VALIDATION_ERROR_MESSAGE } from '../../functions/get-validation-error-message.function';\nimport { getValidationErrorsTooltipContent } from '../../functions/get-validation-errors-tooltip-content.function';\nimport { tableColumnValueToSortValue } from '../../functions/table-column-value-to-sort-value.function';\nimport { NGX_COMPLETE_GLOBAL_DEFAULT_VALUES, NgxGlobalDefaultValues } from '../../global-configuration-values';\nimport { EntityService } from '../../services/entity.service';\nimport { DateUtilities } from '../../utilities/date.utilities';\nimport { Difference, EntityTab, EntityUtilities } from '../../utilities/entity.utilities';\nimport { SelectionUtilities } from '../../utilities/selection.utilities';\nimport { ValidationError, ValidationUtilities } from '../../utilities/validation.utilities';\nimport { ConfirmDialogDataBuilder, ConfirmDialogDataInternal } from '../confirm-dialog/confirm-dialog-data.builder';\nimport { NgxMatEntityConfirmDialogComponent } from '../confirm-dialog/confirm-dialog.component';\nimport { InternalCustomTableConfiguration } from '../custom-table/custom-table-configuration.model';\nimport { CreateDataBuilder, CreateDataInternal } from '../table/create-dialog/create-data.builder';\nimport { DisplayColumnValueComponent } from '../table/display-column-value/display-column-value.component';\nimport { EditActionInternal } from '../table/edit-dialog/edit-data.builder';\nimport { DisplayColumn, DynamicStyleClasses } from '../table/table-data';\nimport { BaseTableActionInternal, TableActionInternal } from '../table/table-data.builder';\nimport { TooltipComponent } from '../tooltip/tooltip.component';\n\n/**\n * Generic type for contexts that can fill an inline template.\n */\ntype TemplateContext<T> = {\n    /**\n     * The actual value. The $implicit is needed so that we don't need to specify a key when writing \"let-context\" in the html template.\n     */\n    $implicit: T\n};\n\n/**\n * A form context that is used to fill an inline template.\n * This is used to go around the limitations of having everything in the same file due to circular dependencies.\n * The forms are used for object, hasMany, referencesMany and the dialogs.\n */\ntype FormContext<EntityType extends BaseEntityType<EntityType>> = {\n    /**\n     * The entity to build the form for.\n     */\n    entity: EntityType,\n    /**\n     * The tabs to display.\n     */\n    tabs: EntityTab<EntityType>[],\n    /**\n     * Whether or not edit values should be omitted.\n     */\n    hideOmitForEdit?: boolean,\n    /**\n     * Whether or not create values should be omitted.\n     */\n    hideOmitForCreate?: boolean,\n    /**\n     * What happens when the input changes.\n     */\n    inputChangeEvent: () => void | Promise<void>,\n    /**\n     * Whether or not the input is readonly.\n     */\n    isReadOnly?: (property: EntityType, key: keyof EntityType) => boolean,\n    /**\n     * Whether or not the input is valid empty.\n     */\n    validEmpty?: () => boolean\n};\n\n/**\n * A table context that is used to fill an inline template.\n * This is used to go around the limitations of having everything in the same file due to circular dependencies.\n * The table is used for entity array and hasMany.\n */\ntype TableContext<T> = InternalCustomTableConfiguration & {\n    /**\n     * The data source of the table.\n     */\n    dataSource: MatTableDataSource<T>,\n    /**\n     * Whether or not a error message should be shown when the table is empty.\n     */\n    shouldShowMissingError: boolean,\n    /**\n     * The selection of the table.\n     */\n    selection: SelectionModel<T>,\n    /**\n     * What happens when a cell is clicked.\n     */\n    clickCell: (value: T, displayColumn: DisplayColumn<T>) => void,\n    /**\n     * Whether or not the data for the table is currently being loaded.\n     */\n    isLoading: boolean,\n    /**\n     * All columns that should be displayed.\n     */\n    displayedColumns: string[]\n};\n\n/**\n * The default input component. It gets the metadata of the property from the given @Input \"entity\" and @Input \"propertyKey\"\n * and displays the input field accordingly.\n *\n * You can also define a method that generates error-messages and if the input should be hidden when its metadata says\n * that it should be omitted for creating or updating.\n * The last part being mostly relevant if you want to use this component inside an ngFor.\n */\n@Component({\n    selector: 'ngx-mat-entity-input',\n    templateUrl: './input.component.html',\n    styleUrls: ['./input.component.scss', '../../scss/dialog-styles.scss', '../../scss/tailwind-classes.scss'],\n    standalone: true,\n    imports: [\n        DisplayColumnValueComponent,\n        CommonModule,\n        MatTabsModule,\n        MatFormFieldModule,\n        MatSelectModule,\n        FormsModule,\n        MatDialogModule,\n        MatBadgeModule,\n        MatInputModule,\n        MatMenuModule,\n        MatPaginatorModule,\n        MatProgressSpinnerModule,\n        MatTableModule,\n        MatCheckboxModule,\n        MatButtonModule,\n        TooltipComponent,\n        StringInputComponent,\n        StringTextboxInputComponent,\n        StringAutocompleteInputComponent,\n        StringDropdownInputComponent,\n        StringPasswordInputComponent,\n        BooleanCheckboxInputComponent,\n        BooleanToggleInputComponent,\n        BooleanDropdownInputComponent,\n        NumberInputComponent,\n        NumberDropdownInputComponent,\n        NumberSliderInputComponent,\n        ArrayDateInputComponent,\n        ArrayDateRangeInputComponent,\n        ArrayDateTimeInputComponent,\n        ArrayStringAutocompleteChipsComponent,\n        ArrayStringChipsInputComponent,\n        DateInputComponent,\n        DateRangeInputComponent,\n        DateTimeInputComponent,\n        FileDefaultInputComponent,\n        FileImageInputComponent,\n        ReferencesManyInputComponent,\n        CustomInputComponent,\n        DynamicStyleClassDirective,\n        MatSortModule,\n        FaIconComponent\n    ]\n})\nexport class NgxMatEntityInputComponent<EntityType extends BaseEntityType<EntityType>> implements OnInit {\n\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    faSearch: IconDefinition = faSearch;\n\n    /**\n     * The entity on which the property exists. Used in conjunction with the \"propertyKey\"\n     * to determine the property for which the input should be generated.\n     */\n    @Input({ required: true })\n    entity!: EntityType;\n\n    /**\n     * The name of the property to generate the input for. Used in conjunction with the \"entity\".\n     */\n    @Input({ required: true })\n    propertyKey!: keyof EntityType;\n\n    /**\n     * (optional) A custom function to generate the error-message for invalid inputs.\n     */\n    @Input()\n    getValidationErrorMessage?: (model: NgModel) => string;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    internalGetValidationErrorMessage!: (model: NgModel) => string;\n\n    /**\n     * Whether to hide a value if it is omitted for creation.\n     * Is used internally for the object property.\n     * @default false\n     */\n    @Input()\n    hideOmitForCreate?: boolean;\n\n    /**\n     * Whether to hide a value if it is omitted for editing.\n     * Is used internally for the object property.\n     * @default false\n     */\n    @Input()\n    hideOmitForEdit?: boolean;\n\n    /**\n     * Whether or not an empty value should be valid.\n     * Is used internally for the object property.\n     * @default undefined\n     */\n    @Input()\n    validEmpty?: boolean; // TODO\n\n    /**\n     * Whether or not the input should be readonly.\n     * In that case it is disabled, but most of the default styling is overwritten.\n     * @default false\n     */\n    @Input()\n    isReadOnly?: boolean;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    internalIsReadOnly!: boolean;\n\n    /**\n     * Emits when the input value has been changed.\n     */\n    @Output()\n    readonly inputChangeEvent: EventEmitter<void> = new EventEmitter<void>();\n\n    /**\n     * A setter for the has many sort.\n     * Is needed because the sort is inside a switch case,\n     * which means that at ngOnInit it can't be initialized.\n     */\n    @ViewChild(MatSort)\n    private set sort(sort: MatSort) {\n        // eslint-disable-next-line typescript/strict-boolean-expressions\n        if (this.hasManyTableContext) {\n            this.hasManyTableContext.$implicit.dataSource.sort = this.hasManyTableContext.$implicit.dataSource.sort ?? sort;\n        }\n        // eslint-disable-next-line typescript/strict-boolean-expressions\n        if (this.entityArrayTableContext) {\n            this.entityArrayTableContext.$implicit.dataSource.sort = this.entityArrayTableContext.$implicit.dataSource.sort ?? sort;\n        }\n    }\n\n    /**\n     * The type of the decorator for this input.\n     */\n    type!: DecoratorTypes;\n    /**\n     * The property metadata received from the decorator.\n     */\n    metadata!: PropertyDecoratorConfigInternal<unknown>;\n\n    /**\n     * The metadata of an object property.\n     */\n    metadataDefaultObject!: DefaultObjectDecoratorConfigInternal<EntityType>;\n    /**\n     * The form context for an object property.\n     */\n    objectFormContext!: TemplateContext<FormContext<EntityType>>;\n\n    /**\n     * The metadata of an dropdown object property.\n     */\n    metadataDropdownObject!: DropdownObjectDecoratorConfigInternal<EntityType>;\n    /**\n     * All possible dropdown values for the object property.\n     */\n    private objectDropdownValues: DropdownValue<EntityType | undefined>[] = [];\n    /**\n     * A unique input name for the references one property.\n     */\n    objectDropdownName!: string;\n    /**\n     * All currently shown dropdown values for the object property.\n     */\n    filteredObjectDropdownValues: DropdownValue<EntityType | undefined>[] = [];\n    // eslint-disable-next-line jsdoc/require-returns\n    /**\n     * The currently selected object as a drop down value.\n     */\n    get currentObjectDropdownValue(): DropdownValue<EntityType | undefined> | undefined {\n        const value: DropdownValue<EntityType | undefined>[] = LodashUtilities.cloneDeep(this.objectDropdownValues ?? []);\n        return value.find(v => LodashUtilities.isEqual(v.value, this.entity[this.propertyKey]));\n    }\n    // eslint-disable-next-line jsdoc/require-returns\n    /**\n     * Whether or not the current object dropdown value should be shown in the dropdown.\n     */\n    get shouldDisplayCurrentObjectDropdownValue(): boolean {\n        return !!this.currentObjectDropdownValue\n            && !this.filteredObjectDropdownValues.find(v => LodashUtilities.isEqual(v.value, this.currentObjectDropdownValue?.value));\n    }\n    /**\n     * A compareWith method for the select.\n     * Uses bind.\n     */\n    compareObjectsBound: (value1?: EntityType, value2?: EntityType) => boolean = this.compareObjects.bind(this);\n\n    @ViewChild('addArrayItemDialog')\n    private readonly addArrayItemDialog!: TemplateRef<unknown>;\n    private addArrayItemDialogRef!: MatDialogRef<unknown>;\n    @ViewChild('editArrayItemDialog')\n    private readonly editArrayItemDialog!: TemplateRef<unknown>;\n    private editArrayItemDialogRef!: MatDialogRef<unknown>;\n    /**\n     * The metadata of an entity array property.\n     */\n    metadataEntityArray!: EntityArrayDecoratorConfigInternal<EntityType>;\n    /**\n     * The table context for the entity array input.\n     */\n    entityArrayTableContext!: TemplateContext<TableContext<EntityType>>;\n    /**\n     * The current array item to be added or updated.\n     */\n    arrayItem!: EntityType;\n    /**\n     * The array item before any changes have been made. Used to check if the form is dirty.\n     */\n    arrayItemPriorChanges!: EntityType;\n    /**\n     * The form context for adding an array item.\n     */\n    addArrayItemFormContext!: TemplateContext<FormContext<EntityType>>;\n    /**\n     * The form context for editing an array item.\n     */\n    editArrayItemFormContext!: TemplateContext<FormContext<EntityType>>;\n    /**\n     * Whether or not the array item is valid.\n     */\n    isArrayItemValid: boolean = false;\n    /**\n     * Whether or not the array item is dirty.\n     */\n    isArrayItemDirty: boolean = false;\n    /**\n     * The index of the array item that is being edited.\n     */\n    private indexOfEditedArrayItem!: number;\n    /**\n     * Config for the dialog that adds a new array item.\n     */\n    addArrayItemDialogData!: CreateDataInternal;\n    /**\n     * The tabs to display inside the edit array item dialog.\n     */\n    editArrayItemDialogData!: EditArrayItemDialogDataInternal<EntityType>;\n    /**\n     * All validation errors for the array item.\n     */\n    arrayItemValidationErrors: ValidationError[] = [];\n    /**\n     * All the changes that have been done to the array item.\n     */\n    arrayItemChanges: Difference<EntityType>[] = [];\n    /**\n     * What to display inside the array item tooltip.\n     */\n    arrayItemTooltipContent: string = '';\n\n    /**\n     * Metadata of a has many property.\n     */\n    metadataHasMany!: HasManyDecoratorConfigInternal<EntityType, EntityType>;\n    /**\n     * The table context for the has many input.\n     */\n    hasManyTableContext!: TemplateContext<TableContext<EntityType>>;\n    /**\n     * The has many import action.\n     */\n    hasManyImportAction!: BaseTableActionInternal;\n    private hasManyEntityService!: EntityService<EntityType>;\n    @ViewChild('createHasManyDialog')\n    private readonly createHasManyDialog!: TemplateRef<unknown>;\n    private createHasManyDialogRef!: MatDialogRef<unknown>;\n    @ViewChild('editHasManyDialog')\n    private readonly editHasManyDialog!: TemplateRef<unknown>;\n    private editHasManyDialogRef!: MatDialogRef<unknown>;\n    /**\n     * A single has many entity.\n     */\n    hasManyEntity!: EntityType;\n    /**\n     * The single has many entity before any changes have been made. Is used to determine if the form is dirty.\n     */\n    hasManyEntityPriorChanges!: EntityType;\n    /**\n     * Whether or not the has many entity is valid.\n     */\n    isHasManyEntityValid: boolean = false;\n    /**\n     * All validation errors of the has many entity.\n     */\n    hasManyValidationErrors: ValidationError[] = [];\n    /**\n     * All the changes that have been done to the has many entity.\n     */\n    hasManyChanges: Difference<EntityType>[] = [];\n    /**\n     * What to display inside the has many tooltip.\n     */\n    hasManyTooltipContent: string = '';\n    /**\n     * Whether or not the has many entity is dirty.\n     */\n    isHasManyEntityDirty: boolean = false;\n    /**\n     * Whether or not the current user is allowed to create a has many entity.\n     */\n    hasManyAllowCreate!: boolean;\n    /**\n     * The form context for creating an has many entity.\n     */\n    hasManyCreateFormContext!: TemplateContext<FormContext<EntityType>>;\n    /**\n     * The form context for editing an has many entity.\n     */\n    hasManyEditFormContext!: TemplateContext<FormContext<EntityType>>;\n    private hasManyCreateBaseUrl!: string;\n\n    /**\n     * The metadata for a references one property.\n     */\n    metadataReferencesOne!: ReferencesOneDecoratorConfigInternal<EntityType>;\n    /**\n     * The values that can be possibly referenced.\n     */\n    private referencesOneAllReferencedEntities!: EntityType[];\n    /**\n     * The possible references one dropdown values.\n     */\n    private referencesOneDropdownValues!: DropdownValue<string>[];\n    /**\n     * The filtered dropdown values that get displayed in the references one dropdown input.\n     */\n    filteredReferencesOneDropdownValues!: DropdownValue<string>[];\n    /**\n     * A unique input name for the references one property.\n     */\n    referencesOneName!: string;\n    /**\n     * The form context for an object property.\n     */\n    referencesOneFormContext!: TemplateContext<FormContext<EntityType>>;\n\n    /**\n     * The enum Values for all the different DecoratorTypes.\n     */\n    readonly DecoratorTypes: typeof DecoratorTypes = DecoratorTypes;\n    /**\n     * Contains HelperMethods around handling Entities and their property-metadata.\n     */\n    EntityUtilities: typeof EntityUtilities = EntityUtilities;\n    /**\n     * Contains Helper Functions for handling date properties.\n     */\n    DateUtilities: typeof DateUtilities = DateUtilities;\n    /**\n     * Provides functionality around material selections inside of tables.\n     */\n    SelectionUtilities: typeof SelectionUtilities = SelectionUtilities;\n\n    // eslint-disable-next-line jsdoc/require-returns\n    /**\n     * Gets the currently selected dropdown value for references one.\n     * Is needed so that the dropdown value will still be displayed,\n     * even when the filter method removes the value from the selectable dropdown values.\n     */\n    get currentReferencesOneDropdownValue(): DropdownValue<string> | undefined {\n        return LodashUtilities.cloneDeep(this.referencesOneDropdownValues ?? [])\n            .find(v => v.value === this.entity[this.propertyKey]);\n    }\n\n    // eslint-disable-next-line jsdoc/require-returns\n    /**\n     * Whether or not the currently selected references one value should be shown,\n     * although it would have been filtered out by the search.\n     */\n    get shouldDisplayCurrentReferencesOneDropdownValue(): boolean {\n        return !!this.currentReferencesOneDropdownValue\n            && !this.filteredReferencesOneDropdownValues.find(v => v.value === this.currentReferencesOneDropdownValue?.value);\n    }\n\n    constructor(\n        private readonly dialog: MatDialog,\n        private readonly injector: EnvironmentInjector,\n        private readonly router: Router,\n        @Inject(NGX_GET_VALIDATION_ERROR_MESSAGE)\n        protected readonly defaultGetValidationErrorMessage: (model: NgModel) => string,\n        @Inject(NGX_COMPLETE_GLOBAL_DEFAULT_VALUES)\n        protected readonly globalConfig: NgxGlobalDefaultValues,\n        private readonly http: HttpClient\n    ) {}\n\n    /**\n     * Checks if the input with the given key on the given property is readonly.\n     * @param property - The property on which to check the input.\n     * @param key - The key for the input to check.\n     * @returns Whether or not the input is readonly.\n     */\n    isPropertyReadOnly(property: EntityType, key: keyof EntityType): boolean {\n        return runInInjectionContext(this.injector, () => {\n            if (this.internalIsReadOnly || this.metadataDefaultObject?.isReadOnly(property)) {\n                return true;\n            }\n            const metadata: PropertyDecoratorConfigInternal<unknown> | undefined = EntityUtilities.getPropertyMetadata(property, key);\n            if (!metadata) {\n                throw new Error(`No metadata was found for the key \"${String(key)}\"`);\n            }\n            return metadata.isReadOnly(property);\n        });\n    }\n\n    /**\n     * Gets the value to display in the column.\n     * Runs in environment context to enable injection.\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 runInInjectionContext(this.injector, () => displayColumn.value(entity));\n    }\n\n    /**\n     * Emits a cellClicked event when the clicked column is enabled and clicking is allowed by the configuration.\n     * @param value - The value of the row that was clicked.\n     * @param dCol - The display column of the row that was clicked.\n     * @param context - The context of the table where the cell was clicked.\n     */\n    clickCell<T>(value: T, dCol: DisplayColumn<T>, context: TableContext<T>): void {\n        if (dCol.disableClick == true || !context.allowClick(value)) {\n            return;\n        }\n        context.clickCell(value, dCol);\n    }\n\n    ngOnInit(): void {\n        this.internalGetValidationErrorMessage = this.getValidationErrorMessage ?? this.defaultGetValidationErrorMessage;\n        this.internalIsReadOnly = this.isReadOnly ?? false;\n\n        const foundType: DecoratorTypes | undefined = EntityUtilities.getPropertyType(this.entity, this.propertyKey);\n        if (foundType == undefined) {\n            throw new Error(`No type was found for the key \"${String(this.propertyKey)}\"`);\n        }\n        this.type = foundType;\n        if (this.validEmpty === true) {\n            const currentMetadata: PropertyDecoratorConfigInternal<unknown> = ReflectUtilities.getMetadata(\n                'metadata',\n                this.entity,\n                this.propertyKey\n            ) as PropertyDecoratorConfigInternal<unknown>;\n            ReflectUtilities.defineMetadata('metadata', { ...currentMetadata, required: defaultFalse }, this.entity, this.propertyKey);\n        }\n\n        const foundMetadata: PropertyDecoratorConfigInternal<unknown> | undefined = EntityUtilities.getPropertyMetadata(\n            this.entity,\n            this.propertyKey,\n            this.type\n        );\n        if (!foundMetadata) {\n            throw new Error(`No metadata was found for the key \"${String(this.propertyKey)}\"`);\n        }\n        this.metadata = foundMetadata;\n\n        switch (this.type) {\n            case DecoratorTypes.OBJECT_DROPDOWN: {\n                void this.initDropdownObjectInput();\n                break;\n            }\n            case DecoratorTypes.OBJECT: {\n                this.initObjectInput();\n                break;\n            }\n            case DecoratorTypes.ARRAY: {\n                this.initEntityArray();\n                break;\n            }\n            case DecoratorTypes.HAS_MANY: {\n                this.initHasMany();\n                break;\n            }\n            case DecoratorTypes.REFERENCES_ONE: {\n                void this.initReferencesOne();\n                break;\n            }\n            default: {\n                break;\n            }\n        }\n    }\n\n    private async initReferencesOne(): Promise<void> {\n        this.metadataReferencesOne = this.metadata as ReferencesOneDecoratorConfigInternal<EntityType>;\n        this.referencesOneName = this.propertyKey.toString() + 'input' + UUIDUtilities.create();\n\n        await runInInjectionContext(\n            this.injector,\n            async () => {\n                this.referencesOneAllReferencedEntities = await this.metadataReferencesOne.getReferencedEntities();\n                this.referencesOneDropdownValues = this.metadataReferencesOne.getDropdownValues(\n                    LodashUtilities.cloneDeep(this.referencesOneAllReferencedEntities)\n                );\n                this.filteredReferencesOneDropdownValues = LodashUtilities.cloneDeep(this.referencesOneDropdownValues);\n                this.setReferencesOneObject();\n            }\n        );\n    }\n\n    /**\n     * Filters the references one dropdown values.\n     * @param searchInput - The search input to filter for.\n     */\n    filterReferencesOneValues(searchInput: string): void {\n        const filter: string = searchInput.toLowerCase();\n        this.filteredReferencesOneDropdownValues = LodashUtilities.cloneDeep(this.referencesOneDropdownValues).filter(option => {\n            return option.displayName.toLowerCase().includes(filter) || option.value.toLowerCase().includes(filter);\n        });\n    }\n\n    private initHasMany(): void {\n        this.metadata = new HasManyDecoratorConfigInternal(\n            this.metadata as HasManyDecoratorConfigInternal<EntityType, EntityType>,\n            this.globalConfig\n        );\n        ReflectUtilities.defineMetadata('metadata', this.metadata, this.entity, this.propertyKey);\n        this.metadataHasMany = this.metadata as HasManyDecoratorConfigInternal<EntityType, EntityType>;\n        this.hasManyImportAction = new BaseTableActionInternal({\n            ...this.metadataHasMany.tableData.baseData.importActionData,\n            action: () => this.startImportJson()\n        }, this.globalConfig);\n\n        runInInjectionContext(this.injector, () => {\n            this.hasManyAllowCreate = this.metadataHasMany.tableData.baseData.allowCreate();\n            this.hasManyEntityService = inject<EntityService<EntityType>>(this.metadataHasMany.tableData.baseData.EntityServiceClass);\n            this.hasManyCreateBaseUrl = this.metadataHasMany.createBaseUrl(this.entity, this.metadataHasMany);\n        });\n\n        const givenDisplayColumns: string[] = this.metadataHasMany.tableData.baseData.displayColumns.map((v) => v.displayName);\n        if (givenDisplayColumns.find(s => s === 'select')) {\n            throw new Error(\n                `The name \"select\" for a display column is reserved.\n                Please choose a different name.`\n            );\n        }\n        this.hasManyTableContext = {\n            $implicit: {\n                ...new InternalCustomTableConfiguration(\n                    this.globalConfig,\n                    {\n                        displayColumns: this.metadataHasMany.tableData.baseData.displayColumns as DisplayColumn<unknown>[],\n                        withSelection: !this.internalIsReadOnly,\n                        // eslint-disable-next-line stylistic/max-len\n                        dynamicRowStyleClasses: this.metadataHasMany.tableData.baseData.dynamicRowStyleClasses as DynamicStyleClasses<unknown>,\n                        allowClick: ((entity: EntityType) => {\n                            return this.metadataHasMany.tableData.baseData.allowRead(entity)\n                                || this.metadataHasMany.tableData.baseData.allowUpdate(entity);\n                        }) as (value: unknown) => boolean,\n                        displayLoadingSpinner: this.metadataHasMany.tableData.baseData.displayLoadingSpinner,\n                        searchStringForRow: this.metadataHasMany.tableData.baseData.searchString as (value: unknown) => string\n                    }\n                ),\n                displayedColumns: !this.metadataHasMany.tableData.baseData.tableActions.filter(tA => tA.type === 'multi-select').length\n                    ? givenDisplayColumns\n                    : ['select'].concat(givenDisplayColumns),\n                dataSource: new MatTableDataSource(),\n                isLoading: true,\n                shouldShowMissingError: false,\n                selection: new SelectionModel<EntityType>(true, []),\n                clickCell: (entity, dCol) => this.editHasManyEntity(entity, dCol)\n            }\n        };\n\n        this.hasManyTableContext.$implicit.dataSource.sortingDataAccessor = (entity: EntityType, header: string) => {\n            return runInInjectionContext(this.injector, () => {\n                const displayColumn: DisplayColumn<EntityType> = this.metadataHasMany.tableData.baseData.displayColumns\n                    .find((dp) => dp.displayName === header) as DisplayColumn<EntityType>;\n                return tableColumnValueToSortValue(displayColumn.value(entity));\n            });\n        };\n        this.hasManyTableContext.$implicit.dataSource.filterPredicate = (entity: EntityType, filter: string) => {\n            const searchStr: string = this.metadataHasMany.tableData.baseData.searchString(entity);\n            const formattedSearchString: string = searchStr.toLowerCase();\n            const formattedFilterString: string = filter.toLowerCase();\n            return formattedSearchString.includes(formattedFilterString);\n        };\n\n        this.hasManyEntityService.entitiesSubject.subscribe((entities) => {\n            this.hasManyTableContext.$implicit.dataSource.data = entities;\n            this.hasManyTableContext.$implicit.selection.clear();\n        });\n        void runInInjectionContext(this.injector, async () => {\n            const readBaseUrl: string = this.metadataHasMany.readBaseUrl(this.entity, this.metadataHasMany);\n            await this.hasManyEntityService.read(readBaseUrl);\n            this.hasManyTableContext.$implicit.isLoading = false;\n        });\n    }\n\n    private initEntityArray(): void {\n        this.metadata = new EntityArrayDecoratorConfigInternal(\n            this.metadata as EntityArrayDecoratorConfigInternal<EntityType>,\n            this.globalConfig\n        );\n        ReflectUtilities.defineMetadata('metadata', this.metadata, this.entity, this.propertyKey);\n        this.metadataEntityArray = this.metadata as EntityArrayDecoratorConfigInternal<EntityType>;\n        if (this.entity[this.propertyKey] == undefined) {\n            (this.entity[this.propertyKey] as EntityType[]) = [];\n        }\n        if (!this.metadataEntityArray.createInline && !this.metadataEntityArray.createDialogData) {\n            this.metadataEntityArray.createDialogData = {\n                title: 'Add'\n            };\n        }\n        const givenDisplayColumns: string[] = this.metadataEntityArray.displayColumns.map((v) => v.displayName);\n        if (givenDisplayColumns.find(s => s === 'select')) {\n            throw new Error(\n                `The name \"select\" for a display column is reserved.\n                Please choose a different name.`\n            );\n        }\n        this.entityArrayTableContext = {\n            $implicit: {\n                ...new InternalCustomTableConfiguration(\n                    this.globalConfig,\n                    {\n                        displayColumns: this.metadataEntityArray.displayColumns as DisplayColumn<unknown>[],\n                        withSelection: !this.internalIsReadOnly,\n                        dynamicRowStyleClasses: this.metadataEntityArray.dynamicRowStyleClasses as DynamicStyleClasses<unknown>,\n                        emptyErrorMessage: this.metadataEntityArray.missingErrorMessage\n                    }\n                ),\n                displayedColumns: this.internalIsReadOnly ? givenDisplayColumns : ['select'].concat(givenDisplayColumns),\n                dataSource: new MatTableDataSource(),\n                isLoading: false,\n                shouldShowMissingError: true,\n                selection: new SelectionModel<EntityType>(true, []),\n                // eslint-disable-next-line typescript/no-misused-promises\n                clickCell: (entity, dCol) => this.editArrayItem(entity, dCol)\n            }\n        };\n        this.entityArrayTableContext.$implicit.dataSource.data = this.entity[this.propertyKey] as EntityType[];\n\n        this.arrayItem = new this.metadataEntityArray.EntityClass();\n        this.arrayItemPriorChanges = LodashUtilities.cloneDeep(this.arrayItem);\n        EntityUtilities.setDefaultValues(this.arrayItem);\n\n        this.addArrayItemFormContext = {\n            $implicit: {\n                entity: this.arrayItem,\n                tabs: EntityUtilities.getEntityTabs(this.arrayItem, this.injector, true),\n                inputChangeEvent: () => {\n                    void this.checkIsArrayItemValid();\n                    this.addArrayItemFormContext.$implicit.tabs = EntityUtilities.getEntityTabs(this.arrayItem, this.injector, true);\n                },\n                hideOmitForCreate: true\n            }\n        };\n        this.addArrayItemDialogData = new CreateDataBuilder(this.globalConfig, this.metadataEntityArray.createDialogData)\n            .withDefault('createButtonLabel', this.globalConfig.addLabel)\n            .withDefault('title', this.globalConfig.addArrayItemTitle)\n            .getResult();\n\n        this.editArrayItemFormContext = {\n            $implicit: {\n                entity: this.arrayItem,\n                tabs: EntityUtilities.getEntityTabs(this.arrayItem, this.injector, true),\n                isReadOnly: (property, key) => this.isPropertyReadOnly(property, key),\n                inputChangeEvent: () => {\n                    void this.checkArrayItem();\n                    this.editArrayItemFormContext.$implicit.tabs = EntityUtilities.getEntityTabs(this.arrayItem, this.injector, true);\n                },\n                hideOmitForEdit: true\n            }\n        };\n        this.editArrayItemDialogData = this.metadataEntityArray.editDialogData;\n    }\n\n    private async initDropdownObjectInput(): Promise<void> {\n        this.metadataDropdownObject = this.metadata as DropdownObjectDecoratorConfigInternal<EntityType>;\n        this.objectDropdownName = this.propertyKey.toString() + 'input' + UUIDUtilities.create();\n\n        await runInInjectionContext(this.injector, async () => {\n            this.objectDropdownValues = await this.metadataDropdownObject.dropdownValues(this.entity);\n            this.filteredObjectDropdownValues = LodashUtilities.cloneDeep(this.objectDropdownValues);\n        });\n    }\n\n    private initObjectInput(): void {\n        this.metadataDefaultObject = this.metadata as DefaultObjectDecoratorConfigInternal<EntityType>;\n        const objectProperty: EntityType = this.entity[this.propertyKey] as EntityType;\n        const objectPropertyTabs: EntityTab<EntityType>[] = EntityUtilities.getEntityTabs(\n            objectProperty,\n            this.injector,\n            this.hideOmitForCreate,\n            this.hideOmitForEdit,\n            this.metadataDefaultObject.omit\n        );\n        this.objectFormContext = {\n            $implicit: {\n                entity: objectProperty,\n                tabs: objectPropertyTabs,\n                hideOmitForCreate: this.hideOmitForCreate,\n                hideOmitForEdit: this.hideOmitForEdit,\n                isReadOnly: (property, key) => this.isPropertyReadOnly(property, key),\n                inputChangeEvent: () => this.emitChange(),\n                validEmpty: () => !this.metadata.required(this.entity)\n            }\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                await this.importJson(input.files[0]);\n            }\n        };\n        input.click();\n    }\n\n    private async importJson(file: File): Promise<void> {\n        // eslint-disable-next-line stylistic/max-len\n        const dialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(this.globalConfig, this.hasManyImportAction.confirmDialogData)\n            .withDefault('text', this.metadataHasMany.tableData.baseData.importActionData.confirmDialogData?.text)\n            .withDefault('title', this.hasManyImportAction.displayName)\n            .getResult();\n        const dialogRef: MatDialogRef<NgxMatEntityConfirmDialogComponent, boolean> = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        const res: boolean | undefined = await firstValueFrom(dialogRef.afterClosed());\n        if (res == true) {\n            await this.hasManyEntityService.import(file);\n        }\n    }\n\n    /**\n     * Checks if two objects are equal. Is needed for the dropdown.\n     * @param value1 - The first object to compare.\n     * @param value2 - The second object to compare.\n     * @returns Whether or not the objects are the same.\n     */\n    private compareObjects(value1?: EntityType, value2?: EntityType): boolean {\n        const valueObject1: EntityType = new this.metadataDropdownObject.EntityClass(value1);\n        const valueObject2: EntityType = new this.metadataDropdownObject.EntityClass(value2);\n        return LodashUtilities.isEqual(valueObject1, valueObject2);\n    }\n\n    /**\n     * Filters the dropdown values.\n     * @param searchInput - The search input to filter for.\n     */\n    filterObjectDropdownValues(searchInput: string): void {\n        const filter: string = searchInput.toLowerCase();\n        this.filteredObjectDropdownValues = LodashUtilities.cloneDeep(this.objectDropdownValues).filter(option => {\n            return option.displayName.toLowerCase().includes(filter) || JSON.stringify(option.value).toLowerCase()\n                .includes(filter);\n        });\n    }\n\n    /**\n     * Sets the references one object using the input id.\n     */\n    setReferencesOneObject(): void {\n        const foundEntity: EntityType | undefined = this.metadataReferencesOne.getEntityForId(\n            this.entity[this.propertyKey] as string,\n            this.referencesOneAllReferencedEntities\n        );\n        const referencesOneObject: EntityType = new this.metadataReferencesOne.EntityClass(foundEntity);\n        const referencesOnePropertyTabs: EntityTab<EntityType>[] = EntityUtilities.getEntityTabs(referencesOneObject, this.injector);\n\n        this.referencesOneFormContext = {\n            $implicit: {\n                entity: referencesOneObject,\n                tabs: referencesOnePropertyTabs,\n                hideOmitForCreate: this.hideOmitForCreate,\n                hideOmitForEdit: this.hideOmitForEdit,\n                isReadOnly: () => true,\n                inputChangeEvent: () => this.emitChange(),\n                validEmpty: () => !this.metadata.required(this.entity)\n            }\n        };\n\n        this.emitChange();\n    }\n\n    /**\n     * Edits an entity. This either calls the edit-Method provided by the user or uses a default edit-dialog.\n     * @param entity - The entity that should be updated.\n     * @param dCol - The display column that was clicked on.\n     * @throws When no EntityClass was provided, as a new call is needed to initialize metadata.\n     */\n    editHasManyEntity(entity: EntityType, dCol: DisplayColumn<EntityType>): void {\n        if ((dCol.disableClick === true) || (!this.hasManyAllowUpdate(entity) && !this.hasManyAllowRead(entity))) {\n            return;\n        }\n        if (!this.metadataHasMany.tableData.baseData.EntityClass) {\n            throw new Error('No \"EntityClass\" specified for this table');\n        }\n        if (this.metadataHasMany.tableData.baseData.edit) {\n            this.metadataHasMany.tableData.baseData.edit(new this.metadataHasMany.tableData.baseData.EntityClass(entity));\n            return;\n        }\n        if (this.metadataHasMany.tableData.baseData.defaultEdit == 'page') {\n            this.editHasManyDefaultPage(new this.metadataHasMany.tableData.baseData.EntityClass(entity));\n            return;\n        }\n        void this.editHasManyDefaultDialog(new this.metadataHasMany.tableData.baseData.EntityClass(entity));\n    }\n\n    /**\n     * Whether updating the provided entity from the has many property is allowed.\n     * @param entity - A single value of the has many property that the user wants to edit.\n     * @returns True when the user can edit the provided entity and false otherwise.\n     */\n    hasManyAllowUpdate(entity: EntityType): boolean {\n        return runInInjectionContext(this.injector, () => {\n            return this.metadataHasMany.tableData.baseData.allowUpdate(entity);\n        });\n    }\n\n    /**\n     * Whether viewing the provided entity from the has many property is allowed.\n     * @param entity - A single value of the has many property that the user wants to view.\n     * @returns True when the user can view the provided entity and false otherwise.\n     */\n    hasManyAllowRead(entity: EntityType): boolean {\n        return runInInjectionContext(this.injector, () => {\n            return this.metadataHasMany.tableData.baseData.allowRead(entity);\n        });\n    }\n\n    /**\n     * Whether deleting the provided entity from the has many property is allowed.\n     * @param entity - A single value of the has many property that the user wants to delete.\n     * @returns True when the user can delete the provided entity and false otherwise.\n     */\n    hasManyAllowDelete(entity: EntityType): boolean {\n        return runInInjectionContext(this.injector, () => {\n            return this.metadataHasMany.tableData.baseData.allowDelete(entity);\n        });\n    }\n\n    /**\n     * Checks if an EditAction is disabled (e.g. Because the current entry doesn't fullfil the requirements).\n     * @param action - The EditAction to check.\n     * @returns Whether or not the Action can be used.\n     */\n    hasManyEditActionDisabled(action: EditActionInternal<EntityType>): boolean {\n        return runInInjectionContext(this.injector, () => {\n            return !action.enabled(this.hasManyEntityPriorChanges);\n        });\n    }\n\n    /**\n     * Runs the edit action on the entity.\n     * @param action - The action to run.\n     */\n    async hasManyRunEditAction(action: EditActionInternal<EntityType>): Promise<void> {\n        const requireConfirmDialog: boolean = runInInjectionContext(this.injector, () => {\n            return action.requireConfirmDialog(this.hasManyEntityPriorChanges);\n        });\n\n        if (!requireConfirmDialog) {\n            await this.confirmHasManyRunEditAction(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        const res: boolean | undefined = await firstValueFrom(dialogRef.afterClosed());\n        if (res == true) {\n            await this.confirmHasManyRunEditAction(action);\n        }\n    }\n\n    private async confirmHasManyRunEditAction(action: EditActionInternal<EntityType>): Promise<void> {\n        await runInInjectionContext(this.injector, async () => {\n            await action.action(this.hasManyEntity, this.hasManyEntityPriorChanges);\n            await this.checkHasManyEntity();\n        });\n    }\n\n    private editHasManyDefaultPage(entity: EntityType): void {\n        void this.router.navigate(['', this.hasManyEntityService.editBaseRoute, entity[this.hasManyEntityService.idKey]]);\n    }\n\n    private async editHasManyDefaultDialog(entity: EntityType): Promise<void> {\n        this.hasManyEntity = LodashUtilities.cloneDeep(entity);\n        this.hasManyEntityPriorChanges = LodashUtilities.cloneDeep(this.hasManyEntity);\n        this.hasManyEditFormContext = {\n            $implicit: {\n                entity: this.hasManyEntity,\n                hideOmitForEdit: true,\n                isReadOnly: (property, key) => this.isPropertyReadOnly(property, key),\n                inputChangeEvent: () => {\n                    void this.checkHasManyEntity();\n                    this.hasManyEditFormContext.$implicit.tabs = EntityUtilities.getEntityTabs(\n                        this.hasManyEntity,\n                        this.injector,\n                        false,\n                        true\n                    );\n                },\n                tabs: EntityUtilities.getEntityTabs(this.hasManyEntity, this.injector, false, true)\n            }\n        };\n        await this.checkHasManyEntity();\n        this.editHasManyDialogRef = this.dialog.open(\n            this.editHasManyDialog,\n            {\n                minWidth: '60%',\n                autoFocus: false,\n                restoreFocus: false\n            }\n        );\n        const res: number = await firstValueFrom(this.editHasManyDialogRef.afterClosed()) as number;\n        if (res === 0) {\n            const data: EntityType[] = this.hasManyTableContext.$implicit.dataSource.data;\n            // eslint-disable-next-line stylistic/max-len\n            data[this.hasManyTableContext.$implicit.dataSource.data.findIndex((e) => e[this.hasManyEntityService.idKey] === entity[this.hasManyEntityService.idKey])] = entity;\n            this.hasManyTableContext.$implicit.dataSource.data = data;\n            this.hasManyTableContext.$implicit.selection.clear();\n        }\n    }\n\n    /**\n     * Tries to save the changes and close the dialog afterwards.\n     * Also handles the confirmation if required.\n     */\n    async dialogEditHasMany(): Promise<void> {\n        if (this.internalIsReadOnly || !this.isHasManyEntityValid || !this.isHasManyEntityDirty) {\n            return;\n        }\n        if (!this.metadataHasMany.tableData.editData.editRequiresConfirmDialog) {\n            await this.dialogConfirmEditHasMany();\n            return;\n        }\n\n        // eslint-disable-next-line stylistic/max-len\n        const dialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(this.globalConfig, this.metadataHasMany.tableData.editData.confirmEditDialogData)\n            .withDefault('text', this.globalConfig.confirmSaveText)\n            .withDefault('confirmButtonLabel', this.globalConfig.saveLabel)\n            .withDefault('title', this.globalConfig.editLabel)\n            .getResult();\n        const dialogRef: MatDialogRef<NgxMatEntityConfirmDialogComponent, boolean> = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        const res: boolean | undefined = await firstValueFrom(dialogRef.afterClosed());\n        if (res == true) {\n            await this.dialogConfirmEditHasMany();\n        }\n    }\n    private async dialogConfirmEditHasMany(): Promise<void> {\n        await this.hasManyEntityService.update(this.hasManyEntity, this.hasManyEntityPriorChanges);\n        this.editHasManyDialogRef.close(1);\n        this.emitChange();\n    }\n\n    /**\n     * Tries to delete the entity and close the dialog afterwards.\n     * Also handles the confirmation if required.\n     */\n    async deleteHasManyEntity(): Promise<void> {\n        if (!this.metadataHasMany.tableData.editData.deleteRequiresConfirmDialog) {\n            await this.confirmDeleteHasManyEntity();\n            return;\n        }\n\n        // eslint-disable-next-line stylistic/max-len\n        const dialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(this.globalConfig, this.metadataHasMany.tableData.editData.confirmDeleteDialogData)\n            .withDefault('text', this.globalConfig.confirmDeleteText)\n            .withDefault('type', 'delete')\n            .withDefault('confirmButtonLabel', this.globalConfig.deleteLabel)\n            .withDefault('title', this.globalConfig.deleteLabel)\n            .getResult();\n        const dialogRef: MatDialogRef<NgxMatEntityConfirmDialogComponent, boolean> = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        const res: boolean | undefined = await firstValueFrom(dialogRef.afterClosed());\n        if (res == true) {\n            await this.confirmDeleteHasManyEntity();\n        }\n    }\n\n    private async confirmDeleteHasManyEntity(): Promise<void> {\n        await this.hasManyEntityService.delete(this.hasManyEntityPriorChanges);\n        this.editHasManyDialogRef.close(2);\n        this.emitChange();\n    }\n\n    /**\n     * Cancels the editing of the has many entity and closes the dialog.\n     */\n    dialogCancelEditHasMany(): void {\n        EntityUtilities.resetChangesOnEntity(this.hasManyEntity, this.hasManyEntityPriorChanges);\n        this.editHasManyDialogRef.close(0);\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     * @throws When no EntityClass was provided, as a new call is needed to initialize metadata.\n     */\n    createHasManyEntity(): void {\n        void runInInjectionContext(this.injector, async () => {\n            if (this.metadataHasMany.tableData.baseData.allowCreate()) {\n                if (!this.metadataHasMany.tableData.baseData.EntityClass) {\n                    throw new Error('No \"EntityClass\" specified for this table');\n                }\n                if (this.metadataHasMany.tableData.baseData.create) {\n                    this.metadataHasMany.tableData.baseData.create(new this.metadataHasMany.tableData.baseData.EntityClass());\n                    return;\n                }\n                const entity: EntityType = new this.metadataHasMany.tableData.baseData.EntityClass();\n                EntityUtilities.setDefaultValues(entity);\n                if (this.metadataHasMany.tableData.baseData.defaultCreate == 'page') {\n                    this.createHasManyDefaultPage();\n                    return;\n                }\n                await this.createHasManyDefaultDialog(entity);\n            }\n        });\n    }\n\n    private createHasManyDefaultPage(): void {\n        void this.router.navigateByUrl(this.hasManyEntityService.createBaseRoute);\n    }\n\n    private async createHasManyDefaultDialog(entity: EntityType): Promise<void> {\n        this.hasManyEntity = entity;\n        this.hasManyCreateFormContext = {\n            $implicit: {\n                entity: this.hasManyEntity,\n                hideOmitForCreate: true,\n                inputChangeEvent: () => {\n                    void this.checkIsHasManyEntityValid('create');\n                    this.hasManyCreateFormContext.$implicit.tabs = EntityUtilities.getEntityTabs(this.hasManyEntity, this.injector, true);\n                },\n                tabs: EntityUtilities.getEntityTabs(this.hasManyEntity, this.injector, true)\n            }\n        };\n        await this.checkIsHasManyEntityValid('create');\n        this.createHasManyDialogRef = this.dialog.open(\n            this.createHasManyDialog,\n            {\n                minWidth: '60%',\n                autoFocus: false,\n                restoreFocus: false\n            }\n        );\n    }\n\n    /**\n     * Creates the has many entity over the dialog.\n     */\n    async dialogCreateHasMany(): Promise<void> {\n        if (!this.isHasManyEntityValid) {\n            return;\n        }\n        if (!this.metadataHasMany.tableData.createData.createRequiresConfirmDialog) {\n            await this.dialogConfirmCreateHasMany();\n            return;\n        }\n\n        // eslint-disable-next-line stylistic/max-len\n        const dialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(this.globalConfig, this.metadataHasMany.tableData.createData.confirmCreateDialogData)\n            .withDefault('text', this.globalConfig.confirmCreateText)\n            .withDefault('confirmButtonLabel', this.globalConfig.createLabel)\n            .withDefault('title', this.globalConfig.createLabel)\n            .getResult();\n        const dialogRef: MatDialogRef<NgxMatEntityConfirmDialogComponent, boolean> = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        const res: boolean | undefined = await firstValueFrom(dialogRef.afterClosed());\n        if (res == true) {\n            await this.dialogConfirmCreateHasMany();\n        }\n    }\n    private async dialogConfirmCreateHasMany(): Promise<void> {\n        await this.hasManyEntityService.create(this.hasManyEntity, this.hasManyCreateBaseUrl);\n        this.createHasManyDialogRef.close();\n        this.emitChange();\n    }\n\n    /**\n     * Cancels the creating of the has many entity and closes the dialog.\n     */\n    dialogCancelCreateHasMany(): void {\n        this.createHasManyDialogRef.close();\n    }\n\n    /**\n     * Runs the TableAction for all selected entries.\n     * Also handles confirmation with an additional dial#og if configured.\n     * @param action - The TableAction to run.\n     */\n    async runHasManyTableAction(action: TableActionInternal<EntityType>): Promise<void> {\n        const requireConfirmDialog: boolean = runInInjectionContext(\n            this.injector,\n            () => action.requireConfirmDialog(this.hasManyTableContext.$implicit.selection.selected)\n        );\n        if (!requireConfirmDialog) {\n            await this.confirmRunHasManyTableAction(action);\n            return;\n        }\n\n        const defaultText: string[] = action.type === 'multi-select'\n            ? this.globalConfig.confirmMultiSelectActionText(this.hasManyTableContext.$implicit.selection.selected)\n            : this.globalConfig.confirmBaseActionText;\n        const dialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(this.globalConfig, action.confirmDialogData)\n            .withDefault('text', defaultText)\n            .withDefault('title', action.displayName)\n            .getResult();\n        const dialogRef: MatDialogRef<NgxMatEntityConfirmDialogComponent, boolean> = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        const res: boolean | undefined = await firstValueFrom(dialogRef.afterClosed());\n        if (res == true) {\n            await this.confirmRunHasManyTableAction(action);\n        }\n    }\n\n    private async confirmRunHasManyTableAction(action: TableActionInternal<EntityType>): Promise<void> {\n        await runInInjectionContext(this.injector, async () => {\n            await action.action(this.hasManyTableContext.$implicit.selection.selected);\n            this.emitChange();\n        });\n    }\n\n    /**\n     * Checks if an TableAction is disabled (e.g. Because no entries have been selected).\n     * @param action - The TableAction to check.\n     * @returns Whether or not the Action can be used.\n     */\n    hasManyTableActionDisabled(action: TableActionInternal<EntityType>): boolean {\n        return runInInjectionContext(this.injector, () => {\n            return !action.enabled(this.hasManyTableContext.$implicit.selection.selected);\n        });\n    }\n\n    /**\n     * Applies the search input to filter the table entries.\n     * @param event - The keyup-event which contains the search-string of the user.\n     */\n    applyHasManyFilter(event: Event): void {\n        const filterValue: string = (event.target as HTMLInputElement).value;\n        this.hasManyTableContext.$implicit.dataSource.filter = filterValue.trim().toLowerCase();\n    }\n\n    /**\n     * Checks if the entity is valid for updating and if it is dirty.\n     */\n    async checkHasManyEntity(): Promise<void> {\n        await this.checkIsHasManyEntityValid('update');\n        this.hasManyChanges = await EntityUtilities.getDifferencesBetweenEntities(\n            this.hasManyEntity,\n            this.hasManyEntityPriorChanges,\n            this.http,\n            this.injector\n        );\n        if (!this.hasManyValidationErrors.length && this.hasManyChanges.length) {\n            this.hasManyTooltipContent = runInInjectionContext(\n                this.injector,\n                () => getChangesTooltipContent(this.hasManyChanges)\n            );\n        }\n        this.isHasManyEntityDirty = !!this.hasManyChanges.length;\n    }\n\n    /**\n     * Checks if the entity is valid.\n     * @param omit - Whether values omitted for create or update should be left out.\n     */\n    async checkIsHasManyEntityValid(omit: 'create' | 'update'): Promise<void> {\n        this.hasManyValidationErrors = await ValidationUtilities.getEntityValidationErrors(this.hasManyEntity, this.injector, omit);\n        if (this.hasManyValidationErrors.length) {\n            this.hasManyTooltipContent = runInInjectionContext(\n                this.injector,\n                () => getValidationErrorsTooltipContent(this.hasManyValidationErrors)\n            );\n        }\n        this.isHasManyEntityValid = this.hasManyValidationErrors.length === 0;\n    }\n\n    /**\n     * Checks whether the array item is valid and if the array item is dirty.\n     */\n    async checkArrayItem(): Promise<void> {\n        await this.checkIsArrayItemValid();\n        await this.checkIsArrayItemDirty();\n    }\n\n    /**\n     * Checks if the array item is dirty.\n     */\n    async checkIsArrayItemDirty(): Promise<void> {\n        this.arrayItemChanges = await EntityUtilities.getDifferencesBetweenEntities(\n            this.arrayItem,\n            this.arrayItemPriorChanges,\n            this.http,\n            this.injector\n        );\n        if (!this.arrayItemValidationErrors.length && this.arrayItemChanges.length) {\n            this.arrayItemTooltipContent = runInInjectionContext(\n                this.injector,\n                () => getChangesTooltipContent(this.arrayItemChanges)\n            );\n        }\n        this.isArrayItemDirty = !!this.arrayItemChanges.length;\n    }\n\n    /**\n     * Checks if the arrayItem is valid.\n     */\n    async checkIsArrayItemValid(): Promise<void> {\n        this.arrayItemValidationErrors = await ValidationUtilities.getEntityValidationErrors(this.arrayItem, this.injector, 'create');\n        if (this.arrayItemValidationErrors.length) {\n            this.arrayItemTooltipContent = runInInjectionContext(\n                this.injector,\n                () => getValidationErrorsTooltipContent(this.arrayItemValidationErrors)\n            );\n        }\n        this.isArrayItemValid = this.arrayItemValidationErrors.length === 0;\n    }\n\n    /**\n     * Emits that a the value has been changed.\n     */\n    emitChange(): void {\n        this.inputChangeEvent.emit();\n    }\n\n    /**\n     * Tries to add an item to the entity array.\n     * Does this either inline if the \"createInline\"-metadata is set to true\n     * or in a separate dialog if it is set to false.\n     */\n    async addEntity(): Promise<void> {\n        await this.checkIsArrayItemValid();\n        if (!this.metadataEntityArray.createInline) {\n            this.addArrayItemDialogRef = this.dialog.open(\n                this.addArrayItemDialog,\n                {\n                    minWidth: '60%',\n                    autoFocus: false,\n                    restoreFocus: false\n                }\n            );\n            return;\n        }\n        if (!this.metadataEntityArray.allowDuplicates) {\n            for (const v of this.entityArrayTableContext.$implicit.dataSource.data) {\n                if (await EntityUtilities.isEqual(this.arrayItem, v, this.metadata, this.metadataEntityArray.itemType, this.http)) {\n                    this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n                        data: this.metadataEntityArray.duplicatesErrorDialog,\n                        autoFocus: false,\n                        restoreFocus: false\n                    });\n                    return;\n                }\n            }\n        }\n        (this.entity[this.propertyKey] as EntityType[]).push(LodashUtilities.cloneDeep(this.arrayItem));\n        this.entityArrayTableContext.$implicit.dataSource.data = (this.entity[this.propertyKey] as EntityType[]);\n        EntityUtilities.resetChangesOnEntity(this.arrayItem, this.arrayItemPriorChanges);\n        EntityUtilities.setDefaultValues(this.arrayItem);\n        await this.checkIsArrayItemValid();\n        this.emitChange();\n    }\n\n    /**\n     * Adds the array item defined in the dialog.\n     */\n    async addArrayItem(): Promise<void> {\n        if (!this.isArrayItemValid) {\n            return;\n        }\n        (this.entity[this.propertyKey] as EntityType[]).push(LodashUtilities.cloneDeep(this.arrayItem));\n        this.entityArrayTableContext.$implicit.dataSource.data = (this.entity[this.propertyKey] as EntityType[]);\n\n        await this.closeAddArrayItemDialog();\n    }\n\n    /**\n     * Cancels adding the array item defined in the dialog.\n     */\n    async closeAddArrayItemDialog(): Promise<void> {\n        this.addArrayItemDialogRef.close();\n        EntityUtilities.resetChangesOnEntity(this.arrayItem, this.arrayItemPriorChanges);\n        await this.checkIsArrayItemValid();\n        this.emitChange();\n    }\n\n    /**\n     * Edits an entity array item.\n     * @param entity - The entity that has been clicked.\n     * @param dCol - The display column that was clicked on.\n     */\n    async editArrayItem(entity: EntityType, dCol: DisplayColumn<EntityType>): Promise<void> {\n        if (dCol.disableClick === true) {\n            return;\n        }\n        this.indexOfEditedArrayItem = this.entityArrayTableContext.$implicit.dataSource.data.indexOf(entity);\n        this.arrayItem = new this.metadataEntityArray.EntityClass(entity);\n        this.arrayItemPriorChanges = LodashUtilities.cloneDeep(this.arrayItem);\n\n        await this.checkArrayItem();\n\n        this.editArrayItemDialogRef = this.dialog.open(\n            this.editArrayItemDialog,\n            {\n                minWidth: '60%',\n                autoFocus: false,\n                restoreFocus: false\n            }\n        );\n    }\n\n    /**\n     * Saves changes on the array item in the dialog.\n     */\n    saveArrayItem(): void {\n        (this.entity[this.propertyKey] as EntityType[])[this.indexOfEditedArrayItem] = LodashUtilities.cloneDeep(this.arrayItem);\n        this.entityArrayTableContext.$implicit.dataSource.data = (this.entity[this.propertyKey] as EntityType[]);\n\n        void this.closeEditArrayItemDialog();\n    }\n\n    /**\n     * Closes the edit array item dialog and resets changes.\n     */\n    async closeEditArrayItemDialog(): Promise<void> {\n        this.editArrayItemDialogRef.close();\n        this.arrayItem = new this.metadataEntityArray.EntityClass();\n        this.arrayItemPriorChanges = LodashUtilities.cloneDeep(this.arrayItem);\n        await this.checkArrayItem();\n        this.emitChange();\n    }\n\n    /**\n     * Removes all selected entries from the entity array.\n     */\n    removeFromEntityArray(): void {\n        SelectionUtilities.remove(\n            this.entityArrayTableContext.$implicit.selection,\n            this.entity[this.propertyKey] as EntityType[],\n            this.entityArrayTableContext.$implicit.dataSource\n        );\n        this.emitChange();\n    }\n}","<!-- eslint-disable angular/no-call-expression -->\n \n@if(!(hideOmitForCreate && metadata.omitForCreate) && !(hideOmitForEdit && metadata.omitForUpdate)) {\n    @switch (type) {\n        <!-------------------------------------------->\n        <!-----------------Strings-------------------->\n        <!-------------------------------------------->\n        @case (DecoratorTypes.STRING) {\n            <string-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </string-input>\n        }\n        @case (DecoratorTypes.STRING_TEXTBOX) {\n            <string-textbox-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </string-textbox-input>\n        }\n        @case (DecoratorTypes.STRING_AUTOCOMPLETE) {\n            <string-autocomplete-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </string-autocomplete-input>\n        }\n        @case (DecoratorTypes.STRING_DROPDOWN) {\n            <string-dropdown-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </string-dropdown-input>\n        }\n        @case (DecoratorTypes.STRING_PASSWORD) {\n            <string-password-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </string-password-input>\n        }\n        <!-------------------------------------------->\n        <!-----------------Booleans------------------->\n        <!-------------------------------------------->\n        @case (DecoratorTypes.BOOLEAN_CHECKBOX) {\n            <boolean-checkbox-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </boolean-checkbox-input>\n        }\n        @case (DecoratorTypes.BOOLEAN_TOGGLE) {\n            <boolean-toggle-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </boolean-toggle-input>\n        }\n        @case (DecoratorTypes.BOOLEAN_DROPDOWN) {\n            <boolean-dropdown-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </boolean-dropdown-input>\n        }\n        <!-------------------------------------------->\n        <!------------------Numbers------------------->\n        <!-------------------------------------------->\n        @case (DecoratorTypes.NUMBER) {\n            <number-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </number-input>\n        }\n        @case (DecoratorTypes.NUMBER_DROPDOWN) {\n            <number-dropdown-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </number-dropdown-input>\n        }\n        @case (DecoratorTypes.NUMBER_SLIDER) {\n            <number-slider-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </number-slider-input>\n        }\n        <!-------------------------------------------->\n        <!-------------------Array-------------------->\n        <!-------------------------------------------->\n        @case (DecoratorTypes.ARRAY_DATE) {\n            <array-date-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </array-date-input>\n        }\n        @case (DecoratorTypes.ARRAY_DATE_TIME) {\n            <array-date-time-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </array-date-time-input>\n        }\n        @case (DecoratorTypes.ARRAY_DATE_RANGE) {\n            <array-date-range-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </array-date-range-input>\n        }\n        @case (DecoratorTypes.ARRAY_STRING_CHIPS) {\n            <array-string-chips-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </array-string-chips-input>\n        }\n        @case (DecoratorTypes.ARRAY_STRING_AUTOCOMPLETE_CHIPS) {\n            <array-string-autocomplete-chips\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </array-string-autocomplete-chips>\n        }\n        <!-------------------------------------------->\n        <!-------------------Dates-------------------->\n        <!-------------------------------------------->\n        @case (DecoratorTypes.DATE) {\n            <date-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </date-input>\n        }\n        @case (DecoratorTypes.DATE_RANGE) {\n            <date-range-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </date-range-input>\n        }\n        @case (DecoratorTypes.DATE_TIME) {\n            <date-time-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </date-time-input>\n        }\n        <!-------------------------------------------->\n        <!-------------------Files-------------------->\n        <!-------------------------------------------->\n        @case (DecoratorTypes.FILE_DEFAULT) {\n            <file-default-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </file-default-input>\n        }\n        @case (DecoratorTypes.FILE_IMAGE) {\n            <file-image-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </file-image-input>\n        }\n        <!-------------------------------------------->\n        <!-------------- references many ------------->\n        <!-------------------------------------------->\n        @case (DecoratorTypes.REFERENCES_MANY) {\n            <references-many-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </references-many-input>\n        }\n        <!-------------------------------------------->\n        <!-------------------Custom------------------->\n        <!-------------------------------------------->\n        @case (DecoratorTypes.CUSTOM) {\n            <custom-input\n                [entity]=\"entity\"\n                [key]=\"propertyKey\"\n                [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                [isReadOnly]=\"internalIsReadOnly\"\n                (inputChangeEvent)=\"emitChange()\"\n            >\n            </custom-input>\n        }\n        <!-------------------------------------------->\n        <!-------------------Object------------------->\n        <!-------------------------------------------->\n        @case (DecoratorTypes.OBJECT) {\n            <b>{{metadataDefaultObject.displayName}}</b>\n            <!-- iterates over the object properties -->\n            <ng-container *ngTemplateOutlet=\"form; context: objectFormContext\"></ng-container>\n        }\n        <!-------------------------------------------->\n        <!---------------Object Dropdown-------------->\n        <!-------------------------------------------->\n        @case (DecoratorTypes.OBJECT_DROPDOWN) {\n            <mat-form-field class=\"object-dropdown\">\n                <mat-label>{{metadata.displayName}}</mat-label>\n                <mat-select #model=\"ngModel\"\n                    [name]=\"objectDropdownName\"\n                    [required]=\"metadata.required(entity)\"\n                    [disabled]=\"internalIsReadOnly\"\n                    [compareWith]=\"compareObjectsBound\"\n                    [(ngModel)]=\"entity[propertyKey]\"\n                    (selectionChange)=\"emitChange()\"\n                    (opened)=\"selectSearchInput.focus()\"\n                >\n                    <mat-form-field class=\"select-search-input\">\n                        <!-- eslint-disable-next-line angular/no-any -->\n                        <input #selectSearchInput matInput (keyup)=\"filterObjectDropdownValues($any($event.target).value)\">\n                        <fa-icon matSuffix [icon]=\"faSearch\"></fa-icon>\n                    </mat-form-field>\n                    @if (!metadata.required(entity)) {\n                        <mat-option>-</mat-option>\n                    }\n                    @if (shouldDisplayCurrentObjectDropdownValue) {\n                        <mat-option [value]=\"currentObjectDropdownValue?.value\">{{currentObjectDropdownValue?.displayName}}</mat-option>\n                    }\n                    @for (value of filteredObjectDropdownValues; track $index) {\n                        <mat-option [value]=\"value.value\">{{value.displayName}}</mat-option>\n                    }\n                </mat-select>\n                <mat-error>{{internalGetValidationErrorMessage(model)}}</mat-error>\n            </mat-form-field>\n        }\n        <!-------------------------------------------->\n        <!-------------- references one -------------->\n        <!-------------------------------------------->\n        @case (DecoratorTypes.REFERENCES_ONE) {\n            <mat-form-field>\n                <mat-label>{{metadata.displayName}}</mat-label>\n                <mat-select #inputModel=\"ngModel\"\n                    [name]=\"referencesOneName\"\n                    [disabled]=\"internalIsReadOnly\"\n                    [required]=\"metadata.required(entity)\"\n                    [(ngModel)]=\"entity[propertyKey]\"\n                    (selectionChange)=\"setReferencesOneObject()\"\n                    (opened)=\"selectSearchInput.focus()\"\n                >\n                    <mat-form-field class=\"select-search-input\">\n                        <!-- eslint-disable-next-line angular/no-any -->\n                        <input #selectSearchInput matInput (keyup)=\"filterReferencesOneValues($any($event.target).value)\">\n                        <fa-icon matSuffix [icon]=\"faSearch\"></fa-icon>\n                    </mat-form-field>\n                    @if (!metadata.required(entity)) {\n                        <mat-option>-</mat-option>\n                    }\n                    @if (shouldDisplayCurrentReferencesOneDropdownValue) {\n                        <mat-option [value]=\"currentReferencesOneDropdownValue?.value\">{{currentReferencesOneDropdownValue?.displayName}}</mat-option>\n                    }\n                    @for (value of filteredReferencesOneDropdownValues; track $index) {\n                        <mat-option [value]=\"value.value\">{{value.displayName}}</mat-option>\n                    }\n                </mat-select>\n                <mat-error>{{internalGetValidationErrorMessage(inputModel)}}</mat-error>\n            </mat-form-field>\n            <!-- iterates over the references one properties -->\n            @if (referencesOneFormContext) {\n                <ng-container *ngTemplateOutlet=\"form; context: referencesOneFormContext\"></ng-container>\n            }\n        }\n        <!-------------------------------------------->\n        <!-------------------Array-------------------->\n        <!-------------------------------------------->\n        @case (DecoratorTypes.ARRAY) {\n            <div class=\"entityArray\">\n                <div class=\"mat-elevation-z8 elevation-container\">\n                    <div class=\"array-headline\">\n                        <b>{{metadataEntityArray.displayName}}</b>\n                    </div>\n                    @if (metadataEntityArray.createInline && !internalIsReadOnly && addArrayItemFormContext) {\n                        <ng-container *ngTemplateOutlet=\"form; context: addArrayItemFormContext\"></ng-container>\n                    }\n                    @if (!internalIsReadOnly && entityArrayTableContext) {\n                        <div class=\"buttons\">\n                            <button type=\"button\" mat-raised-button\n                                [disabled]=\"metadataEntityArray.createInline && !isArrayItemValid\"\n                                (click)=\"addEntity()\">\n                                {{metadataEntityArray.addButtonLabel}}\n                            </button>\n                            <button type=\"button\" mat-raised-button\n                                [disabled]=\"!entityArrayTableContext.$implicit.selection.selected.length\"\n                                (click)=\"removeFromEntityArray()\">\n                                {{metadataEntityArray.removeButtonLabel}}\n                            </button>\n                        </div>\n                    }\n                    @if (entityArrayTableContext) {\n                        <ng-container *ngTemplateOutlet=\"table; context: entityArrayTableContext\"></ng-container>\n                    }\n                </div>\n            </div>\n        }\n        <!-------------------------------------------->\n        <!------------------ has many ---------------->\n        <!-------------------------------------------->\n        @case (DecoratorTypes.HAS_MANY) {\n            <div class=\"hasMany\">\n                <h2 class=\"title\">{{metadataHasMany.tableData.baseData.title}}</h2>\n                <div class=\"grid grid-cols-12\" style=\"column-gap: 24px;\">\n                    <mat-form-field class=\"lg:col-span-8 md:col-span-6 col-span-12\">\n                        <mat-label>{{metadataHasMany.tableData.baseData.searchLabel}}</mat-label>\n                        <input matInput (keyup)=\"applyHasManyFilter($event)\">\n                    </mat-form-field>\n                    @if (metadataHasMany.tableData.baseData.tableActions.length) {\n                        <div\n                            [class.lg:col-span-2]=\"hasManyAllowCreate\"\n                            [class.lg:col-span-4]=\"!hasManyAllowCreate\"\n                            [class.md:col-span-3]=\"hasManyAllowCreate\"\n                            [class.md:col-span-6]=\"!hasManyAllowCreate\"\n                            [class.col-span-6]=\"hasManyAllowCreate\"\n                            [class.col-span-12]=\"!hasManyAllowCreate\"\n                        >\n                            <button type=\"button\" class=\"actions-button\" mat-raised-button [matMenuTriggerFor]=\"menu\">\n                                {{metadataHasMany.tableData.baseData.tableActionsLabel}}\n                            </button>\n                        </div>\n                    }\n                    <mat-menu #menu=\"matMenu\">\n                        @if (metadataHasMany.tableData.baseData.allowJsonImport) {\n                            <button type=\"button\" mat-menu-item [disabled]=\"hasManyTableActionDisabled(hasManyImportAction)\" (click)=\"runHasManyTableAction(hasManyImportAction)\">\n                                {{hasManyImportAction.displayName}}\n                            </button>\n                        }\n                        @for (action of metadataHasMany.tableData.baseData.tableActions; track $index) {\n                            <button type=\"button\" mat-menu-item [disabled]=\"hasManyTableActionDisabled(action)\" (click)=\"runHasManyTableAction(action)\">\n                                {{action.displayName}}\n                            </button>\n                        }\n                    </mat-menu>\n                    @if (hasManyAllowCreate) {\n                        <div\n                            [class.lg:col-span-2]=\"metadataHasMany.tableData.baseData.tableActions.length\"\n                            [class.lg:col-span-4]=\"!metadataHasMany.tableData.baseData.tableActions.length\"\n                            [class.md:col-span-3]=\"metadataHasMany.tableData.baseData.tableActions.length\"\n                            [class.md:col-span-6]=\"!metadataHasMany.tableData.baseData.tableActions.length\"\n                            [class.col-span-6]=\"metadataHasMany.tableData.baseData.tableActions.length\"\n                            [class.col-span-12]=\"!metadataHasMany.tableData.baseData.tableActions.length\"\n                        >\n                            <button type=\"button\" class=\"create-button\" mat-raised-button (click)=\"createHasManyEntity()\">\n                                {{metadataHasMany.tableData.baseData.createButtonLabel}}\n                            </button>\n                        </div>\n                    }\n                </div>\n        \n                <div class=\"mat-elevation-z8 elevation-container\">\n                    @if (hasManyTableContext) {\n                        <ng-container *ngTemplateOutlet=\"table; context: hasManyTableContext\"></ng-container>\n                    }\n                </div>\n            </div>\n        }\n        \n        @default {\n            <div>ERROR: The type {{type}} is not known.</div>\n        }\n    }\n}\n\n\n<ng-template #table let-context>\n    <mat-table matSort [dataSource]=\"context.dataSource\" [class.table-with-error-slot]=\"context.shouldShowMissingError\">\n        <!-- select Column -->\n        <ng-container matColumnDef=\"select\">\n            <mat-header-cell *matHeaderCellDef>\n                <mat-checkbox [checked]=\"context.selection.hasValue() && SelectionUtilities.isAllSelected(context.selection, context.dataSource)\"\n                    [indeterminate]=\"context.selection.hasValue() && !SelectionUtilities.isAllSelected(context.selection, context.dataSource)\"\n                    (change)=\"$event ? SelectionUtilities.masterToggle(context.selection, context.dataSource) : null\">\n                </mat-checkbox>\n            </mat-header-cell>\n            <mat-cell *matCellDef=\"let value\" [dynamicStyleClasses]=\"context.dynamicRowStyleClasses\" [value]=\"value\">\n                <mat-checkbox [checked]=\"context.selection.isSelected(value)\"\n                    (click)=\"$event.stopPropagation()\"\n                    (change)=\"$event ? context.selection.toggle(value) : null\">\n                </mat-checkbox>\n            </mat-cell>\n        </ng-container>\n\n        @for (dCol of context.displayColumns; track $index) {\n            <ng-container [matColumnDef]=\"dCol.displayName\">\n                <mat-header-cell *matHeaderCellDef mat-sort-header>\n                    {{dCol.displayName}}\n                </mat-header-cell>\n                <mat-cell *matCellDef=\"let value\" [class.enabled]=\"!dCol.disableClick && context.allowClick(value)\"\n                    [dynamicStyleClasses]=\"context.dynamicRowStyleClasses\" [value]=\"value\"\n                    (click)=\"clickCell(value, dCol, context)\"\n                >\n                    @if (dCol.Component) {\n                        <display-column-value [entity]=\"value\" [ComponentClass]=\"dCol.Component\"></display-column-value>\n                    }\n                    @else {\n                        {{getDisplayColumnValue(value, dCol)}}\n                    }\n                </mat-cell>\n            </ng-container>\n        }\n\n        <mat-header-row *matHeaderRowDef=\"context.displayedColumns\"></mat-header-row>\n        <mat-row *matRowDef=\"let row; columns: context.displayedColumns\"></mat-row>\n    </mat-table>\n\n    @if (context.displayLoadingSpinner && context.isLoading) {\n        <mat-spinner>\n        </mat-spinner>\n    }\n    @else if (context.shouldShowMissingError && !context.dataSource.data.length) {\n        <div class=\"table-error\">{{context.emptyErrorMessage}}</div>\n    }\n\n    <mat-paginator [length]=\"context.dataSource.filteredData.length\" [pageIndex]=\"0\" [pageSize]=\"10\" [pageSizeOptions]=\"[5, 10, 25, 50]\"></mat-paginator>\n</ng-template>\n\n<!--------------------------------------------------------->\n<!---------------------------Form-------------------------->\n<!--------------------------------------------------------->\n<ng-template #form let-context>\n     <!-- eslint-disable angular/no-call-expression -->\n    @if (context.tabs.length > 1) {\n        <mat-tab-group preserveContent>\n            @for (tab of context.tabs; track $index) {\n                <mat-tab [label]=\"tab.tabName\">\n                    @for (row of tab.rows; track $index) {\n                        <div class=\"grid grid-cols-12\" style=\"column-gap: 24px;\">\n                            @for (key of row.keys; track key) {\n                                <ngx-mat-entity-input\n                                    [entity]=\"context.entity\"\n                                    [propertyKey]=\"key\"\n                                    [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                                    [validEmpty]=\"context.validEmpty?.()\"\n                                    [isReadOnly]=\"context.isReadOnly?.(context.entity, key)\"\n                                    [class]=\"EntityUtilities.getWidthClasses(context.entity, key)\"\n                                    [hideOmitForEdit]=\"context.hideOmitForEdit\"\n                                    [hideOmitForCreate]=\"context.hideOmitForCreate\"\n                                    (inputChangeEvent)=\"context.inputChangeEvent()\"\n                                >\n                                </ngx-mat-entity-input>\n                            }\n                        </div>\n                    }\n                </mat-tab>\n            }\n        </mat-tab-group>\n    }\n    @else {\n        @if (!context.tabs.length) {\n            <span class=\"no-entity-tabs\">\n                ERROR: No Inputs. Did you correctly assign all values in the model constructor?\n            </span>\n        }\n        @else {\n            @for (row of context.tabs[0].rows; track $index) {\n                <div class=\"grid grid-cols-12\" style=\"column-gap: 24px;\">\n                    @for (key of row.keys; track key) {\n                        <ngx-mat-entity-input\n                            [entity]=\"context.entity\"\n                            [propertyKey]=\"key\"\n                            [getValidationErrorMessage]=\"internalGetValidationErrorMessage\"\n                            [validEmpty]=\"context.validEmpty?.()\"\n                            [isReadOnly]=\"context.isReadOnly?.(context.entity, key)\"\n                            [class]=\"EntityUtilities.getWidthClasses(context.entity, key)\"\n                            [hideOmitForEdit]=\"context.hideOmitForEdit\"\n                            [hideOmitForCreate]=\"context.hideOmitForCreate\"\n                            (inputChangeEvent)=\"context.inputChangeEvent()\"\n                        >\n                        </ngx-mat-entity-input>\n                    }\n                </div>\n            }\n        }\n    }\n</ng-template>\n\n<!--------------------------------------------------------->\n<!--------------------Add Array Item Dialog---------------->\n<!--------------------------------------------------------->\n<ng-template #addArrayItemDialog>\n    <div class=\"mat-dialog-title\">\n        <div>{{addArrayItemDialogData.title}}</div>\n    </div>\n\n    <form>\n        <mat-dialog-content>\n            @if (addArrayItemFormContext) {\n                <ng-container *ngTemplateOutlet=\"form; context: addArrayItemFormContext\"></ng-container>\n            }\n        </mat-dialog-content>\n    \n        <mat-dialog-actions>\n            <div class=\"dialog-button-with-info-icon\">\n                <button type=\"submit\" mat-raised-button matBadgeColor=\"warn\"\n                    [disabled]=\"!isArrayItemValid\"\n                    [matBadge]=\"arrayItemValidationErrors.length\"\n                    [matBadgeHidden]=\"!arrayItemValidationErrors.length\"\n                    (click)=\"addArrayItem()\"\n                >\n                    {{addArrayItemDialogData.createButtonLabel}}\n                </button>\n                @if (arrayItemValidationErrors.length) {\n                    <ngx-mat-entity-tooltip [tooltipContent]=\"arrayItemTooltipContent\"></ngx-mat-entity-tooltip>\n                }\n            </div>\n            <button type=\"button\" mat-raised-button class=\"cancel-button\" (click)=\"closeAddArrayItemDialog()\">\n                {{addArrayItemDialogData.cancelButtonLabel}}\n            </button>\n        </mat-dialog-actions>\n    </form>\n\n</ng-template>\n\n<!--------------------------------------------------------->\n<!--------------------Edit Array Item Dialog---------------->\n<!--------------------------------------------------------->\n<ng-template #editArrayItemDialog>\n    <div class=\"mat-dialog-title\">\n        <div>{{editArrayItemDialogData.title(arrayItemPriorChanges)}}</div>\n    </div>\n    \n    <form>\n        <mat-dialog-content>\n            @if (editArrayItemFormContext) {\n                <ng-container *ngTemplateOutlet=\"form; context: editArrayItemFormContext\"></ng-container>\n            }\n        </mat-dialog-content>\n        \n        <mat-dialog-actions>\n            <div class=\"dialog-button-with-info-icon\">\n                <button type=\"submit\" mat-raised-button matBadgeColor=\"warn\"\n                    [class.badge-changes]=\"!arrayItemValidationErrors.length\"\n                    [disabled]=\"internalIsReadOnly || !isArrayItemValid || !isArrayItemDirty\"\n                    [matBadge]=\"arrayItemValidationErrors.length > 0 ? arrayItemValidationErrors.length : arrayItemChanges.length\"\n                    [matBadgeHidden]=\"!arrayItemValidationErrors.length && !arrayItemChanges.length\"\n                    (click)=\"saveArrayItem()\"\n                >\n                    {{editArrayItemDialogData.confirmButtonLabel}}\n                </button>\n                @if (arrayItemValidationErrors.length || arrayItemChanges.length) {\n                    <ngx-mat-entity-tooltip [tooltipContent]=\"arrayItemTooltipContent\"></ngx-mat-entity-tooltip>\n                }\n            </div>\n            <button type=\"button\" mat-raised-button class=\"cancel-button\" (click)=\"closeEditArrayItemDialog()\">\n                {{editArrayItemDialogData.cancelButtonLabel}}\n            </button>\n        </mat-dialog-actions>\n    </form>\n</ng-template>\n\n<!--------------------------------------------------------->\n<!--------------------Create Has Many Dialog---------------->\n<!--------------------------------------------------------->\n<ng-template #createHasManyDialog>\n    <div class=\"mat-dialog-title\">\n        <div>{{metadataHasMany.tableData.createData.title}}</div>\n    </div>\n    \n    <form>\n        <mat-dialog-content>\n            @if (hasManyCreateFormContext) {\n                <ng-container *ngTemplateOutlet=\"form; context: hasManyCreateFormContext\"></ng-container>\n            }\n        </mat-dialog-content>\n        \n        <mat-dialog-actions>\n            <div class=\"dialog-button-with-info-icon\">\n                <button type=\"submit\" mat-raised-button matBadgeColor=\"warn\"\n                    [disabled]=\"!isHasManyEntityValid\"\n                    [matBadge]=\"hasManyValidationErrors.length\"\n                    [matBadgeHidden]=\"!hasManyValidationErrors.length\"\n                    (click)=\"dialogCreateHasMany()\"\n                >\n                    {{metadataHasMany.tableData.createData.createButtonLabel}}\n                </button>\n                @if (hasManyValidationErrors.length) {\n                    <ngx-mat-entity-tooltip [tooltipContent]=\"hasManyTooltipContent\"></ngx-mat-entity-tooltip>\n                }\n            </div>\n            <button type=\"button\" mat-raised-button class=\"cancel-button\" (click)=\"dialogCancelCreateHasMany()\">\n                {{metadataHasMany.tableData.createData.cancelButtonLabel}}\n            </button>\n        </mat-dialog-actions>\n    </form>\n    \n</ng-template>\n\n<!--------------------------------------------------------->\n<!--------------------Edit Has Many Dialog----------------->\n<!--------------------------------------------------------->\n<ng-template #editHasManyDialog>\n    <div class=\"mat-dialog-title\">\n        <div>{{metadataHasMany.tableData.editData.title(hasManyEntityPriorChanges)}}</div>\n\n        <div class=\"actions-container\">\n            @if (metadataHasMany.tableData.editData.actions.length) {\n                <button type=\"button\" mat-raised-button [matMenuTriggerFor]=\"menu\">\n                    {{metadataHasMany.tableData.editData.actionsLabel}}\n                </button>\n            }\n            <mat-menu #menu=\"matMenu\">\n                @for (action of metadataHasMany.tableData.editData.actions; track $index) {\n                    <button type=\"button\" mat-menu-item [disabled]=\"hasManyEditActionDisabled(action)\" (click)=\"hasManyRunEditAction(action)\">\n                        {{action.displayName}}\n                    </button>\n                }\n            </mat-menu>\n        \n            @if (hasManyAllowDelete(hasManyEntity)) {\n                <button type=\"button\" mat-raised-button color=\"warn\" class=\"delete-button\" tabindex=\"-1\" (click)=\"deleteHasManyEntity()\">\n                    {{metadataHasMany.tableData.editData.deleteButtonLabel}}\n                </button>\n            }\n        </div>\n    </div>\n    \n    <form>\n        <mat-dialog-content>\n            @if (hasManyEditFormContext) {\n                <ng-container *ngTemplateOutlet=\"form; context: hasManyEditFormContext\"></ng-container>\n            }\n        </mat-dialog-content>\n        \n        <mat-dialog-actions>\n            <div class=\"dialog-button-with-info-icon\">\n                <button type=\"submit\" mat-raised-button matBadgeColor=\"warn\"\n                    [class.badge-changes]=\"!hasManyValidationErrors.length\"\n                    [disabled]=\"internalIsReadOnly || !isHasManyEntityValid || !isHasManyEntityDirty\"\n                    [matBadge]=\"hasManyValidationErrors.length > 0 ? hasManyValidationErrors.length : hasManyChanges.length\"\n                    [matBadgeHidden]=\"!hasManyValidationErrors.length && !hasManyChanges.length\"\n                    (click)=\"dialogEditHasMany()\"\n                >\n                    {{metadataHasMany.tableData.editData.confirmButtonLabel}}\n                </button>\n                @if (hasManyValidationErrors.length || hasManyChanges.length) {\n                    <ngx-mat-entity-tooltip [tooltipContent]=\"hasManyTooltipContent\"></ngx-mat-entity-tooltip>\n                }\n            </div>\n            <button type=\"button\" mat-raised-button class=\"cancel-button\" (click)=\"dialogCancelEditHasMany()\">\n                {{metadataHasMany.tableData.editData.cancelButtonLabel}}\n            </button>\n        </mat-dialog-actions>\n    </form>\n</ng-template>"]}
|