ngx-material-entity 0.1.1 → 0.1.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (133) hide show
  1. package/CONTRIBUTING.md +7 -1
  2. package/README.md +536 -328
  3. package/classes/base.builder.d.ts +35 -0
  4. package/classes/date.utilities.d.ts +58 -0
  5. package/classes/entity.model.d.ts +13 -0
  6. package/classes/{entity-service.class.d.ts → entity.service.d.ts} +35 -20
  7. package/classes/entity.utilities.d.ts +153 -0
  8. package/components/confirm-dialog/confirm-dialog-data.builder.d.ts +23 -0
  9. package/components/confirm-dialog/confirm-dialog-data.d.ts +18 -8
  10. package/components/confirm-dialog/confirm-dialog.component.d.ts +15 -5
  11. package/components/get-validation-error-message.function.d.ts +3 -2
  12. package/components/input/add-array-item-dialog-data.builder.d.ts +20 -0
  13. package/components/input/add-array-item-dialog-data.d.ts +19 -0
  14. package/components/input/input.component.d.ts +151 -30
  15. package/components/input/input.module.d.ts +7 -4
  16. package/components/table/create-dialog/create-dialog-data.builder.d.ts +21 -0
  17. package/components/table/create-dialog/create-entity-dialog-data.builder.d.ts +21 -0
  18. package/components/table/create-dialog/create-entity-dialog-data.d.ts +4 -5
  19. package/components/table/create-dialog/create-entity-dialog.component.d.ts +21 -8
  20. package/components/table/edit-dialog/edit-dialog-data.builder.d.ts +24 -0
  21. package/components/table/edit-dialog/edit-entity-dialog-data.d.ts +7 -8
  22. package/components/table/edit-dialog/edit-entity-dialog.builder.d.ts +22 -0
  23. package/components/table/edit-dialog/edit-entity-dialog.component.d.ts +25 -8
  24. package/components/table/table-data.builder.d.ts +51 -0
  25. package/components/table/table-data.d.ts +46 -30
  26. package/components/table/table.component.d.ts +53 -7
  27. package/components/table/table.module.d.ts +3 -1
  28. package/decorators/array/array-decorator-internal.data.d.ts +45 -0
  29. package/decorators/array/array-decorator.data.d.ts +129 -0
  30. package/decorators/array/array.decorator.d.ts +9 -0
  31. package/decorators/base/base-property.decorator.d.ts +7 -6
  32. package/decorators/base/decorator-types.enum.d.ts +12 -9
  33. package/decorators/base/dropdown-value.interface.d.ts +14 -0
  34. package/decorators/base/property-decorator-internal.data.d.ts +24 -0
  35. package/decorators/base/property-decorator.data.d.ts +70 -0
  36. package/decorators/boolean/boolean-decorator-internal.data.d.ts +25 -0
  37. package/decorators/boolean/boolean-decorator.data.d.ts +37 -0
  38. package/decorators/boolean/boolean.decorator.d.ts +8 -0
  39. package/decorators/date/date-decorator-internal.data.d.ts +44 -0
  40. package/decorators/date/date-decorator.data.d.ts +129 -0
  41. package/decorators/number/number-decorator-internal.data.d.ts +20 -0
  42. package/decorators/number/number-decorator.data.d.ts +36 -0
  43. package/decorators/number/number.decorator.d.ts +8 -0
  44. package/decorators/object/object-decorator-internal.data.d.ts +11 -0
  45. package/decorators/object/object-decorator.data.d.ts +25 -0
  46. package/decorators/object/object.decorator.d.ts +8 -0
  47. package/decorators/string/string-decorator-internal.data.d.ts +41 -0
  48. package/decorators/string/string-decorator.data.d.ts +77 -0
  49. package/decorators/string/string.decorator.d.ts +8 -0
  50. package/esm2020/classes/base.builder.mjs +43 -0
  51. package/esm2020/classes/date.utilities.mjs +138 -0
  52. package/esm2020/classes/entity.model.mjs +19 -0
  53. package/esm2020/classes/entity.service.mjs +83 -0
  54. package/esm2020/classes/entity.utilities.mjs +538 -0
  55. package/esm2020/components/confirm-dialog/confirm-dialog-data.builder.mjs +44 -0
  56. package/esm2020/components/confirm-dialog/confirm-dialog-data.mjs +1 -1
  57. package/esm2020/components/confirm-dialog/confirm-dialog.component.mjs +18 -22
  58. package/esm2020/components/get-validation-error-message.function.mjs +8 -3
  59. package/esm2020/components/input/add-array-item-dialog-data.builder.mjs +30 -0
  60. package/esm2020/components/input/add-array-item-dialog-data.mjs +2 -0
  61. package/esm2020/components/input/input.component.mjs +240 -36
  62. package/esm2020/components/input/input.module.mjs +23 -9
  63. package/esm2020/components/table/create-dialog/create-dialog-data.builder.mjs +32 -0
  64. package/esm2020/components/table/create-dialog/create-entity-dialog-data.builder.mjs +26 -0
  65. package/esm2020/components/table/create-dialog/create-entity-dialog-data.mjs +1 -1
  66. package/esm2020/components/table/create-dialog/create-entity-dialog.component.mjs +31 -31
  67. package/esm2020/components/table/create-dialog/create-entity-dialog.module.mjs +20 -4
  68. package/esm2020/components/table/edit-dialog/edit-dialog-data.builder.mjs +41 -0
  69. package/esm2020/components/table/edit-dialog/edit-entity-dialog-data.mjs +1 -1
  70. package/esm2020/components/table/edit-dialog/edit-entity-dialog.builder.mjs +27 -0
  71. package/esm2020/components/table/edit-dialog/edit-entity-dialog.component.mjs +45 -49
  72. package/esm2020/components/table/table-data.builder.mjs +105 -0
  73. package/esm2020/components/table/table-data.mjs +1 -1
  74. package/esm2020/components/table/table.component.mjs +91 -83
  75. package/esm2020/components/table/table.module.mjs +12 -4
  76. package/esm2020/decorators/array/array-decorator-internal.data.mjs +51 -0
  77. package/esm2020/decorators/array/array-decorator.data.mjs +7 -0
  78. package/esm2020/decorators/array/array.decorator.mjs +24 -0
  79. package/esm2020/decorators/base/base-property.decorator.mjs +6 -5
  80. package/esm2020/decorators/base/decorator-types.enum.mjs +4 -1
  81. package/esm2020/decorators/base/dropdown-value.interface.mjs +2 -0
  82. package/esm2020/decorators/base/property-decorator-internal.data.mjs +38 -0
  83. package/esm2020/decorators/base/property-decorator.data.mjs +6 -0
  84. package/esm2020/decorators/boolean/boolean-decorator-internal.data.mjs +33 -0
  85. package/esm2020/decorators/boolean/boolean-decorator.data.mjs +7 -0
  86. package/esm2020/decorators/boolean/boolean.decorator.mjs +21 -0
  87. package/esm2020/decorators/date/date-decorator-internal.data.mjs +48 -0
  88. package/esm2020/decorators/date/date-decorator.data.mjs +7 -0
  89. package/esm2020/decorators/number/number-decorator-internal.data.mjs +23 -0
  90. package/esm2020/decorators/number/number-decorator.data.mjs +7 -0
  91. package/esm2020/decorators/number/number.decorator.mjs +18 -0
  92. package/esm2020/decorators/object/object-decorator-internal.data.mjs +12 -0
  93. package/esm2020/decorators/object/object-decorator.data.mjs +7 -0
  94. package/esm2020/decorators/object/object.decorator.mjs +13 -0
  95. package/esm2020/decorators/string/string-decorator-internal.data.mjs +48 -0
  96. package/esm2020/decorators/string/string-decorator.data.mjs +7 -0
  97. package/esm2020/decorators/string/string.decorator.mjs +24 -0
  98. package/esm2020/public-api.mjs +20 -13
  99. package/fesm2015/ngx-material-entity.mjs +1664 -944
  100. package/fesm2015/ngx-material-entity.mjs.map +1 -1
  101. package/fesm2020/ngx-material-entity.mjs +1667 -941
  102. package/fesm2020/ngx-material-entity.mjs.map +1 -1
  103. package/package.json +7 -1
  104. package/public-api.d.ts +21 -10
  105. package/classes/entity-model.class.d.ts +0 -9
  106. package/classes/entity-utilities.class.d.ts +0 -95
  107. package/components/input/array-table/add-array-item-dialog/add-array-item-dialog.component.d.ts +0 -35
  108. package/components/input/array-table/add-array-item-dialog/add-array-item-dialog.module.d.ts +0 -12
  109. package/components/input/array-table/array-table.component.d.ts +0 -34
  110. package/components/input/array-table/array-table.module.d.ts +0 -19
  111. package/components/input/internal-input/internal-input.component.d.ts +0 -57
  112. package/components/input/internal-input/internal-input.module.d.ts +0 -16
  113. package/decorators/array.decorator.d.ts +0 -125
  114. package/decorators/base/property-decorator-config.interface.d.ts +0 -50
  115. package/decorators/boolean.decorator.d.ts +0 -42
  116. package/decorators/number.decorator.d.ts +0 -40
  117. package/decorators/object.decorator.d.ts +0 -27
  118. package/decorators/string.decorator.d.ts +0 -76
  119. package/esm2020/classes/entity-model.class.mjs +0 -19
  120. package/esm2020/classes/entity-service.class.mjs +0 -70
  121. package/esm2020/classes/entity-utilities.class.mjs +0 -296
  122. package/esm2020/components/input/array-table/add-array-item-dialog/add-array-item-dialog.component.mjs +0 -43
  123. package/esm2020/components/input/array-table/add-array-item-dialog/add-array-item-dialog.module.mjs +0 -22
  124. package/esm2020/components/input/array-table/array-table.component.mjs +0 -116
  125. package/esm2020/components/input/array-table/array-table.module.mjs +0 -66
  126. package/esm2020/components/input/internal-input/internal-input.component.mjs +0 -73
  127. package/esm2020/components/input/internal-input/internal-input.module.mjs +0 -54
  128. package/esm2020/decorators/array.decorator.mjs +0 -70
  129. package/esm2020/decorators/base/property-decorator-config.interface.mjs +0 -31
  130. package/esm2020/decorators/boolean.decorator.mjs +0 -44
  131. package/esm2020/decorators/number.decorator.mjs +0 -36
  132. package/esm2020/decorators/object.decorator.mjs +0 -23
  133. package/esm2020/decorators/string.decorator.mjs +0 -61
