ngx-material-entity 0.1.1 → 0.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CONTRIBUTING.md +7 -1
- package/README.md +3 -2
- package/classes/entity-model.class.d.ts +1 -1
- package/classes/entity-service.class.d.ts +27 -17
- package/classes/entity-utilities.class.d.ts +62 -45
- package/components/confirm-dialog/confirm-dialog-data.builder.d.ts +24 -0
- package/components/confirm-dialog/confirm-dialog-data.d.ts +14 -8
- package/components/confirm-dialog/confirm-dialog.component.d.ts +4 -5
- package/components/get-validation-error-message.function.d.ts +3 -2
- package/components/input/array-table/add-array-item-dialog/add-array-item-dialog-data.builder.d.ts +17 -0
- package/components/input/array-table/add-array-item-dialog/add-array-item-dialog-data.d.ts +17 -0
- package/components/input/array-table/add-array-item-dialog/add-array-item-dialog.component.d.ts +5 -18
- package/components/input/array-table/array-table.component.d.ts +3 -3
- package/components/input/input.component.d.ts +18 -21
- package/components/input/internal-input/internal-input.component.d.ts +14 -17
- package/components/table/create-dialog/create-dialog-data.builder.d.ts +20 -0
- package/components/table/create-dialog/create-entity-dialog-data.builder.d.ts +16 -0
- package/components/table/create-dialog/create-entity-dialog-data.d.ts +2 -2
- package/components/table/create-dialog/create-entity-dialog.component.d.ts +4 -2
- package/components/table/edit-dialog/edit-dialog-data.builder.d.ts +27 -0
- package/components/table/edit-dialog/edit-entity-dialog-data.d.ts +5 -5
- package/components/table/edit-dialog/edit-entity-dialog.builder.d.ts +17 -0
- package/components/table/edit-dialog/edit-entity-dialog.component.d.ts +4 -2
- package/components/table/table-data.builder.d.ts +40 -0
- package/components/table/table-data.d.ts +26 -22
- package/components/table/table.component.d.ts +6 -5
- package/decorators/array/array-decorator-internal.data.d.ts +34 -0
- package/decorators/{array.decorator.d.ts → array/array-decorator.data.d.ts} +32 -37
- package/decorators/array/array.decorator.d.ts +10 -0
- package/decorators/base/base-property.decorator.d.ts +7 -6
- package/decorators/base/decorator-types.enum.d.ts +7 -7
- package/decorators/base/property-decorator-internal.data.d.ts +11 -0
- package/decorators/base/{property-decorator-config.interface.d.ts → property-decorator.data.d.ts} +11 -12
- package/decorators/boolean/boolean-decorator-internal.data.d.ts +16 -0
- package/decorators/boolean/boolean-decorator.data.d.ts +28 -0
- package/decorators/boolean/boolean.decorator.d.ts +8 -0
- package/decorators/number/number-decorator-internal.data.d.ts +16 -0
- package/decorators/number/number-decorator.data.d.ts +32 -0
- package/decorators/number/number.decorator.d.ts +8 -0
- package/decorators/object/object-decorator-internal.data.d.ts +8 -0
- package/decorators/object/object-decorator.data.d.ts +22 -0
- package/decorators/object/object.decorator.d.ts +9 -0
- package/decorators/string/string-decorator-internal.data.d.ts +31 -0
- package/decorators/string/string-decorator.data.d.ts +67 -0
- package/decorators/string/string.decorator.d.ts +8 -0
- package/esm2020/classes/entity-model.class.mjs +2 -2
- package/esm2020/classes/entity-service.class.mjs +20 -14
- package/esm2020/classes/entity-utilities.class.mjs +108 -75
- package/esm2020/components/confirm-dialog/confirm-dialog-data.builder.mjs +77 -0
- package/esm2020/components/confirm-dialog/confirm-dialog-data.mjs +1 -1
- package/esm2020/components/confirm-dialog/confirm-dialog.component.mjs +7 -22
- package/esm2020/components/get-validation-error-message.function.mjs +4 -3
- package/esm2020/components/input/array-table/add-array-item-dialog/add-array-item-dialog-data.builder.mjs +33 -0
- package/esm2020/components/input/array-table/add-array-item-dialog/add-array-item-dialog-data.mjs +2 -0
- package/esm2020/components/input/array-table/add-array-item-dialog/add-array-item-dialog.component.mjs +7 -5
- package/esm2020/components/input/array-table/array-table.component.mjs +14 -11
- package/esm2020/components/input/input.component.mjs +3 -6
- package/esm2020/components/input/internal-input/internal-input.component.mjs +1 -4
- package/esm2020/components/table/create-dialog/create-dialog-data.builder.mjs +54 -0
- package/esm2020/components/table/create-dialog/create-entity-dialog-data.builder.mjs +18 -0
- package/esm2020/components/table/create-dialog/create-entity-dialog-data.mjs +1 -1
- package/esm2020/components/table/create-dialog/create-entity-dialog.component.mjs +14 -21
- package/esm2020/components/table/edit-dialog/edit-dialog-data.builder.mjs +81 -0
- package/esm2020/components/table/edit-dialog/edit-entity-dialog-data.mjs +1 -1
- package/esm2020/components/table/edit-dialog/edit-entity-dialog.builder.mjs +19 -0
- package/esm2020/components/table/edit-dialog/edit-entity-dialog.component.mjs +21 -36
- package/esm2020/components/table/table-data.builder.mjs +89 -0
- package/esm2020/components/table/table-data.mjs +1 -1
- package/esm2020/components/table/table.component.mjs +41 -80
- package/esm2020/decorators/array/array-decorator-internal.data.mjs +40 -0
- package/esm2020/decorators/array/array-decorator.data.mjs +7 -0
- package/esm2020/decorators/array/array.decorator.mjs +24 -0
- package/esm2020/decorators/base/base-property.decorator.mjs +6 -5
- package/esm2020/decorators/base/decorator-types.enum.mjs +1 -1
- package/esm2020/decorators/base/property-decorator-internal.data.mjs +15 -0
- package/esm2020/decorators/base/property-decorator.data.mjs +6 -0
- package/esm2020/decorators/boolean/boolean-decorator-internal.data.mjs +22 -0
- package/esm2020/decorators/boolean/boolean-decorator.data.mjs +7 -0
- package/esm2020/decorators/boolean/boolean.decorator.mjs +21 -0
- package/esm2020/decorators/number/number-decorator-internal.data.mjs +17 -0
- package/esm2020/decorators/number/number-decorator.data.mjs +7 -0
- package/esm2020/decorators/number/number.decorator.mjs +18 -0
- package/esm2020/decorators/object/object-decorator-internal.data.mjs +9 -0
- package/esm2020/decorators/object/object-decorator.data.mjs +7 -0
- package/esm2020/decorators/object/object.decorator.mjs +13 -0
- package/esm2020/decorators/string/string-decorator-internal.data.mjs +36 -0
- package/esm2020/decorators/string/string-decorator.data.mjs +7 -0
- package/esm2020/decorators/string/string.decorator.mjs +24 -0
- package/esm2020/public-api.mjs +15 -10
- package/fesm2015/ngx-material-entity.mjs +1019 -683
- package/fesm2015/ngx-material-entity.mjs.map +1 -1
- package/fesm2020/ngx-material-entity.mjs +1005 -684
- package/fesm2020/ngx-material-entity.mjs.map +1 -1
- package/package.json +1 -1
- package/public-api.d.ts +16 -7
- package/decorators/boolean.decorator.d.ts +0 -42
- package/decorators/number.decorator.d.ts +0 -40
- package/decorators/object.decorator.d.ts +0 -27
- package/decorators/string.decorator.d.ts +0 -76
- package/esm2020/decorators/array.decorator.mjs +0 -70
- package/esm2020/decorators/base/property-decorator-config.interface.mjs +0 -31
- package/esm2020/decorators/boolean.decorator.mjs +0 -44
- package/esm2020/decorators/number.decorator.mjs +0 -36
- package/esm2020/decorators/object.decorator.mjs +0 -23
- package/esm2020/decorators/string.decorator.mjs +0 -61
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLWVudGl0eS1kaWFsb2ctZGF0YS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1tYXRlcmlhbC1lbnRpdHkvc3JjL2NvbXBvbmVudHMvdGFibGUvY3JlYXRlLWRpYWxvZy9jcmVhdGUtZW50aXR5LWRpYWxvZy1kYXRhLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgRW50aXR5U2VydmljZSB9IGZyb20gJy4uLy4uLy4uL2NsYXNzZXMvZW50aXR5LXNlcnZpY2UuY2xhc3MnO1xuaW1wb3J0IHsgRW50aXR5IH0gZnJvbSAnLi4vLi4vLi4vY2xhc3Nlcy9lbnRpdHktbW9kZWwuY2xhc3MnO1xuaW1wb3J0IHsgQ3JlYXRlRGlhbG9nRGF0YSB9IGZyb20gJy4uL3RhYmxlLWRhdGEnO1xuXG4vKipcbiAqIFRoZSBEZWZpbml0aW9uIG9mIHRoZSBDcmVhdGUgRW50aXR5IERpYWxvZyBEYXRhLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIENyZWF0ZUVudGl0eURpYWxvZ0RhdGE8RW50aXR5VHlwZSBleHRlbmRzIEVudGl0eT4ge1xuICAgIC8qKlxuICAgICAqIEFuIGVtcHR5IGVudGl0eSB0aGF0IGlzIHVzZWQgYXMgdGhlIGRhdGEgbW9kZWwuXG4gICAgICovXG4gICAgZW50aXR5OiBFbnRpdHlUeXBlLFxuICAgIC8qKlxuICAgICAqIFRoZSBFbnRpdHkgU2VydmljZSBjbGFzcyB1c2VkIGZvciB0aGUgY3JlYXRlIHJlcXVlc3QuXG4gICAgICovXG4gICAgRW50aXR5U2VydmljZUNsYXNzOiBuZXcgKGh0dHBDbGllbnQ6IEh0dHBDbGllbnQpID0+IEVudGl0eVNlcnZpY2U8RW50aXR5VHlwZT4sXG4gICAgLyoqXG4gICAgICogVGhlIGluZm8gb2YgdGhlIGdlbmVyaWMgY3JlYXRlLWRpYWxvZy5cbiAgICAgKi9cbiAgICBjcmVhdGVEaWFsb2dEYXRhPzogQ3JlYXRlRGlhbG9nRGF0YVxufSJdfQ==
|
|
@@ -2,6 +2,8 @@ import { Component, Inject, Injector } from '@angular/core';
|
|
|
2
2
|
import { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';
|
|
3
3
|
import { EntityUtilities } from '../../../classes/entity-utilities.class';
|
|
4
4
|
import { NgxMatEntityConfirmDialogComponent } from '../../confirm-dialog/confirm-dialog.component';
|
|
5
|
+
import { ConfirmDialogDataBuilder } from '../../confirm-dialog/confirm-dialog-data.builder';
|
|
6
|
+
import { CreateEntityDialogDataBuilder } from './create-entity-dialog-data.builder';
|
|
5
7
|
import * as i0 from "@angular/core";
|
|
6
8
|
import * as i1 from "@angular/material/dialog";
|
|
7
9
|
import * as i2 from "../../input/input.component";
|
|
@@ -9,8 +11,8 @@ import * as i3 from "@angular/material/button";
|
|
|
9
11
|
import * as i4 from "@angular/forms";
|
|
10
12
|
import * as i5 from "@angular/common";
|
|
11
13
|
export class NgxMatEntityCreateDialogComponent {
|
|
12
|
-
constructor(
|
|
13
|
-
this.
|
|
14
|
+
constructor(inputData, dialogRef, injector, dialog) {
|
|
15
|
+
this.inputData = inputData;
|
|
14
16
|
this.dialogRef = dialogRef;
|
|
15
17
|
this.injector = injector;
|
|
16
18
|
this.dialog = dialog;
|
|
@@ -18,6 +20,7 @@ export class NgxMatEntityCreateDialogComponent {
|
|
|
18
20
|
this.getWidth = EntityUtilities.getWidth;
|
|
19
21
|
}
|
|
20
22
|
ngOnInit() {
|
|
23
|
+
this.data = new CreateEntityDialogDataBuilder(this.inputData).createDialogData;
|
|
21
24
|
this.dialogRef.disableClose = true;
|
|
22
25
|
this.setEntityKeys();
|
|
23
26
|
this.entityService = this.injector.get(this.data.EntityServiceClass);
|
|
@@ -29,24 +32,14 @@ export class NgxMatEntityCreateDialogComponent {
|
|
|
29
32
|
.sort((a, b) => EntityUtilities.compareOrder(a, b, this.data.entity));
|
|
30
33
|
}
|
|
31
34
|
create() {
|
|
32
|
-
if (this.data.createDialogData
|
|
35
|
+
if (!this.data.createDialogData?.createRequiresConfirmDialog) {
|
|
33
36
|
return this.confirmCreate();
|
|
34
37
|
}
|
|
35
|
-
const dialogData =
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
confirmButtonLabel: this.data.createDialogData.confirmCreateDialogData?.confirmButtonLabel ? this.data.createDialogData.confirmCreateDialogData?.confirmButtonLabel : 'Create',
|
|
41
|
-
// eslint-disable-next-line max-len
|
|
42
|
-
cancelButtonLabel: this.data.createDialogData.confirmCreateDialogData?.cancelButtonLabel ? this.data.createDialogData.confirmCreateDialogData?.cancelButtonLabel : 'Cancel',
|
|
43
|
-
// eslint-disable-next-line max-len
|
|
44
|
-
title: this.data.createDialogData.confirmCreateDialogData?.title ? this.data.createDialogData.confirmCreateDialogData?.title : 'Create',
|
|
45
|
-
// eslint-disable-next-line max-len
|
|
46
|
-
requireConfirmation: this.data.createDialogData.confirmCreateDialogData?.requireConfirmation ? this.data.createDialogData.confirmCreateDialogData?.requireConfirmation : false,
|
|
47
|
-
// eslint-disable-next-line max-len
|
|
48
|
-
confirmationText: this.data.createDialogData.confirmCreateDialogData?.confirmationText ? this.data.createDialogData.confirmCreateDialogData?.confirmationText : undefined,
|
|
49
|
-
};
|
|
38
|
+
const dialogData = new ConfirmDialogDataBuilder(this.data.createDialogData?.confirmCreateDialogData)
|
|
39
|
+
.withDefaultText(['Do you really want to create this entity?'])
|
|
40
|
+
.withDefaultConfirmButtonLabel('Create')
|
|
41
|
+
.withDefaultTitle('Create')
|
|
42
|
+
.confirmDialogData;
|
|
50
43
|
const dialogref = this.dialog.open(NgxMatEntityConfirmDialogComponent, {
|
|
51
44
|
data: dialogData,
|
|
52
45
|
autoFocus: false,
|
|
@@ -66,12 +59,12 @@ export class NgxMatEntityCreateDialogComponent {
|
|
|
66
59
|
}
|
|
67
60
|
}
|
|
68
61
|
NgxMatEntityCreateDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityCreateDialogComponent, deps: [{ token: MAT_DIALOG_DATA }, { token: i1.MatDialogRef }, { token: i0.Injector }, { token: i1.MatDialog }], target: i0.ɵɵFactoryTarget.Component });
|
|
69
|
-
NgxMatEntityCreateDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: NgxMatEntityCreateDialogComponent, selector: "ngx-mat-entity-create-dialog", ngImport: i0, template: "<h2 mat-dialog-title>{{data.createDialogData.title}}</h2>\n\n<mat-dialog-content>\n <form #form=\"ngForm\" class=\"row\">\n <ngx-mat-entity-input\n *ngFor=\"let key of entityKeys\"\n [entity]=\"data.entity\"\n [propertyKey]=\"key\"\n [hideOmitForCreate]=\"true\"\n class=\"col-lg-{{getWidth(data.entity, key, 'lg')}} col-md-{{getWidth(data.entity, key, 'md')}} col-sm-{{getWidth(data.entity, key, 'sm')}}\"\n >\n </ngx-mat-entity-input>\n </form>\n</mat-dialog-content>\n\n<mat-dialog-actions>\n <button mat-raised-button (click)=\"create()\" [disabled]=\"!EntityUtilities.isEntityValid(data.entity, 'create')\">\n {{data.createDialogData.createButtonLabel
|
|
62
|
+
NgxMatEntityCreateDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: NgxMatEntityCreateDialogComponent, selector: "ngx-mat-entity-create-dialog", ngImport: i0, template: "<h2 mat-dialog-title>{{data.createDialogData.title}}</h2>\n\n<mat-dialog-content>\n <form #form=\"ngForm\" class=\"row\">\n <ngx-mat-entity-input\n *ngFor=\"let key of entityKeys\"\n [entity]=\"data.entity\"\n [propertyKey]=\"key\"\n [hideOmitForCreate]=\"true\"\n class=\"col-lg-{{getWidth(data.entity, key, 'lg')}} col-md-{{getWidth(data.entity, key, 'md')}} col-sm-{{getWidth(data.entity, key, 'sm')}}\"\n >\n </ngx-mat-entity-input>\n </form>\n</mat-dialog-content>\n\n<mat-dialog-actions>\n <button mat-raised-button (click)=\"create()\" [disabled]=\"!EntityUtilities.isEntityValid(data.entity, 'create')\">\n {{data.createDialogData.createButtonLabel}}\n </button>\n <button mat-raised-button (click)=\"cancel()\" class=\"cancel-button\">\n {{data.createDialogData.cancelButtonLabel}}\n </button>\n</mat-dialog-actions>\n", styles: ["mat-dialog-actions{display:flex;justify-content:space-between}\n"], components: [{ type: i2.NgxMatEntityInputComponent, selector: "ngx-mat-entity-input", inputs: ["entity", "propertyKey", "getValidationErrorMessage", "hideOmitForCreate", "hideOmitForEdit"] }, { 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"] }], directives: [{ type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i4.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]" }] });
|
|
70
63
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityCreateDialogComponent, decorators: [{
|
|
71
64
|
type: Component,
|
|
72
|
-
args: [{ selector: 'ngx-mat-entity-create-dialog', template: "<h2 mat-dialog-title>{{data.createDialogData.title}}</h2>\n\n<mat-dialog-content>\n <form #form=\"ngForm\" class=\"row\">\n <ngx-mat-entity-input\n *ngFor=\"let key of entityKeys\"\n [entity]=\"data.entity\"\n [propertyKey]=\"key\"\n [hideOmitForCreate]=\"true\"\n class=\"col-lg-{{getWidth(data.entity, key, 'lg')}} col-md-{{getWidth(data.entity, key, 'md')}} col-sm-{{getWidth(data.entity, key, 'sm')}}\"\n >\n </ngx-mat-entity-input>\n </form>\n</mat-dialog-content>\n\n<mat-dialog-actions>\n <button mat-raised-button (click)=\"create()\" [disabled]=\"!EntityUtilities.isEntityValid(data.entity, 'create')\">\n {{data.createDialogData.createButtonLabel
|
|
65
|
+
args: [{ selector: 'ngx-mat-entity-create-dialog', template: "<h2 mat-dialog-title>{{data.createDialogData.title}}</h2>\n\n<mat-dialog-content>\n <form #form=\"ngForm\" class=\"row\">\n <ngx-mat-entity-input\n *ngFor=\"let key of entityKeys\"\n [entity]=\"data.entity\"\n [propertyKey]=\"key\"\n [hideOmitForCreate]=\"true\"\n class=\"col-lg-{{getWidth(data.entity, key, 'lg')}} col-md-{{getWidth(data.entity, key, 'md')}} col-sm-{{getWidth(data.entity, key, 'sm')}}\"\n >\n </ngx-mat-entity-input>\n </form>\n</mat-dialog-content>\n\n<mat-dialog-actions>\n <button mat-raised-button (click)=\"create()\" [disabled]=\"!EntityUtilities.isEntityValid(data.entity, 'create')\">\n {{data.createDialogData.createButtonLabel}}\n </button>\n <button mat-raised-button (click)=\"cancel()\" class=\"cancel-button\">\n {{data.createDialogData.cancelButtonLabel}}\n </button>\n</mat-dialog-actions>\n", styles: ["mat-dialog-actions{display:flex;justify-content:space-between}\n"] }]
|
|
73
66
|
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
74
67
|
type: Inject,
|
|
75
68
|
args: [MAT_DIALOG_DATA]
|
|
76
69
|
}] }, { type: i1.MatDialogRef }, { type: i0.Injector }, { type: i1.MatDialog }]; } });
|
|
77
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-entity-dialog.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-material-entity/src/components/table/create-dialog/create-entity-dialog.component.ts","../../../../../../projects/ngx-material-entity/src/components/table/create-dialog/create-entity-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, Injector, OnInit } from '@angular/core';\nimport { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\nimport { EntityService } from '../../../classes/entity-service.class';\nimport { Entity } from '../../../classes/entity-model.class';\nimport { EntityUtilities } from '../../../classes/entity-utilities.class';\nimport { CreateEntityDialogData } from './create-entity-dialog-data';\nimport { ConfirmDialogData } from '../../confirm-dialog/confirm-dialog-data';\nimport { NgxMatEntityConfirmDialogComponent } from '../../confirm-dialog/confirm-dialog.component';\n\n@Component({\n    selector: 'ngx-mat-entity-create-dialog',\n    templateUrl: './create-entity-dialog.component.html',\n    styleUrls: ['./create-entity-dialog.component.scss']\n})\nexport class NgxMatEntityCreateDialogComponent<EntityType extends Entity> implements OnInit {\n    EntityUtilities = EntityUtilities;\n\n    entityKeys!: (keyof EntityType)[];\n\n    entityService!: EntityService<EntityType>;\n\n    getWidth = EntityUtilities.getWidth;\n\n    constructor(\n        @Inject(MAT_DIALOG_DATA)\n        public data: CreateEntityDialogData<EntityType>,\n        public dialogRef: MatDialogRef<NgxMatEntityCreateDialogComponent<EntityType>>,\n        private readonly injector: Injector,\n        private readonly dialog: MatDialog\n    ) { }\n\n    ngOnInit(): void {\n        this.dialogRef.disableClose = true;\n        this.setEntityKeys();\n        this.entityService = this.injector.get(this.data.EntityServiceClass) as EntityService<EntityType>;\n    }\n\n    private setEntityKeys(): void {\n        this.entityKeys = Reflect.ownKeys(this.data.entity) as (keyof EntityType)[];\n        const omitCreateKeys = EntityUtilities.getOmitForCreate(this.data.entity);\n        this.entityKeys = this.entityKeys.filter((k) => !omitCreateKeys.includes(k))\n            .sort((a, b) => EntityUtilities.compareOrder(a, b, this.data.entity));\n    }\n\n    create(): void {\n        if (this.data.createDialogData.createRequiresConfirmDialog === false) {\n            return this.confirmCreate();\n        }\n        const dialogData: ConfirmDialogData = {\n            // eslint-disable-next-line max-len\n            text: this.data.createDialogData.confirmCreateDialogData?.text ? this.data.createDialogData.confirmCreateDialogData?.text : ['Do you really want to create this entity?'],\n            type: 'default',\n            // eslint-disable-next-line max-len\n            confirmButtonLabel: this.data.createDialogData.confirmCreateDialogData?.confirmButtonLabel ? this.data.createDialogData.confirmCreateDialogData?.confirmButtonLabel : 'Create',\n            // eslint-disable-next-line max-len\n            cancelButtonLabel: this.data.createDialogData.confirmCreateDialogData?.cancelButtonLabel ? this.data.createDialogData.confirmCreateDialogData?.cancelButtonLabel : 'Cancel',\n            // eslint-disable-next-line max-len\n            title: this.data.createDialogData.confirmCreateDialogData?.title ? this.data.createDialogData.confirmCreateDialogData?.title : 'Create',\n            // eslint-disable-next-line max-len\n            requireConfirmation: this.data.createDialogData.confirmCreateDialogData?.requireConfirmation ? this.data.createDialogData.confirmCreateDialogData?.requireConfirmation : false,\n            // eslint-disable-next-line max-len\n            confirmationText: this.data.createDialogData.confirmCreateDialogData?.confirmationText ? this.data.createDialogData.confirmCreateDialogData?.confirmationText : undefined,\n        };\n        const dialogref = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        dialogref.afterClosed().subscribe((res: number) => {\n            if (res === 1) {\n                this.confirmCreate();\n            }\n        });\n    }\n    private confirmCreate(): void {\n        this.entityService.create(this.data.entity).then(() => this.dialogRef.close());\n    }\n\n    cancel(): void {\n        this.dialogRef.close();\n    }\n}","<h2 mat-dialog-title>{{data.createDialogData.title}}</h2>\n\n<mat-dialog-content>\n    <form #form=\"ngForm\" class=\"row\">\n        <ngx-mat-entity-input\n            *ngFor=\"let key of entityKeys\"\n            [entity]=\"data.entity\"\n            [propertyKey]=\"key\"\n            [hideOmitForCreate]=\"true\"\n            class=\"col-lg-{{getWidth(data.entity, key, 'lg')}} col-md-{{getWidth(data.entity, key, 'md')}} col-sm-{{getWidth(data.entity, key, 'sm')}}\"\n        >\n        </ngx-mat-entity-input>\n    </form>\n</mat-dialog-content>\n\n<mat-dialog-actions>\n    <button mat-raised-button (click)=\"create()\" [disabled]=\"!EntityUtilities.isEntityValid(data.entity, 'create')\">\n        {{data.createDialogData.createButtonLabel ? data.createDialogData.createButtonLabel : 'Create'}}\n    </button>\n    <button mat-raised-button (click)=\"cancel()\" class=\"cancel-button\">\n        {{data.createDialogData.cancelButtonLabel ? data.createDialogData.cancelButtonLabel : 'Cancel'}}\n    </button>\n</mat-dialog-actions>\n"]}
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-entity-dialog.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-material-entity/src/components/table/create-dialog/create-entity-dialog.component.ts","../../../../../../projects/ngx-material-entity/src/components/table/create-dialog/create-entity-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, Injector, OnInit } from '@angular/core';\nimport { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\nimport { EntityService } from '../../../classes/entity-service.class';\nimport { Entity } from '../../../classes/entity-model.class';\nimport { EntityUtilities } from '../../../classes/entity-utilities.class';\nimport { NgxMatEntityConfirmDialogComponent } from '../../confirm-dialog/confirm-dialog.component';\nimport { ConfirmDialogDataBuilder, ConfirmDialogDataInternal } from '../../confirm-dialog/confirm-dialog-data.builder';\nimport { CreateEntityDialogDataBuilder, CreateEntityDialogDataInternal } from './create-entity-dialog-data.builder';\nimport { CreateEntityDialogData } from './create-entity-dialog-data';\n\n@Component({\n    selector: 'ngx-mat-entity-create-dialog',\n    templateUrl: './create-entity-dialog.component.html',\n    styleUrls: ['./create-entity-dialog.component.scss']\n})\nexport class NgxMatEntityCreateDialogComponent<EntityType extends Entity> implements OnInit {\n    EntityUtilities = EntityUtilities;\n\n    entityKeys!: (keyof EntityType)[];\n\n    entityService!: EntityService<EntityType>;\n\n    data!: CreateEntityDialogDataInternal<EntityType>;\n\n    getWidth = EntityUtilities.getWidth;\n\n    constructor(\n        @Inject(MAT_DIALOG_DATA)\n        private readonly inputData: CreateEntityDialogData<EntityType>,\n        public dialogRef: MatDialogRef<NgxMatEntityCreateDialogComponent<EntityType>>,\n        private readonly injector: Injector,\n        private readonly dialog: MatDialog\n    ) {}\n\n    ngOnInit(): void {\n        this.data = new CreateEntityDialogDataBuilder(this.inputData).createDialogData;\n        this.dialogRef.disableClose = true;\n        this.setEntityKeys();\n        this.entityService = this.injector.get(this.data.EntityServiceClass) as EntityService<EntityType>;\n    }\n\n    private setEntityKeys(): void {\n        this.entityKeys = Reflect.ownKeys(this.data.entity) as (keyof EntityType)[];\n        const omitCreateKeys = EntityUtilities.getOmitForCreate(this.data.entity);\n        this.entityKeys = this.entityKeys.filter((k) => !omitCreateKeys.includes(k))\n            .sort((a, b) => EntityUtilities.compareOrder(a, b, this.data.entity));\n    }\n\n    create(): void {\n        if (!this.data.createDialogData?.createRequiresConfirmDialog) {\n            return this.confirmCreate();\n        }\n        const dialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(this.data.createDialogData?.confirmCreateDialogData)\n            .withDefaultText(['Do you really want to create this entity?'])\n            .withDefaultConfirmButtonLabel('Create')\n            .withDefaultTitle('Create')\n            .confirmDialogData;\n        const dialogref = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        dialogref.afterClosed().subscribe((res: number) => {\n            if (res === 1) {\n                this.confirmCreate();\n            }\n        });\n    }\n    private confirmCreate(): void {\n        this.entityService.create(this.data.entity).then(() => this.dialogRef.close());\n    }\n\n    cancel(): void {\n        this.dialogRef.close();\n    }\n}","<h2 mat-dialog-title>{{data.createDialogData.title}}</h2>\n\n<mat-dialog-content>\n    <form #form=\"ngForm\" class=\"row\">\n        <ngx-mat-entity-input\n            *ngFor=\"let key of entityKeys\"\n            [entity]=\"data.entity\"\n            [propertyKey]=\"key\"\n            [hideOmitForCreate]=\"true\"\n            class=\"col-lg-{{getWidth(data.entity, key, 'lg')}} col-md-{{getWidth(data.entity, key, 'md')}} col-sm-{{getWidth(data.entity, key, 'sm')}}\"\n        >\n        </ngx-mat-entity-input>\n    </form>\n</mat-dialog-content>\n\n<mat-dialog-actions>\n    <button mat-raised-button (click)=\"create()\" [disabled]=\"!EntityUtilities.isEntityValid(data.entity, 'create')\">\n        {{data.createDialogData.createButtonLabel}}\n    </button>\n    <button mat-raised-button (click)=\"cancel()\" class=\"cancel-button\">\n        {{data.createDialogData.cancelButtonLabel}}\n    </button>\n</mat-dialog-actions>\n"]}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import { ConfirmDialogDataBuilder } from '../../confirm-dialog/confirm-dialog-data.builder';
|
|
2
|
+
export class EditDialogDataInternal {
|
|
3
|
+
constructor(title, confirmButtonLabel, deleteButtonLabel, cancelButtonLabel, deleteRequiresConfirmDialog, editRequiresConfirmDialog, confirmDeleteDialogData, confirmEditDialogData) {
|
|
4
|
+
this.title = title;
|
|
5
|
+
this.confirmButtonLabel = confirmButtonLabel;
|
|
6
|
+
this.deleteButtonLabel = deleteButtonLabel;
|
|
7
|
+
this.cancelButtonLabel = cancelButtonLabel;
|
|
8
|
+
this.deleteRequiresConfirmDialog = deleteRequiresConfirmDialog;
|
|
9
|
+
this.editRequiresConfirmDialog = editRequiresConfirmDialog;
|
|
10
|
+
this.confirmDeleteDialogData = confirmDeleteDialogData;
|
|
11
|
+
this.confirmEditDialogData = confirmEditDialogData;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
export class EditDialogDataBuilder {
|
|
15
|
+
constructor(data) {
|
|
16
|
+
// this.validateInput(data);
|
|
17
|
+
this.dataInput = data;
|
|
18
|
+
const confirmEditDialogData = new ConfirmDialogDataBuilder(data?.confirmEditDialogData)
|
|
19
|
+
.withDefaultConfirmButtonLabel('Save')
|
|
20
|
+
.withDefaultText(['Do you really want to save all changes?'])
|
|
21
|
+
.withDefaultTitle('Edit')
|
|
22
|
+
.confirmDialogData;
|
|
23
|
+
const confirmDeleteDialogData = new ConfirmDialogDataBuilder(data?.confirmDeleteDialogData)
|
|
24
|
+
.withDefaultConfirmButtonLabel('Delete')
|
|
25
|
+
.withDefaultType('delete')
|
|
26
|
+
.withDefaultText(['Do you really want to delete this entity?'])
|
|
27
|
+
.withDefaultTitle('Delete')
|
|
28
|
+
.confirmDialogData;
|
|
29
|
+
this.editDialogData = new EditDialogDataInternal(data?.title ? data.title : () => 'Edit', data?.confirmButtonLabel ? data.confirmButtonLabel : 'Save', data?.deleteButtonLabel ? data.deleteButtonLabel : 'Delete', data?.cancelButtonLabel ? data.cancelButtonLabel : 'Cancel', data?.deleteRequiresConfirmDialog ? data.deleteRequiresConfirmDialog : true, data?.editRequiresConfirmDialog ? data.editRequiresConfirmDialog : false, confirmDeleteDialogData, confirmEditDialogData);
|
|
30
|
+
return this;
|
|
31
|
+
}
|
|
32
|
+
withDefaultTitle(title) {
|
|
33
|
+
if (!this.dataInput?.title) {
|
|
34
|
+
this.editDialogData.title = title;
|
|
35
|
+
}
|
|
36
|
+
return this;
|
|
37
|
+
}
|
|
38
|
+
withDefaultConfirmButtonLabel(label) {
|
|
39
|
+
if (!this.dataInput?.confirmButtonLabel) {
|
|
40
|
+
this.editDialogData.confirmButtonLabel = label;
|
|
41
|
+
}
|
|
42
|
+
return this;
|
|
43
|
+
}
|
|
44
|
+
withDefaultDeleteButtonLabel(label) {
|
|
45
|
+
if (!this.dataInput?.deleteButtonLabel) {
|
|
46
|
+
this.editDialogData.deleteButtonLabel = label;
|
|
47
|
+
}
|
|
48
|
+
return this;
|
|
49
|
+
}
|
|
50
|
+
withDefaultCancelButtonLabel(label) {
|
|
51
|
+
if (!this.dataInput?.cancelButtonLabel) {
|
|
52
|
+
this.editDialogData.cancelButtonLabel = label;
|
|
53
|
+
}
|
|
54
|
+
return this;
|
|
55
|
+
}
|
|
56
|
+
withDefaultDeleteRequiresConfirmDialog(deleteRequiresConfirmDialog) {
|
|
57
|
+
if (!this.dataInput?.deleteRequiresConfirmDialog) {
|
|
58
|
+
this.editDialogData.deleteRequiresConfirmDialog = deleteRequiresConfirmDialog;
|
|
59
|
+
}
|
|
60
|
+
return this;
|
|
61
|
+
}
|
|
62
|
+
withDefaultEditRequiresConfirmDialog(editRequiresConfirmDialog) {
|
|
63
|
+
if (!this.dataInput?.editRequiresConfirmDialog) {
|
|
64
|
+
this.editDialogData.editRequiresConfirmDialog = editRequiresConfirmDialog;
|
|
65
|
+
}
|
|
66
|
+
return this;
|
|
67
|
+
}
|
|
68
|
+
withDefaultConfirmDeleteDialogData(confirmDeleteDialogData) {
|
|
69
|
+
if (!this.dataInput?.confirmDeleteDialogData) {
|
|
70
|
+
this.editDialogData.confirmDeleteDialogData = confirmDeleteDialogData;
|
|
71
|
+
}
|
|
72
|
+
return this;
|
|
73
|
+
}
|
|
74
|
+
withDefaultConfirmEditDialogData(confirmEditDialogData) {
|
|
75
|
+
if (!this.dataInput?.confirmEditDialogData) {
|
|
76
|
+
this.editDialogData.confirmEditDialogData = confirmEditDialogData;
|
|
77
|
+
}
|
|
78
|
+
return this;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"edit-dialog-data.builder.js","sourceRoot":"","sources":["../../../../../../projects/ngx-material-entity/src/components/table/edit-dialog/edit-dialog-data.builder.ts"],"names":[],"mappings":"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","sourcesContent":["import { Entity } from '../../../classes/entity-model.class';\nimport { ConfirmDialogData } from '../../confirm-dialog/confirm-dialog-data';\nimport { ConfirmDialogDataBuilder, ConfirmDialogDataInternal } from '../../confirm-dialog/confirm-dialog-data.builder';\nimport { EditDialogData } from '../table-data';\n\nexport class EditDialogDataInternal<EntityType extends Entity> implements EditDialogData<EntityType> {\n    title: (entity: EntityType) => string;\n    confirmButtonLabel: string;\n    deleteButtonLabel: string;\n    cancelButtonLabel: string;\n    deleteRequiresConfirmDialog: boolean;\n    editRequiresConfirmDialog: boolean;\n    confirmDeleteDialogData: ConfirmDialogData;\n    confirmEditDialogData: ConfirmDialogData;\n\n    constructor(\n        title: (entity: EntityType) => string,\n        confirmButtonLabel: string,\n        deleteButtonLabel: string,\n        cancelButtonLabel: string,\n        deleteRequiresConfirmDialog: boolean,\n        editRequiresConfirmDialog: boolean,\n        confirmDeleteDialogData: ConfirmDialogData,\n        confirmEditDialogData: ConfirmDialogData\n    ) {\n        this.title = title;\n        this.confirmButtonLabel = confirmButtonLabel;\n        this.deleteButtonLabel = deleteButtonLabel;\n        this.cancelButtonLabel = cancelButtonLabel;\n        this.deleteRequiresConfirmDialog = deleteRequiresConfirmDialog;\n        this.editRequiresConfirmDialog = editRequiresConfirmDialog;\n        this.confirmDeleteDialogData = confirmDeleteDialogData;\n        this.confirmEditDialogData = confirmEditDialogData;\n    }\n}\n\nexport class EditDialogDataBuilder<EntityType extends Entity> {\n    editDialogData: EditDialogDataInternal<EntityType>;\n    private readonly dataInput?: EditDialogData<EntityType>;\n\n    constructor(data?: EditDialogData<EntityType>) {\n        // this.validateInput(data);\n        this.dataInput = data;\n        const confirmEditDialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(data?.confirmEditDialogData)\n            .withDefaultConfirmButtonLabel('Save')\n            .withDefaultText(['Do you really want to save all changes?'])\n            .withDefaultTitle('Edit')\n            .confirmDialogData;\n        const confirmDeleteDialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(data?.confirmDeleteDialogData)\n            .withDefaultConfirmButtonLabel('Delete')\n            .withDefaultType('delete')\n            .withDefaultText(['Do you really want to delete this entity?'])\n            .withDefaultTitle('Delete')\n            .confirmDialogData;\n        this.editDialogData = new EditDialogDataInternal(\n            data?.title ? data.title : () => 'Edit',\n            data?.confirmButtonLabel ? data.confirmButtonLabel : 'Save',\n            data?.deleteButtonLabel ? data.deleteButtonLabel : 'Delete',\n            data?.cancelButtonLabel ? data.cancelButtonLabel : 'Cancel',\n            data?.deleteRequiresConfirmDialog ? data.deleteRequiresConfirmDialog : true,\n            data?.editRequiresConfirmDialog ? data.editRequiresConfirmDialog : false,\n            confirmDeleteDialogData,\n            confirmEditDialogData\n        );\n        return this;\n    }\n\n    withDefaultTitle(title: (entity: EntityType) => string): EditDialogDataBuilder<EntityType> {\n        if (!this.dataInput?.title) {\n            this.editDialogData.title = title;\n        }\n        return this;\n    }\n\n    withDefaultConfirmButtonLabel(label: string): EditDialogDataBuilder<EntityType> {\n        if (!this.dataInput?.confirmButtonLabel) {\n            this.editDialogData.confirmButtonLabel = label;\n        }\n        return this;\n    }\n\n    withDefaultDeleteButtonLabel(label: string): EditDialogDataBuilder<EntityType> {\n        if (!this.dataInput?.deleteButtonLabel) {\n            this.editDialogData.deleteButtonLabel = label;\n        }\n        return this;\n    }\n\n    withDefaultCancelButtonLabel(label: string): EditDialogDataBuilder<EntityType> {\n        if (!this.dataInput?.cancelButtonLabel) {\n            this.editDialogData.cancelButtonLabel = label;\n        }\n        return this;\n    }\n\n    withDefaultDeleteRequiresConfirmDialog(deleteRequiresConfirmDialog: boolean): EditDialogDataBuilder<EntityType> {\n        if (!this.dataInput?.deleteRequiresConfirmDialog) {\n            this.editDialogData.deleteRequiresConfirmDialog = deleteRequiresConfirmDialog;\n        }\n        return this;\n    }\n\n    withDefaultEditRequiresConfirmDialog(editRequiresConfirmDialog: boolean): EditDialogDataBuilder<EntityType> {\n        if (!this.dataInput?.editRequiresConfirmDialog) {\n            this.editDialogData.editRequiresConfirmDialog = editRequiresConfirmDialog;\n        }\n        return this;\n    }\n\n    withDefaultConfirmDeleteDialogData(confirmDeleteDialogData: ConfirmDialogData): EditDialogDataBuilder<EntityType> {\n        if (!this.dataInput?.confirmDeleteDialogData) {\n            this.editDialogData.confirmDeleteDialogData = confirmDeleteDialogData;\n        }\n        return this;\n    }\n\n    withDefaultConfirmEditDialogData(confirmEditDialogData: ConfirmDialogData): EditDialogDataBuilder<EntityType> {\n        if (!this.dataInput?.confirmEditDialogData) {\n            this.editDialogData.confirmEditDialogData = confirmEditDialogData;\n        }\n        return this;\n    }\n}"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRpdC1lbnRpdHktZGlhbG9nLWRhdGEuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtbWF0ZXJpYWwtZW50aXR5L3NyYy9jb21wb25lbnRzL3RhYmxlL2VkaXQtZGlhbG9nL2VkaXQtZW50aXR5LWRpYWxvZy1kYXRhLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgRW50aXR5U2VydmljZSB9IGZyb20gJy4uLy4uLy4uL2NsYXNzZXMvZW50aXR5LXNlcnZpY2UuY2xhc3MnO1xuaW1wb3J0IHsgRW50aXR5IH0gZnJvbSAnLi4vLi4vLi4vY2xhc3Nlcy9lbnRpdHktbW9kZWwuY2xhc3MnO1xuaW1wb3J0IHsgRWRpdERpYWxvZ0RhdGEgfSBmcm9tICcuLi90YWJsZS1kYXRhJztcblxuLyoqXG4gKiBUaGUgRGVmaW5pdGlvbiBvZiB0aGUgRWRpdCBFbnRpdHkgRGlhbG9nIERhdGEuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRWRpdEVudGl0eURpYWxvZ0RhdGE8RW50aXR5VHlwZSBleHRlbmRzIEVudGl0eT4ge1xuICAgIC8qKlxuICAgICAqIFRoZSBlbnRpdHkgdG8gZWRpdC5cbiAgICAgKi9cbiAgICBlbnRpdHk6IEVudGl0eVR5cGUsXG4gICAgLyoqXG4gICAgICogVGhlIEVudGl0eSBTZXJ2aWNlIGNsYXNzIHVzZWQgZm9yIHVwZGF0aW5nL2RlbGV0aW5nIHRoZSBlbnRpdHkuXG4gICAgICovXG4gICAgRW50aXR5U2VydmljZUNsYXNzOiBuZXcgKGh0dHBDbGllbnQ6IEh0dHBDbGllbnQpID0+IEVudGl0eVNlcnZpY2U8RW50aXR5VHlwZT4sXG4gICAgLyoqXG4gICAgICogVGhlIGluZm8gb2YgdGhlIGdlbmVyaWMgZWRpdC1kaWFsb2cuXG4gICAgICovXG4gICAgZWRpdERpYWxvZ0RhdGE/OiBFZGl0RGlhbG9nRGF0YTxFbnRpdHlUeXBlPixcbiAgICAvKipcbiAgICAgKiBXaGV0aGVyIG9yIG5vdCB0aGUgdXNlciBjYW4gZGVsZXRlIHRoaXMgc3BlY2lmaWMgZW50aXR5LlxuICAgICAqL1xuICAgIGFsbG93RGVsZXRlPzogKGVudGl0eTogRW50aXR5VHlwZSkgPT4gYm9vbGVhblxufSJdfQ==
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { EditDialogDataBuilder } from './edit-dialog-data.builder';
|
|
2
|
+
export class EditEntityDialogDataInternal {
|
|
3
|
+
constructor(entity, EntityServiceClass, editDialogData, allowDelete) {
|
|
4
|
+
this.entity = entity;
|
|
5
|
+
this.EntityServiceClass = EntityServiceClass;
|
|
6
|
+
this.editDialogData = editDialogData;
|
|
7
|
+
this.allowDelete = allowDelete;
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
export class EditEntityDialogDataBuilder {
|
|
11
|
+
constructor(data) {
|
|
12
|
+
// this.validateInput(data);
|
|
13
|
+
this.dataInput = data;
|
|
14
|
+
const editDialogData = new EditDialogDataBuilder(data.editDialogData).editDialogData;
|
|
15
|
+
this.editDialogData = new EditEntityDialogDataInternal(data.entity, data.EntityServiceClass, editDialogData, data.allowDelete ? data.allowDelete : () => true);
|
|
16
|
+
return this;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRpdC1lbnRpdHktZGlhbG9nLmJ1aWxkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtbWF0ZXJpYWwtZW50aXR5L3NyYy9jb21wb25lbnRzL3RhYmxlL2VkaXQtZGlhbG9nL2VkaXQtZW50aXR5LWRpYWxvZy5idWlsZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlBLE9BQU8sRUFBRSxxQkFBcUIsRUFBMEIsTUFBTSw0QkFBNEIsQ0FBQztBQUUzRixNQUFNLE9BQU8sNEJBQTRCO0lBTXJDLFlBQ0ksTUFBa0IsRUFDbEIsa0JBQTZFLEVBQzdFLGNBQWtELEVBQ2xELFdBQTRDO1FBRTVDLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDO1FBQ3JCLElBQUksQ0FBQyxrQkFBa0IsR0FBRyxrQkFBa0IsQ0FBQztRQUM3QyxJQUFJLENBQUMsY0FBYyxHQUFHLGNBQWMsQ0FBQztRQUNyQyxJQUFJLENBQUMsV0FBVyxHQUFHLFdBQVcsQ0FBQztJQUNuQyxDQUFDO0NBQ0o7QUFFRCxNQUFNLE9BQU8sMkJBQTJCO0lBSXBDLFlBQVksSUFBc0M7UUFDOUMsNEJBQTRCO1FBQzVCLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDO1FBQ3RCLE1BQU0sY0FBYyxHQUF1QyxJQUFJLHFCQUFxQixDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQyxjQUFjLENBQUM7UUFDekgsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLDRCQUE0QixDQUNsRCxJQUFJLENBQUMsTUFBTSxFQUNYLElBQUksQ0FBQyxrQkFBa0IsRUFDdkIsY0FBYyxFQUNkLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FDbkQsQ0FBQztRQUNGLE9BQU8sSUFBSSxDQUFDO0lBQ2hCLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEVudGl0eVNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi9jbGFzc2VzL2VudGl0eS1zZXJ2aWNlLmNsYXNzJztcbmltcG9ydCB7IEVudGl0eSB9IGZyb20gJy4uLy4uLy4uL2NsYXNzZXMvZW50aXR5LW1vZGVsLmNsYXNzJ1xuaW1wb3J0IHsgSHR0cENsaWVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcbmltcG9ydCB7IEVkaXRFbnRpdHlEaWFsb2dEYXRhIH0gZnJvbSAnLi9lZGl0LWVudGl0eS1kaWFsb2ctZGF0YSc7XG5pbXBvcnQgeyBFZGl0RGlhbG9nRGF0YUJ1aWxkZXIsIEVkaXREaWFsb2dEYXRhSW50ZXJuYWwgfSBmcm9tICcuL2VkaXQtZGlhbG9nLWRhdGEuYnVpbGRlcic7XG5cbmV4cG9ydCBjbGFzcyBFZGl0RW50aXR5RGlhbG9nRGF0YUludGVybmFsPEVudGl0eVR5cGUgZXh0ZW5kcyBFbnRpdHk+IGltcGxlbWVudHMgRWRpdEVudGl0eURpYWxvZ0RhdGE8RW50aXR5VHlwZT4ge1xuICAgIGVudGl0eTogRW50aXR5VHlwZTtcbiAgICBFbnRpdHlTZXJ2aWNlQ2xhc3M6IG5ldyAoaHR0cENsaWVudDogSHR0cENsaWVudCkgPT4gRW50aXR5U2VydmljZTxFbnRpdHlUeXBlPjtcbiAgICBlZGl0RGlhbG9nRGF0YTogRWRpdERpYWxvZ0RhdGFJbnRlcm5hbDxFbnRpdHlUeXBlPjtcbiAgICBhbGxvd0RlbGV0ZTogKGVudGl0eTogRW50aXR5VHlwZSkgPT4gYm9vbGVhbjtcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBlbnRpdHk6IEVudGl0eVR5cGUsXG4gICAgICAgIEVudGl0eVNlcnZpY2VDbGFzczogbmV3IChodHRwQ2xpZW50OiBIdHRwQ2xpZW50KSA9PiBFbnRpdHlTZXJ2aWNlPEVudGl0eVR5cGU+LFxuICAgICAgICBlZGl0RGlhbG9nRGF0YTogRWRpdERpYWxvZ0RhdGFJbnRlcm5hbDxFbnRpdHlUeXBlPixcbiAgICAgICAgYWxsb3dEZWxldGU6IChlbnRpdHk6IEVudGl0eVR5cGUpID0+IGJvb2xlYW5cbiAgICApIHtcbiAgICAgICAgdGhpcy5lbnRpdHkgPSBlbnRpdHk7XG4gICAgICAgIHRoaXMuRW50aXR5U2VydmljZUNsYXNzID0gRW50aXR5U2VydmljZUNsYXNzO1xuICAgICAgICB0aGlzLmVkaXREaWFsb2dEYXRhID0gZWRpdERpYWxvZ0RhdGE7XG4gICAgICAgIHRoaXMuYWxsb3dEZWxldGUgPSBhbGxvd0RlbGV0ZTtcbiAgICB9XG59XG5cbmV4cG9ydCBjbGFzcyBFZGl0RW50aXR5RGlhbG9nRGF0YUJ1aWxkZXI8RW50aXR5VHlwZSBleHRlbmRzIEVudGl0eT4ge1xuICAgIGVkaXREaWFsb2dEYXRhOiBFZGl0RW50aXR5RGlhbG9nRGF0YUludGVybmFsPEVudGl0eVR5cGU+O1xuICAgIHByaXZhdGUgcmVhZG9ubHkgZGF0YUlucHV0OiBFZGl0RW50aXR5RGlhbG9nRGF0YTxFbnRpdHlUeXBlPjtcblxuICAgIGNvbnN0cnVjdG9yKGRhdGE6IEVkaXRFbnRpdHlEaWFsb2dEYXRhPEVudGl0eVR5cGU+KSB7XG4gICAgICAgIC8vIHRoaXMudmFsaWRhdGVJbnB1dChkYXRhKTtcbiAgICAgICAgdGhpcy5kYXRhSW5wdXQgPSBkYXRhO1xuICAgICAgICBjb25zdCBlZGl0RGlhbG9nRGF0YTogRWRpdERpYWxvZ0RhdGFJbnRlcm5hbDxFbnRpdHlUeXBlPiA9IG5ldyBFZGl0RGlhbG9nRGF0YUJ1aWxkZXIoZGF0YS5lZGl0RGlhbG9nRGF0YSkuZWRpdERpYWxvZ0RhdGE7XG4gICAgICAgIHRoaXMuZWRpdERpYWxvZ0RhdGEgPSBuZXcgRWRpdEVudGl0eURpYWxvZ0RhdGFJbnRlcm5hbDxFbnRpdHlUeXBlPihcbiAgICAgICAgICAgIGRhdGEuZW50aXR5LFxuICAgICAgICAgICAgZGF0YS5FbnRpdHlTZXJ2aWNlQ2xhc3MsXG4gICAgICAgICAgICBlZGl0RGlhbG9nRGF0YSxcbiAgICAgICAgICAgIGRhdGEuYWxsb3dEZWxldGUgPyBkYXRhLmFsbG93RGVsZXRlIDogKCkgPT4gdHJ1ZVxuICAgICAgICApO1xuICAgICAgICByZXR1cm4gdGhpcztcbiAgICB9XG59Il19
|
|
@@ -3,6 +3,8 @@ import { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dial
|
|
|
3
3
|
import { EntityUtilities } from '../../../classes/entity-utilities.class';
|
|
4
4
|
import { cloneDeep } from 'lodash';
|
|
5
5
|
import { NgxMatEntityConfirmDialogComponent } from '../../confirm-dialog/confirm-dialog.component';
|
|
6
|
+
import { ConfirmDialogDataBuilder } from '../../confirm-dialog/confirm-dialog-data.builder';
|
|
7
|
+
import { EditEntityDialogDataBuilder } from './edit-entity-dialog.builder';
|
|
6
8
|
import * as i0 from "@angular/core";
|
|
7
9
|
import * as i1 from "@angular/material/dialog";
|
|
8
10
|
import * as i2 from "@angular/material/button";
|
|
@@ -10,8 +12,8 @@ import * as i3 from "../../input/input.component";
|
|
|
10
12
|
import * as i4 from "@angular/common";
|
|
11
13
|
import * as i5 from "@angular/forms";
|
|
12
14
|
export class NgxMatEntityEditDialogComponent {
|
|
13
|
-
constructor(
|
|
14
|
-
this.
|
|
15
|
+
constructor(inputData, dialogRef, injector, dialog) {
|
|
16
|
+
this.inputData = inputData;
|
|
15
17
|
this.dialogRef = dialogRef;
|
|
16
18
|
this.injector = injector;
|
|
17
19
|
this.dialog = dialog;
|
|
@@ -19,6 +21,7 @@ export class NgxMatEntityEditDialogComponent {
|
|
|
19
21
|
this.getWidth = EntityUtilities.getWidth;
|
|
20
22
|
}
|
|
21
23
|
ngOnInit() {
|
|
24
|
+
this.data = new EditEntityDialogDataBuilder(this.inputData).editDialogData;
|
|
22
25
|
this.dialogRef.disableClose = true;
|
|
23
26
|
this.setEntityKeys();
|
|
24
27
|
this.entityService = this.injector.get(this.data.EntityServiceClass);
|
|
@@ -31,23 +34,14 @@ export class NgxMatEntityEditDialogComponent {
|
|
|
31
34
|
.sort((a, b) => EntityUtilities.compareOrder(a, b, this.data.entity));
|
|
32
35
|
}
|
|
33
36
|
edit() {
|
|
34
|
-
if (this.data.editDialogData.editRequiresConfirmDialog
|
|
37
|
+
if (!this.data.editDialogData.editRequiresConfirmDialog) {
|
|
35
38
|
return this.confirmEdit();
|
|
36
39
|
}
|
|
37
|
-
const dialogData =
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
confirmButtonLabel: this.data.editDialogData.confirmEditDialogData?.confirmButtonLabel ? this.data.editDialogData.confirmEditDialogData?.confirmButtonLabel : 'Confirm',
|
|
43
|
-
// eslint-disable-next-line max-len
|
|
44
|
-
cancelButtonLabel: this.data.editDialogData.confirmEditDialogData?.cancelButtonLabel ? this.data.editDialogData.confirmEditDialogData?.cancelButtonLabel : 'Cancel',
|
|
45
|
-
title: this.data.editDialogData.confirmEditDialogData?.title ? this.data.editDialogData.confirmEditDialogData?.title : 'Edit',
|
|
46
|
-
// eslint-disable-next-line max-len
|
|
47
|
-
requireConfirmation: this.data.editDialogData.confirmEditDialogData?.requireConfirmation ? this.data.editDialogData.confirmEditDialogData?.requireConfirmation : false,
|
|
48
|
-
// eslint-disable-next-line max-len
|
|
49
|
-
confirmationText: this.data.editDialogData.confirmEditDialogData?.confirmationText ? this.data.editDialogData.confirmEditDialogData?.confirmationText : undefined,
|
|
50
|
-
};
|
|
40
|
+
const dialogData = new ConfirmDialogDataBuilder(this.data.editDialogData.confirmEditDialogData)
|
|
41
|
+
.withDefaultText(['Do you really want to save all changes?'])
|
|
42
|
+
.withDefaultConfirmButtonLabel('Save')
|
|
43
|
+
.withDefaultTitle('Edit')
|
|
44
|
+
.confirmDialogData;
|
|
51
45
|
const dialogref = this.dialog.open(NgxMatEntityConfirmDialogComponent, {
|
|
52
46
|
data: dialogData,
|
|
53
47
|
autoFocus: false,
|
|
@@ -63,24 +57,15 @@ export class NgxMatEntityEditDialogComponent {
|
|
|
63
57
|
this.entityService.update(this.data.entity, this.entityPriorChanges).then(() => this.dialogRef.close(1));
|
|
64
58
|
}
|
|
65
59
|
delete() {
|
|
66
|
-
if (this.data.editDialogData.deleteRequiresConfirmDialog
|
|
60
|
+
if (!this.data.editDialogData.deleteRequiresConfirmDialog) {
|
|
67
61
|
return this.confirmDelete();
|
|
68
62
|
}
|
|
69
|
-
const dialogData =
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
// eslint-disable-next-line max-len
|
|
76
|
-
cancelButtonLabel: this.data.editDialogData.confirmDeleteDialogData?.cancelButtonLabel ? this.data.editDialogData.confirmDeleteDialogData?.cancelButtonLabel : 'Cancel',
|
|
77
|
-
// eslint-disable-next-line max-len
|
|
78
|
-
title: this.data.editDialogData.confirmDeleteDialogData?.title ? this.data.editDialogData.confirmDeleteDialogData?.title : 'Delete',
|
|
79
|
-
// eslint-disable-next-line max-len
|
|
80
|
-
requireConfirmation: this.data.editDialogData.confirmDeleteDialogData?.requireConfirmation ? this.data.editDialogData.confirmDeleteDialogData?.requireConfirmation : false,
|
|
81
|
-
// eslint-disable-next-line max-len
|
|
82
|
-
confirmationText: this.data.editDialogData.confirmDeleteDialogData?.confirmationText ? this.data.editDialogData.confirmDeleteDialogData?.confirmationText : undefined,
|
|
83
|
-
};
|
|
63
|
+
const dialogData = new ConfirmDialogDataBuilder(this.data.editDialogData.confirmDeleteDialogData)
|
|
64
|
+
.withDefaultText(['Do you really want to delete this entity?'])
|
|
65
|
+
.withDefaultType('delete')
|
|
66
|
+
.withDefaultConfirmButtonLabel('Delete')
|
|
67
|
+
.withDefaultTitle('Delete')
|
|
68
|
+
.confirmDialogData;
|
|
84
69
|
const dialogref = this.dialog.open(NgxMatEntityConfirmDialogComponent, {
|
|
85
70
|
data: dialogData,
|
|
86
71
|
autoFocus: false,
|
|
@@ -101,12 +86,12 @@ export class NgxMatEntityEditDialogComponent {
|
|
|
101
86
|
}
|
|
102
87
|
}
|
|
103
88
|
NgxMatEntityEditDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityEditDialogComponent, deps: [{ token: MAT_DIALOG_DATA }, { token: i1.MatDialogRef }, { token: i0.Injector }, { token: i1.MatDialog }], target: i0.ɵɵFactoryTarget.Component });
|
|
104
|
-
NgxMatEntityEditDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: NgxMatEntityEditDialogComponent, selector: "ngx-mat-entity-edit-dialog", ngImport: i0, template: "<h2 mat-dialog-title>\n {{data.editDialogData.title(data.entity)}}\n <button *ngIf=\"data.allowDelete(data.entity)\" mat-raised-button (click)=\"delete()\" color=\"warn\" class=\"delete-button\" tabindex=\"-1\">\n {{data.editDialogData.deleteButtonLabel
|
|
89
|
+
NgxMatEntityEditDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: NgxMatEntityEditDialogComponent, selector: "ngx-mat-entity-edit-dialog", ngImport: i0, template: "<h2 mat-dialog-title>\n {{data.editDialogData.title(data.entity)}}\n <button *ngIf=\"data.allowDelete(data.entity)\" mat-raised-button (click)=\"delete()\" color=\"warn\" class=\"delete-button\" tabindex=\"-1\">\n {{data.editDialogData.deleteButtonLabel}}\n </button>\n</h2>\n\n<mat-dialog-content>\n <form #form=\"ngForm\" class=\"row\">\n <ngx-mat-entity-input\n *ngFor=\"let key of entityKeys\"\n [entity]=\"data.entity\"\n [propertyKey]=\"key\"\n [hideOmitForEdit]=\"true\"\n class=\"col-lg-{{getWidth(data.entity, key, 'lg')}} col-md-{{getWidth(data.entity, key, 'md')}} col-sm-{{getWidth(data.entity, key, 'sm')}}\"\n >\n </ngx-mat-entity-input>\n </form>\n</mat-dialog-content>\n\n<mat-dialog-actions>\n <button mat-raised-button (click)=\"edit()\" [disabled]=\"!EntityUtilities.isEntityValid(data.entity, 'update') || !EntityUtilities.dirty(data.entity, entityPriorChanges)\">\n {{data.editDialogData.confirmButtonLabel}}\n </button>\n <button mat-raised-button (click)=\"cancel()\" class=\"cancel-button\">\n {{data.editDialogData.cancelButtonLabel}}\n </button>\n</mat-dialog-actions>\n", styles: ["mat-dialog-actions{display:flex;justify-content:space-between}.delete-button{float:right}\n"], components: [{ type: i2.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: i3.NgxMatEntityInputComponent, selector: "ngx-mat-entity-input", inputs: ["entity", "propertyKey", "getValidationErrorMessage", "hideOmitForCreate", "hideOmitForEdit"] }], directives: [{ type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { type: i5.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i5.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i5.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]" }] });
|
|
105
90
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NgxMatEntityEditDialogComponent, decorators: [{
|
|
106
91
|
type: Component,
|
|
107
|
-
args: [{ selector: 'ngx-mat-entity-edit-dialog', template: "<h2 mat-dialog-title>\n {{data.editDialogData.title(data.entity)}}\n <button *ngIf=\"data.allowDelete(data.entity)\" mat-raised-button (click)=\"delete()\" color=\"warn\" class=\"delete-button\" tabindex=\"-1\">\n {{data.editDialogData.deleteButtonLabel
|
|
92
|
+
args: [{ selector: 'ngx-mat-entity-edit-dialog', template: "<h2 mat-dialog-title>\n {{data.editDialogData.title(data.entity)}}\n <button *ngIf=\"data.allowDelete(data.entity)\" mat-raised-button (click)=\"delete()\" color=\"warn\" class=\"delete-button\" tabindex=\"-1\">\n {{data.editDialogData.deleteButtonLabel}}\n </button>\n</h2>\n\n<mat-dialog-content>\n <form #form=\"ngForm\" class=\"row\">\n <ngx-mat-entity-input\n *ngFor=\"let key of entityKeys\"\n [entity]=\"data.entity\"\n [propertyKey]=\"key\"\n [hideOmitForEdit]=\"true\"\n class=\"col-lg-{{getWidth(data.entity, key, 'lg')}} col-md-{{getWidth(data.entity, key, 'md')}} col-sm-{{getWidth(data.entity, key, 'sm')}}\"\n >\n </ngx-mat-entity-input>\n </form>\n</mat-dialog-content>\n\n<mat-dialog-actions>\n <button mat-raised-button (click)=\"edit()\" [disabled]=\"!EntityUtilities.isEntityValid(data.entity, 'update') || !EntityUtilities.dirty(data.entity, entityPriorChanges)\">\n {{data.editDialogData.confirmButtonLabel}}\n </button>\n <button mat-raised-button (click)=\"cancel()\" class=\"cancel-button\">\n {{data.editDialogData.cancelButtonLabel}}\n </button>\n</mat-dialog-actions>\n", styles: ["mat-dialog-actions{display:flex;justify-content:space-between}.delete-button{float:right}\n"] }]
|
|
108
93
|
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
109
94
|
type: Inject,
|
|
110
95
|
args: [MAT_DIALOG_DATA]
|
|
111
96
|
}] }, { type: i1.MatDialogRef }, { type: i0.Injector }, { type: i1.MatDialog }]; } });
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"edit-entity-dialog.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-material-entity/src/components/table/edit-dialog/edit-entity-dialog.component.ts","../../../../../../projects/ngx-material-entity/src/components/table/edit-dialog/edit-entity-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, Injector, OnInit } from '@angular/core';\nimport { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\nimport { EntityService } from '../../../classes/entity-service.class';\nimport { Entity } from '../../../classes/entity-model.class';\nimport { EntityUtilities } from '../../../classes/entity-utilities.class';\nimport { cloneDeep } from 'lodash';\nimport { EditEntityDialogData } from './edit-entity-dialog-data';\nimport { NgxMatEntityConfirmDialogComponent } from '../../confirm-dialog/confirm-dialog.component';\nimport { ConfirmDialogData } from '../../confirm-dialog/confirm-dialog-data';\n\n@Component({\n    selector: 'ngx-mat-entity-edit-dialog',\n    templateUrl: './edit-entity-dialog.component.html',\n    styleUrls: ['./edit-entity-dialog.component.scss']\n})\nexport class  NgxMatEntityEditDialogComponent<EntityType extends Entity> implements OnInit {\n    EntityUtilities = EntityUtilities;\n\n    entityKeys!: (keyof EntityType)[];\n\n    entityService!: EntityService<EntityType>;\n\n    entityPriorChanges!: EntityType;\n\n    getWidth = EntityUtilities.getWidth;\n\n    constructor(\n        @Inject(MAT_DIALOG_DATA)\n        public data: EditEntityDialogData<EntityType>,\n        public dialogRef: MatDialogRef<NgxMatEntityEditDialogComponent<EntityType>>,\n        private readonly injector: Injector,\n        private readonly dialog: MatDialog\n    ) { }\n\n    ngOnInit(): void {\n        this.dialogRef.disableClose = true;\n        this.setEntityKeys();\n        this.entityService = this.injector.get(this.data.EntityServiceClass) as EntityService<EntityType>;\n        this.entityPriorChanges = cloneDeep(this.data.entity);\n    }\n\n    private setEntityKeys(): void {\n        this.entityKeys = Reflect.ownKeys(this.data.entity) as (keyof EntityType)[];\n        const omitUpdateKeys = EntityUtilities.getOmitForUpdate(this.data.entity);\n        this.entityKeys = this.entityKeys.filter((k) => !omitUpdateKeys.includes(k))\n            .sort((a, b) => EntityUtilities.compareOrder(a, b, this.data.entity));\n    }\n\n    edit(): void {\n        if (this.data.editDialogData.editRequiresConfirmDialog === false) {\n            return this.confirmEdit();\n        }\n        const dialogData: ConfirmDialogData = {\n            // eslint-disable-next-line max-len\n            text: this.data.editDialogData.confirmEditDialogData?.text ? this.data.editDialogData.confirmEditDialogData?.text : ['Do you really want to save all changes?'],\n            type: 'default',\n            // eslint-disable-next-line max-len\n            confirmButtonLabel: this.data.editDialogData.confirmEditDialogData?.confirmButtonLabel ? this.data.editDialogData.confirmEditDialogData?.confirmButtonLabel : 'Confirm',\n            // eslint-disable-next-line max-len\n            cancelButtonLabel: this.data.editDialogData.confirmEditDialogData?.cancelButtonLabel ? this.data.editDialogData.confirmEditDialogData?.cancelButtonLabel : 'Cancel',\n            title: this.data.editDialogData.confirmEditDialogData?.title ? this.data.editDialogData.confirmEditDialogData?.title : 'Edit',\n            // eslint-disable-next-line max-len\n            requireConfirmation: this.data.editDialogData.confirmEditDialogData?.requireConfirmation ? this.data.editDialogData.confirmEditDialogData?.requireConfirmation : false,\n            // eslint-disable-next-line max-len\n            confirmationText: this.data.editDialogData.confirmEditDialogData?.confirmationText ? this.data.editDialogData.confirmEditDialogData?.confirmationText : undefined,\n        };\n        const dialogref = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        dialogref.afterClosed().subscribe((res: number) => {\n            if (res === 1) {\n                this.confirmEdit();\n            }\n        });\n    }\n    private confirmEdit(): void {\n        this.entityService.update(this.data.entity, this.entityPriorChanges).then(() => this.dialogRef.close(1));\n    }\n\n    delete(): void {\n        if (this.data.editDialogData.deleteRequiresConfirmDialog === false) {\n            return this.confirmDelete();\n        }\n        const dialogData: ConfirmDialogData = {\n            // eslint-disable-next-line max-len\n            text: this.data.editDialogData.confirmDeleteDialogData?.text ? this.data.editDialogData.confirmDeleteDialogData?.text : ['Do you really want to delete this entity?'],\n            type: 'delete',\n            // eslint-disable-next-line max-len\n            confirmButtonLabel: this.data.editDialogData.confirmDeleteDialogData?.confirmButtonLabel ? this.data.editDialogData.confirmDeleteDialogData?.confirmButtonLabel : 'Delete',\n            // eslint-disable-next-line max-len\n            cancelButtonLabel: this.data.editDialogData.confirmDeleteDialogData?.cancelButtonLabel ? this.data.editDialogData.confirmDeleteDialogData?.cancelButtonLabel : 'Cancel',\n            // eslint-disable-next-line max-len\n            title: this.data.editDialogData.confirmDeleteDialogData?.title ? this.data.editDialogData.confirmDeleteDialogData?.title : 'Delete',\n            // eslint-disable-next-line max-len\n            requireConfirmation: this.data.editDialogData.confirmDeleteDialogData?.requireConfirmation ? this.data.editDialogData.confirmDeleteDialogData?.requireConfirmation : false,\n            // eslint-disable-next-line max-len\n            confirmationText: this.data.editDialogData.confirmDeleteDialogData?.confirmationText ? this.data.editDialogData.confirmDeleteDialogData?.confirmationText : undefined,\n        };\n        const dialogref = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        dialogref.afterClosed().subscribe((res: number) => {\n            if (res === 1) {\n                this.confirmDelete();\n            }\n        });\n    }\n    private confirmDelete(): void {\n        this.entityService.delete(this.entityPriorChanges.id).then(() => this.dialogRef.close(2));\n    }\n\n    cancel(): void {\n        EntityUtilities.resetChangesOnEntity(this.data.entity, this.entityPriorChanges);\n        this.dialogRef.close(0);\n    }\n}","<h2 mat-dialog-title>\n    {{data.editDialogData.title(data.entity)}}\n    <button *ngIf=\"data.allowDelete(data.entity)\" mat-raised-button (click)=\"delete()\" color=\"warn\" class=\"delete-button\" tabindex=\"-1\">\n        {{data.editDialogData.deleteButtonLabel ? data.editDialogData.deleteButtonLabel : 'Delete'}}\n    </button>\n</h2>\n\n<mat-dialog-content>\n    <form #form=\"ngForm\" class=\"row\">\n        <ngx-mat-entity-input\n            *ngFor=\"let key of entityKeys\"\n            [entity]=\"data.entity\"\n            [propertyKey]=\"key\"\n            [hideOmitForEdit]=\"true\"\n            class=\"col-lg-{{getWidth(data.entity, key, 'lg')}} col-md-{{getWidth(data.entity, key, 'md')}} col-sm-{{getWidth(data.entity, key, 'sm')}}\"\n        >\n        </ngx-mat-entity-input>\n    </form>\n</mat-dialog-content>\n\n<mat-dialog-actions>\n    <button mat-raised-button (click)=\"edit()\" [disabled]=\"!EntityUtilities.isEntityValid(data.entity, 'edit') || !EntityUtilities.dirty(data.entity, entityPriorChanges)\">\n        {{data.editDialogData.confirmButtonLabel ? data.editDialogData.confirmButtonLabel : 'Save'}}\n    </button>\n    <button mat-raised-button (click)=\"cancel()\" class=\"cancel-button\">\n        {{data.editDialogData.cancelButtonLabel ? data.editDialogData.cancelButtonLabel : 'Cancel'}}\n    </button>\n</mat-dialog-actions>\n"]}
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"edit-entity-dialog.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-material-entity/src/components/table/edit-dialog/edit-entity-dialog.component.ts","../../../../../../projects/ngx-material-entity/src/components/table/edit-dialog/edit-entity-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, Injector, OnInit } from '@angular/core';\nimport { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\nimport { EntityService } from '../../../classes/entity-service.class';\nimport { Entity } from '../../../classes/entity-model.class';\nimport { EntityUtilities } from '../../../classes/entity-utilities.class';\nimport { cloneDeep } from 'lodash';\nimport { EditEntityDialogData } from './edit-entity-dialog-data';\nimport { NgxMatEntityConfirmDialogComponent } from '../../confirm-dialog/confirm-dialog.component';\nimport { ConfirmDialogDataBuilder, ConfirmDialogDataInternal } from '../../confirm-dialog/confirm-dialog-data.builder';\nimport { EditEntityDialogDataBuilder, EditEntityDialogDataInternal } from './edit-entity-dialog.builder';\n\n@Component({\n    selector: 'ngx-mat-entity-edit-dialog',\n    templateUrl: './edit-entity-dialog.component.html',\n    styleUrls: ['./edit-entity-dialog.component.scss']\n})\nexport class  NgxMatEntityEditDialogComponent<EntityType extends Entity> implements OnInit {\n    EntityUtilities = EntityUtilities;\n\n    entityKeys!: (keyof EntityType)[];\n\n    entityService!: EntityService<EntityType>;\n\n    entityPriorChanges!: EntityType;\n\n    data!: EditEntityDialogDataInternal<EntityType>;\n\n    getWidth = EntityUtilities.getWidth;\n\n    constructor(\n        @Inject(MAT_DIALOG_DATA)\n        private readonly inputData: EditEntityDialogData<EntityType>,\n        public dialogRef: MatDialogRef<NgxMatEntityEditDialogComponent<EntityType>>,\n        private readonly injector: Injector,\n        private readonly dialog: MatDialog\n    ) {}\n\n    ngOnInit(): void {\n        this.data = new EditEntityDialogDataBuilder(this.inputData).editDialogData;\n        this.dialogRef.disableClose = true;\n        this.setEntityKeys();\n        this.entityService = this.injector.get(this.data.EntityServiceClass) as EntityService<EntityType>;\n        this.entityPriorChanges = cloneDeep(this.data.entity);\n    }\n\n    private setEntityKeys(): void {\n        this.entityKeys = Reflect.ownKeys(this.data.entity) as (keyof EntityType)[];\n        const omitUpdateKeys = EntityUtilities.getOmitForUpdate(this.data.entity);\n        this.entityKeys = this.entityKeys.filter((k) => !omitUpdateKeys.includes(k))\n            .sort((a, b) => EntityUtilities.compareOrder(a, b, this.data.entity));\n    }\n\n    edit(): void {\n        if (!this.data.editDialogData.editRequiresConfirmDialog) {\n            return this.confirmEdit();\n        }\n        const dialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(this.data.editDialogData.confirmEditDialogData)\n            .withDefaultText(['Do you really want to save all changes?'])\n            .withDefaultConfirmButtonLabel('Save')\n            .withDefaultTitle('Edit')\n            .confirmDialogData;\n        const dialogref = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        dialogref.afterClosed().subscribe((res: number) => {\n            if (res === 1) {\n                this.confirmEdit();\n            }\n        });\n    }\n    private confirmEdit(): void {\n        this.entityService.update(this.data.entity, this.entityPriorChanges).then(() => this.dialogRef.close(1));\n    }\n\n    delete(): void {\n        if (!this.data.editDialogData.deleteRequiresConfirmDialog) {\n            return this.confirmDelete();\n        }\n        const dialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(this.data.editDialogData.confirmDeleteDialogData)\n            .withDefaultText(['Do you really want to delete this entity?'])\n            .withDefaultType('delete')\n            .withDefaultConfirmButtonLabel('Delete')\n            .withDefaultTitle('Delete')\n            .confirmDialogData;\n        const dialogref = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        dialogref.afterClosed().subscribe((res: number) => {\n            if (res === 1) {\n                this.confirmDelete();\n            }\n        });\n    }\n    private confirmDelete(): void {\n        this.entityService.delete(this.entityPriorChanges.id).then(() => this.dialogRef.close(2));\n    }\n\n    cancel(): void {\n        EntityUtilities.resetChangesOnEntity(this.data.entity, this.entityPriorChanges);\n        this.dialogRef.close(0);\n    }\n}","<h2 mat-dialog-title>\n    {{data.editDialogData.title(data.entity)}}\n    <button *ngIf=\"data.allowDelete(data.entity)\" mat-raised-button (click)=\"delete()\" color=\"warn\" class=\"delete-button\" tabindex=\"-1\">\n        {{data.editDialogData.deleteButtonLabel}}\n    </button>\n</h2>\n\n<mat-dialog-content>\n    <form #form=\"ngForm\" class=\"row\">\n        <ngx-mat-entity-input\n            *ngFor=\"let key of entityKeys\"\n            [entity]=\"data.entity\"\n            [propertyKey]=\"key\"\n            [hideOmitForEdit]=\"true\"\n            class=\"col-lg-{{getWidth(data.entity, key, 'lg')}} col-md-{{getWidth(data.entity, key, 'md')}} col-sm-{{getWidth(data.entity, key, 'sm')}}\"\n        >\n        </ngx-mat-entity-input>\n    </form>\n</mat-dialog-content>\n\n<mat-dialog-actions>\n    <button mat-raised-button (click)=\"edit()\" [disabled]=\"!EntityUtilities.isEntityValid(data.entity, 'update') || !EntityUtilities.dirty(data.entity, entityPriorChanges)\">\n        {{data.editDialogData.confirmButtonLabel}}\n    </button>\n    <button mat-raised-button (click)=\"cancel()\" class=\"cancel-button\">\n        {{data.editDialogData.cancelButtonLabel}}\n    </button>\n</mat-dialog-actions>\n"]}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
import { CreateDialogDataBuilder } from './create-dialog/create-dialog-data.builder';
|
|
2
|
+
import { EditDialogDataBuilder } from './edit-dialog/edit-dialog-data.builder';
|
|
3
|
+
export class TableDataInternal {
|
|
4
|
+
constructor(baseData, createDialogData, editDialogData) {
|
|
5
|
+
this.baseData = baseData;
|
|
6
|
+
this.createDialogData = createDialogData;
|
|
7
|
+
this.editDialogData = editDialogData;
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
export class BaseDataBuilder {
|
|
11
|
+
constructor(data) {
|
|
12
|
+
//this.validateInput(data);
|
|
13
|
+
this.dataInput = data;
|
|
14
|
+
this.baseData = new BaseDataInternal(data.title, data.displayColumns, data.EntityServiceClass, data.searchLabel ? data.searchLabel : 'Search', data.createButtonLabel ? data.createButtonLabel : 'Create', data.searchString ? data.searchString : defaultSearchFunction, data.allowCreate ? data.allowCreate : true, data.allowEdit ? data.allowEdit : () => true, data.allowDelete ? data.allowDelete : () => true, data.multiSelectActions ? data.multiSelectActions : [], data.multiSelectLabel ? data.multiSelectLabel : 'Actions', data.EntityClass, data.edit, data.create);
|
|
15
|
+
return this;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
export class BaseDataInternal {
|
|
19
|
+
constructor(title, displayColumns, EntityServiceClass, searchLabel, createButtonLabel, searchString, allowCreate, allowEdit, allowDelete, multiSelectActions, multiSelectLabel, EntityClass, edit, create) {
|
|
20
|
+
this.title = title;
|
|
21
|
+
this.displayColumns = displayColumns;
|
|
22
|
+
this.EntityServiceClass = EntityServiceClass;
|
|
23
|
+
this.EntityClass = EntityClass;
|
|
24
|
+
this.searchLabel = searchLabel;
|
|
25
|
+
this.createButtonLabel = createButtonLabel;
|
|
26
|
+
this.searchString = searchString;
|
|
27
|
+
this.allowCreate = allowCreate;
|
|
28
|
+
this.allowEdit = allowEdit;
|
|
29
|
+
this.allowDelete = allowDelete;
|
|
30
|
+
this.multiSelectActions = multiSelectActions;
|
|
31
|
+
this.multiSelectLabel = multiSelectLabel;
|
|
32
|
+
this.edit = edit;
|
|
33
|
+
this.create = create;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
export class TableDataBuilder {
|
|
37
|
+
constructor(data) {
|
|
38
|
+
this.validateInput(data);
|
|
39
|
+
this.dataInput = data;
|
|
40
|
+
const createDialogData = new CreateDialogDataBuilder(data.createDialogData).createDialogData;
|
|
41
|
+
const editDialogData = new EditDialogDataBuilder(data.editDialogData).editDialogData;
|
|
42
|
+
const baseData = new BaseDataBuilder(data.baseData).baseData;
|
|
43
|
+
this.tableData = new TableDataInternal(baseData, createDialogData, editDialogData);
|
|
44
|
+
return this;
|
|
45
|
+
}
|
|
46
|
+
validateInput(data) {
|
|
47
|
+
if (data.baseData.multiSelectActions?.length && data.baseData.displayColumns.find(dp => dp.displayName === 'select')) {
|
|
48
|
+
throw new Error(`The name "select" for a display column is reserved for the multi-select action functionality.
|
|
49
|
+
Please choose a different name.`);
|
|
50
|
+
}
|
|
51
|
+
if ((data.baseData.allowEdit && data.baseData.allowEdit !== (() => false)
|
|
52
|
+
|| data.baseData.allowDelete && data.baseData.allowDelete !== (() => false)
|
|
53
|
+
|| data.baseData.allowCreate)
|
|
54
|
+
&& !data.baseData.EntityClass) {
|
|
55
|
+
throw new Error(`
|
|
56
|
+
Missing required Input data "EntityClass".
|
|
57
|
+
You can only omit this value if you can neither create or update entities.`);
|
|
58
|
+
}
|
|
59
|
+
if (data.baseData.allowCreate !== false && !data.baseData.create && !data.createDialogData) {
|
|
60
|
+
throw new Error(`Missing required Input data "createDialogData".
|
|
61
|
+
You can only omit this value when creation is disallowed or done with a custom create method.`);
|
|
62
|
+
}
|
|
63
|
+
if ((data.baseData.allowEdit !== (() => false)
|
|
64
|
+
|| data.baseData.allowDelete !== (() => false))
|
|
65
|
+
&& !data.baseData.edit
|
|
66
|
+
&& !data.editDialogData) {
|
|
67
|
+
throw new Error(`Missing required Input data "editDialogData".
|
|
68
|
+
You can only omit this value when editing and deleting is disallowed or done with a custom edit method.`);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
/**
|
|
73
|
+
* The default search function taken from googles mat table.
|
|
74
|
+
* This will be used if no custom search function is provided by the configuration.
|
|
75
|
+
*
|
|
76
|
+
* It generates a string from an entity which is then used to compare it to the search input.
|
|
77
|
+
*
|
|
78
|
+
* @param entity - An entity that is in the search.
|
|
79
|
+
* @returns The generated string of the given entity used for comparison with the search input.
|
|
80
|
+
*/
|
|
81
|
+
function defaultSearchFunction(entity) {
|
|
82
|
+
const searchString = Object.keys(entity)
|
|
83
|
+
.reduce((currentTerm, key) => {
|
|
84
|
+
return `${currentTerm}${entity[key]}◬`;
|
|
85
|
+
}, '')
|
|
86
|
+
.toLowerCase();
|
|
87
|
+
return searchString;
|
|
88
|
+
}
|
|
89
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-data.builder.js","sourceRoot":"","sources":["../../../../../projects/ngx-material-entity/src/components/table/table-data.builder.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,uBAAuB,EAA4B,MAAM,4CAA4C,CAAC;AAC/G,OAAO,EAAE,qBAAqB,EAA0B,MAAM,wCAAwC,CAAC;AAIvG,MAAM,OAAO,iBAAiB;IAK1B,YACI,QAAsC,EACtC,gBAA0C,EAC1C,cAAkD;QAElD,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,gBAAgB,GAAG,gBAAgB,CAAC;QACzC,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC;IACzC,CAAC;CACJ;AAED,MAAM,OAAO,eAAe;IAIxB,YAAY,IAA0B;QAClC,2BAA2B;QAC3B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,QAAQ,GAAG,IAAI,gBAAgB,CAChC,IAAI,CAAC,KAAK,EACV,IAAI,CAAC,cAAc,EACnB,IAAI,CAAC,kBAAkB,EACvB,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,QAAQ,EAC9C,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,QAAQ,EAC1D,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,qBAAqB,EAC7D,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,EAC1C,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,IAAI,EAC5C,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,IAAI,EAChD,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC,EAAE,EACtD,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,SAAS,EACzD,IAAI,CAAC,WAAW,EAChB,IAAI,CAAC,IAAI,EACT,IAAI,CAAC,MAAM,CACd,CAAC;QACF,OAAO,IAAI,CAAC;IAChB,CAAC;CACJ;AAED,MAAM,OAAO,gBAAgB;IAiBzB,YACI,KAAa,EACb,cAA2C,EAC3C,kBAA6E,EAC7E,WAAmB,EACnB,iBAAyB,EACzB,YAA2C,EAC3C,WAAoB,EACpB,SAA0C,EAC1C,WAA4C,EAC5C,kBAAmD,EACnD,gBAAwB,EAExB,WAAqD,EACrD,IAAsC,EACtC,MAAwC;QAExC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC;QACrC,IAAI,CAAC,kBAAkB,GAAG,kBAAkB,CAAC;QAC7C,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,iBAAiB,GAAG,iBAAiB,CAAC;QAC3C,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;QACjC,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,kBAAkB,GAAG,kBAAkB,CAAC;QAC7C,IAAI,CAAC,gBAAgB,GAAG,gBAAgB,CAAC;QACzC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACzB,CAAC;CACJ;AAED,MAAM,OAAO,gBAAgB;IAIzB,YAAY,IAA2B;QACnC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QACzB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,MAAM,gBAAgB,GAA6B,IAAI,uBAAuB,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,gBAAgB,CAAC;QACvH,MAAM,cAAc,GAAuC,IAAI,qBAAqB,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,cAAc,CAAC;QACzH,MAAM,QAAQ,GAAiC,IAAI,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC;QAC3F,IAAI,CAAC,SAAS,GAAG,IAAI,iBAAiB,CAClC,QAAQ,EACR,gBAAgB,EAChB,cAAc,CACjB,CAAC;QACF,OAAO,IAAI,CAAC;IAChB,CAAC;IAEO,aAAa,CAAC,IAA2B;QAC7C,IAAI,IAAI,CAAC,QAAQ,CAAC,kBAAkB,EAAE,MAAM,IAAI,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,WAAW,KAAK,QAAQ,CAAC,EAAE;YAClH,MAAM,IAAI,KAAK,CACX;gDACgC,CACnC,CAAC;SACL;QACD,IACI,CACI,IAAI,CAAC,QAAQ,CAAC,SAAS,IAAI,IAAI,CAAC,QAAQ,CAAC,SAAS,KAAK,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC;eACjE,IAAI,CAAC,QAAQ,CAAC,WAAW,IAAI,IAAI,CAAC,QAAQ,CAAC,WAAW,KAAK,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC;eACxE,IAAI,CAAC,QAAQ,CAAC,WAAW,CAC/B;eACE,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,EAC/B;YACE,MAAM,IAAI,KAAK,CAAC;;2FAE+D,CAC9E,CAAC;SACL;QACD,IAAI,IAAI,CAAC,QAAQ,CAAC,WAAW,KAAK,KAAK,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE;YACxF,MAAM,IAAI,KAAK,CACX;8GAC8F,CACjG,CAAC;SACL;QACD,IACI,CACI,IAAI,CAAC,QAAQ,CAAC,SAAS,KAAK,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC;eACtC,IAAI,CAAC,QAAQ,CAAC,WAAW,KAAK,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CACjD;eACE,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI;eACnB,CAAC,IAAI,CAAC,cAAc,EACzB;YACE,MAAM,IAAI,KAAK,CACX;wHACwG,CAC3G,CAAC;SACL;IACL,CAAC;CACJ;AAED;;;;;;;;GAQG;AACH,SAAS,qBAAqB,CAA4B,MAAkB;IACxE,MAAM,YAAY,GAAG,MAAM,CAAC,IAAI,CAAC,MAA4C,CAAC;SACzE,MAAM,CAAC,CAAC,WAAmB,EAAE,GAAW,EAAE,EAAE;QACzC,OAAO,GAAG,WAAW,GAAI,MAA6C,CAAC,GAAG,CAAC,GAAG,CAAC;IACnF,CAAC,EAAE,EAAE,CAAC;SACL,WAAW,EAAE,CAAC;IACnB,OAAO,YAAY,CAAC;AACxB,CAAC","sourcesContent":["import { EntityService } from '../../classes/entity-service.class';\nimport { Entity } from '../../classes/entity-model.class';\nimport { CreateDialogDataBuilder, CreateDialogDataInternal } from './create-dialog/create-dialog-data.builder';\nimport { EditDialogDataBuilder, EditDialogDataInternal } from './edit-dialog/edit-dialog-data.builder';\nimport { BaseData, DisplayColumn, MultiSelectAction, TableData } from './table-data';\nimport { HttpClient } from '@angular/common/http';\n\nexport class TableDataInternal<EntityType extends Entity> implements TableData<EntityType> {\n    baseData: BaseDataInternal<EntityType>;\n    createDialogData: CreateDialogDataInternal;\n    editDialogData: EditDialogDataInternal<EntityType>;\n\n    constructor(\n        baseData: BaseDataInternal<EntityType>,\n        createDialogData: CreateDialogDataInternal,\n        editDialogData: EditDialogDataInternal<EntityType>\n    ) {\n        this.baseData = baseData;\n        this.createDialogData = createDialogData;\n        this.editDialogData = editDialogData;\n    }\n}\n\nexport class BaseDataBuilder<EntityType extends Entity> {\n    baseData: BaseDataInternal<EntityType>;\n    private readonly dataInput: BaseData<EntityType>;\n\n    constructor(data: BaseData<EntityType>) {\n        //this.validateInput(data);\n        this.dataInput = data;\n        this.baseData = new BaseDataInternal<EntityType>(\n            data.title,\n            data.displayColumns,\n            data.EntityServiceClass,\n            data.searchLabel ? data.searchLabel : 'Search',\n            data.createButtonLabel ? data.createButtonLabel : 'Create',\n            data.searchString ? data.searchString : defaultSearchFunction,\n            data.allowCreate ? data.allowCreate : true,\n            data.allowEdit ? data.allowEdit : () => true,\n            data.allowDelete ? data.allowDelete : () => true,\n            data.multiSelectActions ? data.multiSelectActions : [],\n            data.multiSelectLabel ? data.multiSelectLabel : 'Actions',\n            data.EntityClass,\n            data.edit,\n            data.create\n        );\n        return this;\n    }\n}\n\nexport class BaseDataInternal<EntityType extends Entity> implements BaseData<EntityType> {\n    title: string;\n    displayColumns: DisplayColumn<EntityType>[];\n    EntityServiceClass: new (httpClient: HttpClient) => EntityService<EntityType>;\n    searchLabel: string;\n    createButtonLabel: string;\n    searchString: (enity: EntityType) => string;\n    allowCreate: boolean;\n    allowEdit: (entity: EntityType) => boolean;\n    allowDelete: (entity: EntityType) => boolean;\n    multiSelectActions: MultiSelectAction<EntityType>[];\n    multiSelectLabel: string\n\n    EntityClass?: new (entity?: EntityType) => EntityType;\n    edit?: (entity: EntityType) => unknown;\n    create?: (entity: EntityType) => unknown;\n\n    constructor(\n        title: string,\n        displayColumns: DisplayColumn<EntityType>[],\n        EntityServiceClass: new (httpClient: HttpClient) => EntityService<EntityType>,\n        searchLabel: string,\n        createButtonLabel: string,\n        searchString: (enity: EntityType) => string,\n        allowCreate: boolean,\n        allowEdit: (entity: EntityType) => boolean,\n        allowDelete: (entity: EntityType) => boolean,\n        multiSelectActions: MultiSelectAction<EntityType>[],\n        multiSelectLabel: string,\n\n        EntityClass?: new (entity?: EntityType) => EntityType,\n        edit?: (entity: EntityType) => unknown,\n        create?: (entity: EntityType) => unknown,\n    ) {\n        this.title = title;\n        this.displayColumns = displayColumns;\n        this.EntityServiceClass = EntityServiceClass;\n        this.EntityClass = EntityClass;\n        this.searchLabel = searchLabel;\n        this.createButtonLabel = createButtonLabel;\n        this.searchString = searchString;\n        this.allowCreate = allowCreate;\n        this.allowEdit = allowEdit;\n        this.allowDelete = allowDelete;\n        this.multiSelectActions = multiSelectActions;\n        this.multiSelectLabel = multiSelectLabel;\n        this.edit = edit;\n        this.create = create;\n    }\n}\n\nexport class TableDataBuilder<EntityType extends Entity> {\n    tableData: TableDataInternal<EntityType>;\n    private readonly dataInput: TableData<EntityType>;\n\n    constructor(data: TableData<EntityType>) {\n        this.validateInput(data);\n        this.dataInput = data;\n        const createDialogData: CreateDialogDataInternal = new CreateDialogDataBuilder(data.createDialogData).createDialogData;\n        const editDialogData: EditDialogDataInternal<EntityType> = new EditDialogDataBuilder(data.editDialogData).editDialogData;\n        const baseData: BaseDataInternal<EntityType> = new BaseDataBuilder(data.baseData).baseData;\n        this.tableData = new TableDataInternal<EntityType>(\n            baseData,\n            createDialogData,\n            editDialogData\n        );\n        return this;\n    }\n\n    private validateInput(data: TableData<EntityType>): void {\n        if (data.baseData.multiSelectActions?.length && data.baseData.displayColumns.find(dp => dp.displayName === 'select')) {\n            throw new Error(\n                `The name \"select\" for a display column is reserved for the multi-select action functionality.\n                Please choose a different name.`\n            );\n        }\n        if (\n            (\n                data.baseData.allowEdit && data.baseData.allowEdit !== (() => false)\n                || data.baseData.allowDelete && data.baseData.allowDelete !== (() => false)\n                || data.baseData.allowCreate\n            )\n            && !data.baseData.EntityClass\n        ) {\n            throw new Error(`\n                Missing required Input data \"EntityClass\".\n                You can only omit this value if you can neither create or update entities.`\n            );\n        }\n        if (data.baseData.allowCreate !== false && !data.baseData.create && !data.createDialogData) {\n            throw new Error(\n                `Missing required Input data \"createDialogData\".\n                You can only omit this value when creation is disallowed or done with a custom create method.`\n            );\n        }\n        if (\n            (\n                data.baseData.allowEdit !== (() => false)\n                || data.baseData.allowDelete !== (() => false)\n            )\n            && !data.baseData.edit\n            && !data.editDialogData\n        ) {\n            throw new Error(\n                `Missing required Input data \"editDialogData\".\n                You can only omit this value when editing and deleting is disallowed or done with a custom edit method.`\n            );\n        }\n    }\n}\n\n/**\n * The default search function taken from googles mat table.\n * This will be used if no custom search function is provided by the configuration.\n *\n * It generates a string from an entity which is then used to compare it to the search input.\n *\n * @param entity - An entity that is in the search.\n * @returns The generated string of the given entity used for comparison with the search input.\n */\nfunction defaultSearchFunction<EntityType extends Entity>(entity: EntityType): string {\n    const searchString = Object.keys(entity as unknown as Record<string, unknown>)\n        .reduce((currentTerm: string, key: string) => {\n            return `${currentTerm}${(entity as unknown as Record<string, unknown>)[key]}◬`;\n        }, '')\n        .toLowerCase();\n    return searchString;\n}"]}
|