@@ -1,116 +0,0 @@
1
- import { SelectionModel } from '@angular/cdk/collections';
2
- import { Component, Input } from '@angular/core';
3
- import { EntityArrayDecoratorConfig } from '../../../decorators/array.decorator';
4
- import { EntityUtilities } from '../../../classes/entity-utilities.class';
5
- import { MatTableDataSource } from '@angular/material/table';
6
- import { MatDialog } from '@angular/material/dialog';
7
- import { cloneDeep } from 'lodash';
8
- import { firstValueFrom } from 'rxjs';
9
- import { NgxMatEntityAddArrayItemDialogComponent } from './add-array-item-dialog/add-array-item-dialog.component';
10
- import * as i0 from "@angular/core";
11
- import * as i1 from "@angular/material/dialog";
12
- import * as i2 from "../internal-input/internal-input.component";
13
- import * as i3 from "@angular/material/button";
14
- import * as i4 from "@angular/material/table";
15
- import * as i5 from "@angular/material/checkbox";
16
- import * as i6 from "@angular/common";
17
- export class NgxMatEntityArrayTableComponent {
18
- constructor(dialog) {
19
- this.dialog = dialog;
20
- this.selection = new SelectionModel(true, []);
21
- this.getWidth = EntityUtilities.getWidth;
22
- this.EntityUtilities = EntityUtilities;
23
- }
24
- trackByFn(index) {
25
- return index;
26
- }
27
- ngOnInit() {
28
- this.validateInput();
29
- const givenDisplayColumns = this.metadata.displayColumns.map((v) => v.displayName);
30
- if (givenDisplayColumns.find((s) => s === 'select')) {
31
- throw new Error(`The name "select" for a display column is reserved.
32
- Please choose a different name.`);
33
- }
34
- this.displayedColumns = ['select'].concat(givenDisplayColumns);
35
- this.dataSource = new MatTableDataSource();
36
- this.dataSource.data = this.arrayItems;
37
- this.arrayItem = new this.metadata.EntityClass();
38
- this.arrayItemPriorChanges = cloneDeep(this.arrayItem);
39
- }
40
- validateInput() {
41
- if (!this.metadata.createInline && !this.metadata.createDialogData) {
42
- throw new Error(`Missing required Input data "createDialogData".
43
- You can only omit this value when the creation is inline.`);
44
- }
45
- }
46
- add() {
47
- if (this.metadata.createInline) {
48
- this.arrayItems.push(cloneDeep(this.arrayItem));
49
- this.dataSource.data = this.arrayItems;
50
- EntityUtilities.resetChangesOnEntity(this.arrayItem, this.arrayItemPriorChanges);
51
- }
52
- else {
53
- const dialogData = {
54
- entity: this.arrayItem,
55
- createDialogData: this.metadata.createDialogData,
56
- getValidationErrorMessage: this.getValidationErrorMessage
57
- };
58
- firstValueFrom(this.dialog.open(NgxMatEntityAddArrayItemDialogComponent, {
59
- data: dialogData,
60
- autoFocus: false,
61
- restoreFocus: false
62
- }).afterClosed()).then((res) => {
63
- if (res === 1) {
64
- this.arrayItems.push(cloneDeep(this.arrayItem));
65
- this.dataSource.data = this.arrayItems;
66
- }
67
- EntityUtilities.resetChangesOnEntity(this.arrayItem, this.arrayItemPriorChanges);
68
- });
69
- }
70
- }
71
- remove() {
72
- this.selection.selected.forEach(s => {
73
- this.arrayItems.splice(this.arrayItems.indexOf(s), 1);
74
- });
75
- this.dataSource.data = this.arrayItems;
76
- this.selection.clear();
77
- }
78
- getObjectProperties() {
79
- const res = [];
80
- for (const property in this.arrayItem) {
81
- const metadata = EntityUtilities.getPropertyMetadata(this.arrayItem, property, EntityUtilities.getPropertyType(this.arrayItem, property));
82
- if (!(metadata.omitForCreate)) {
83
- res.push(property);
84
- }
85
- }
86
- return res.sort((a, b) => EntityUtilities.compareOrder(a, b, this.arrayItem));
87
- }
88
- masterToggle() {
89
- if (this.isAllSelected()) {
90
- this.selection.clear();
91
- }
92
- else {
93
- this.dataSource.data.forEach((row) => this.selection.select(row));
94
- }
95
- }
96
- isAllSelected() {
97
- const numSelected = this.selection.selected.length;
98
- const numRows = this.dataSource.data.length;
99
- return numSelected === numRows;
100
- }
101
- }
102
- NgxMatEntityArrayTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityArrayTableComponent, deps: [{ token: i1.MatDialog }], target: i0.ɵɵFactoryTarget.Component });
103
- NgxMatEntityArrayTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: NgxMatEntityArrayTableComponent, selector: "ngx-mat-entity-array-table", inputs: { arrayItems: "arrayItems", metadata: "metadata", getValidationErrorMessage: "getValidationErrorMessage", omit: "omit" }, ngImport: i0, template: "<div class=\"mat-elevation-z8\" style=\"border-radius: 5px;padding: 15px;margin-bottom: 15px;margin-top: 15px;\">\n\n <div style=\"padding-bottom: 10px\">\n <b>{{metadata.displayName}}</b>\n </div>\n <div class=\"row\" *ngIf=\"metadata.createInline\">\n <ngx-mat-entity-internal-input\n *ngFor=\"let key of getObjectProperties(); let i = index; trackBy: trackByFn\"\n [entity]=\"arrayItem\"\n [propertyKey]=\"key\"\n [hideOmitForCreate]=\"true\"\n [getValidationErrorMessage]=\"getValidationErrorMessage\"\n class=\"col-lg-{{getWidth(arrayItem, key, 'lg')}} col-md-{{getWidth(arrayItem, key, 'md')}} col-sm-{{getWidth(arrayItem, key, 'sm')}}\"\n >\n </ngx-mat-entity-internal-input>\n </div>\n <div class=\"buttons\">\n <button mat-raised-button\n [disabled]=\"metadata.createInline && !EntityUtilities.isEntityValid(arrayItem, 'create')\"\n (click)=\"add()\">\n Add\n </button>\n <button mat-raised-button\n [disabled]=\"!selection.selected.length\"\n (click)=\"remove()\">\n Remove\n </button>\n </div>\n\n <mat-table [dataSource]=\"dataSource\">\n <!-- select Column -->\n <ng-container matColumnDef=\"select\">\n <mat-header-cell *matHeaderCellDef>\n <mat-checkbox (change)=\"$event ? masterToggle() : null\" [checked]=\"selection.hasValue() && isAllSelected()\" [indeterminate]=\"selection.hasValue() && !isAllSelected()\"></mat-checkbox>\n </mat-header-cell>\n <mat-cell *matCellDef=\"let module\" class=\"module\">\n <mat-checkbox (click)=\"$event.stopPropagation()\" (change)=\"$event ? selection.toggle(module) : null\" [checked]=\"selection.isSelected(module)\"></mat-checkbox>\n </mat-cell>\n </ng-container>\n \n <ng-container *ngFor=\"let dCol of metadata.displayColumns\" [matColumnDef]=\"dCol.displayName\">\n <mat-header-cell *matHeaderCellDef>\n {{dCol.displayName}}\n </mat-header-cell>\n <mat-cell class=\"entity\" *matCellDef=\"let entity\">\n {{dCol.value(entity)}}\n </mat-cell>\n </ng-container>\n \n <mat-header-row *matHeaderRowDef=\"displayedColumns\"></mat-header-row>\n <mat-row *matRowDef=\"let row; columns: displayedColumns\"></mat-row>\n </mat-table>\n\n <div class=\"array-error\" *ngIf=\"metadata.required && !dataSource.data.length\">\n {{metadata.missingErrorMessage ? metadata.missingErrorMessage : 'Needs to have at least one value'}}\n </div>\n</div>", styles: [".buttons{display:flex;justify-content:space-between;margin-bottom:10px;margin-top:5px}mat-table{border:1px solid #E0E0E0;border-radius:5px;padding-top:5px;padding-bottom:25px}.mat-column-select{flex:0 0 75px}.array-error{display:flex;align-items:center;justify-content:center;margin-top:-25.5px;border:1px solid #E0E0E0;background-color:#f8d3d7;color:#721c24;height:25px;border-bottom-left-radius:5px;border-bottom-right-radius:5px}\n"], components: [{ type: i2.NgxMatEntityInternalInputComponent, selector: "ngx-mat-entity-internal-input", inputs: ["entity", "propertyKey", "hideOmitForCreate", "hideOmitForEdit", "getValidationErrorMessage"] }, { type: i3.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i4.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { type: i5.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex", "aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { type: i4.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { type: i4.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i4.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { type: i4.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { type: i4.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { type: i4.MatCellDef, selector: "[matCellDef]" }, { type: i4.MatCell, selector: "mat-cell, td[mat-cell]" }, { type: i4.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { type: i4.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }] });
104
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityArrayTableComponent, decorators: [{
105
- type: Component,
106
- args: [{ selector: 'ngx-mat-entity-array-table', template: "<div class=\"mat-elevation-z8\" style=\"border-radius: 5px;padding: 15px;margin-bottom: 15px;margin-top: 15px;\">\n\n <div style=\"padding-bottom: 10px\">\n <b>{{metadata.displayName}}</b>\n </div>\n <div class=\"row\" *ngIf=\"metadata.createInline\">\n <ngx-mat-entity-internal-input\n *ngFor=\"let key of getObjectProperties(); let i = index; trackBy: trackByFn\"\n [entity]=\"arrayItem\"\n [propertyKey]=\"key\"\n [hideOmitForCreate]=\"true\"\n [getValidationErrorMessage]=\"getValidationErrorMessage\"\n class=\"col-lg-{{getWidth(arrayItem, key, 'lg')}} col-md-{{getWidth(arrayItem, key, 'md')}} col-sm-{{getWidth(arrayItem, key, 'sm')}}\"\n >\n </ngx-mat-entity-internal-input>\n </div>\n <div class=\"buttons\">\n <button mat-raised-button\n [disabled]=\"metadata.createInline && !EntityUtilities.isEntityValid(arrayItem, 'create')\"\n (click)=\"add()\">\n Add\n </button>\n <button mat-raised-button\n [disabled]=\"!selection.selected.length\"\n (click)=\"remove()\">\n Remove\n </button>\n </div>\n\n <mat-table [dataSource]=\"dataSource\">\n <!-- select Column -->\n <ng-container matColumnDef=\"select\">\n <mat-header-cell *matHeaderCellDef>\n <mat-checkbox (change)=\"$event ? masterToggle() : null\" [checked]=\"selection.hasValue() && isAllSelected()\" [indeterminate]=\"selection.hasValue() && !isAllSelected()\"></mat-checkbox>\n </mat-header-cell>\n <mat-cell *matCellDef=\"let module\" class=\"module\">\n <mat-checkbox (click)=\"$event.stopPropagation()\" (change)=\"$event ? selection.toggle(module) : null\" [checked]=\"selection.isSelected(module)\"></mat-checkbox>\n </mat-cell>\n </ng-container>\n \n <ng-container *ngFor=\"let dCol of metadata.displayColumns\" [matColumnDef]=\"dCol.displayName\">\n <mat-header-cell *matHeaderCellDef>\n {{dCol.displayName}}\n </mat-header-cell>\n <mat-cell class=\"entity\" *matCellDef=\"let entity\">\n {{dCol.value(entity)}}\n </mat-cell>\n </ng-container>\n \n <mat-header-row *matHeaderRowDef=\"displayedColumns\"></mat-header-row>\n <mat-row *matRowDef=\"let row; columns: displayedColumns\"></mat-row>\n </mat-table>\n\n <div class=\"array-error\" *ngIf=\"metadata.required && !dataSource.data.length\">\n {{metadata.missingErrorMessage ? metadata.missingErrorMessage : 'Needs to have at least one value'}}\n </div>\n</div>", styles: [".buttons{display:flex;justify-content:space-between;margin-bottom:10px;margin-top:5px}mat-table{border:1px solid #E0E0E0;border-radius:5px;padding-top:5px;padding-bottom:25px}.mat-column-select{flex:0 0 75px}.array-error{display:flex;align-items:center;justify-content:center;margin-top:-25.5px;border:1px solid #E0E0E0;background-color:#f8d3d7;color:#721c24;height:25px;border-bottom-left-radius:5px;border-bottom-right-radius:5px}\n"] }]
107
- }], ctorParameters: function () { return [{ type: i1.MatDialog }]; }, propDecorators: { arrayItems: [{
108
- type: Input
109
- }], metadata: [{
110
- type: Input
111
- }], getValidationErrorMessage: [{
112
- type: Input
113
- }], omit: [{
114
- type: Input
115
- }] } });
116
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"array-table.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-material-entity/src/components/input/array-table/array-table.component.ts","../../../../../../projects/ngx-material-entity/src/components/input/array-table/array-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { SelectionModel } from '@angular/cdk/collections';\nimport { Component, Input, OnInit } from '@angular/core';\nimport { EntityArrayDecoratorConfig } from '../../../decorators/array.decorator';\nimport { Entity } from '../../../classes/entity-model.class';\nimport { EntityUtilities } from '../../../classes/entity-utilities.class';\nimport { NgModel } from '@angular/forms';\nimport { MatTableDataSource } from '@angular/material/table';\nimport { MatDialog } from '@angular/material/dialog';\nimport { cloneDeep } from 'lodash';\nimport { firstValueFrom } from 'rxjs';\nimport { AddArrayItemDialogData, NgxMatEntityAddArrayItemDialogComponent } from './add-array-item-dialog/add-array-item-dialog.component';\nimport { CreateDialogData } from '../../table/table-data';\n\n@Component({\n    selector: 'ngx-mat-entity-array-table',\n    templateUrl: './array-table.component.html',\n    styleUrls: ['./array-table.component.scss']\n})\nexport class NgxMatEntityArrayTableComponent<EntityType extends Entity> implements OnInit {\n    @Input()\n    arrayItems!: EntityType[];\n\n    @Input()\n    metadata!: EntityArrayDecoratorConfig<EntityType>;\n\n    @Input()\n    getValidationErrorMessage!: (model: NgModel) => string;\n\n    @Input()\n    omit!: 'create' | 'edit';\n\n    dataSource!: MatTableDataSource<EntityType>;\n\n    selection: SelectionModel<EntityType> = new SelectionModel<EntityType>(true, []);\n\n    displayedColumns!: string[];\n\n    arrayItem!: EntityType;\n\n    private arrayItemPriorChanges!: EntityType;\n\n    getWidth = EntityUtilities.getWidth;\n\n    EntityUtilities = EntityUtilities;\n\n    constructor(private readonly dialog: MatDialog) {}\n\n    trackByFn(index: unknown): unknown {\n        return index;\n    }\n\n    ngOnInit(): void {\n        this.validateInput();\n        const givenDisplayColumns = this.metadata.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.displayedColumns = ['select'].concat(givenDisplayColumns);\n        this.dataSource = new MatTableDataSource();\n        this.dataSource.data = this.arrayItems;\n        this.arrayItem = new this.metadata.EntityClass();\n        this.arrayItemPriorChanges = cloneDeep(this.arrayItem);\n    }\n    private validateInput(): void {\n        if (!this.metadata.createInline && !this.metadata.createDialogData) {\n            throw new Error(\n                `Missing required Input data \"createDialogData\".\n                You can only omit this value when the creation is inline.`\n            );\n        }\n    }\n\n    add(): void {\n        if (this.metadata.createInline) {\n            this.arrayItems.push(cloneDeep(this.arrayItem));\n            this.dataSource.data = this.arrayItems;\n            EntityUtilities.resetChangesOnEntity(this.arrayItem, this.arrayItemPriorChanges);\n        }\n        else {\n            const dialogData: AddArrayItemDialogData<EntityType> = {\n                entity: this.arrayItem,\n                createDialogData: this.metadata.createDialogData as CreateDialogData,\n                getValidationErrorMessage: this.getValidationErrorMessage\n            }\n            firstValueFrom(\n                this.dialog.open(\n                    NgxMatEntityAddArrayItemDialogComponent,\n                    {\n                        data: dialogData,\n                        autoFocus: false,\n                        restoreFocus: false\n                    }\n                ).afterClosed()\n            ).then((res: number) => {\n                if (res === 1) {\n                    this.arrayItems.push(cloneDeep(this.arrayItem));\n                    this.dataSource.data = this.arrayItems;\n                }\n                EntityUtilities.resetChangesOnEntity(this.arrayItem, this.arrayItemPriorChanges);\n            });\n        }\n    }\n    remove(): void {\n        this.selection.selected.forEach(s => {\n            this.arrayItems.splice(this.arrayItems.indexOf(s), 1);\n        });\n        this.dataSource.data = this.arrayItems;\n        this.selection.clear();\n    }\n\n    getObjectProperties(): (keyof EntityType)[] {\n        const res: (keyof EntityType)[] = [];\n        for (const property in this.arrayItem) {\n            const metadata = EntityUtilities.getPropertyMetadata(\n                this.arrayItem,\n                property as keyof Entity,\n                EntityUtilities.getPropertyType(this.arrayItem, property as keyof Entity)\n            );\n            if (!(metadata.omitForCreate)) {\n                res.push(property as keyof Entity);\n            }\n        }\n        return res.sort((a, b) => EntityUtilities.compareOrder(a, b, this.arrayItem));\n    }\n\n    masterToggle(): void {\n        if (this.isAllSelected()) {\n            this.selection.clear();\n        }\n        else {\n            this.dataSource.data.forEach((row) => this.selection.select(row));\n        }\n    }\n\n    isAllSelected(): boolean {\n        const numSelected = this.selection.selected.length;\n        const numRows = this.dataSource.data.length;\n        return numSelected === numRows;\n    }\n}","<div class=\"mat-elevation-z8\" style=\"border-radius: 5px;padding: 15px;margin-bottom: 15px;margin-top: 15px;\">\n\n    <div style=\"padding-bottom: 10px\">\n        <b>{{metadata.displayName}}</b>\n    </div>\n    <div class=\"row\" *ngIf=\"metadata.createInline\">\n        <ngx-mat-entity-internal-input\n            *ngFor=\"let key of getObjectProperties(); let i = index; trackBy: trackByFn\"\n            [entity]=\"arrayItem\"\n            [propertyKey]=\"key\"\n            [hideOmitForCreate]=\"true\"\n            [getValidationErrorMessage]=\"getValidationErrorMessage\"\n            class=\"col-lg-{{getWidth(arrayItem, key, 'lg')}} col-md-{{getWidth(arrayItem, key, 'md')}} col-sm-{{getWidth(arrayItem, key, 'sm')}}\"\n        >\n        </ngx-mat-entity-internal-input>\n    </div>\n    <div class=\"buttons\">\n        <button mat-raised-button\n            [disabled]=\"metadata.createInline && !EntityUtilities.isEntityValid(arrayItem, 'create')\"\n            (click)=\"add()\">\n            Add\n        </button>\n        <button mat-raised-button\n            [disabled]=\"!selection.selected.length\"\n            (click)=\"remove()\">\n            Remove\n        </button>\n    </div>\n\n    <mat-table [dataSource]=\"dataSource\">\n        <!-- select Column -->\n        <ng-container matColumnDef=\"select\">\n            <mat-header-cell *matHeaderCellDef>\n                <mat-checkbox (change)=\"$event ? masterToggle() : null\" [checked]=\"selection.hasValue() && isAllSelected()\" [indeterminate]=\"selection.hasValue() && !isAllSelected()\"></mat-checkbox>\n            </mat-header-cell>\n            <mat-cell *matCellDef=\"let module\" class=\"module\">\n                <mat-checkbox (click)=\"$event.stopPropagation()\" (change)=\"$event ? selection.toggle(module) : null\" [checked]=\"selection.isSelected(module)\"></mat-checkbox>\n            </mat-cell>\n        </ng-container>\n    \n        <ng-container *ngFor=\"let dCol of metadata.displayColumns\" [matColumnDef]=\"dCol.displayName\">\n            <mat-header-cell *matHeaderCellDef>\n                {{dCol.displayName}}\n            </mat-header-cell>\n            <mat-cell class=\"entity\" *matCellDef=\"let entity\">\n                {{dCol.value(entity)}}\n            </mat-cell>\n        </ng-container>\n    \n        <mat-header-row *matHeaderRowDef=\"displayedColumns\"></mat-header-row>\n        <mat-row *matRowDef=\"let row; columns: displayedColumns\"></mat-row>\n    </mat-table>\n\n    <div class=\"array-error\" *ngIf=\"metadata.required && !dataSource.data.length\">\n        {{metadata.missingErrorMessage ? metadata.missingErrorMessage : 'Needs to have at least one value'}}\n    </div>\n</div>"]}
@@ -1,66 +0,0 @@
1
- import { NgModule } from '@angular/core';
2
- import { CommonModule } from '@angular/common';
3
- import { MatInputModule } from '@angular/material/input';
4
- import { FormsModule } from '@angular/forms';
5
- import { MatFormFieldModule } from '@angular/material/form-field';
6
- import { MatSelectModule } from '@angular/material/select';
7
- import { MatAutocompleteModule } from '@angular/material/autocomplete';
8
- import { MatCheckboxModule } from '@angular/material/checkbox';
9
- import { MatSlideToggleModule } from '@angular/material/slide-toggle';
10
- import { MatTableModule } from '@angular/material/table';
11
- import { NgxMatEntityArrayTableComponent } from './array-table.component';
12
- import { NgxMatEntityInternalInputModule } from '../internal-input/internal-input.module';
13
- import { MatButtonModule } from '@angular/material/button';
14
- import { NgxMatEntityAddArrayItemDialogModule } from './add-array-item-dialog/add-array-item-dialog.module';
15
- import * as i0 from "@angular/core";
16
- export class NgxMatEntityArrayTableModule {
17
- }
18
- NgxMatEntityArrayTableModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityArrayTableModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
19
- NgxMatEntityArrayTableModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityArrayTableModule, declarations: [NgxMatEntityArrayTableComponent], imports: [CommonModule,
20
- MatInputModule,
21
- FormsModule,
22
- MatFormFieldModule,
23
- MatSelectModule,
24
- MatAutocompleteModule,
25
- MatCheckboxModule,
26
- MatSlideToggleModule,
27
- MatTableModule,
28
- NgxMatEntityInternalInputModule,
29
- MatButtonModule,
30
- NgxMatEntityAddArrayItemDialogModule], exports: [NgxMatEntityArrayTableComponent] });
31
- NgxMatEntityArrayTableModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityArrayTableModule, imports: [[
32
- CommonModule,
33
- MatInputModule,
34
- FormsModule,
35
- MatFormFieldModule,
36
- MatSelectModule,
37
- MatAutocompleteModule,
38
- MatCheckboxModule,
39
- MatSlideToggleModule,
40
- MatTableModule,
41
- NgxMatEntityInternalInputModule,
42
- MatButtonModule,
43
- NgxMatEntityAddArrayItemDialogModule
44
- ]] });
45
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityArrayTableModule, decorators: [{
46
- type: NgModule,
47
- args: [{
48
- declarations: [NgxMatEntityArrayTableComponent],
49
- imports: [
50
- CommonModule,
51
- MatInputModule,
52
- FormsModule,
53
- MatFormFieldModule,
54
- MatSelectModule,
55
- MatAutocompleteModule,
56
- MatCheckboxModule,
57
- MatSlideToggleModule,
58
- MatTableModule,
59
- NgxMatEntityInternalInputModule,
60
- MatButtonModule,
61
- NgxMatEntityAddArrayItemDialogModule
62
- ],
63
- exports: [NgxMatEntityArrayTableComponent]
64
- }]
65
- }] });
66
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJyYXktdGFibGUubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW1hdGVyaWFsLWVudGl0eS9zcmMvY29tcG9uZW50cy9pbnB1dC9hcnJheS10YWJsZS9hcnJheS10YWJsZS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDdkUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDL0QsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDdEUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSwrQkFBK0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzFFLE9BQU8sRUFBRSwrQkFBK0IsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBQzFGLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsb0NBQW9DLEVBQUUsTUFBTSxzREFBc0QsQ0FBQzs7QUFvQjVHLE1BQU0sT0FBTyw0QkFBNEI7OzBIQUE1Qiw0QkFBNEI7MkhBQTVCLDRCQUE0QixpQkFqQnRCLCtCQUErQixhQUUxQyxZQUFZO1FBQ1osY0FBYztRQUNkLFdBQVc7UUFDWCxrQkFBa0I7UUFDbEIsZUFBZTtRQUNmLHFCQUFxQjtRQUNyQixpQkFBaUI7UUFDakIsb0JBQW9CO1FBQ3BCLGNBQWM7UUFDZCwrQkFBK0I7UUFDL0IsZUFBZTtRQUNmLG9DQUFvQyxhQUU5QiwrQkFBK0I7MkhBRWhDLDRCQUE0QixZQWhCNUI7WUFDTCxZQUFZO1lBQ1osY0FBYztZQUNkLFdBQVc7WUFDWCxrQkFBa0I7WUFDbEIsZUFBZTtZQUNmLHFCQUFxQjtZQUNyQixpQkFBaUI7WUFDakIsb0JBQW9CO1lBQ3BCLGNBQWM7WUFDZCwrQkFBK0I7WUFDL0IsZUFBZTtZQUNmLG9DQUFvQztTQUN2Qzs0RkFHUSw0QkFBNEI7a0JBbEJ4QyxRQUFRO21CQUFDO29CQUNOLFlBQVksRUFBRSxDQUFDLCtCQUErQixDQUFDO29CQUMvQyxPQUFPLEVBQUU7d0JBQ0wsWUFBWTt3QkFDWixjQUFjO3dCQUNkLFdBQVc7d0JBQ1gsa0JBQWtCO3dCQUNsQixlQUFlO3dCQUNmLHFCQUFxQjt3QkFDckIsaUJBQWlCO3dCQUNqQixvQkFBb0I7d0JBQ3BCLGNBQWM7d0JBQ2QsK0JBQStCO3dCQUMvQixlQUFlO3dCQUNmLG9DQUFvQztxQkFDdkM7b0JBQ0QsT0FBTyxFQUFFLENBQUMsK0JBQStCLENBQUM7aUJBQzdDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBNYXRJbnB1dE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2lucHV0JztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgTWF0Rm9ybUZpZWxkTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZm9ybS1maWVsZCc7XG5pbXBvcnQgeyBNYXRTZWxlY3RNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9zZWxlY3QnO1xuaW1wb3J0IHsgTWF0QXV0b2NvbXBsZXRlTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYXV0b2NvbXBsZXRlJztcbmltcG9ydCB7IE1hdENoZWNrYm94TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY2hlY2tib3gnO1xuaW1wb3J0IHsgTWF0U2xpZGVUb2dnbGVNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9zbGlkZS10b2dnbGUnO1xuaW1wb3J0IHsgTWF0VGFibGVNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC90YWJsZSc7XG5pbXBvcnQgeyBOZ3hNYXRFbnRpdHlBcnJheVRhYmxlQ29tcG9uZW50IH0gZnJvbSAnLi9hcnJheS10YWJsZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgTmd4TWF0RW50aXR5SW50ZXJuYWxJbnB1dE1vZHVsZSB9IGZyb20gJy4uL2ludGVybmFsLWlucHV0L2ludGVybmFsLWlucHV0Lm1vZHVsZSc7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgTmd4TWF0RW50aXR5QWRkQXJyYXlJdGVtRGlhbG9nTW9kdWxlIH0gZnJvbSAnLi9hZGQtYXJyYXktaXRlbS1kaWFsb2cvYWRkLWFycmF5LWl0ZW0tZGlhbG9nLm1vZHVsZSc7XG5cbkBOZ01vZHVsZSh7XG4gICAgZGVjbGFyYXRpb25zOiBbTmd4TWF0RW50aXR5QXJyYXlUYWJsZUNvbXBvbmVudF0sXG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsXG4gICAgICAgIE1hdElucHV0TW9kdWxlLFxuICAgICAgICBGb3Jtc01vZHVsZSxcbiAgICAgICAgTWF0Rm9ybUZpZWxkTW9kdWxlLFxuICAgICAgICBNYXRTZWxlY3RNb2R1bGUsXG4gICAgICAgIE1hdEF1dG9jb21wbGV0ZU1vZHVsZSxcbiAgICAgICAgTWF0Q2hlY2tib3hNb2R1bGUsXG4gICAgICAgIE1hdFNsaWRlVG9nZ2xlTW9kdWxlLFxuICAgICAgICBNYXRUYWJsZU1vZHVsZSxcbiAgICAgICAgTmd4TWF0RW50aXR5SW50ZXJuYWxJbnB1dE1vZHVsZSxcbiAgICAgICAgTWF0QnV0dG9uTW9kdWxlLFxuICAgICAgICBOZ3hNYXRFbnRpdHlBZGRBcnJheUl0ZW1EaWFsb2dNb2R1bGVcbiAgICBdLFxuICAgIGV4cG9ydHM6IFtOZ3hNYXRFbnRpdHlBcnJheVRhYmxlQ29tcG9uZW50XVxufSlcbmV4cG9ydCBjbGFzcyBOZ3hNYXRFbnRpdHlBcnJheVRhYmxlTW9kdWxlIHt9Il19
@@ -1,73 +0,0 @@
1
- import { Component, Input } from '@angular/core';
2
- import { DecoratorTypes } from '../../../decorators/base/decorator-types.enum';
3
- import { EntityUtilities } from '../../../classes/entity-utilities.class';
4
- import * as i0 from "@angular/core";
5
- import * as i1 from "@angular/material/form-field";
6
- import * as i2 from "@angular/material/autocomplete";
7
- import * as i3 from "@angular/material/core";
8
- import * as i4 from "@angular/material/select";
9
- import * as i5 from "@angular/material/checkbox";
10
- import * as i6 from "@angular/material/slide-toggle";
11
- import * as i7 from "@angular/common";
12
- import * as i8 from "@angular/material/input";
13
- import * as i9 from "@angular/forms";
14
- import * as i10 from "@angular/cdk/text-field";
15
- export class NgxMatEntityInternalInputComponent {
16
- constructor() {
17
- this.DecoratorTypes = DecoratorTypes;
18
- this.getWidth = EntityUtilities.getWidth;
19
- }
20
- /**
21
- * Helper method needed to recursively generate property input components (used eg. with the object)
22
- */
23
- trackByFn(index) {
24
- return index;
25
- }
26
- ngOnInit() {
27
- if (!this.entity) {
28
- throw new Error('Missing required Input data "entity"');
29
- }
30
- if (!this.propertyKey) {
31
- throw new Error('Missing required Input data "propertyKey"');
32
- }
33
- this.type = EntityUtilities.getPropertyType(this.entity, this.propertyKey);
34
- this.metadata = EntityUtilities.getPropertyMetadata(this.entity, this.propertyKey, this.type);
35
- this.metadataDefaultString = this.metadata;
36
- this.metadataTextboxString = this.metadata;
37
- this.metadataAutocompleteString = this.metadata;
38
- this.metadataDropdownString = this.metadata;
39
- this.metadataDropdownBoolean = this.metadata;
40
- this.metadataDefaultNumber = this.metadata;
41
- this.metadataDropdownNumber = this.metadata;
42
- this.metadataDefaultObject = this.metadata;
43
- this.objectProperty = this.entity[this.propertyKey];
44
- }
45
- getObjectProperties() {
46
- const res = [];
47
- for (const property in this.objectProperty) {
48
- const metadata = EntityUtilities.getPropertyMetadata(this.objectProperty, property, EntityUtilities.getPropertyType(this.objectProperty, property));
49
- if (!(this.hideOmitForCreate && metadata.omitForCreate)
50
- && !(this.hideOmitForEdit && metadata.omitForUpdate)) {
51
- res.push(property);
52
- }
53
- }
54
- return res.sort((a, b) => EntityUtilities.compareOrder(a, b, this.objectProperty));
55
- }
56
- }
57
- NgxMatEntityInternalInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityInternalInputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
58
- NgxMatEntityInternalInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: NgxMatEntityInternalInputComponent, selector: "ngx-mat-entity-internal-input", inputs: { entity: "entity", propertyKey: "propertyKey", hideOmitForCreate: "hideOmitForCreate", hideOmitForEdit: "hideOmitForEdit", getValidationErrorMessage: "getValidationErrorMessage" }, ngImport: i0, template: "<div [ngSwitch]=\"type\" *ngIf=\"!(hideOmitForCreate && metadata.omitForCreate) && !(hideOmitForEdit && metadata.omitForUpdate)\">\n <!-------------------------------------------->\n <!-----------------Strings-------------------->\n <!-------------------------------------------->\n <div *ngSwitchCase=\"DecoratorTypes.STRING\">\n <mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <input\n matInput\n [(ngModel)]=\"entity[propertyKey]\"\n [name]=\"propertyKey.toString()\"\n #model=\"ngModel\"\n [pattern]=\"metadataDefaultString.regex ? metadataDefaultString.regex : '[\\\\s\\\\S]*'\"\n [minlength]=\"metadataDefaultString.minLength ? metadataDefaultString.minLength : null\"\n [maxlength]=\"metadataDefaultString.maxLength ? metadataDefaultString.maxLength : null\"\n />\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n </mat-form-field>\n </div>\n\n <div *ngSwitchCase=\"DecoratorTypes.STRING_TEXTBOX\">\n <mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <textarea\n matInput\n [(ngModel)]=\"entity[propertyKey]\"\n [name]=\"propertyKey.toString()\"\n #model=\"ngModel\"\n cdkTextareaAutosize\n cdkAutosizeMinRows=\"10\"\n [minlength]=\"metadataTextboxString.minLength ? metadataTextboxString.minLength : null\"\n [maxlength]=\"metadataTextboxString.maxLength ? metadataTextboxString.maxLength : null\"\n >\n </textarea>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n </mat-form-field>\n </div>\n\n <div *ngSwitchCase=\"DecoratorTypes.STRING_AUTOCOMPLETE\">\n <mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <input\n matInput\n [(ngModel)]=\"entity[propertyKey]\"\n [name]=\"propertyKey.toString()\"\n #model=\"ngModel\"\n [matAutocomplete]=\"auto\"\n [minlength]=\"metadataAutocompleteString.minLength ? metadataAutocompleteString.minLength : null\"\n [maxlength]=\"metadataAutocompleteString.maxLength ? metadataAutocompleteString.maxLength : null\"\n [pattern]=\"metadataAutocompleteString.regex ? metadataAutocompleteString.regex : '[\\\\s\\\\S]*'\"\n />\n <mat-autocomplete #auto=\"matAutocomplete\">\n <mat-option *ngFor=\"let value of metadataAutocompleteString.autocompleteValues\" [value]=\"value\">\n {{value}}\n </mat-option>\n </mat-autocomplete>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n </mat-form-field>\n </div>\n\n <div *ngSwitchCase=\"DecoratorTypes.STRING_DROPDOWN\">\n <mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <mat-select [(ngModel)]=\"entity[propertyKey]\" [name]=\"propertyKey.toString()\" #model=\"ngModel\">\n <mat-option *ngFor=\"let value of metadataDropdownString.dropdownValues\" [value]=\"value.value\">{{value.displayName}}</mat-option>\n </mat-select>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n </mat-form-field>\n </div>\n\n <!-------------------------------------------->\n <!-----------------Booleans------------------->\n <!-------------------------------------------->\n <div *ngSwitchCase=\"DecoratorTypes.BOOLEAN_CHECKBOX\">\n <mat-form-field>\n <mat-checkbox [(ngModel)]=\"entity[propertyKey]\" [name]=\"propertyKey.toString()\" #model=\"ngModel\">\n {{metadata.displayName}}\n </mat-checkbox>\n <!-- hidden input is needed so that the checkbox can be used inside a mat-form-field -->\n <textarea matInput hidden></textarea>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n </mat-form-field>\n </div>\n\n <div *ngSwitchCase=\"DecoratorTypes.BOOLEAN_TOGGLE\">\n <mat-form-field>\n <mat-slide-toggle [(ngModel)]=\"entity[propertyKey]\" [name]=\"propertyKey.toString()\" #model=\"ngModel\">\n {{metadata.displayName}}\n </mat-slide-toggle>\n <!-- hidden input is needed so that the toggle can be used inside a mat-form-field -->\n <textarea matInput hidden></textarea>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n </mat-form-field>\n </div>\n\n <div *ngSwitchCase=\"DecoratorTypes.BOOLEAN_DROPDOWN\">\n <mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <mat-select [(ngModel)]=\"entity[propertyKey]\" [name]=\"propertyKey.toString()\" #model=\"ngModel\">\n <mat-option [value]=\"undefined\">-</mat-option>\n <mat-option [value]=\"true\">{{metadataDropdownBoolean.dropdownTrue}}</mat-option>\n <mat-option [value]=\"false\">{{metadataDropdownBoolean.dropdownFalse}}</mat-option>\n </mat-select>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n </mat-form-field>\n </div>\n\n <!-------------------------------------------->\n <!------------------Numbers------------------->\n <!-------------------------------------------->\n <div *ngSwitchCase=\"DecoratorTypes.NUMBER\">\n <mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <input\n matInput\n type=\"number\"\n [(ngModel)]=\"entity[propertyKey]\"\n [name]=\"propertyKey.toString()\"\n #model=\"ngModel\"\n [min]=\"metadataDefaultNumber.min ? metadataDefaultNumber.min : null\"\n [max]=\"metadataDefaultNumber.max ? metadataDefaultNumber.max : null\"\n />\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n </mat-form-field>\n </div>\n\n <div *ngSwitchCase=\"DecoratorTypes.NUMBER_DROPDOWN\">\n <mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <mat-select [(ngModel)]=\"entity[propertyKey]\" [name]=\"propertyKey.toString()\" #model=\"ngModel\">\n <mat-option *ngFor=\"let value of metadataDropdownNumber.dropdownValues\" [value]=\"value.value\">{{value.displayName}}</mat-option>\n </mat-select>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n </mat-form-field>\n </div>\n\n <!-------------------------------------------->\n <!-------------------Object------------------->\n <!-------------------------------------------->\n <div *ngSwitchCase=\"DecoratorTypes.OBJECT\">\n <b>{{metadataDefaultObject.displayName}}</b>\n <!-- iterates over the object properties -->\n <div class=\"row\">\n <!--\n displays another ngx-material-entity with the:\n object as the entity,\n the current key in the loop received by the keyvalue direction as the propertyKey\n and the getValidationErrorMessage of the current component\n -->\n <ngx-mat-entity-internal-input\n *ngFor=\"let key of getObjectProperties(); let i = index; trackBy: trackByFn\"\n [entity]=\"objectProperty\"\n [propertyKey]=\"key\"\n [getValidationErrorMessage]=\"getValidationErrorMessage\"\n [hideOmitForCreate]=\"hideOmitForCreate\"\n [hideOmitForEdit]=\"hideOmitForEdit\"\n class=\"col-lg-{{getWidth(objectProperty, key, 'lg')}} col-md-{{getWidth(objectProperty, key, 'md')}} col-sm-{{getWidth(objectProperty, key, 'sm')}}\"\n >\n </ngx-mat-entity-internal-input>\n </div>\n </div>\n\n <div *ngSwitchDefault>ERROR: The type {{type}}is not known.</div>\n</div>", styles: ["mat-form-field{width:100%}\n"], components: [{ type: i1.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { type: i2.MatAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple"], exportAs: ["matAutocomplete"] }, { type: i3.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { type: i4.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { type: i5.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex", "aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { type: i6.MatSlideToggle, selector: "mat-slide-toggle", inputs: ["disabled", "disableRipple", "color", "tabIndex", "name", "id", "labelPosition", "aria-label", "aria-labelledby", "aria-describedby", "required", "checked"], outputs: ["change", "toggleChange"], exportAs: ["matSlideToggle"] }, { type: NgxMatEntityInternalInputComponent, selector: "ngx-mat-entity-internal-input", inputs: ["entity", "propertyKey", "hideOmitForCreate", "hideOmitForEdit", "getValidationErrorMessage"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i7.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i1.MatLabel, selector: "mat-label" }, { type: i8.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"] }, { type: i9.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i9.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i9.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { type: i9.MinLengthValidator, selector: "[minlength][formControlName],[minlength][formControl],[minlength][ngModel]", inputs: ["minlength"] }, { type: i9.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { type: i1.MatError, selector: "mat-error", inputs: ["id"] }, { type: i10.CdkTextareaAutosize, selector: "textarea[cdkTextareaAutosize]", inputs: ["cdkAutosizeMinRows", "cdkAutosizeMaxRows", "cdkTextareaAutosize", "placeholder"], exportAs: ["cdkTextareaAutosize"] }, { type: i2.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i9.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { type: i9.MinValidator, selector: "input[type=number][min][formControlName],input[type=number][min][formControl],input[type=number][min][ngModel]", inputs: ["min"] }, { type: i9.MaxValidator, selector: "input[type=number][max][formControlName],input[type=number][max][formControl],input[type=number][max][ngModel]", inputs: ["max"] }, { type: i7.NgSwitchDefault, selector: "[ngSwitchDefault]" }] });
59
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityInternalInputComponent, decorators: [{
60
- type: Component,
61
- args: [{ selector: 'ngx-mat-entity-internal-input', template: "<div [ngSwitch]=\"type\" *ngIf=\"!(hideOmitForCreate && metadata.omitForCreate) && !(hideOmitForEdit && metadata.omitForUpdate)\">\n <!-------------------------------------------->\n <!-----------------Strings-------------------->\n <!-------------------------------------------->\n <div *ngSwitchCase=\"DecoratorTypes.STRING\">\n <mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <input\n matInput\n [(ngModel)]=\"entity[propertyKey]\"\n [name]=\"propertyKey.toString()\"\n #model=\"ngModel\"\n [pattern]=\"metadataDefaultString.regex ? metadataDefaultString.regex : '[\\\\s\\\\S]*'\"\n [minlength]=\"metadataDefaultString.minLength ? metadataDefaultString.minLength : null\"\n [maxlength]=\"metadataDefaultString.maxLength ? metadataDefaultString.maxLength : null\"\n />\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n </mat-form-field>\n </div>\n\n <div *ngSwitchCase=\"DecoratorTypes.STRING_TEXTBOX\">\n <mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <textarea\n matInput\n [(ngModel)]=\"entity[propertyKey]\"\n [name]=\"propertyKey.toString()\"\n #model=\"ngModel\"\n cdkTextareaAutosize\n cdkAutosizeMinRows=\"10\"\n [minlength]=\"metadataTextboxString.minLength ? metadataTextboxString.minLength : null\"\n [maxlength]=\"metadataTextboxString.maxLength ? metadataTextboxString.maxLength : null\"\n >\n </textarea>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n </mat-form-field>\n </div>\n\n <div *ngSwitchCase=\"DecoratorTypes.STRING_AUTOCOMPLETE\">\n <mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <input\n matInput\n [(ngModel)]=\"entity[propertyKey]\"\n [name]=\"propertyKey.toString()\"\n #model=\"ngModel\"\n [matAutocomplete]=\"auto\"\n [minlength]=\"metadataAutocompleteString.minLength ? metadataAutocompleteString.minLength : null\"\n [maxlength]=\"metadataAutocompleteString.maxLength ? metadataAutocompleteString.maxLength : null\"\n [pattern]=\"metadataAutocompleteString.regex ? metadataAutocompleteString.regex : '[\\\\s\\\\S]*'\"\n />\n <mat-autocomplete #auto=\"matAutocomplete\">\n <mat-option *ngFor=\"let value of metadataAutocompleteString.autocompleteValues\" [value]=\"value\">\n {{value}}\n </mat-option>\n </mat-autocomplete>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n </mat-form-field>\n </div>\n\n <div *ngSwitchCase=\"DecoratorTypes.STRING_DROPDOWN\">\n <mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <mat-select [(ngModel)]=\"entity[propertyKey]\" [name]=\"propertyKey.toString()\" #model=\"ngModel\">\n <mat-option *ngFor=\"let value of metadataDropdownString.dropdownValues\" [value]=\"value.value\">{{value.displayName}}</mat-option>\n </mat-select>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n </mat-form-field>\n </div>\n\n <!-------------------------------------------->\n <!-----------------Booleans------------------->\n <!-------------------------------------------->\n <div *ngSwitchCase=\"DecoratorTypes.BOOLEAN_CHECKBOX\">\n <mat-form-field>\n <mat-checkbox [(ngModel)]=\"entity[propertyKey]\" [name]=\"propertyKey.toString()\" #model=\"ngModel\">\n {{metadata.displayName}}\n </mat-checkbox>\n <!-- hidden input is needed so that the checkbox can be used inside a mat-form-field -->\n <textarea matInput hidden></textarea>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n </mat-form-field>\n </div>\n\n <div *ngSwitchCase=\"DecoratorTypes.BOOLEAN_TOGGLE\">\n <mat-form-field>\n <mat-slide-toggle [(ngModel)]=\"entity[propertyKey]\" [name]=\"propertyKey.toString()\" #model=\"ngModel\">\n {{metadata.displayName}}\n </mat-slide-toggle>\n <!-- hidden input is needed so that the toggle can be used inside a mat-form-field -->\n <textarea matInput hidden></textarea>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n </mat-form-field>\n </div>\n\n <div *ngSwitchCase=\"DecoratorTypes.BOOLEAN_DROPDOWN\">\n <mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <mat-select [(ngModel)]=\"entity[propertyKey]\" [name]=\"propertyKey.toString()\" #model=\"ngModel\">\n <mat-option [value]=\"undefined\">-</mat-option>\n <mat-option [value]=\"true\">{{metadataDropdownBoolean.dropdownTrue}}</mat-option>\n <mat-option [value]=\"false\">{{metadataDropdownBoolean.dropdownFalse}}</mat-option>\n </mat-select>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n </mat-form-field>\n </div>\n\n <!-------------------------------------------->\n <!------------------Numbers------------------->\n <!-------------------------------------------->\n <div *ngSwitchCase=\"DecoratorTypes.NUMBER\">\n <mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <input\n matInput\n type=\"number\"\n [(ngModel)]=\"entity[propertyKey]\"\n [name]=\"propertyKey.toString()\"\n #model=\"ngModel\"\n [min]=\"metadataDefaultNumber.min ? metadataDefaultNumber.min : null\"\n [max]=\"metadataDefaultNumber.max ? metadataDefaultNumber.max : null\"\n />\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n </mat-form-field>\n </div>\n\n <div *ngSwitchCase=\"DecoratorTypes.NUMBER_DROPDOWN\">\n <mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <mat-select [(ngModel)]=\"entity[propertyKey]\" [name]=\"propertyKey.toString()\" #model=\"ngModel\">\n <mat-option *ngFor=\"let value of metadataDropdownNumber.dropdownValues\" [value]=\"value.value\">{{value.displayName}}</mat-option>\n </mat-select>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n </mat-form-field>\n </div>\n\n <!-------------------------------------------->\n <!-------------------Object------------------->\n <!-------------------------------------------->\n <div *ngSwitchCase=\"DecoratorTypes.OBJECT\">\n <b>{{metadataDefaultObject.displayName}}</b>\n <!-- iterates over the object properties -->\n <div class=\"row\">\n <!--\n displays another ngx-material-entity with the:\n object as the entity,\n the current key in the loop received by the keyvalue direction as the propertyKey\n and the getValidationErrorMessage of the current component\n -->\n <ngx-mat-entity-internal-input\n *ngFor=\"let key of getObjectProperties(); let i = index; trackBy: trackByFn\"\n [entity]=\"objectProperty\"\n [propertyKey]=\"key\"\n [getValidationErrorMessage]=\"getValidationErrorMessage\"\n [hideOmitForCreate]=\"hideOmitForCreate\"\n [hideOmitForEdit]=\"hideOmitForEdit\"\n class=\"col-lg-{{getWidth(objectProperty, key, 'lg')}} col-md-{{getWidth(objectProperty, key, 'md')}} col-sm-{{getWidth(objectProperty, key, 'sm')}}\"\n >\n </ngx-mat-entity-internal-input>\n </div>\n </div>\n\n <div *ngSwitchDefault>ERROR: The type {{type}}is not known.</div>\n</div>", styles: ["mat-form-field{width:100%}\n"] }]
62
- }], propDecorators: { entity: [{
63
- type: Input
64
- }], propertyKey: [{
65
- type: Input
66
- }], hideOmitForCreate: [{
67
- type: Input
68
- }], hideOmitForEdit: [{
69
- type: Input
70
- }], getValidationErrorMessage: [{
71
- type: Input
72
- }] } });
73
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"internal-input.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-material-entity/src/components/input/internal-input/internal-input.component.ts","../../../../../../projects/ngx-material-entity/src/components/input/internal-input/internal-input.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;AACzD,OAAO,EAAE,cAAc,EAAE,MAAM,+CAA+C,CAAC;AAO/E,OAAO,EAAE,eAAe,EAAE,MAAM,yCAAyC,CAAC;;;;;;;;;;;;AAQ1E,MAAM,OAAO,kCAAkC;IAL/C;QAwDa,mBAAc,GAAG,cAAc,CAAC;QAEzC,aAAQ,GAAG,eAAe,CAAC,QAAQ,CAAC;KAkDvC;IAhDG;;OAEG;IACH,SAAS,CAAC,KAAc;QACpB,OAAO,KAAK,CAAC;IACjB,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YACd,MAAM,IAAI,KAAK,CAAC,sCAAsC,CAAC,CAAC;SAC3D;QACD,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;YACnB,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;SAChE;QACD,IAAI,CAAC,IAAI,GAAG,eAAe,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;QAC3E,IAAI,CAAC,QAAQ,GAAG,eAAe,CAAC,mBAAmB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;QAE9F,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,QAAwC,CAAC;QAC3E,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,QAAwC,CAAC;QAC3E,IAAI,CAAC,0BAA0B,GAAG,IAAI,CAAC,QAA6C,CAAC;QACrF,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC,QAAyC,CAAC;QAE7E,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC,QAA0C,CAAC;QAE/E,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,QAAwC,CAAC;QAC3E,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC,QAAyC,CAAC;QAE7E,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,QAAwC,CAAC;QAC3E,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAsB,CAAC;IAC7E,CAAC;IAED,mBAAmB;QACf,MAAM,GAAG,GAAqB,EAAE,CAAC;QACjC,KAAK,MAAM,QAAQ,IAAI,IAAI,CAAC,cAAc,EAAE;YACxC,MAAM,QAAQ,GAAG,eAAe,CAAC,mBAAmB,CAChD,IAAI,CAAC,cAAc,EAClB,QAAwB,EACxB,eAAe,CAAC,eAAe,CAAC,IAAI,CAAC,cAAc,EAAE,QAAwB,CAAC,CAClF,CAAC;YACF,IACI,CAAC,CAAC,IAAI,CAAC,iBAAiB,IAAI,QAAQ,CAAC,aAAa,CAAC;mBAC/C,CAAC,CAAC,IAAI,CAAC,eAAe,IAAI,QAAQ,CAAC,aAAa,CAAC,EACvD;gBACE,GAAG,CAAC,IAAI,CAAC,QAAwB,CAAC,CAAC;aACtC;SACJ;QACD,OAAO,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,eAAe,CAAC,YAAY,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC;IACvF,CAAC;;gIAtGQ,kCAAkC;oHAAlC,kCAAkC,mQChB/C,0iQAmKM,koCDnJO,kCAAkC;4FAAlC,kCAAkC;kBAL9C,SAAS;+BACI,+BAA+B;8BAUzC,MAAM;sBADL,KAAK;gBAON,WAAW;sBADV,KAAK;gBAQN,iBAAiB;sBADhB,KAAK;gBAQN,eAAe;sBADd,KAAK;gBAON,yBAAyB;sBADxB,KAAK","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { DecoratorTypes } from '../../../decorators/base/decorator-types.enum';\nimport { PropertyDecoratorConfig } from '../../../decorators/base/property-decorator-config.interface';\nimport { DefaultNumberDecoratorConfig, DropdownNumberDecoratorConfig } from '../../../decorators/number.decorator';\nimport { AutocompleteStringDecoratorConfig, DefaultStringDecoratorConfig, DropdownStringDecoratorConfig, TextboxStringDecoratorConfig } from '../../../decorators/string.decorator';\nimport { DropdownBooleanDecoratorConfig } from '../../../decorators/boolean.decorator';\nimport { Entity } from '../../../classes/entity-model.class';\nimport { DefaultObjectDecoratorConfig } from '../../../decorators/object.decorator';\nimport { EntityUtilities } from '../../../classes/entity-utilities.class';\nimport { NgModel } from '@angular/forms';\n\n@Component({\n    selector: 'ngx-mat-entity-internal-input',\n    templateUrl: './internal-input.component.html',\n    styleUrls: ['./internal-input.component.scss']\n})\nexport class NgxMatEntityInternalInputComponent<EntityType extends Entity> implements OnInit {\n    /**\n     * The entity on which the property exists. Used in conjuction with the \"propertyKey\"\n     * to determine the property for which the input should be generated.\n     */\n    @Input()\n    entity!: EntityType;\n\n    /**\n     * The name of the property to generate the input for. Used in conjuction with the \"entity\".\n     */\n    @Input()\n    propertyKey!: keyof EntityType;\n\n    /**\n     * Whether to hide a value if it is omitted for creation.\n     * Is used internally for the object property.\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     */\n    @Input()\n    hideOmitForEdit?: boolean;\n\n    /**\n     * (optional) A custom function to generate the error-message for invalid inputs.\n     */\n    @Input()\n    getValidationErrorMessage!: (model: NgModel) => string;\n\n    type!: DecoratorTypes;\n\n    metadata!: PropertyDecoratorConfig;\n\n    metadataDefaultString!: DefaultStringDecoratorConfig;\n    metadataTextboxString!: TextboxStringDecoratorConfig;\n    metadataAutocompleteString!: AutocompleteStringDecoratorConfig;\n    metadataDropdownString!: DropdownStringDecoratorConfig;\n\n    metadataDropdownBoolean!: DropdownBooleanDecoratorConfig;\n\n    metadataDefaultNumber!: DefaultNumberDecoratorConfig;\n    metadataDropdownNumber!: DropdownNumberDecoratorConfig;\n\n    metadataDefaultObject!: DefaultObjectDecoratorConfig;\n    objectProperty!: Entity;\n\n    readonly DecoratorTypes = DecoratorTypes;\n\n    getWidth = EntityUtilities.getWidth;\n\n    /**\n     * Helper method needed to recursively generate property input components (used eg. with the object)\n     */\n    trackByFn(index: unknown): unknown {\n        return index;\n    }\n\n    ngOnInit(): void {\n        if (!this.entity) {\n            throw new Error('Missing required Input data \"entity\"');\n        }\n        if (!this.propertyKey) {\n            throw new Error('Missing required Input data \"propertyKey\"');\n        }\n        this.type = EntityUtilities.getPropertyType(this.entity, this.propertyKey);\n        this.metadata = EntityUtilities.getPropertyMetadata(this.entity, this.propertyKey, this.type);\n\n        this.metadataDefaultString = this.metadata as DefaultStringDecoratorConfig;\n        this.metadataTextboxString = this.metadata as TextboxStringDecoratorConfig;\n        this.metadataAutocompleteString = this.metadata as AutocompleteStringDecoratorConfig;\n        this.metadataDropdownString = this.metadata as DropdownStringDecoratorConfig;\n\n        this.metadataDropdownBoolean = this.metadata as DropdownBooleanDecoratorConfig;\n\n        this.metadataDefaultNumber = this.metadata as DefaultNumberDecoratorConfig;\n        this.metadataDropdownNumber = this.metadata as DropdownNumberDecoratorConfig;\n\n        this.metadataDefaultObject = this.metadata as DefaultObjectDecoratorConfig;\n        this.objectProperty = this.entity[this.propertyKey] as unknown as Entity;\n    }\n\n    getObjectProperties(): (keyof Entity)[] {\n        const res: (keyof Entity)[] = [];\n        for (const property in this.objectProperty) {\n            const metadata = EntityUtilities.getPropertyMetadata(\n                this.objectProperty,\n                 property as keyof Entity,\n                 EntityUtilities.getPropertyType(this.objectProperty, property as keyof Entity)\n            );\n            if (\n                !(this.hideOmitForCreate && metadata.omitForCreate)\n                 && !(this.hideOmitForEdit && metadata.omitForUpdate)\n            ) {\n                res.push(property as keyof Entity);\n            }\n        }\n        return res.sort((a, b) => EntityUtilities.compareOrder(a, b, this.objectProperty));\n    }\n}","<div [ngSwitch]=\"type\" *ngIf=\"!(hideOmitForCreate && metadata.omitForCreate) && !(hideOmitForEdit && metadata.omitForUpdate)\">\n    <!-------------------------------------------->\n    <!-----------------Strings-------------------->\n    <!-------------------------------------------->\n    <div *ngSwitchCase=\"DecoratorTypes.STRING\">\n        <mat-form-field>\n            <mat-label>{{metadata.displayName}}</mat-label>\n            <input\n                matInput\n                [(ngModel)]=\"entity[propertyKey]\"\n                [name]=\"propertyKey.toString()\"\n                #model=\"ngModel\"\n                [pattern]=\"metadataDefaultString.regex ? metadataDefaultString.regex : '[\\\\s\\\\S]*'\"\n                [minlength]=\"metadataDefaultString.minLength ? metadataDefaultString.minLength : null\"\n                [maxlength]=\"metadataDefaultString.maxLength ? metadataDefaultString.maxLength : null\"\n            />\n            <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n        </mat-form-field>\n    </div>\n\n    <div *ngSwitchCase=\"DecoratorTypes.STRING_TEXTBOX\">\n        <mat-form-field>\n            <mat-label>{{metadata.displayName}}</mat-label>\n            <textarea\n                matInput\n                [(ngModel)]=\"entity[propertyKey]\"\n                [name]=\"propertyKey.toString()\"\n                #model=\"ngModel\"\n                cdkTextareaAutosize\n                cdkAutosizeMinRows=\"10\"\n                [minlength]=\"metadataTextboxString.minLength ? metadataTextboxString.minLength : null\"\n                [maxlength]=\"metadataTextboxString.maxLength ? metadataTextboxString.maxLength : null\"\n            >\n            </textarea>\n            <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n        </mat-form-field>\n    </div>\n\n    <div *ngSwitchCase=\"DecoratorTypes.STRING_AUTOCOMPLETE\">\n        <mat-form-field>\n            <mat-label>{{metadata.displayName}}</mat-label>\n            <input\n                matInput\n                [(ngModel)]=\"entity[propertyKey]\"\n                [name]=\"propertyKey.toString()\"\n                #model=\"ngModel\"\n                [matAutocomplete]=\"auto\"\n                [minlength]=\"metadataAutocompleteString.minLength ? metadataAutocompleteString.minLength : null\"\n                [maxlength]=\"metadataAutocompleteString.maxLength ? metadataAutocompleteString.maxLength : null\"\n                [pattern]=\"metadataAutocompleteString.regex ? metadataAutocompleteString.regex : '[\\\\s\\\\S]*'\"\n            />\n            <mat-autocomplete #auto=\"matAutocomplete\">\n                <mat-option *ngFor=\"let value of metadataAutocompleteString.autocompleteValues\" [value]=\"value\">\n                    {{value}}\n                </mat-option>\n            </mat-autocomplete>\n            <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n        </mat-form-field>\n    </div>\n\n    <div *ngSwitchCase=\"DecoratorTypes.STRING_DROPDOWN\">\n        <mat-form-field>\n            <mat-label>{{metadata.displayName}}</mat-label>\n            <mat-select [(ngModel)]=\"entity[propertyKey]\" [name]=\"propertyKey.toString()\" #model=\"ngModel\">\n                <mat-option *ngFor=\"let value of metadataDropdownString.dropdownValues\" [value]=\"value.value\">{{value.displayName}}</mat-option>\n            </mat-select>\n            <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n        </mat-form-field>\n    </div>\n\n    <!-------------------------------------------->\n    <!-----------------Booleans------------------->\n    <!-------------------------------------------->\n    <div *ngSwitchCase=\"DecoratorTypes.BOOLEAN_CHECKBOX\">\n        <mat-form-field>\n            <mat-checkbox [(ngModel)]=\"entity[propertyKey]\" [name]=\"propertyKey.toString()\" #model=\"ngModel\">\n                {{metadata.displayName}}\n            </mat-checkbox>\n            <!-- hidden input is needed so that the checkbox can be used inside a mat-form-field -->\n            <textarea matInput hidden></textarea>\n            <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n        </mat-form-field>\n    </div>\n\n    <div *ngSwitchCase=\"DecoratorTypes.BOOLEAN_TOGGLE\">\n        <mat-form-field>\n            <mat-slide-toggle [(ngModel)]=\"entity[propertyKey]\" [name]=\"propertyKey.toString()\" #model=\"ngModel\">\n                {{metadata.displayName}}\n            </mat-slide-toggle>\n            <!-- hidden input is needed so that the toggle can be used inside a mat-form-field -->\n            <textarea matInput hidden></textarea>\n            <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n        </mat-form-field>\n    </div>\n\n    <div *ngSwitchCase=\"DecoratorTypes.BOOLEAN_DROPDOWN\">\n        <mat-form-field>\n            <mat-label>{{metadata.displayName}}</mat-label>\n            <mat-select [(ngModel)]=\"entity[propertyKey]\" [name]=\"propertyKey.toString()\" #model=\"ngModel\">\n                <mat-option [value]=\"undefined\">-</mat-option>\n                <mat-option [value]=\"true\">{{metadataDropdownBoolean.dropdownTrue}}</mat-option>\n                <mat-option [value]=\"false\">{{metadataDropdownBoolean.dropdownFalse}}</mat-option>\n            </mat-select>\n            <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n        </mat-form-field>\n    </div>\n\n    <!-------------------------------------------->\n    <!------------------Numbers------------------->\n    <!-------------------------------------------->\n    <div *ngSwitchCase=\"DecoratorTypes.NUMBER\">\n        <mat-form-field>\n            <mat-label>{{metadata.displayName}}</mat-label>\n            <input\n                matInput\n                type=\"number\"\n                [(ngModel)]=\"entity[propertyKey]\"\n                [name]=\"propertyKey.toString()\"\n                #model=\"ngModel\"\n                [min]=\"metadataDefaultNumber.min ? metadataDefaultNumber.min : null\"\n                [max]=\"metadataDefaultNumber.max ? metadataDefaultNumber.max : null\"\n            />\n            <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n        </mat-form-field>\n    </div>\n\n    <div *ngSwitchCase=\"DecoratorTypes.NUMBER_DROPDOWN\">\n        <mat-form-field>\n            <mat-label>{{metadata.displayName}}</mat-label>\n            <mat-select [(ngModel)]=\"entity[propertyKey]\" [name]=\"propertyKey.toString()\" #model=\"ngModel\">\n                <mat-option *ngFor=\"let value of metadataDropdownNumber.dropdownValues\" [value]=\"value.value\">{{value.displayName}}</mat-option>\n            </mat-select>\n            <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n        </mat-form-field>\n    </div>\n\n    <!-------------------------------------------->\n    <!-------------------Object------------------->\n    <!-------------------------------------------->\n    <div *ngSwitchCase=\"DecoratorTypes.OBJECT\">\n        <b>{{metadataDefaultObject.displayName}}</b>\n        <!-- iterates over the object properties -->\n        <div class=\"row\">\n            <!--\n                displays another ngx-material-entity with the:\n                object as the entity,\n                the current key in the loop received by the keyvalue direction as the propertyKey\n                and the getValidationErrorMessage of the current component\n            -->\n            <ngx-mat-entity-internal-input\n                *ngFor=\"let key of getObjectProperties(); let i = index; trackBy: trackByFn\"\n                [entity]=\"objectProperty\"\n                [propertyKey]=\"key\"\n                [getValidationErrorMessage]=\"getValidationErrorMessage\"\n                [hideOmitForCreate]=\"hideOmitForCreate\"\n                [hideOmitForEdit]=\"hideOmitForEdit\"\n                class=\"col-lg-{{getWidth(objectProperty, key, 'lg')}} col-md-{{getWidth(objectProperty, key, 'md')}} col-sm-{{getWidth(objectProperty, key, 'sm')}}\"\n            >\n            </ngx-mat-entity-internal-input>\n        </div>\n    </div>\n\n    <div *ngSwitchDefault>ERROR: The type {{type}}is not known.</div>\n</div>"]}
@@ -1,54 +0,0 @@
1
- import { NgModule } from '@angular/core';
2
- import { CommonModule } from '@angular/common';
3
- import { MatInputModule } from '@angular/material/input';
4
- import { FormsModule } from '@angular/forms';
5
- import { MatFormFieldModule } from '@angular/material/form-field';
6
- import { MatSelectModule } from '@angular/material/select';
7
- import { MatAutocompleteModule } from '@angular/material/autocomplete';
8
- import { MatCheckboxModule } from '@angular/material/checkbox';
9
- import { MatSlideToggleModule } from '@angular/material/slide-toggle';
10
- import { MatTableModule } from '@angular/material/table';
11
- import { NgxMatEntityInternalInputComponent } from './internal-input.component';
12
- import * as i0 from "@angular/core";
13
- export class NgxMatEntityInternalInputModule {
14
- }
15
- NgxMatEntityInternalInputModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityInternalInputModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
16
- NgxMatEntityInternalInputModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityInternalInputModule, declarations: [NgxMatEntityInternalInputComponent], imports: [CommonModule,
17
- MatInputModule,
18
- FormsModule,
19
- MatFormFieldModule,
20
- MatSelectModule,
21
- MatAutocompleteModule,
22
- MatCheckboxModule,
23
- MatSlideToggleModule,
24
- MatTableModule], exports: [NgxMatEntityInternalInputComponent] });
25
- NgxMatEntityInternalInputModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityInternalInputModule, imports: [[
26
- CommonModule,
27
- MatInputModule,
28
- FormsModule,
29
- MatFormFieldModule,
30
- MatSelectModule,
31
- MatAutocompleteModule,
32
- MatCheckboxModule,
33
- MatSlideToggleModule,
34
- MatTableModule
35
- ]] });
36
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityInternalInputModule, decorators: [{
37
- type: NgModule,
38
- args: [{
39
- declarations: [NgxMatEntityInternalInputComponent],
40
- imports: [
41
- CommonModule,
42
- MatInputModule,
43
- FormsModule,
44
- MatFormFieldModule,
45
- MatSelectModule,
46
- MatAutocompleteModule,
47
- MatCheckboxModule,
48
- MatSlideToggleModule,
49
- MatTableModule
50
- ],
51
- exports: [NgxMatEntityInternalInputComponent]
52
- }]
53
- }] });
54
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJuYWwtaW5wdXQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW1hdGVyaWFsLWVudGl0eS9zcmMvY29tcG9uZW50cy9pbnB1dC9pbnRlcm5hbC1pbnB1dC9pbnRlcm5hbC1pbnB1dC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDdkUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDL0QsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDdEUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxrQ0FBa0MsRUFBRSxNQUFNLDRCQUE0QixDQUFDOztBQWlCaEYsTUFBTSxPQUFPLCtCQUErQjs7NkhBQS9CLCtCQUErQjs4SEFBL0IsK0JBQStCLGlCQWR6QixrQ0FBa0MsYUFFN0MsWUFBWTtRQUNaLGNBQWM7UUFDZCxXQUFXO1FBQ1gsa0JBQWtCO1FBQ2xCLGVBQWU7UUFDZixxQkFBcUI7UUFDckIsaUJBQWlCO1FBQ2pCLG9CQUFvQjtRQUNwQixjQUFjLGFBRVIsa0NBQWtDOzhIQUVuQywrQkFBK0IsWUFiL0I7WUFDTCxZQUFZO1lBQ1osY0FBYztZQUNkLFdBQVc7WUFDWCxrQkFBa0I7WUFDbEIsZUFBZTtZQUNmLHFCQUFxQjtZQUNyQixpQkFBaUI7WUFDakIsb0JBQW9CO1lBQ3BCLGNBQWM7U0FDakI7NEZBR1EsK0JBQStCO2tCQWYzQyxRQUFRO21CQUFDO29CQUNOLFlBQVksRUFBRSxDQUFDLGtDQUFrQyxDQUFDO29CQUNsRCxPQUFPLEVBQUU7d0JBQ0wsWUFBWTt3QkFDWixjQUFjO3dCQUNkLFdBQVc7d0JBQ1gsa0JBQWtCO3dCQUNsQixlQUFlO3dCQUNmLHFCQUFxQjt3QkFDckIsaUJBQWlCO3dCQUNqQixvQkFBb0I7d0JBQ3BCLGNBQWM7cUJBQ2pCO29CQUNELE9BQU8sRUFBRSxDQUFDLGtDQUFrQyxDQUFDO2lCQUNoRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTWF0SW5wdXRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pbnB1dCc7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IE1hdEZvcm1GaWVsZE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGQnO1xuaW1wb3J0IHsgTWF0U2VsZWN0TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc2VsZWN0JztcbmltcG9ydCB7IE1hdEF1dG9jb21wbGV0ZU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2F1dG9jb21wbGV0ZSc7XG5pbXBvcnQgeyBNYXRDaGVja2JveE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NoZWNrYm94JztcbmltcG9ydCB7IE1hdFNsaWRlVG9nZ2xlTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc2xpZGUtdG9nZ2xlJztcbmltcG9ydCB7IE1hdFRhYmxlTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdGFibGUnO1xuaW1wb3J0IHsgTmd4TWF0RW50aXR5SW50ZXJuYWxJbnB1dENvbXBvbmVudCB9IGZyb20gJy4vaW50ZXJuYWwtaW5wdXQuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgICBkZWNsYXJhdGlvbnM6IFtOZ3hNYXRFbnRpdHlJbnRlcm5hbElucHV0Q29tcG9uZW50XSxcbiAgICBpbXBvcnRzOiBbXG4gICAgICAgIENvbW1vbk1vZHVsZSxcbiAgICAgICAgTWF0SW5wdXRNb2R1bGUsXG4gICAgICAgIEZvcm1zTW9kdWxlLFxuICAgICAgICBNYXRGb3JtRmllbGRNb2R1bGUsXG4gICAgICAgIE1hdFNlbGVjdE1vZHVsZSxcbiAgICAgICAgTWF0QXV0b2NvbXBsZXRlTW9kdWxlLFxuICAgICAgICBNYXRDaGVja2JveE1vZHVsZSxcbiAgICAgICAgTWF0U2xpZGVUb2dnbGVNb2R1bGUsXG4gICAgICAgIE1hdFRhYmxlTW9kdWxlXG4gICAgXSxcbiAgICBleHBvcnRzOiBbTmd4TWF0RW50aXR5SW50ZXJuYWxJbnB1dENvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgTmd4TWF0RW50aXR5SW50ZXJuYWxJbnB1dE1vZHVsZSB7fSJdfQ==
@@ -1,70 +0,0 @@
1
- import { baseProperty } from './base/base-property.decorator';
2
- import { DecoratorTypes } from './base/decorator-types.enum';
3
- import { PropertyDecoratorConfig } from './base/property-decorator-config.interface';
4
- /**
5
- * Decorator for setting and getting array propery metadata
6
- * @param metadata The metadata of the array property
7
- */
8
- export function array(metadata) {
9
- switch (metadata.itemType) {
10
- case DecoratorTypes.OBJECT:
11
- return baseProperty(new EntityArrayDecoratorConfig(metadata), DecoratorTypes.ARRAY);
12
- case DecoratorTypes.STRING:
13
- return baseProperty(new StringChipsArrayDecoratorConfig(metadata), DecoratorTypes.ARRAY_STRING_CHIPS);
14
- case DecoratorTypes.STRING_AUTOCOMPLETE:
15
- return baseProperty(new AutocompleteStringChipsArrayDecoratorConfig(metadata), DecoratorTypes.ARRAY_STRING_AUTOCOMPLETE_CHIPS);
16
- default:
17
- // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/no-unsafe-member-access
18
- throw new Error(`Unknown itemType ${metadata.itemType}`);
19
- }
20
- }
21
- /**
22
- * Interface definition for the @array metadata
23
- */
24
- class ArrayDecoratorConfig extends PropertyDecoratorConfig {
25
- }
26
- /**
27
- * Definition for an array of Entities
28
- */
29
- export class EntityArrayDecoratorConfig extends ArrayDecoratorConfig {
30
- constructor(metadata) {
31
- super(metadata.displayName, metadata.display, metadata.required, metadata.omitForCreate, metadata.omitForUpdate, metadata.defaultWidths, metadata.order);
32
- this.itemType = metadata.itemType;
33
- this.displayStyle = metadata.displayStyle;
34
- this.EntityClass = metadata.EntityClass;
35
- this.createDialogData = metadata.createDialogData;
36
- this.missingErrorMessage = metadata.missingErrorMessage;
37
- this.createInline = metadata.createInline;
38
- this.displayColumns = metadata.displayColumns;
39
- }
40
- }
41
- /**
42
- * Definition for an array of strings displayed as a chips list
43
- */
44
- export class StringChipsArrayDecoratorConfig extends ArrayDecoratorConfig {
45
- constructor(metadata) {
46
- super(metadata.displayName, metadata.display, metadata.required, metadata.omitForCreate, metadata.omitForUpdate, metadata.defaultWidths, metadata.order);
47
- this.itemType = metadata.itemType;
48
- this.displayStyle = metadata.displayStyle;
49
- this.deleteHtml = metadata.deleteHtml;
50
- this.minLength = metadata.minLength;
51
- this.maxLength = metadata.maxLength;
52
- this.regex = metadata.regex;
53
- }
54
- }
55
- /**
56
- * Definition for an array of autocomplete strings displayed as a chips list
57
- */
58
- export class AutocompleteStringChipsArrayDecoratorConfig extends ArrayDecoratorConfig {
59
- constructor(metadata) {
60
- super(metadata.displayName, metadata.display, metadata.required, metadata.omitForCreate, metadata.omitForUpdate, metadata.defaultWidths, metadata.order);
61
- this.itemType = metadata.itemType;
62
- this.displayStyle = metadata.displayStyle;
63
- this.deleteHtml = metadata.deleteHtml;
64
- this.autocompleteValues = metadata.autocompleteValues;
65
- this.minLength = metadata.minLength;
66
- this.maxLength = metadata.maxLength;
67
- this.regex = metadata.regex;
68
- }
69
- }
70
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"array.decorator.js","sourceRoot":"","sources":["../../../../projects/ngx-material-entity/src/decorators/array.decorator.ts"],"names":[],"mappings":"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","sourcesContent":["import { Entity } from '../classes/entity-model.class';\nimport { CreateDialogData } from '../components/table/table-data';\nimport { baseProperty } from './base/base-property.decorator';\nimport { DecoratorTypes } from './base/decorator-types.enum';\nimport { PropertyDecoratorConfig } from './base/property-decorator-config.interface';\n\n/**\n * Decorator for setting and getting array propery metadata\n * @param metadata The metadata of the array property\n */\nexport function array<EntityType extends Entity>(\n    metadata: EntityArrayDecoratorConfig<EntityType> | StringChipsArrayDecoratorConfig | AutocompleteStringChipsArrayDecoratorConfig\n): (target: object, propertyKey: string) => void {\n    switch (metadata.itemType) {\n        case DecoratorTypes.OBJECT:\n            return baseProperty(new EntityArrayDecoratorConfig(metadata), DecoratorTypes.ARRAY);\n        case DecoratorTypes.STRING:\n            return baseProperty(new StringChipsArrayDecoratorConfig(metadata), DecoratorTypes.ARRAY_STRING_CHIPS);\n        case DecoratorTypes.STRING_AUTOCOMPLETE:\n            return baseProperty(new AutocompleteStringChipsArrayDecoratorConfig(metadata), DecoratorTypes.ARRAY_STRING_AUTOCOMPLETE_CHIPS);\n        default:\n            // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/no-unsafe-member-access\n            throw new Error(`Unknown itemType ${(metadata as any).itemType}`);\n    }\n}\n\nexport interface ArrayTableDisplayColumn<EntityType extends Entity> {\n    /**\n     * The name inside the header.\n     */\n    displayName: string,\n    /**\n     * A method to get the value inside an row\n     */\n    value: (entity: EntityType) => string\n}\n\n/**\n * Interface definition for the @array metadata\n */\nabstract class ArrayDecoratorConfig extends PropertyDecoratorConfig {\n    /**\n     * How to display the string\n     */\n    displayStyle!: 'table' | 'chips';\n\n    /**\n     * The type of the items inside the array\n     */\n    itemType!: DecoratorTypes;\n\n    /**\n     * The error-message to display when the array is required but contains no values\n     */\n    missingErrorMessage?: string;\n}\n\n/**\n * Definition for an array of Entities\n */\nexport class EntityArrayDecoratorConfig<EntityType extends Entity> extends ArrayDecoratorConfig {\n    override itemType: DecoratorTypes.OBJECT;\n    override displayStyle: 'table';\n\n    /**\n     * The EntityClass used for generating the create inputs\n     */\n    EntityClass!: new (entity?: EntityType) => EntityType;\n\n    /**\n     * The definition of the columns to display. Consists of the displayName to show in the header of the row\n     * and the value, which is a function that generates the value to display inside a column\n     */\n    displayColumns: ArrayTableDisplayColumn<EntityType>[];\n\n    /**\n     * The data for the add-item-dialog.\n     * Can be omitted when adding items inline.\n     */\n    createDialogData?: CreateDialogData\n\n    /**\n     * Whether or not the form for adding items to the array\n     * should be displayed inline.\n     * @default true\n     */\n    createInline?: boolean\n\n    constructor(metadata: EntityArrayDecoratorConfig<EntityType>) {\n        super(\n            metadata.displayName,\n            metadata.display,\n            metadata.required,\n            metadata.omitForCreate,\n            metadata.omitForUpdate,\n            metadata.defaultWidths,\n            metadata.order\n        );\n        this.itemType = metadata.itemType;\n        this.displayStyle = metadata.displayStyle;\n        this.EntityClass = metadata.EntityClass;\n        this.createDialogData = metadata.createDialogData;\n        this.missingErrorMessage = metadata.missingErrorMessage;\n        this.createInline = metadata.createInline;\n        this.displayColumns = metadata.displayColumns\n    }\n}\n\n/**\n * Definition for an array of strings displayed as a chips list\n */\nexport class StringChipsArrayDecoratorConfig extends ArrayDecoratorConfig {\n    override itemType: DecoratorTypes.STRING;\n    override displayStyle: 'chips';\n\n    /**\n     * The html inside the delete-button.\n     * Please note that custom tags such as <mat-icon></mat-icon>\n     * need to be defined as known elements, otherwise the sanitizer will remove them.\n     * You can however work around this by using `<span class=\"material-icons\"></span>`\n     * @default <mat-icon>cancel</mat-icon>\n     */\n    deleteHtml?: string\n    /**\n     * (optional) The minimum required length of the string\n     */\n    minLength?: number;\n    /**\n     * (optional) The maximum required length of the string\n     */\n    maxLength?: number;\n    /**\n     * (optional) A regex used for validation\n     */\n    regex?: RegExp;\n\n    constructor(metadata: StringChipsArrayDecoratorConfig) {\n        super(\n            metadata.displayName,\n            metadata.display,\n            metadata.required,\n            metadata.omitForCreate,\n            metadata.omitForUpdate,\n            metadata.defaultWidths,\n            metadata.order\n        );\n        this.itemType = metadata.itemType;\n        this.displayStyle = metadata.displayStyle;\n        this.deleteHtml =  metadata.deleteHtml;\n        this.minLength = metadata.minLength;\n        this.maxLength = metadata.maxLength;\n        this.regex = metadata.regex;\n    }\n}\n\n/**\n * Definition for an array of autocomplete strings displayed as a chips list\n */\nexport class AutocompleteStringChipsArrayDecoratorConfig extends ArrayDecoratorConfig {\n    override itemType: DecoratorTypes.STRING_AUTOCOMPLETE;\n    override displayStyle: 'chips';\n\n    /**\n     * The html inside the delete-button.\n     * Please note that custom tags such as <mat-icon></mat-icon>\n     * need to be defined as known elements, otherwise the sanitizer will remove them.\n     * You can however work around this by using `<span class=\"material-icons\"></span>`\n     * @default <mat-icon>cancel</mat-icon>\n     */\n    deleteHtml?: string;\n    /**\n     * The autocomplete values\n     */\n    autocompleteValues: string[];\n    /**\n     * (optional) The minimum required length of the string\n     */\n    minLength?: number;\n    /**\n     * (optional) The maximum required length of the string\n     */\n    maxLength?: number;\n    /**\n     * (optional) A regex used for validation\n     */\n    regex?: RegExp;\n\n    constructor(metadata: AutocompleteStringChipsArrayDecoratorConfig) {\n        super(\n            metadata.displayName,\n            metadata.display,\n            metadata.required,\n            metadata.omitForCreate,\n            metadata.omitForUpdate,\n            metadata.defaultWidths,\n            metadata.order\n        );\n        this.itemType = metadata.itemType;\n        this.displayStyle = metadata.displayStyle;\n        this.deleteHtml =  metadata.deleteHtml;\n        this.autocompleteValues = metadata.autocompleteValues;\n        this.minLength = metadata.minLength;\n        this.maxLength = metadata.maxLength;\n        this.regex = metadata.regex;\n    }\n}"]}
@@ -1,31 +0,0 @@
1
- /**
2
- * The base options for all propertyDecorators
3
- */
4
- export class PropertyDecoratorConfig {
5
- /**
6
- * Defines, Whether or not there should be a line break after this input.
7
- * Is used inside the default create and edit dialogs.
8
- */
9
- // lineBreakAfter?: boolean;
10
- constructor(displayName, display = true, required = true, omitForCreate = false, omitForUpdate = false, defaultWidths = [6, 6, 12], order
11
- // lineBreakAfter: boolean = false
12
- ) {
13
- this.displayName = displayName;
14
- this.display = display;
15
- this.required = required;
16
- this.omitForCreate = omitForCreate;
17
- this.omitForUpdate = omitForUpdate;
18
- this.defaultWidths = defaultWidths;
19
- if (order) {
20
- if (order < 0) {
21
- throw new Error('order must be at least 0');
22
- }
23
- this.order = order;
24
- }
25
- else {
26
- this.order = -1;
27
- }
28
- // this.lineBreakAfter = lineBreakAfter;
29
- }
30
- }
31
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvcGVydHktZGVjb3JhdG9yLWNvbmZpZy5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtbWF0ZXJpYWwtZW50aXR5L3NyYy9kZWNvcmF0b3JzL2Jhc2UvcHJvcGVydHktZGVjb3JhdG9yLWNvbmZpZy5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUE7O0dBRUc7QUFDSCxNQUFNLE9BQWdCLHVCQUF1QjtJQXdDekM7OztPQUdHO0lBQ0gsNEJBQTRCO0lBRTVCLFlBQ0ksV0FBbUIsRUFDbkIsVUFBbUIsSUFBSSxFQUN2QixXQUFvQixJQUFJLEVBQ3hCLGdCQUF5QixLQUFLLEVBQzlCLGdCQUF5QixLQUFLLEVBQzlCLGdCQUFvQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLEVBQzlDLEtBQWM7SUFDZCxrQ0FBa0M7O1FBRWxDLElBQUksQ0FBQyxXQUFXLEdBQUcsV0FBVyxDQUFDO1FBQy9CLElBQUksQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDO1FBQ3pCLElBQUksQ0FBQyxhQUFhLEdBQUcsYUFBYSxDQUFDO1FBQ25DLElBQUksQ0FBQyxhQUFhLEdBQUcsYUFBYSxDQUFDO1FBQ25DLElBQUksQ0FBQyxhQUFhLEdBQUcsYUFBYSxDQUFDO1FBRW5DLElBQUksS0FBSyxFQUFFO1lBQ1AsSUFBSSxLQUFLLEdBQUcsQ0FBQyxFQUFFO2dCQUNYLE1BQU0sSUFBSSxLQUFLLENBQUMsMEJBQTBCLENBQUMsQ0FBQzthQUMvQztZQUVELElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1NBQ3RCO2FBQ0k7WUFDRCxJQUFJLENBQUMsS0FBSyxHQUFHLENBQUMsQ0FBQyxDQUFDO1NBQ25CO1FBQ0Qsd0NBQXdDO0lBQzVDLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbInR5cGUgY29scyA9IDEgfCAyIHwgMyB8IDQgfCA1IHwgNiB8IDcgfCA4IHwgOSB8IDEwIHwgMTEgfCAxMjtcblxuLyoqXG4gKiBUaGUgYmFzZSBvcHRpb25zIGZvciBhbGwgcHJvcGVydHlEZWNvcmF0b3JzXG4gKi9cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBQcm9wZXJ0eURlY29yYXRvckNvbmZpZyB7XG4gICAgLyoqXG4gICAgICogV2hldGhlciBvciBub3QgdGhlIFByb3BlcnR5IGlzIGRpc3BsYXllZCBhdCBhbGwuXG4gICAgICogQGRlZmF1bHQgdHJ1ZVxuICAgICAqL1xuICAgIGRpc3BsYXk/OiBib29sZWFuO1xuICAgIC8qKlxuICAgICAqIFRoZSBuYW1lIG9mIHRoZSBwcm9wZXJ0eSB1c2VkIGFzIGEgbGFiZWwgZm9yIGZvcm0gZmllbGRzLlxuICAgICAqL1xuICAgIGRpc3BsYXlOYW1lOiBzdHJpbmc7XG4gICAgLyoqXG4gICAgICogV2hldGhlciBvciBub3QgdGhlIFByb3BlcnR5IGlzIHJlcXVpcmVkLlxuICAgICAqIEBkZWZhdWx0IHRydWVcbiAgICAgKi9cbiAgICByZXF1aXJlZD86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogV2hldGhlciBvciBub3QgdGhlIHByb3BlcnR5IGdldHMgb21pdHRlZCB3aGVuIGNyZWF0aW5nIG5ldyBFbnRpdGllcy5cbiAgICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgICAqL1xuICAgIG9taXRGb3JDcmVhdGU/OiBib29sZWFuO1xuICAgIC8qKlxuICAgICAqIFdoZXRoZXIgb3Igbm90IHRoZSBwcm9wZXJ0eSBnZXRzIG9taXR0ZWQgd2hlbiB1cGRhdGluZyBFbnRpdGllcy5cbiAgICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgICAqL1xuICAgIG9taXRGb3JVcGRhdGU/OiBib29sZWFuO1xuICAgIC8qKlxuICAgICAqIERlZmluZXMgdGhlIHdpZHRoIG9mIHRoZSBpbnB1dCBwcm9wZXJ0eSB3aGVuIHVzZWQgaW5zaWRlIHRoZSBkZWZhdWx0IGNyZWF0ZSBvciBlZGl0IGRpYWxvZy5cbiAgICAgKiBIYXMgMyBib290c3RyYXAgdmFsdWVzIGZvciBkaWZmZXJlbnQgYnJlYWtwb2ludHMgZm9yIHNpbXBsZSByZXNwb25zaXZlIGRlc2lnbi5cbiAgICAgKiBAdmFyIGZpcnN0VmFsdWU6IGNvbC1sZy17e2ZpcnN0VmFsdWV9fVxuICAgICAqIEB2YXIgc2Vjb25kVmFsdWU6IGNvbC1tZC17e3NlY29uZFZhbHVlfX1cbiAgICAgKiBAdmFyIHRoaXJkVmFsdWU6IGNvbC1zbS17e3RoaXJkVmFsdWV9fVxuICAgICAqL1xuICAgIGRlZmF1bHRXaWR0aHM/OiBbY29scywgY29scywgY29sc107XG4gICAgLyoqXG4gICAgICogU3BlY2lmaWVzIG9yZGVyIG9mIHRoZSBpbnB1dCBwcm9wZXJ0eSB3aGVuIHVzZWQgaW5zaWRlIHRoZSBkZWZhdWx0IGNyZWF0ZSBvciBlZGl0IGRpYWxvZy5cbiAgICAgKiBPcmRlcmluZyBpcyBhc2NlbmRpbmdcbiAgICAgKiBAZGVmYXVsdCAtMSAoc2V0cyB0aGlzIHByb3BlcnR5IGF0IHRoZSBlbmQpXG4gICAgICovXG4gICAgb3JkZXI/OiBudW1iZXI7XG5cbiAgICAvKipcbiAgICAgKiBEZWZpbmVzLCBXaGV0aGVyIG9yIG5vdCB0aGVyZSBzaG91bGQgYmUgYSBsaW5lIGJyZWFrIGFmdGVyIHRoaXMgaW5wdXQuXG4gICAgICogSXMgdXNlZCBpbnNpZGUgdGhlIGRlZmF1bHQgY3JlYXRlIGFuZCBlZGl0IGRpYWxvZ3MuXG4gICAgICovXG4gICAgLy8gbGluZUJyZWFrQWZ0ZXI/OiBib29sZWFuO1xuXG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIGRpc3BsYXlOYW1lOiBzdHJpbmcsXG4gICAgICAgIGRpc3BsYXk6IGJvb2xlYW4gPSB0cnVlLFxuICAgICAgICByZXF1aXJlZDogYm9vbGVhbiA9IHRydWUsXG4gICAgICAgIG9taXRGb3JDcmVhdGU6IGJvb2xlYW4gPSBmYWxzZSxcbiAgICAgICAgb21pdEZvclVwZGF0ZTogYm9vbGVhbiA9IGZhbHNlLFxuICAgICAgICBkZWZhdWx0V2lkdGhzOiBbY29scywgY29scywgY29sc10gPSBbNiwgNiwgMTJdLFxuICAgICAgICBvcmRlcj86IG51bWJlclxuICAgICAgICAvLyBsaW5lQnJlYWtBZnRlcjogYm9vbGVhbiA9IGZhbHNlXG4gICAgKSB7XG4gICAgICAgIHRoaXMuZGlzcGxheU5hbWUgPSBkaXNwbGF5TmFtZTtcbiAgICAgICAgdGhpcy5kaXNwbGF5ID0gZGlzcGxheTtcbiAgICAgICAgdGhpcy5yZXF1aXJlZCA9IHJlcXVpcmVkO1xuICAgICAgICB0aGlzLm9taXRGb3JDcmVhdGUgPSBvbWl0Rm9yQ3JlYXRlO1xuICAgICAgICB0aGlzLm9taXRGb3JVcGRhdGUgPSBvbWl0Rm9yVXBkYXRlO1xuICAgICAgICB0aGlzLmRlZmF1bHRXaWR0aHMgPSBkZWZhdWx0V2lkdGhzO1xuXG4gICAgICAgIGlmIChvcmRlcikge1xuICAgICAgICAgICAgaWYgKG9yZGVyIDwgMCkge1xuICAgICAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcignb3JkZXIgbXVzdCBiZSBhdCBsZWFzdCAwJyk7XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIHRoaXMub3JkZXIgPSBvcmRlcjtcbiAgICAgICAgfVxuICAgICAgICBlbHNlIHtcbiAgICAgICAgICAgIHRoaXMub3JkZXIgPSAtMTtcbiAgICAgICAgfVxuICAgICAgICAvLyB0aGlzLmxpbmVCcmVha0FmdGVyID0gbGluZUJyZWFrQWZ0ZXI7XG4gICAgfVxufSJdfQ==