ngx-material-entity 15.2.3 → 15.2.5
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/components/edit-page/edit-page.component.d.ts +27 -2
- package/components/table/edit-dialog/edit-data.builder.d.ts +16 -2
- package/components/table/edit-dialog/edit-entity-dialog.component.d.ts +17 -2
- package/components/table/table-data.d.ts +37 -0
- package/components/table/table.component.d.ts +1 -0
- package/encapsulation/reflect.utilities.d.ts +1 -0
- package/esm2020/components/edit-page/edit-page.component.mjs +66 -11
- package/esm2020/components/edit-page/page-edit-data.builder.mjs +3 -3
- package/esm2020/components/input/input.component.mjs +7 -5
- package/esm2020/components/table/create-dialog/create-entity-dialog.component.mjs +3 -3
- package/esm2020/components/table/edit-dialog/edit-data.builder.mjs +21 -4
- package/esm2020/components/table/edit-dialog/edit-entity-dialog.component.mjs +54 -9
- package/esm2020/components/table/table-data.builder.mjs +11 -6
- package/esm2020/components/table/table-data.mjs +1 -1
- package/esm2020/components/table/table.component.mjs +4 -3
- package/esm2020/encapsulation/reflect.utilities.mjs +2 -1
- package/esm2020/public-api.mjs +1 -2
- package/esm2020/utilities/date.utilities.mjs +3 -2
- package/fesm2015/ngx-material-entity.mjs +202 -80
- package/fesm2015/ngx-material-entity.mjs.map +1 -1
- package/fesm2020/ngx-material-entity.mjs +201 -80
- package/fesm2020/ngx-material-entity.mjs.map +1 -1
- package/package.json +1 -2
- package/public-api.d.ts +0 -1
|
@@ -81,7 +81,7 @@ export class NgxMatEntityCreateDialogComponent {
|
|
|
81
81
|
}
|
|
82
82
|
}
|
|
83
83
|
NgxMatEntityCreateDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: NgxMatEntityCreateDialogComponent, deps: [{ token: MAT_DIALOG_DATA }, { token: i1.MatDialogRef }, { token: i0.Injector }, { token: i1.MatDialog }], target: i0.ɵɵFactoryTarget.Component });
|
|
84
|
-
NgxMatEntityCreateDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.3", type: NgxMatEntityCreateDialogComponent, isStandalone: true, selector: "ngx-mat-entity-create-dialog", ngImport: i0, template: "<div class=\"mat-dialog-title\">\n <div>{{data.createDialogData.title}}</div>\n</div>\n\n<form>\n <mat-dialog-content>\n <mat-tab-group *ngIf=\"entityTabs.length > 1\" preserveContent>\n <mat-tab *ngFor=\"let tab of entityTabs\" [label]=\"tab.tabName\">\n <div class=\"row\" *ngFor=\"let row of tab.rows\">\n <ngx-mat-entity-input\n *ngFor=\"let key of row.keys\"\n [entity]=\"data.entity\"\n [propertyKey]=\"key\"\n [hideOmitForCreate]=\"true\"\n class=\"col-lg-{{EntityUtilities.getWidth(data.entity, key, 'lg')}} col-md-{{EntityUtilities.getWidth(data.entity, key, 'md')}} col-sm-{{EntityUtilities.getWidth(data.entity, key, 'sm')}}\"\n (inputChangeEvent)=\"checkIsEntityValid()\"\n >\n </ngx-mat-entity-input>\n </div>\n </mat-tab>\n </mat-tab-group>\n \n <div *ngIf=\"entityTabs.length <= 1\">\n <div class=\"row\" *ngFor=\"let row of entityTabs[0]
|
|
84
|
+
NgxMatEntityCreateDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.3", type: NgxMatEntityCreateDialogComponent, isStandalone: true, selector: "ngx-mat-entity-create-dialog", ngImport: i0, template: "<div class=\"mat-dialog-title\">\n <div>{{data.createDialogData.title}}</div>\n</div>\n\n<form>\n <mat-dialog-content>\n <mat-tab-group *ngIf=\"entityTabs.length > 1\" preserveContent>\n <mat-tab *ngFor=\"let tab of entityTabs\" [label]=\"tab.tabName\">\n <div class=\"row\" *ngFor=\"let row of tab.rows\">\n <ngx-mat-entity-input\n *ngFor=\"let key of row.keys\"\n [entity]=\"data.entity\"\n [propertyKey]=\"key\"\n [hideOmitForCreate]=\"true\"\n class=\"col-lg-{{EntityUtilities.getWidth(data.entity, key, 'lg')}} col-md-{{EntityUtilities.getWidth(data.entity, key, 'md')}} col-sm-{{EntityUtilities.getWidth(data.entity, key, 'sm')}}\"\n (inputChangeEvent)=\"checkIsEntityValid()\"\n >\n </ngx-mat-entity-input>\n </div>\n </mat-tab>\n </mat-tab-group>\n \n <div *ngIf=\"entityTabs.length <= 1\">\n <span class=\"no-entity-tabs\" *ngIf=\"!entityTabs.length\">\n ERROR: No Inputs. Did you correctly assign all values in the model constructor?\n </span>\n <div class=\"row\" *ngFor=\"let row of entityTabs[0]?.rows\">\n <ngx-mat-entity-input\n *ngFor=\"let key of row.keys\"\n [entity]=\"data.entity\"\n [propertyKey]=\"key\"\n [hideOmitForCreate]=\"true\"\n class=\"col-lg-{{EntityUtilities.getWidth(data.entity, key, 'lg')}} col-md-{{EntityUtilities.getWidth(data.entity, key, 'md')}} col-sm-{{EntityUtilities.getWidth(data.entity, key, 'sm')}}\"\n (inputChangeEvent)=\"checkIsEntityValid()\"\n >\n </ngx-mat-entity-input>\n </div>\n </div>\n </mat-dialog-content>\n \n <mat-dialog-actions>\n <button type=\"submit\" (click)=\"create()\" mat-raised-button [disabled]=\"!isEntityValid\">\n {{data.createDialogData.createButtonLabel}}\n </button>\n <button type=\"button\" mat-raised-button (click)=\"cancel()\" class=\"cancel-button\">\n {{data.createDialogData.cancelButtonLabel}}\n </button>\n </mat-dialog-actions>\n</form>\n", styles: [".mat-dialog-title{padding:20px;display:flex;justify-content:space-between;align-items:center}.mat-dialog-title div{font-size:var(--mdc-dialog-subhead-size, 14px);font-weight:var(--mdc-dialog-subhead-weight, 500)}.no-entity-tabs{padding:10px;background-color:red;color:#f5f5f5}::ng-deep .mdc-dialog .mdc-dialog__content{padding:6px 20px!important}mat-dialog-actions{justify-content:space-between;align-items:center;padding-left:20px;padding-right:20px}\n"], dependencies: [{ kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: NgxMatEntityInputModule }, { kind: "component", type: i2.NgxMatEntityInputComponent, selector: "ngx-mat-entity-input", inputs: ["entity", "propertyKey", "getValidationErrorMessage", "hideOmitForCreate", "hideOmitForEdit", "validEmpty", "isReadOnly"], outputs: ["inputChangeEvent"] }, { kind: "ngmodule", type: MatDialogModule }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i4.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "ngmodule", type: MatTabsModule }, { kind: "component", type: i5.MatTab, selector: "mat-tab", inputs: ["disabled"], exportAs: ["matTab"] }, { kind: "component", type: i5.MatTabGroup, selector: "mat-tab-group", inputs: ["color", "disableRipple", "fitInkBarToContent", "mat-stretch-tabs"], exportAs: ["matTabGroup"] }] });
|
|
85
85
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: NgxMatEntityCreateDialogComponent, decorators: [{
|
|
86
86
|
type: Component,
|
|
87
87
|
args: [{ selector: 'ngx-mat-entity-create-dialog', standalone: true, imports: [
|
|
@@ -92,9 +92,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.3", ngImpor
|
|
|
92
92
|
FormsModule,
|
|
93
93
|
MatButtonModule,
|
|
94
94
|
MatTabsModule
|
|
95
|
-
], template: "<div class=\"mat-dialog-title\">\n <div>{{data.createDialogData.title}}</div>\n</div>\n\n<form>\n <mat-dialog-content>\n <mat-tab-group *ngIf=\"entityTabs.length > 1\" preserveContent>\n <mat-tab *ngFor=\"let tab of entityTabs\" [label]=\"tab.tabName\">\n <div class=\"row\" *ngFor=\"let row of tab.rows\">\n <ngx-mat-entity-input\n *ngFor=\"let key of row.keys\"\n [entity]=\"data.entity\"\n [propertyKey]=\"key\"\n [hideOmitForCreate]=\"true\"\n class=\"col-lg-{{EntityUtilities.getWidth(data.entity, key, 'lg')}} col-md-{{EntityUtilities.getWidth(data.entity, key, 'md')}} col-sm-{{EntityUtilities.getWidth(data.entity, key, 'sm')}}\"\n (inputChangeEvent)=\"checkIsEntityValid()\"\n >\n </ngx-mat-entity-input>\n </div>\n </mat-tab>\n </mat-tab-group>\n \n <div *ngIf=\"entityTabs.length <= 1\">\n <div class=\"row\" *ngFor=\"let row of entityTabs[0]
|
|
95
|
+
], template: "<div class=\"mat-dialog-title\">\n <div>{{data.createDialogData.title}}</div>\n</div>\n\n<form>\n <mat-dialog-content>\n <mat-tab-group *ngIf=\"entityTabs.length > 1\" preserveContent>\n <mat-tab *ngFor=\"let tab of entityTabs\" [label]=\"tab.tabName\">\n <div class=\"row\" *ngFor=\"let row of tab.rows\">\n <ngx-mat-entity-input\n *ngFor=\"let key of row.keys\"\n [entity]=\"data.entity\"\n [propertyKey]=\"key\"\n [hideOmitForCreate]=\"true\"\n class=\"col-lg-{{EntityUtilities.getWidth(data.entity, key, 'lg')}} col-md-{{EntityUtilities.getWidth(data.entity, key, 'md')}} col-sm-{{EntityUtilities.getWidth(data.entity, key, 'sm')}}\"\n (inputChangeEvent)=\"checkIsEntityValid()\"\n >\n </ngx-mat-entity-input>\n </div>\n </mat-tab>\n </mat-tab-group>\n \n <div *ngIf=\"entityTabs.length <= 1\">\n <span class=\"no-entity-tabs\" *ngIf=\"!entityTabs.length\">\n ERROR: No Inputs. Did you correctly assign all values in the model constructor?\n </span>\n <div class=\"row\" *ngFor=\"let row of entityTabs[0]?.rows\">\n <ngx-mat-entity-input\n *ngFor=\"let key of row.keys\"\n [entity]=\"data.entity\"\n [propertyKey]=\"key\"\n [hideOmitForCreate]=\"true\"\n class=\"col-lg-{{EntityUtilities.getWidth(data.entity, key, 'lg')}} col-md-{{EntityUtilities.getWidth(data.entity, key, 'md')}} col-sm-{{EntityUtilities.getWidth(data.entity, key, 'sm')}}\"\n (inputChangeEvent)=\"checkIsEntityValid()\"\n >\n </ngx-mat-entity-input>\n </div>\n </div>\n </mat-dialog-content>\n \n <mat-dialog-actions>\n <button type=\"submit\" (click)=\"create()\" mat-raised-button [disabled]=\"!isEntityValid\">\n {{data.createDialogData.createButtonLabel}}\n </button>\n <button type=\"button\" mat-raised-button (click)=\"cancel()\" class=\"cancel-button\">\n {{data.createDialogData.cancelButtonLabel}}\n </button>\n </mat-dialog-actions>\n</form>\n", styles: [".mat-dialog-title{padding:20px;display:flex;justify-content:space-between;align-items:center}.mat-dialog-title div{font-size:var(--mdc-dialog-subhead-size, 14px);font-weight:var(--mdc-dialog-subhead-weight, 500)}.no-entity-tabs{padding:10px;background-color:red;color:#f5f5f5}::ng-deep .mdc-dialog .mdc-dialog__content{padding:6px 20px!important}mat-dialog-actions{justify-content:space-between;align-items:center;padding-left:20px;padding-right:20px}\n"] }]
|
|
96
96
|
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
97
97
|
type: Inject,
|
|
98
98
|
args: [MAT_DIALOG_DATA]
|
|
99
99
|
}] }, { type: i1.MatDialogRef }, { type: i0.Injector }, { type: i1.MatDialog }]; } });
|
|
100
|
-
//# 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 { NgFor, NgIf } from '@angular/common';\nimport { Component, Inject, Injector, OnInit } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MAT_DIALOG_DATA, MatDialog, MatDialogModule, MatDialogRef } from '@angular/material/dialog';\nimport { MatTabsModule } from '@angular/material/tabs';\nimport { BaseEntityType } from '../../../classes/entity.model';\nimport { EntityService } from '../../../services/entity.service';\nimport { EntityTab, EntityUtilities } from '../../../utilities/entity.utilities';\nimport { ConfirmDialogDataBuilder, ConfirmDialogDataInternal } from '../../confirm-dialog/confirm-dialog-data.builder';\nimport { NgxMatEntityConfirmDialogComponent } from '../../confirm-dialog/confirm-dialog.component';\nimport { NgxMatEntityInputModule } from '../../input/input.module';\nimport { CreateEntityDialogData } from './create-entity-dialog-data';\nimport { CreateEntityDialogDataBuilder, CreateEntityDialogDataInternal } from './create-entity-dialog-data.builder';\n\n/**\n * The default dialog used to create new entities based on the configuration passed in the MAT_DIALOG_DATA \"inputData\".\n * Used by the ngx-mat-entity-table.\n *\n * It offers a lot of customization options which can be found in \"CreateEntityDialogData\".\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    standalone: true,\n    imports: [\n        NgFor,\n        NgIf,\n        NgxMatEntityInputModule,\n        MatDialogModule,\n        FormsModule,\n        MatButtonModule,\n        MatTabsModule\n    ]\n})\nexport class NgxMatEntityCreateDialogComponent<EntityType extends BaseEntityType<EntityType>> implements OnInit {\n    EntityUtilities: typeof EntityUtilities = EntityUtilities;\n\n    entityTabs!: EntityTab<EntityType>[];\n\n    entityService!: EntityService<EntityType>;\n\n    data!: CreateEntityDialogDataInternal<EntityType>;\n\n    isEntityValid: boolean = false;\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).getResult();\n        this.dialogRef.disableClose = true;\n        this.entityTabs = EntityUtilities.getEntityTabs(this.data.entity, true);\n        this.entityService = this.injector.get(this.data.EntityServiceClass) as EntityService<EntityType>;\n    }\n\n    /**\n     * Checks if the entity is valid.\n     */\n    checkIsEntityValid(): void {\n        this.isEntityValid = EntityUtilities.isEntityValid(this.data.entity, 'create');\n    }\n\n    /**\n     * Tries add the new entity and close the dialog afterwards.\n     * Also handles the confirmation if required.\n     */\n    create(): void {\n        if (!this.isEntityValid) {\n            return;\n        }\n        if (!this.data.createDialogData.createRequiresConfirmDialog) {\n            this.confirmCreate();\n            return;\n        }\n        const dialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(this.data.createDialogData.confirmCreateDialogData)\n            .withDefault('text', ['Do you really want to create this entity?'])\n            .withDefault('confirmButtonLabel', 'Create')\n            .withDefault('title', 'Create')\n            .getResult();\n        const dialogRef: MatDialogRef<NgxMatEntityConfirmDialogComponent, boolean> = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        dialogRef.afterClosed().subscribe(res => {\n            if (res == true) {\n                this.confirmCreate();\n            }\n        });\n    }\n    private confirmCreate(): void {\n        void this.entityService.create(this.data.entity).then(() => this.dialogRef.close());\n    }\n\n    /**\n     * Closes the dialog.\n     */\n    cancel(): void {\n        this.dialogRef.close();\n    }\n}","<div class=\"mat-dialog-title\">\n    <div>{{data.createDialogData.title}}</div>\n</div>\n\n<form>\n    <mat-dialog-content>\n        <mat-tab-group *ngIf=\"entityTabs.length > 1\" preserveContent>\n            <mat-tab *ngFor=\"let tab of entityTabs\" [label]=\"tab.tabName\">\n                <div class=\"row\" *ngFor=\"let row of tab.rows\">\n                    <ngx-mat-entity-input\n                        *ngFor=\"let key of row.keys\"\n                        [entity]=\"data.entity\"\n                        [propertyKey]=\"key\"\n                        [hideOmitForCreate]=\"true\"\n                        class=\"col-lg-{{EntityUtilities.getWidth(data.entity, key, 'lg')}} col-md-{{EntityUtilities.getWidth(data.entity, key, 'md')}} col-sm-{{EntityUtilities.getWidth(data.entity, key, 'sm')}}\"\n                        (inputChangeEvent)=\"checkIsEntityValid()\"\n                    >\n                    </ngx-mat-entity-input>\n                </div>\n            </mat-tab>\n        </mat-tab-group>\n    \n        <div *ngIf=\"entityTabs.length <= 1\">\n            <div class=\"row\" *ngFor=\"let row of entityTabs[0].rows\">\n                <ngx-mat-entity-input\n                    *ngFor=\"let key of row.keys\"\n                    [entity]=\"data.entity\"\n                    [propertyKey]=\"key\"\n                    [hideOmitForCreate]=\"true\"\n                    class=\"col-lg-{{EntityUtilities.getWidth(data.entity, key, 'lg')}} col-md-{{EntityUtilities.getWidth(data.entity, key, 'md')}} col-sm-{{EntityUtilities.getWidth(data.entity, key, 'sm')}}\"\n                    (inputChangeEvent)=\"checkIsEntityValid()\"\n                >\n                </ngx-mat-entity-input>\n            </div>\n        </div>\n    </mat-dialog-content>\n    \n    <mat-dialog-actions>\n        <button type=\"submit\" (click)=\"create()\" mat-raised-button [disabled]=\"!isEntityValid\">\n            {{data.createDialogData.createButtonLabel}}\n        </button>\n        <button type=\"button\" mat-raised-button (click)=\"cancel()\" class=\"cancel-button\">\n            {{data.createDialogData.cancelButtonLabel}}\n        </button>\n    </mat-dialog-actions>\n</form>\n"]}
|
|
100
|
+
//# 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 { NgFor, NgIf } from '@angular/common';\nimport { Component, Inject, Injector, OnInit } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MAT_DIALOG_DATA, MatDialog, MatDialogModule, MatDialogRef } from '@angular/material/dialog';\nimport { MatTabsModule } from '@angular/material/tabs';\nimport { BaseEntityType } from '../../../classes/entity.model';\nimport { EntityService } from '../../../services/entity.service';\nimport { EntityTab, EntityUtilities } from '../../../utilities/entity.utilities';\nimport { ConfirmDialogDataBuilder, ConfirmDialogDataInternal } from '../../confirm-dialog/confirm-dialog-data.builder';\nimport { NgxMatEntityConfirmDialogComponent } from '../../confirm-dialog/confirm-dialog.component';\nimport { NgxMatEntityInputModule } from '../../input/input.module';\nimport { CreateEntityDialogData } from './create-entity-dialog-data';\nimport { CreateEntityDialogDataBuilder, CreateEntityDialogDataInternal } from './create-entity-dialog-data.builder';\n\n/**\n * The default dialog used to create new entities based on the configuration passed in the MAT_DIALOG_DATA \"inputData\".\n * Used by the ngx-mat-entity-table.\n *\n * It offers a lot of customization options which can be found in \"CreateEntityDialogData\".\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    standalone: true,\n    imports: [\n        NgFor,\n        NgIf,\n        NgxMatEntityInputModule,\n        MatDialogModule,\n        FormsModule,\n        MatButtonModule,\n        MatTabsModule\n    ]\n})\nexport class NgxMatEntityCreateDialogComponent<EntityType extends BaseEntityType<EntityType>> implements OnInit {\n    EntityUtilities: typeof EntityUtilities = EntityUtilities;\n\n    entityTabs!: EntityTab<EntityType>[];\n\n    entityService!: EntityService<EntityType>;\n\n    data!: CreateEntityDialogDataInternal<EntityType>;\n\n    isEntityValid: boolean = false;\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).getResult();\n        this.dialogRef.disableClose = true;\n        this.entityTabs = EntityUtilities.getEntityTabs(this.data.entity, true);\n        this.entityService = this.injector.get(this.data.EntityServiceClass) as EntityService<EntityType>;\n    }\n\n    /**\n     * Checks if the entity is valid.\n     */\n    checkIsEntityValid(): void {\n        this.isEntityValid = EntityUtilities.isEntityValid(this.data.entity, 'create');\n    }\n\n    /**\n     * Tries add the new entity and close the dialog afterwards.\n     * Also handles the confirmation if required.\n     */\n    create(): void {\n        if (!this.isEntityValid) {\n            return;\n        }\n        if (!this.data.createDialogData.createRequiresConfirmDialog) {\n            this.confirmCreate();\n            return;\n        }\n        const dialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(this.data.createDialogData.confirmCreateDialogData)\n            .withDefault('text', ['Do you really want to create this entity?'])\n            .withDefault('confirmButtonLabel', 'Create')\n            .withDefault('title', 'Create')\n            .getResult();\n        const dialogRef: MatDialogRef<NgxMatEntityConfirmDialogComponent, boolean> = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        dialogRef.afterClosed().subscribe(res => {\n            if (res == true) {\n                this.confirmCreate();\n            }\n        });\n    }\n    private confirmCreate(): void {\n        void this.entityService.create(this.data.entity).then(() => this.dialogRef.close());\n    }\n\n    /**\n     * Closes the dialog.\n     */\n    cancel(): void {\n        this.dialogRef.close();\n    }\n}","<div class=\"mat-dialog-title\">\n    <div>{{data.createDialogData.title}}</div>\n</div>\n\n<form>\n    <mat-dialog-content>\n        <mat-tab-group *ngIf=\"entityTabs.length > 1\" preserveContent>\n            <mat-tab *ngFor=\"let tab of entityTabs\" [label]=\"tab.tabName\">\n                <div class=\"row\" *ngFor=\"let row of tab.rows\">\n                    <ngx-mat-entity-input\n                        *ngFor=\"let key of row.keys\"\n                        [entity]=\"data.entity\"\n                        [propertyKey]=\"key\"\n                        [hideOmitForCreate]=\"true\"\n                        class=\"col-lg-{{EntityUtilities.getWidth(data.entity, key, 'lg')}} col-md-{{EntityUtilities.getWidth(data.entity, key, 'md')}} col-sm-{{EntityUtilities.getWidth(data.entity, key, 'sm')}}\"\n                        (inputChangeEvent)=\"checkIsEntityValid()\"\n                    >\n                    </ngx-mat-entity-input>\n                </div>\n            </mat-tab>\n        </mat-tab-group>\n    \n        <div *ngIf=\"entityTabs.length <= 1\">\n            <span class=\"no-entity-tabs\" *ngIf=\"!entityTabs.length\">\n                ERROR: No Inputs. Did you correctly assign all values in the model constructor?\n            </span>\n            <div class=\"row\" *ngFor=\"let row of entityTabs[0]?.rows\">\n                <ngx-mat-entity-input\n                    *ngFor=\"let key of row.keys\"\n                    [entity]=\"data.entity\"\n                    [propertyKey]=\"key\"\n                    [hideOmitForCreate]=\"true\"\n                    class=\"col-lg-{{EntityUtilities.getWidth(data.entity, key, 'lg')}} col-md-{{EntityUtilities.getWidth(data.entity, key, 'md')}} col-sm-{{EntityUtilities.getWidth(data.entity, key, 'sm')}}\"\n                    (inputChangeEvent)=\"checkIsEntityValid()\"\n                >\n                </ngx-mat-entity-input>\n            </div>\n        </div>\n    </mat-dialog-content>\n    \n    <mat-dialog-actions>\n        <button type=\"submit\" (click)=\"create()\" mat-raised-button [disabled]=\"!isEntityValid\">\n            {{data.createDialogData.createButtonLabel}}\n        </button>\n        <button type=\"button\" mat-raised-button (click)=\"cancel()\" class=\"cancel-button\">\n            {{data.createDialogData.cancelButtonLabel}}\n        </button>\n    </mat-dialog-actions>\n</form>\n"]}
|
|
@@ -1,10 +1,25 @@
|
|
|
1
|
-
import { BaseBuilder } from '../../../classes/base.builder';
|
|
1
|
+
import { BaseBuilder, defaultFalse, defaultTrue } from '../../../classes/base.builder';
|
|
2
2
|
import { ConfirmDialogDataBuilder } from '../../confirm-dialog/confirm-dialog-data.builder';
|
|
3
|
+
/**
|
|
4
|
+
* The internal edit action.
|
|
5
|
+
* Sets default values.
|
|
6
|
+
*/
|
|
7
|
+
export class EditActionInternal {
|
|
8
|
+
constructor(data) {
|
|
9
|
+
this.displayName = data.displayName;
|
|
10
|
+
this.action = data.action;
|
|
11
|
+
this.enabled = data.enabled ?? defaultTrue;
|
|
12
|
+
this.requireConfirmDialog = data.requireConfirmDialog ?? defaultFalse;
|
|
13
|
+
this.confirmDialogData = new ConfirmDialogDataBuilder(data.confirmDialogData)
|
|
14
|
+
.withDefault('text', ['Do you really want to run this action?'])
|
|
15
|
+
.getResult();
|
|
16
|
+
}
|
|
17
|
+
}
|
|
3
18
|
/**
|
|
4
19
|
* The internal EditData. Requires all default values the user can leave out.
|
|
5
20
|
*/
|
|
6
21
|
export class EditDataInternal {
|
|
7
|
-
constructor(title, confirmButtonLabel, deleteButtonLabel, cancelButtonLabel, deleteRequiresConfirmDialog, editRequiresConfirmDialog, confirmDeleteDialogData, confirmEditDialogData) {
|
|
22
|
+
constructor(title, confirmButtonLabel, deleteButtonLabel, cancelButtonLabel, deleteRequiresConfirmDialog, editRequiresConfirmDialog, confirmDeleteDialogData, confirmEditDialogData, actionsLabel, actions) {
|
|
8
23
|
this.title = title;
|
|
9
24
|
this.confirmButtonLabel = confirmButtonLabel;
|
|
10
25
|
this.deleteButtonLabel = deleteButtonLabel;
|
|
@@ -13,6 +28,8 @@ export class EditDataInternal {
|
|
|
13
28
|
this.editRequiresConfirmDialog = editRequiresConfirmDialog;
|
|
14
29
|
this.confirmDeleteDialogData = confirmDeleteDialogData;
|
|
15
30
|
this.confirmEditDialogData = confirmEditDialogData;
|
|
31
|
+
this.actionsLabel = actionsLabel;
|
|
32
|
+
this.actions = actions.map(a => new EditActionInternal(a));
|
|
16
33
|
}
|
|
17
34
|
}
|
|
18
35
|
/**
|
|
@@ -35,7 +52,7 @@ export class EditDialogDataBuilder extends BaseBuilder {
|
|
|
35
52
|
.withDefault('text', ['Do you really want to delete this entity?'])
|
|
36
53
|
.withDefault('title', 'Delete')
|
|
37
54
|
.getResult();
|
|
38
|
-
return new EditDataInternal(data?.title ?? (() => 'Edit'), data?.confirmButtonLabel ?? 'Save', data?.deleteButtonLabel ?? 'Delete', data?.cancelButtonLabel ?? 'Cancel', data?.deleteRequiresConfirmDialog ?? true, data?.editRequiresConfirmDialog ?? false, confirmDeleteDialogData, confirmEditDialogData);
|
|
55
|
+
return new EditDataInternal(data?.title ?? (() => 'Edit'), data?.confirmButtonLabel ?? 'Save', data?.deleteButtonLabel ?? 'Delete', data?.cancelButtonLabel ?? 'Cancel', data?.deleteRequiresConfirmDialog ?? true, data?.editRequiresConfirmDialog ?? false, confirmDeleteDialogData, confirmEditDialogData, data?.actionsLabel ?? 'Actions', data?.actions ?? []);
|
|
39
56
|
}
|
|
40
57
|
}
|
|
41
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRpdC1kYXRhLmJ1aWxkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtbWF0ZXJpYWwtZW50aXR5L3NyYy9jb21wb25lbnRzL3RhYmxlL2VkaXQtZGlhbG9nL2VkaXQtZGF0YS5idWlsZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUc1RCxPQUFPLEVBQUUsd0JBQXdCLEVBQTZCLE1BQU0sa0RBQWtELENBQUM7QUFHdkg7O0dBRUc7QUFDSCxNQUFNLE9BQU8sZ0JBQWdCO0lBa0J6QixZQUNJLEtBQXFDLEVBQ3JDLGtCQUEwQixFQUMxQixpQkFBeUIsRUFDekIsaUJBQXlCLEVBQ3pCLDJCQUFvQyxFQUNwQyx5QkFBa0MsRUFDbEMsdUJBQTBDLEVBQzFDLHFCQUF3QztRQUV4QyxJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztRQUNuQixJQUFJLENBQUMsa0JBQWtCLEdBQUcsa0JBQWtCLENBQUM7UUFDN0MsSUFBSSxDQUFDLGlCQUFpQixHQUFHLGlCQUFpQixDQUFDO1FBQzNDLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxpQkFBaUIsQ0FBQztRQUMzQyxJQUFJLENBQUMsMkJBQTJCLEdBQUcsMkJBQTJCLENBQUM7UUFDL0QsSUFBSSxDQUFDLHlCQUF5QixHQUFHLHlCQUF5QixDQUFDO1FBQzNELElBQUksQ0FBQyx1QkFBdUIsR0FBRyx1QkFBdUIsQ0FBQztRQUN2RCxJQUFJLENBQUMscUJBQXFCLEdBQUcscUJBQXFCLENBQUM7SUFDdkQsQ0FBQztDQUNKO0FBRUQ7O0dBRUc7QUFDSCxNQUFNLE9BQU8scUJBQ1QsU0FBUSxXQUErRDtJQUV2RSxZQUFZLElBQTJCO1FBQ25DLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNoQixDQUFDO0lBRUQsK0NBQStDO0lBQ3JDLGdCQUFnQixDQUFDLElBQTJCO1FBQ2xELE1BQU0scUJBQXFCLEdBQThCLElBQUksd0JBQXdCLENBQUMsSUFBSSxFQUFFLHFCQUFxQixDQUFDO2FBQzdHLFdBQVcsQ0FBQyxvQkFBb0IsRUFBRSxNQUFNLENBQUM7YUFDekMsV0FBVyxDQUFDLE1BQU0sRUFBRSxDQUFDLHlDQUF5QyxDQUFDLENBQUM7YUFDaEUsV0FBVyxDQUFDLE9BQU8sRUFBRSxNQUFNLENBQUM7YUFDNUIsU0FBUyxFQUFFLENBQUM7UUFFakIsTUFBTSx1QkFBdUIsR0FBOEIsSUFBSSx3QkFBd0IsQ0FBQyxJQUFJLEVBQUUsdUJBQXVCLENBQUM7YUFDakgsV0FBVyxDQUFDLG9CQUFvQixFQUFFLFFBQVEsQ0FBQzthQUMzQyxXQUFXLENBQUMsTUFBTSxFQUFFLFFBQVEsQ0FBQzthQUM3QixXQUFXLENBQUMsTUFBTSxFQUFFLENBQUMsMkNBQTJDLENBQUMsQ0FBQzthQUNsRSxXQUFXLENBQUMsT0FBTyxFQUFFLFFBQVEsQ0FBQzthQUM5QixTQUFTLEVBQUUsQ0FBQztRQUVqQixPQUFPLElBQUksZ0JBQWdCLENBQ3ZCLElBQUksRUFBRSxLQUFLLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxNQUFNLENBQUMsRUFDN0IsSUFBSSxFQUFFLGtCQUFrQixJQUFJLE1BQU0sRUFDbEMsSUFBSSxFQUFFLGlCQUFpQixJQUFJLFFBQVEsRUFDbkMsSUFBSSxFQUFFLGlCQUFpQixJQUFJLFFBQVEsRUFDbkMsSUFBSSxFQUFFLDJCQUEyQixJQUFJLElBQUksRUFDekMsSUFBSSxFQUFFLHlCQUF5QixJQUFJLEtBQUssRUFDeEMsdUJBQXVCLEVBQ3ZCLHFCQUFxQixDQUN4QixDQUFDO0lBQ04sQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFzZUJ1aWxkZXIgfSBmcm9tICcuLi8uLi8uLi9jbGFzc2VzL2Jhc2UuYnVpbGRlcic7XG5pbXBvcnQgeyBCYXNlRW50aXR5VHlwZSB9IGZyb20gJy4uLy4uLy4uL2NsYXNzZXMvZW50aXR5Lm1vZGVsJztcbmltcG9ydCB7IENvbmZpcm1EaWFsb2dEYXRhIH0gZnJvbSAnLi4vLi4vY29uZmlybS1kaWFsb2cvY29uZmlybS1kaWFsb2ctZGF0YSc7XG5pbXBvcnQgeyBDb25maXJtRGlhbG9nRGF0YUJ1aWxkZXIsIENvbmZpcm1EaWFsb2dEYXRhSW50ZXJuYWwgfSBmcm9tICcuLi8uLi9jb25maXJtLWRpYWxvZy9jb25maXJtLWRpYWxvZy1kYXRhLmJ1aWxkZXInO1xuaW1wb3J0IHsgRWRpdERhdGEgfSBmcm9tICcuLi90YWJsZS1kYXRhJztcblxuLyoqXG4gKiBUaGUgaW50ZXJuYWwgRWRpdERhdGEuIFJlcXVpcmVzIGFsbCBkZWZhdWx0IHZhbHVlcyB0aGUgdXNlciBjYW4gbGVhdmUgb3V0LlxuICovXG5leHBvcnQgY2xhc3MgRWRpdERhdGFJbnRlcm5hbDxFbnRpdHlUeXBlIGV4dGVuZHMgQmFzZUVudGl0eVR5cGU8RW50aXR5VHlwZT4+IGltcGxlbWVudHMgRWRpdERhdGE8RW50aXR5VHlwZT4ge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBqc2RvYy9yZXF1aXJlLWpzZG9jXG4gICAgdGl0bGU6IChlbnRpdHk6IEVudGl0eVR5cGUpID0+IHN0cmluZztcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUganNkb2MvcmVxdWlyZS1qc2RvY1xuICAgIGNvbmZpcm1CdXR0b25MYWJlbDogc3RyaW5nO1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBqc2RvYy9yZXF1aXJlLWpzZG9jXG4gICAgZGVsZXRlQnV0dG9uTGFiZWw6IHN0cmluZztcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUganNkb2MvcmVxdWlyZS1qc2RvY1xuICAgIGNhbmNlbEJ1dHRvbkxhYmVsOiBzdHJpbmc7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGpzZG9jL3JlcXVpcmUtanNkb2NcbiAgICBkZWxldGVSZXF1aXJlc0NvbmZpcm1EaWFsb2c6IGJvb2xlYW47XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGpzZG9jL3JlcXVpcmUtanNkb2NcbiAgICBlZGl0UmVxdWlyZXNDb25maXJtRGlhbG9nOiBib29sZWFuO1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBqc2RvYy9yZXF1aXJlLWpzZG9jXG4gICAgY29uZmlybURlbGV0ZURpYWxvZ0RhdGE6IENvbmZpcm1EaWFsb2dEYXRhO1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBqc2RvYy9yZXF1aXJlLWpzZG9jXG4gICAgY29uZmlybUVkaXREaWFsb2dEYXRhOiBDb25maXJtRGlhbG9nRGF0YTtcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICB0aXRsZTogKGVudGl0eTogRW50aXR5VHlwZSkgPT4gc3RyaW5nLFxuICAgICAgICBjb25maXJtQnV0dG9uTGFiZWw6IHN0cmluZyxcbiAgICAgICAgZGVsZXRlQnV0dG9uTGFiZWw6IHN0cmluZyxcbiAgICAgICAgY2FuY2VsQnV0dG9uTGFiZWw6IHN0cmluZyxcbiAgICAgICAgZGVsZXRlUmVxdWlyZXNDb25maXJtRGlhbG9nOiBib29sZWFuLFxuICAgICAgICBlZGl0UmVxdWlyZXNDb25maXJtRGlhbG9nOiBib29sZWFuLFxuICAgICAgICBjb25maXJtRGVsZXRlRGlhbG9nRGF0YTogQ29uZmlybURpYWxvZ0RhdGEsXG4gICAgICAgIGNvbmZpcm1FZGl0RGlhbG9nRGF0YTogQ29uZmlybURpYWxvZ0RhdGFcbiAgICApIHtcbiAgICAgICAgdGhpcy50aXRsZSA9IHRpdGxlO1xuICAgICAgICB0aGlzLmNvbmZpcm1CdXR0b25MYWJlbCA9IGNvbmZpcm1CdXR0b25MYWJlbDtcbiAgICAgICAgdGhpcy5kZWxldGVCdXR0b25MYWJlbCA9IGRlbGV0ZUJ1dHRvbkxhYmVsO1xuICAgICAgICB0aGlzLmNhbmNlbEJ1dHRvbkxhYmVsID0gY2FuY2VsQnV0dG9uTGFiZWw7XG4gICAgICAgIHRoaXMuZGVsZXRlUmVxdWlyZXNDb25maXJtRGlhbG9nID0gZGVsZXRlUmVxdWlyZXNDb25maXJtRGlhbG9nO1xuICAgICAgICB0aGlzLmVkaXRSZXF1aXJlc0NvbmZpcm1EaWFsb2cgPSBlZGl0UmVxdWlyZXNDb25maXJtRGlhbG9nO1xuICAgICAgICB0aGlzLmNvbmZpcm1EZWxldGVEaWFsb2dEYXRhID0gY29uZmlybURlbGV0ZURpYWxvZ0RhdGE7XG4gICAgICAgIHRoaXMuY29uZmlybUVkaXREaWFsb2dEYXRhID0gY29uZmlybUVkaXREaWFsb2dEYXRhO1xuICAgIH1cbn1cblxuLyoqXG4gKiBUaGUgQnVpbGRlciBmb3IgdGhlIEVkaXREaWFsb2dEYXRhLiBTZXRzIGRlZmF1bHQgdmFsdWVzLlxuICovXG5leHBvcnQgY2xhc3MgRWRpdERpYWxvZ0RhdGFCdWlsZGVyPEVudGl0eVR5cGUgZXh0ZW5kcyBCYXNlRW50aXR5VHlwZTxFbnRpdHlUeXBlPj5cbiAgICBleHRlbmRzIEJhc2VCdWlsZGVyPEVkaXREYXRhSW50ZXJuYWw8RW50aXR5VHlwZT4sIEVkaXREYXRhPEVudGl0eVR5cGU+PiB7XG5cbiAgICBjb25zdHJ1Y3RvcihkYXRhPzogRWRpdERhdGE8RW50aXR5VHlwZT4pIHtcbiAgICAgICAgc3VwZXIoZGF0YSk7XG4gICAgfVxuXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGpzZG9jL3JlcXVpcmUtanNkb2NcbiAgICBwcm90ZWN0ZWQgZ2VuZXJhdGVCYXNlRGF0YShkYXRhPzogRWRpdERhdGE8RW50aXR5VHlwZT4pOiBFZGl0RGF0YUludGVybmFsPEVudGl0eVR5cGU+IHtcbiAgICAgICAgY29uc3QgY29uZmlybUVkaXREaWFsb2dEYXRhOiBDb25maXJtRGlhbG9nRGF0YUludGVybmFsID0gbmV3IENvbmZpcm1EaWFsb2dEYXRhQnVpbGRlcihkYXRhPy5jb25maXJtRWRpdERpYWxvZ0RhdGEpXG4gICAgICAgICAgICAud2l0aERlZmF1bHQoJ2NvbmZpcm1CdXR0b25MYWJlbCcsICdTYXZlJylcbiAgICAgICAgICAgIC53aXRoRGVmYXVsdCgndGV4dCcsIFsnRG8geW91IHJlYWxseSB3YW50IHRvIHNhdmUgYWxsIGNoYW5nZXM/J10pXG4gICAgICAgICAgICAud2l0aERlZmF1bHQoJ3RpdGxlJywgJ0VkaXQnKVxuICAgICAgICAgICAgLmdldFJlc3VsdCgpO1xuXG4gICAgICAgIGNvbnN0IGNvbmZpcm1EZWxldGVEaWFsb2dEYXRhOiBDb25maXJtRGlhbG9nRGF0YUludGVybmFsID0gbmV3IENvbmZpcm1EaWFsb2dEYXRhQnVpbGRlcihkYXRhPy5jb25maXJtRGVsZXRlRGlhbG9nRGF0YSlcbiAgICAgICAgICAgIC53aXRoRGVmYXVsdCgnY29uZmlybUJ1dHRvbkxhYmVsJywgJ0RlbGV0ZScpXG4gICAgICAgICAgICAud2l0aERlZmF1bHQoJ3R5cGUnLCAnZGVsZXRlJylcbiAgICAgICAgICAgIC53aXRoRGVmYXVsdCgndGV4dCcsIFsnRG8geW91IHJlYWxseSB3YW50IHRvIGRlbGV0ZSB0aGlzIGVudGl0eT8nXSlcbiAgICAgICAgICAgIC53aXRoRGVmYXVsdCgndGl0bGUnLCAnRGVsZXRlJylcbiAgICAgICAgICAgIC5nZXRSZXN1bHQoKTtcblxuICAgICAgICByZXR1cm4gbmV3IEVkaXREYXRhSW50ZXJuYWwoXG4gICAgICAgICAgICBkYXRhPy50aXRsZSA/PyAoKCkgPT4gJ0VkaXQnKSxcbiAgICAgICAgICAgIGRhdGE/LmNvbmZpcm1CdXR0b25MYWJlbCA/PyAnU2F2ZScsXG4gICAgICAgICAgICBkYXRhPy5kZWxldGVCdXR0b25MYWJlbCA/PyAnRGVsZXRlJyxcbiAgICAgICAgICAgIGRhdGE/LmNhbmNlbEJ1dHRvbkxhYmVsID8/ICdDYW5jZWwnLFxuICAgICAgICAgICAgZGF0YT8uZGVsZXRlUmVxdWlyZXNDb25maXJtRGlhbG9nID8/IHRydWUsXG4gICAgICAgICAgICBkYXRhPy5lZGl0UmVxdWlyZXNDb25maXJtRGlhbG9nID8/IGZhbHNlLFxuICAgICAgICAgICAgY29uZmlybURlbGV0ZURpYWxvZ0RhdGEsXG4gICAgICAgICAgICBjb25maXJtRWRpdERpYWxvZ0RhdGFcbiAgICAgICAgKTtcbiAgICB9XG59Il19
|
|
58
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"edit-data.builder.js","sourceRoot":"","sources":["../../../../../../projects/ngx-material-entity/src/components/table/edit-dialog/edit-data.builder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseBuilder, defaultFalse, defaultTrue } from '../../../classes/base.builder';\nimport { BaseEntityType } from '../../../classes/entity.model';\nimport { ConfirmDialogData } from '../../confirm-dialog/confirm-dialog-data';\nimport { ConfirmDialogDataBuilder, ConfirmDialogDataInternal } from '../../confirm-dialog/confirm-dialog-data.builder';\nimport { EditAction, EditData } from '../table-data';\n\n/**\n * The internal edit action.\n * Sets default values.\n */\nexport class EditActionInternal<EntityType extends BaseEntityType<EntityType>> implements EditAction<EntityType> {\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    displayName: string;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    action: (e: EntityType) => unknown;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    enabled: ((e: EntityType) => boolean);\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    requireConfirmDialog: ((e: EntityType) => boolean);\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    confirmDialogData: ConfirmDialogData;\n\n    constructor(data: EditAction<EntityType>) {\n        this.displayName = data.displayName;\n        this.action = data.action;\n        this.enabled = data.enabled ?? defaultTrue;\n        this.requireConfirmDialog = data.requireConfirmDialog ?? defaultFalse;\n        this.confirmDialogData = new ConfirmDialogDataBuilder(data.confirmDialogData)\n            .withDefault('text', ['Do you really want to run this action?'])\n            .getResult();\n    }\n}\n\n/**\n * The internal EditData. Requires all default values the user can leave out.\n */\nexport class EditDataInternal<EntityType extends BaseEntityType<EntityType>> implements EditData<EntityType> {\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    title: (entity: EntityType) => string;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    confirmButtonLabel: string;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    deleteButtonLabel: string;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    cancelButtonLabel: string;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    deleteRequiresConfirmDialog: boolean;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    editRequiresConfirmDialog: boolean;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    confirmDeleteDialogData: ConfirmDialogData;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    confirmEditDialogData: ConfirmDialogData;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    actionsLabel: string;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    actions: EditActionInternal<EntityType>[];\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        actionsLabel: string,\n        actions: EditAction<EntityType>[]\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        this.actionsLabel = actionsLabel;\n        this.actions = actions.map(a => new EditActionInternal(a));\n    }\n}\n\n/**\n * The Builder for the EditDialogData. Sets default values.\n */\nexport class EditDialogDataBuilder<EntityType extends BaseEntityType<EntityType>>\n    extends BaseBuilder<EditDataInternal<EntityType>, EditData<EntityType>> {\n\n    constructor(data?: EditData<EntityType>) {\n        super(data);\n    }\n\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    protected generateBaseData(data?: EditData<EntityType>): EditDataInternal<EntityType> {\n        const confirmEditDialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(data?.confirmEditDialogData)\n            .withDefault('confirmButtonLabel', 'Save')\n            .withDefault('text', ['Do you really want to save all changes?'])\n            .withDefault('title', 'Edit')\n            .getResult();\n\n        const confirmDeleteDialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(data?.confirmDeleteDialogData)\n            .withDefault('confirmButtonLabel', 'Delete')\n            .withDefault('type', 'delete')\n            .withDefault('text', ['Do you really want to delete this entity?'])\n            .withDefault('title', 'Delete')\n            .getResult();\n\n        return new EditDataInternal(\n            data?.title ?? (() => 'Edit'),\n            data?.confirmButtonLabel ?? 'Save',\n            data?.deleteButtonLabel ?? 'Delete',\n            data?.cancelButtonLabel ?? 'Cancel',\n            data?.deleteRequiresConfirmDialog ?? true,\n            data?.editRequiresConfirmDialog ?? false,\n            confirmDeleteDialogData,\n            confirmEditDialogData,\n            data?.actionsLabel ?? 'Actions',\n            data?.actions ?? []\n        );\n    }\n}"]}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import { NgFor, NgIf } from '@angular/common';
|
|
2
|
-
import { Component,
|
|
2
|
+
import { Component, EnvironmentInjector, Inject } from '@angular/core';
|
|
3
3
|
import { FormsModule } from '@angular/forms';
|
|
4
4
|
import { MatButtonModule } from '@angular/material/button';
|
|
5
5
|
import { MAT_DIALOG_DATA, MatDialog, MatDialogModule, MatDialogRef } from '@angular/material/dialog';
|
|
6
|
+
import { MatMenuModule } from '@angular/material/menu';
|
|
6
7
|
import { MatTabsModule } from '@angular/material/tabs';
|
|
7
8
|
import { LodashUtilities } from '../../../encapsulation/lodash.utilities';
|
|
8
9
|
import { EntityUtilities } from '../../../utilities/entity.utilities';
|
|
@@ -16,6 +17,7 @@ import * as i2 from "../../input/input.component";
|
|
|
16
17
|
import * as i3 from "@angular/forms";
|
|
17
18
|
import * as i4 from "@angular/material/button";
|
|
18
19
|
import * as i5 from "@angular/material/tabs";
|
|
20
|
+
import * as i6 from "@angular/material/menu";
|
|
19
21
|
/**
|
|
20
22
|
* The default dialog used to edit an existing entity based on the configuration passed in the MAT_DIALOG_DATA "inputData".
|
|
21
23
|
* Used by the ngx-mat-entity-table.
|
|
@@ -47,8 +49,10 @@ export class NgxMatEntityEditDialogComponent {
|
|
|
47
49
|
* @returns Whether or not the input for the key is read only.
|
|
48
50
|
*/
|
|
49
51
|
isReadOnly(key) {
|
|
50
|
-
|
|
51
|
-
|
|
52
|
+
return this.injector.runInContext(() => {
|
|
53
|
+
const metadata = EntityUtilities.getPropertyMetadata(this.data.entity, key);
|
|
54
|
+
return this.isEntityReadOnly || metadata.isReadOnly(this.data.entity);
|
|
55
|
+
});
|
|
52
56
|
}
|
|
53
57
|
/**
|
|
54
58
|
* Checks if the entity has become invalid or dirty.
|
|
@@ -124,9 +128,49 @@ export class NgxMatEntityEditDialogComponent {
|
|
|
124
128
|
EntityUtilities.resetChangesOnEntity(this.data.entity, this.entityPriorChanges);
|
|
125
129
|
this.dialogRef.close(0);
|
|
126
130
|
}
|
|
131
|
+
/**
|
|
132
|
+
* Runs the edit action on the entity.
|
|
133
|
+
*
|
|
134
|
+
* @param action - The action to run.
|
|
135
|
+
*/
|
|
136
|
+
runEditAction(action) {
|
|
137
|
+
const requireConfirmDialog = this.injector.runInContext(() => {
|
|
138
|
+
return action.requireConfirmDialog(this.entityPriorChanges);
|
|
139
|
+
});
|
|
140
|
+
if (!requireConfirmDialog) {
|
|
141
|
+
this.confirmRunEditAction(action);
|
|
142
|
+
return;
|
|
143
|
+
}
|
|
144
|
+
const dialogRef = this.dialog.open(NgxMatEntityConfirmDialogComponent, {
|
|
145
|
+
data: action.confirmDialogData,
|
|
146
|
+
autoFocus: false,
|
|
147
|
+
restoreFocus: false
|
|
148
|
+
});
|
|
149
|
+
dialogRef.afterClosed().subscribe(res => {
|
|
150
|
+
if (res == true) {
|
|
151
|
+
this.confirmRunEditAction(action);
|
|
152
|
+
}
|
|
153
|
+
});
|
|
154
|
+
}
|
|
155
|
+
confirmRunEditAction(action) {
|
|
156
|
+
this.injector.runInContext(() => {
|
|
157
|
+
action.action(this.entityPriorChanges);
|
|
158
|
+
});
|
|
159
|
+
}
|
|
160
|
+
/**
|
|
161
|
+
* Checks if an EditAction is disabled (e.g. Because the current entry doesn't fullfil the requirements).
|
|
162
|
+
*
|
|
163
|
+
* @param action - The EditAction to check.
|
|
164
|
+
* @returns Whether or not the Action can be used.
|
|
165
|
+
*/
|
|
166
|
+
editActionDisabled(action) {
|
|
167
|
+
return this.injector.runInContext(() => {
|
|
168
|
+
return !action.enabled(this.entityPriorChanges);
|
|
169
|
+
});
|
|
170
|
+
}
|
|
127
171
|
}
|
|
128
|
-
NgxMatEntityEditDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: NgxMatEntityEditDialogComponent, deps: [{ token: MAT_DIALOG_DATA }, { token: i1.MatDialogRef }, { token: i0.
|
|
129
|
-
NgxMatEntityEditDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.3", type: NgxMatEntityEditDialogComponent, isStandalone: true, selector: "ngx-mat-entity-edit-dialog", ngImport: i0, template: "<div class=\"mat-dialog-title\">\n <div>{{data.editData.title(entityPriorChanges)}}</div>\n <button type=\"button\" *ngIf=\"data.allowDelete(data.entity)\" mat-raised-button (click)=\"delete()\" color=\"warn\" class=\"delete-button\" tabindex=\"-1\">\n
|
|
172
|
+
NgxMatEntityEditDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: NgxMatEntityEditDialogComponent, deps: [{ token: MAT_DIALOG_DATA }, { token: i1.MatDialogRef }, { token: i0.EnvironmentInjector }, { token: i1.MatDialog }], target: i0.ɵɵFactoryTarget.Component });
|
|
173
|
+
NgxMatEntityEditDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.3", type: NgxMatEntityEditDialogComponent, isStandalone: true, selector: "ngx-mat-entity-edit-dialog", ngImport: i0, template: "<div class=\"mat-dialog-title\">\n <div>{{data.editData.title(entityPriorChanges)}}</div>\n\n <div class=\"actions-container\">\n <button *ngIf=\"data.editData.actions.length\" type=\"button\" [matMenuTriggerFor]=\"menu\" mat-raised-button>\n {{data.editData.actionsLabel}}\n </button>\n <mat-menu #menu=\"matMenu\">\n <button type=\"button\" *ngFor=\"let action of data.editData.actions\" [disabled]=\"editActionDisabled(action)\" (click)=\"runEditAction(action)\" mat-menu-item>\n {{action.displayName}}\n </button>\n </mat-menu>\n \n <button type=\"button\" *ngIf=\"data.allowDelete(data.entity)\" mat-raised-button (click)=\"delete()\" color=\"warn\" class=\"delete-button\" tabindex=\"-1\">\n {{data.editData.deleteButtonLabel}}\n </button>\n </div>\n</div>\n\n<form>\n <mat-dialog-content>\n <mat-tab-group *ngIf=\"entityTabs.length > 1\" preserveContent>\n <mat-tab *ngFor=\"let tab of entityTabs\" [label]=\"tab.tabName\">\n <div class=\"row\" *ngFor=\"let row of tab.rows\">\n <ngx-mat-entity-input\n *ngFor=\"let key of row.keys\"\n [entity]=\"data.entity\"\n [propertyKey]=\"key\"\n [hideOmitForEdit]=\"true\"\n class=\"col-lg-{{EntityUtilities.getWidth(data.entity, key, 'lg')}} col-md-{{EntityUtilities.getWidth(data.entity, key, 'md')}} col-sm-{{EntityUtilities.getWidth(data.entity, key, 'sm')}}\"\n (inputChangeEvent)=\"checkEntity()\"\n [isReadOnly]=\"isReadOnly(key)\"\n >\n </ngx-mat-entity-input>\n </div>\n </mat-tab>\n </mat-tab-group>\n \n <div *ngIf=\"entityTabs.length <= 1\">\n <span class=\"no-entity-tabs\" *ngIf=\"!entityTabs.length\">\n ERROR: No Inputs. Did you correctly assign all values in the model constructor?\n </span>\n <div class=\"row\" *ngFor=\"let row of entityTabs[0].rows\">\n <ngx-mat-entity-input\n *ngFor=\"let key of row.keys\"\n [entity]=\"data.entity\"\n [propertyKey]=\"key\"\n [hideOmitForEdit]=\"true\"\n class=\"col-lg-{{EntityUtilities.getWidth(data.entity, key, 'lg')}} col-md-{{EntityUtilities.getWidth(data.entity, key, 'md')}} col-sm-{{EntityUtilities.getWidth(data.entity, key, 'sm')}}\"\n (inputChangeEvent)=\"checkEntity()\"\n [isReadOnly]=\"isReadOnly(key)\"\n >\n </ngx-mat-entity-input>\n </div>\n </div>\n </mat-dialog-content>\n \n <mat-dialog-actions>\n <button type=\"submit\" (click)=\"edit()\" mat-raised-button [disabled]=\"isEntityReadOnly || !isEntityValid || !isEntityDirty\">\n {{data.editData.confirmButtonLabel}}\n </button>\n <button type=\"button\" mat-raised-button (click)=\"cancel()\" class=\"cancel-button\">\n {{data.editData.cancelButtonLabel}}\n </button>\n </mat-dialog-actions>\n</form>\n", styles: [".mat-dialog-title{padding:12px 20px;display:flex;justify-content:space-between;align-items:center}.mat-dialog-title div{font-size:var(--mdc-dialog-subhead-size, 14px);font-weight:var(--mdc-dialog-subhead-weight, 500)}.actions-container{display:flex;gap:10px}.no-entity-tabs{padding:10px;background-color:red;color:#f5f5f5}::ng-deep .mdc-dialog .mdc-dialog__content{padding:6px 20px!important}mat-dialog-actions{justify-content:space-between;align-items:center;padding-left:20px;padding-right:20px}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "ngmodule", type: NgxMatEntityInputModule }, { kind: "component", type: i2.NgxMatEntityInputComponent, selector: "ngx-mat-entity-input", inputs: ["entity", "propertyKey", "getValidationErrorMessage", "hideOmitForCreate", "hideOmitForEdit", "validEmpty", "isReadOnly"], outputs: ["inputChangeEvent"] }, { kind: "ngmodule", type: MatDialogModule }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i4.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "ngmodule", type: MatTabsModule }, { kind: "component", type: i5.MatTab, selector: "mat-tab", inputs: ["disabled"], exportAs: ["matTab"] }, { kind: "component", type: i5.MatTabGroup, selector: "mat-tab-group", inputs: ["color", "disableRipple", "fitInkBarToContent", "mat-stretch-tabs"], exportAs: ["matTabGroup"] }, { kind: "ngmodule", type: MatMenuModule }, { kind: "component", type: i6.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i6.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i6.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }] });
|
|
130
174
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: NgxMatEntityEditDialogComponent, decorators: [{
|
|
131
175
|
type: Component,
|
|
132
176
|
args: [{ selector: 'ngx-mat-entity-edit-dialog', standalone: true, imports: [
|
|
@@ -137,10 +181,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.3", ngImpor
|
|
|
137
181
|
FormsModule,
|
|
138
182
|
MatButtonModule,
|
|
139
183
|
MatTabsModule,
|
|
140
|
-
NgxMatEntityConfirmDialogComponent
|
|
141
|
-
|
|
184
|
+
NgxMatEntityConfirmDialogComponent,
|
|
185
|
+
MatMenuModule
|
|
186
|
+
], template: "<div class=\"mat-dialog-title\">\n <div>{{data.editData.title(entityPriorChanges)}}</div>\n\n <div class=\"actions-container\">\n <button *ngIf=\"data.editData.actions.length\" type=\"button\" [matMenuTriggerFor]=\"menu\" mat-raised-button>\n {{data.editData.actionsLabel}}\n </button>\n <mat-menu #menu=\"matMenu\">\n <button type=\"button\" *ngFor=\"let action of data.editData.actions\" [disabled]=\"editActionDisabled(action)\" (click)=\"runEditAction(action)\" mat-menu-item>\n {{action.displayName}}\n </button>\n </mat-menu>\n \n <button type=\"button\" *ngIf=\"data.allowDelete(data.entity)\" mat-raised-button (click)=\"delete()\" color=\"warn\" class=\"delete-button\" tabindex=\"-1\">\n {{data.editData.deleteButtonLabel}}\n </button>\n </div>\n</div>\n\n<form>\n <mat-dialog-content>\n <mat-tab-group *ngIf=\"entityTabs.length > 1\" preserveContent>\n <mat-tab *ngFor=\"let tab of entityTabs\" [label]=\"tab.tabName\">\n <div class=\"row\" *ngFor=\"let row of tab.rows\">\n <ngx-mat-entity-input\n *ngFor=\"let key of row.keys\"\n [entity]=\"data.entity\"\n [propertyKey]=\"key\"\n [hideOmitForEdit]=\"true\"\n class=\"col-lg-{{EntityUtilities.getWidth(data.entity, key, 'lg')}} col-md-{{EntityUtilities.getWidth(data.entity, key, 'md')}} col-sm-{{EntityUtilities.getWidth(data.entity, key, 'sm')}}\"\n (inputChangeEvent)=\"checkEntity()\"\n [isReadOnly]=\"isReadOnly(key)\"\n >\n </ngx-mat-entity-input>\n </div>\n </mat-tab>\n </mat-tab-group>\n \n <div *ngIf=\"entityTabs.length <= 1\">\n <span class=\"no-entity-tabs\" *ngIf=\"!entityTabs.length\">\n ERROR: No Inputs. Did you correctly assign all values in the model constructor?\n </span>\n <div class=\"row\" *ngFor=\"let row of entityTabs[0].rows\">\n <ngx-mat-entity-input\n *ngFor=\"let key of row.keys\"\n [entity]=\"data.entity\"\n [propertyKey]=\"key\"\n [hideOmitForEdit]=\"true\"\n class=\"col-lg-{{EntityUtilities.getWidth(data.entity, key, 'lg')}} col-md-{{EntityUtilities.getWidth(data.entity, key, 'md')}} col-sm-{{EntityUtilities.getWidth(data.entity, key, 'sm')}}\"\n (inputChangeEvent)=\"checkEntity()\"\n [isReadOnly]=\"isReadOnly(key)\"\n >\n </ngx-mat-entity-input>\n </div>\n </div>\n </mat-dialog-content>\n \n <mat-dialog-actions>\n <button type=\"submit\" (click)=\"edit()\" mat-raised-button [disabled]=\"isEntityReadOnly || !isEntityValid || !isEntityDirty\">\n {{data.editData.confirmButtonLabel}}\n </button>\n <button type=\"button\" mat-raised-button (click)=\"cancel()\" class=\"cancel-button\">\n {{data.editData.cancelButtonLabel}}\n </button>\n </mat-dialog-actions>\n</form>\n", styles: [".mat-dialog-title{padding:12px 20px;display:flex;justify-content:space-between;align-items:center}.mat-dialog-title div{font-size:var(--mdc-dialog-subhead-size, 14px);font-weight:var(--mdc-dialog-subhead-weight, 500)}.actions-container{display:flex;gap:10px}.no-entity-tabs{padding:10px;background-color:red;color:#f5f5f5}::ng-deep .mdc-dialog .mdc-dialog__content{padding:6px 20px!important}mat-dialog-actions{justify-content:space-between;align-items:center;padding-left:20px;padding-right:20px}\n"] }]
|
|
142
187
|
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
143
188
|
type: Inject,
|
|
144
189
|
args: [MAT_DIALOG_DATA]
|
|
145
|
-
}] }, { type: i1.MatDialogRef }, { type: i0.
|
|
146
|
-
//# 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 { NgFor, NgIf } from '@angular/common';\nimport { Component, Inject, Injector, OnInit } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MAT_DIALOG_DATA, MatDialog, MatDialogModule, MatDialogRef } from '@angular/material/dialog';\nimport { MatTabsModule } from '@angular/material/tabs';\nimport { BaseEntityType } from '../../../classes/entity.model';\nimport { PropertyDecoratorConfigInternal } from '../../../decorators/base/property-decorator-internal.data';\nimport { LodashUtilities } from '../../../encapsulation/lodash.utilities';\nimport { EntityService } from '../../../services/entity.service';\nimport { EntityTab, EntityUtilities } from '../../../utilities/entity.utilities';\nimport { ConfirmDialogDataBuilder, ConfirmDialogDataInternal } from '../../confirm-dialog/confirm-dialog-data.builder';\nimport { NgxMatEntityConfirmDialogComponent } from '../../confirm-dialog/confirm-dialog.component';\nimport { NgxMatEntityInputModule } from '../../input/input.module';\nimport { EditEntityData } from './edit-entity-data';\nimport { EditEntityDataBuilder, EditEntityDataInternal } from './edit-entity.builder';\n\n/**\n * The default dialog used to edit an existing entity based on the configuration passed in the MAT_DIALOG_DATA \"inputData\".\n * Used by the ngx-mat-entity-table.\n *\n * It offers a lot of customization options which can be found in \"EditEntityDialogData\".\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    standalone: true,\n    imports: [\n        NgIf,\n        NgFor,\n        NgxMatEntityInputModule,\n        MatDialogModule,\n        FormsModule,\n        MatButtonModule,\n        MatTabsModule,\n        NgxMatEntityConfirmDialogComponent\n    ]\n})\nexport class NgxMatEntityEditDialogComponent<EntityType extends BaseEntityType<EntityType>> implements OnInit {\n    EntityUtilities: typeof EntityUtilities = EntityUtilities;\n\n    entityTabs!: EntityTab<EntityType>[];\n\n    entityService!: EntityService<EntityType>;\n\n    entityPriorChanges!: EntityType;\n\n    data!: EditEntityDataInternal<EntityType>;\n\n    isEntityValid: boolean = true;\n    isEntityDirty: boolean = false;\n\n    isEntityReadOnly!: boolean;\n\n    constructor(\n        @Inject(MAT_DIALOG_DATA)\n        private readonly inputData: EditEntityData<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 EditEntityDataBuilder(this.inputData).getResult();\n        this.entityPriorChanges = LodashUtilities.cloneDeep(this.data.entity);\n        this.isEntityReadOnly = !this.data.allowUpdate(this.entityPriorChanges);\n        this.dialogRef.disableClose = true;\n        this.entityTabs = EntityUtilities.getEntityTabs(this.data.entity, false, true);\n        this.entityService = this.injector.get(this.data.EntityServiceClass) as EntityService<EntityType>;\n    }\n\n    /**\n     * Checks if the input with the given key is readonly.\n     *\n     * @param key - The key for the input to check.\n     * @returns Whether or not the input for the key is read only.\n     */\n    isReadOnly(key: keyof EntityType): boolean {\n        const metadata: PropertyDecoratorConfigInternal = EntityUtilities.getPropertyMetadata(this.data.entity, key);\n        return this.isEntityReadOnly || metadata.isReadOnly(this.data.entity);\n    }\n\n    /**\n     * Checks if the entity has become invalid or dirty.\n     */\n    async checkEntity(): Promise<void> {\n        this.isEntityValid = EntityUtilities.isEntityValid(this.data.entity, 'update');\n        this.isEntityDirty = await EntityUtilities.isDirty(this.data.entity, this.entityPriorChanges);\n    }\n\n    /**\n     * Tries to save the changes and close the dialog afterwards.\n     * Also handles the confirmation if required.\n     */\n    edit(): void {\n        if (this.isEntityReadOnly || !this.isEntityValid || !this.isEntityDirty) {\n            return;\n        }\n        if (!this.data.editData.editRequiresConfirmDialog) {\n            this.confirmEdit();\n            return;\n        }\n        const dialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(this.data.editData.confirmEditDialogData)\n            .withDefault('text', ['Do you really want to save all changes?'])\n            .withDefault('confirmButtonLabel', 'Save')\n            .withDefault('title', 'Edit')\n            .getResult();\n        const dialogRef: MatDialogRef<NgxMatEntityConfirmDialogComponent, boolean> = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        dialogRef.afterClosed().subscribe(res => {\n            if (res == true) {\n                this.confirmEdit();\n            }\n        });\n    }\n\n    private confirmEdit(): void {\n        void this.entityService.update(this.data.entity, this.entityPriorChanges).then(() => this.dialogRef.close(1));\n    }\n\n    /**\n     * Tries to delete the entity and close the dialog afterwards.\n     * Also handles the confirmation if required.\n     */\n    delete(): void {\n        if (!this.data.editData.deleteRequiresConfirmDialog) {\n            this.confirmDelete();\n            return;\n        }\n        const dialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(this.data.editData.confirmDeleteDialogData)\n            .withDefault('text', ['Do you really want to delete this entity?'])\n            .withDefault('type', 'delete')\n            .withDefault('confirmButtonLabel', 'Delete')\n            .withDefault('title', 'Delete')\n            .getResult();\n        const dialogRef: MatDialogRef<NgxMatEntityConfirmDialogComponent, boolean> = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        dialogRef.afterClosed().subscribe(res => {\n            if (res == true) {\n                this.confirmDelete();\n            }\n        });\n    }\n\n    private confirmDelete(): void {\n        void this.entityService.delete(this.entityPriorChanges).then(() => this.dialogRef.close(2));\n    }\n\n    /**\n     * Reverts all changes made and closes the dialog.\n     */\n    cancel(): void {\n        EntityUtilities.resetChangesOnEntity(this.data.entity, this.entityPriorChanges);\n        this.dialogRef.close(0);\n    }\n}","<div class=\"mat-dialog-title\">\n    <div>{{data.editData.title(entityPriorChanges)}}</div>\n    <button type=\"button\" *ngIf=\"data.allowDelete(data.entity)\" mat-raised-button (click)=\"delete()\" color=\"warn\" class=\"delete-button\" tabindex=\"-1\">\n        {{data.editData.deleteButtonLabel}}\n    </button>\n</div>\n\n<form>\n    <mat-dialog-content>\n        <mat-tab-group *ngIf=\"entityTabs.length > 1\" preserveContent>\n            <mat-tab *ngFor=\"let tab of entityTabs\" [label]=\"tab.tabName\">\n                <div class=\"row\" *ngFor=\"let row of tab.rows\">\n                    <ngx-mat-entity-input\n                        *ngFor=\"let key of row.keys\"\n                        [entity]=\"data.entity\"\n                        [propertyKey]=\"key\"\n                        [hideOmitForEdit]=\"true\"\n                        class=\"col-lg-{{EntityUtilities.getWidth(data.entity, key, 'lg')}} col-md-{{EntityUtilities.getWidth(data.entity, key, 'md')}} col-sm-{{EntityUtilities.getWidth(data.entity, key, 'sm')}}\"\n                        (inputChangeEvent)=\"checkEntity()\"\n                        [isReadOnly]=\"isReadOnly(key)\"\n                    >\n                    </ngx-mat-entity-input>\n                </div>\n            </mat-tab>\n        </mat-tab-group>\n    \n        <div *ngIf=\"entityTabs.length <= 1\">\n            <div class=\"row\" *ngFor=\"let row of entityTabs[0].rows\">\n                <ngx-mat-entity-input\n                    *ngFor=\"let key of row.keys\"\n                    [entity]=\"data.entity\"\n                    [propertyKey]=\"key\"\n                    [hideOmitForEdit]=\"true\"\n                    class=\"col-lg-{{EntityUtilities.getWidth(data.entity, key, 'lg')}} col-md-{{EntityUtilities.getWidth(data.entity, key, 'md')}} col-sm-{{EntityUtilities.getWidth(data.entity, key, 'sm')}}\"\n                    (inputChangeEvent)=\"checkEntity()\"\n                    [isReadOnly]=\"isReadOnly(key)\"\n                >\n                </ngx-mat-entity-input>\n            </div>\n        </div>\n    </mat-dialog-content>\n    \n    <mat-dialog-actions>\n        <button type=\"submit\" (click)=\"edit()\" mat-raised-button [disabled]=\"isEntityReadOnly || !isEntityValid || !isEntityDirty\">\n            {{data.editData.confirmButtonLabel}}\n        </button>\n        <button type=\"button\" mat-raised-button (click)=\"cancel()\" class=\"cancel-button\">\n            {{data.editData.cancelButtonLabel}}\n        </button>\n    </mat-dialog-actions>\n</form>\n"]}
|
|
190
|
+
}] }, { type: i1.MatDialogRef }, { type: i0.EnvironmentInjector }, { type: i1.MatDialog }]; } });
|
|
191
|
+
//# 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 { NgFor, NgIf } from '@angular/common';\nimport { Component, EnvironmentInjector, Inject, OnInit } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MAT_DIALOG_DATA, MatDialog, MatDialogModule, MatDialogRef } from '@angular/material/dialog';\nimport { MatMenuModule } from '@angular/material/menu';\nimport { MatTabsModule } from '@angular/material/tabs';\nimport { BaseEntityType } from '../../../classes/entity.model';\nimport { PropertyDecoratorConfigInternal } from '../../../decorators/base/property-decorator-internal.data';\nimport { LodashUtilities } from '../../../encapsulation/lodash.utilities';\nimport { EntityService } from '../../../services/entity.service';\nimport { EntityTab, EntityUtilities } from '../../../utilities/entity.utilities';\nimport { ConfirmDialogDataBuilder, ConfirmDialogDataInternal } from '../../confirm-dialog/confirm-dialog-data.builder';\nimport { NgxMatEntityConfirmDialogComponent } from '../../confirm-dialog/confirm-dialog.component';\nimport { NgxMatEntityInputModule } from '../../input/input.module';\nimport { EditActionInternal } from './edit-data.builder';\nimport { EditEntityData } from './edit-entity-data';\nimport { EditEntityDataBuilder, EditEntityDataInternal } from './edit-entity.builder';\n\n/**\n * The default dialog used to edit an existing entity based on the configuration passed in the MAT_DIALOG_DATA \"inputData\".\n * Used by the ngx-mat-entity-table.\n *\n * It offers a lot of customization options which can be found in \"EditEntityDialogData\".\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    standalone: true,\n    imports: [\n        NgIf,\n        NgFor,\n        NgxMatEntityInputModule,\n        MatDialogModule,\n        FormsModule,\n        MatButtonModule,\n        MatTabsModule,\n        NgxMatEntityConfirmDialogComponent,\n        MatMenuModule\n    ]\n})\nexport class NgxMatEntityEditDialogComponent<EntityType extends BaseEntityType<EntityType>> implements OnInit {\n    EntityUtilities: typeof EntityUtilities = EntityUtilities;\n\n    entityTabs!: EntityTab<EntityType>[];\n\n    entityService!: EntityService<EntityType>;\n\n    entityPriorChanges!: EntityType;\n\n    data!: EditEntityDataInternal<EntityType>;\n\n    isEntityValid: boolean = true;\n    isEntityDirty: boolean = false;\n\n    isEntityReadOnly!: boolean;\n\n    constructor(\n        @Inject(MAT_DIALOG_DATA)\n        private readonly inputData: EditEntityData<EntityType>,\n        public dialogRef: MatDialogRef<NgxMatEntityEditDialogComponent<EntityType>>,\n        private readonly injector: EnvironmentInjector,\n        private readonly dialog: MatDialog\n    ) {}\n\n    ngOnInit(): void {\n        this.data = new EditEntityDataBuilder(this.inputData).getResult();\n        this.entityPriorChanges = LodashUtilities.cloneDeep(this.data.entity);\n        this.isEntityReadOnly = !this.data.allowUpdate(this.entityPriorChanges);\n        this.dialogRef.disableClose = true;\n        this.entityTabs = EntityUtilities.getEntityTabs(this.data.entity, false, true);\n        this.entityService = this.injector.get(this.data.EntityServiceClass) as EntityService<EntityType>;\n    }\n\n    /**\n     * Checks if the input with the given key is readonly.\n     *\n     * @param key - The key for the input to check.\n     * @returns Whether or not the input for the key is read only.\n     */\n    isReadOnly(key: keyof EntityType): boolean {\n        return this.injector.runInContext(() => {\n            const metadata: PropertyDecoratorConfigInternal = EntityUtilities.getPropertyMetadata(this.data.entity, key);\n            return this.isEntityReadOnly || metadata.isReadOnly(this.data.entity);\n        });\n    }\n\n    /**\n     * Checks if the entity has become invalid or dirty.\n     */\n    async checkEntity(): Promise<void> {\n        this.isEntityValid = EntityUtilities.isEntityValid(this.data.entity, 'update');\n        this.isEntityDirty = await EntityUtilities.isDirty(this.data.entity, this.entityPriorChanges);\n    }\n\n    /**\n     * Tries to save the changes and close the dialog afterwards.\n     * Also handles the confirmation if required.\n     */\n    edit(): void {\n        if (this.isEntityReadOnly || !this.isEntityValid || !this.isEntityDirty) {\n            return;\n        }\n        if (!this.data.editData.editRequiresConfirmDialog) {\n            this.confirmEdit();\n            return;\n        }\n        const dialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(this.data.editData.confirmEditDialogData)\n            .withDefault('text', ['Do you really want to save all changes?'])\n            .withDefault('confirmButtonLabel', 'Save')\n            .withDefault('title', 'Edit')\n            .getResult();\n        const dialogRef: MatDialogRef<NgxMatEntityConfirmDialogComponent, boolean> = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        dialogRef.afterClosed().subscribe(res => {\n            if (res == true) {\n                this.confirmEdit();\n            }\n        });\n    }\n\n    private confirmEdit(): void {\n        void this.entityService.update(this.data.entity, this.entityPriorChanges).then(() => this.dialogRef.close(1));\n    }\n\n    /**\n     * Tries to delete the entity and close the dialog afterwards.\n     * Also handles the confirmation if required.\n     */\n    delete(): void {\n        if (!this.data.editData.deleteRequiresConfirmDialog) {\n            this.confirmDelete();\n            return;\n        }\n        const dialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(this.data.editData.confirmDeleteDialogData)\n            .withDefault('text', ['Do you really want to delete this entity?'])\n            .withDefault('type', 'delete')\n            .withDefault('confirmButtonLabel', 'Delete')\n            .withDefault('title', 'Delete')\n            .getResult();\n        const dialogRef: MatDialogRef<NgxMatEntityConfirmDialogComponent, boolean> = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        dialogRef.afterClosed().subscribe(res => {\n            if (res == true) {\n                this.confirmDelete();\n            }\n        });\n    }\n\n    private confirmDelete(): void {\n        void this.entityService.delete(this.entityPriorChanges).then(() => this.dialogRef.close(2));\n    }\n\n    /**\n     * Reverts all changes made and closes the dialog.\n     */\n    cancel(): void {\n        EntityUtilities.resetChangesOnEntity(this.data.entity, this.entityPriorChanges);\n        this.dialogRef.close(0);\n    }\n\n    /**\n     * Runs the edit action on the entity.\n     *\n     * @param action - The action to run.\n     */\n    runEditAction(action: EditActionInternal<EntityType>): void {\n        const requireConfirmDialog: boolean = this.injector.runInContext(() => {\n            return action.requireConfirmDialog(this.entityPriorChanges);\n        });\n\n        if (!requireConfirmDialog) {\n            this.confirmRunEditAction(action);\n            return;\n        }\n        const dialogRef: MatDialogRef<NgxMatEntityConfirmDialogComponent, boolean> = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: action.confirmDialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        dialogRef.afterClosed().subscribe(res => {\n            if (res == true) {\n                this.confirmRunEditAction(action);\n            }\n        });\n    }\n\n    private confirmRunEditAction(action: EditActionInternal<EntityType>): void {\n        this.injector.runInContext(() => {\n            action.action(this.entityPriorChanges);\n        });\n    }\n\n    /**\n     * Checks if an EditAction is disabled (e.g. Because the current entry doesn't fullfil the requirements).\n     *\n     * @param action - The EditAction to check.\n     * @returns Whether or not the Action can be used.\n     */\n    editActionDisabled(action: EditActionInternal<EntityType>): boolean {\n        return this.injector.runInContext(() => {\n            return !action.enabled(this.entityPriorChanges);\n        });\n    }\n}","<div class=\"mat-dialog-title\">\n    <div>{{data.editData.title(entityPriorChanges)}}</div>\n\n    <div class=\"actions-container\">\n        <button *ngIf=\"data.editData.actions.length\" type=\"button\" [matMenuTriggerFor]=\"menu\" mat-raised-button>\n            {{data.editData.actionsLabel}}\n        </button>\n        <mat-menu #menu=\"matMenu\">\n            <button type=\"button\" *ngFor=\"let action of data.editData.actions\" [disabled]=\"editActionDisabled(action)\" (click)=\"runEditAction(action)\" mat-menu-item>\n                {{action.displayName}}\n            </button>\n        </mat-menu>\n    \n        <button type=\"button\" *ngIf=\"data.allowDelete(data.entity)\" mat-raised-button (click)=\"delete()\" color=\"warn\" class=\"delete-button\" tabindex=\"-1\">\n            {{data.editData.deleteButtonLabel}}\n        </button>\n    </div>\n</div>\n\n<form>\n    <mat-dialog-content>\n        <mat-tab-group *ngIf=\"entityTabs.length > 1\" preserveContent>\n            <mat-tab *ngFor=\"let tab of entityTabs\" [label]=\"tab.tabName\">\n                <div class=\"row\" *ngFor=\"let row of tab.rows\">\n                    <ngx-mat-entity-input\n                        *ngFor=\"let key of row.keys\"\n                        [entity]=\"data.entity\"\n                        [propertyKey]=\"key\"\n                        [hideOmitForEdit]=\"true\"\n                        class=\"col-lg-{{EntityUtilities.getWidth(data.entity, key, 'lg')}} col-md-{{EntityUtilities.getWidth(data.entity, key, 'md')}} col-sm-{{EntityUtilities.getWidth(data.entity, key, 'sm')}}\"\n                        (inputChangeEvent)=\"checkEntity()\"\n                        [isReadOnly]=\"isReadOnly(key)\"\n                    >\n                    </ngx-mat-entity-input>\n                </div>\n            </mat-tab>\n        </mat-tab-group>\n    \n        <div *ngIf=\"entityTabs.length <= 1\">\n            <span class=\"no-entity-tabs\" *ngIf=\"!entityTabs.length\">\n                ERROR: No Inputs. Did you correctly assign all values in the model constructor?\n            </span>\n            <div class=\"row\" *ngFor=\"let row of entityTabs[0].rows\">\n                <ngx-mat-entity-input\n                    *ngFor=\"let key of row.keys\"\n                    [entity]=\"data.entity\"\n                    [propertyKey]=\"key\"\n                    [hideOmitForEdit]=\"true\"\n                    class=\"col-lg-{{EntityUtilities.getWidth(data.entity, key, 'lg')}} col-md-{{EntityUtilities.getWidth(data.entity, key, 'md')}} col-sm-{{EntityUtilities.getWidth(data.entity, key, 'sm')}}\"\n                    (inputChangeEvent)=\"checkEntity()\"\n                    [isReadOnly]=\"isReadOnly(key)\"\n                >\n                </ngx-mat-entity-input>\n            </div>\n        </div>\n    </mat-dialog-content>\n    \n    <mat-dialog-actions>\n        <button type=\"submit\" (click)=\"edit()\" mat-raised-button [disabled]=\"isEntityReadOnly || !isEntityValid || !isEntityDirty\">\n            {{data.editData.confirmButtonLabel}}\n        </button>\n        <button type=\"button\" mat-raised-button (click)=\"cancel()\" class=\"cancel-button\">\n            {{data.editData.cancelButtonLabel}}\n        </button>\n    </mat-dialog-actions>\n</form>\n"]}
|
|
@@ -11,8 +11,8 @@ export class BaseTableActionInternal {
|
|
|
11
11
|
this.type = 'default';
|
|
12
12
|
this.displayName = data.displayName;
|
|
13
13
|
this.action = data.action;
|
|
14
|
-
this.enabled = data.enabled ??
|
|
15
|
-
this.requireConfirmDialog = data.requireConfirmDialog ??
|
|
14
|
+
this.enabled = data.enabled ?? defaultTrue;
|
|
15
|
+
this.requireConfirmDialog = data.requireConfirmDialog ?? defaultFalse;
|
|
16
16
|
this.confirmDialogData = new ConfirmDialogDataBuilder(data.confirmDialogData)
|
|
17
17
|
.withDefault('text', ['Do you really want to run this action?'])
|
|
18
18
|
.getResult();
|
|
@@ -28,7 +28,7 @@ export class MultiSelectActionInternal {
|
|
|
28
28
|
this.displayName = data.displayName;
|
|
29
29
|
this.action = data.action;
|
|
30
30
|
this.enabled = data.enabled ?? ((entities) => !!entities.length);
|
|
31
|
-
this.requireConfirmDialog = data.requireConfirmDialog ??
|
|
31
|
+
this.requireConfirmDialog = data.requireConfirmDialog ?? defaultFalse;
|
|
32
32
|
this.confirmDialogData = new ConfirmDialogDataBuilder(data.confirmDialogData)
|
|
33
33
|
.withDefault('text', ['Do you really want to run this action?'])
|
|
34
34
|
.getResult();
|
|
@@ -98,8 +98,8 @@ export class BaseDataInternal {
|
|
|
98
98
|
/* istanbul ignore next */
|
|
99
99
|
const data = {
|
|
100
100
|
...importActionData,
|
|
101
|
-
enabled: importActionData.enabled ??
|
|
102
|
-
requireConfirmDialog:
|
|
101
|
+
enabled: importActionData.enabled ?? defaultTrue,
|
|
102
|
+
requireConfirmDialog: defaultFalse,
|
|
103
103
|
confirmDialogData: new ConfirmDialogDataBuilder(importActionData.confirmDialogData).getResult(),
|
|
104
104
|
type: 'default'
|
|
105
105
|
};
|
|
@@ -146,6 +146,11 @@ export class TableDataBuilder extends BaseBuilder {
|
|
|
146
146
|
throw new Error(`Missing required Input data "EntityClass".
|
|
147
147
|
You can only omit this value if you can neither create, read, update or delete entities.`);
|
|
148
148
|
}
|
|
149
|
+
if (data.editData && data.baseData.defaultEdit == 'page') {
|
|
150
|
+
throw new Error(`The configured edit data can't be used, as the entity gets edited on its own page.
|
|
151
|
+
You need to provide values for the "NGX_EDIT_DATA", "NGX_EDIT_DATA_ENTITY" and "NGX_EDIT_DATA_ENTITY_SERVICE" injection keys
|
|
152
|
+
on the route where the edit page is used.`);
|
|
153
|
+
}
|
|
149
154
|
}
|
|
150
155
|
}
|
|
151
156
|
/**
|
|
@@ -165,4 +170,4 @@ export function defaultSearchFunction(entity) {
|
|
|
165
170
|
.toLowerCase();
|
|
166
171
|
return searchString;
|
|
167
172
|
}
|
|
168
|
-
//# 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":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { BaseBuilder, defaultFalse, defaultTrue } from '../../classes/base.builder';\nimport { BaseEntityType, EntityClassNewable } from '../../classes/entity.model';\nimport { EntityService } from '../../services/entity.service';\nimport { ConfirmDialogDataBuilder, ConfirmDialogDataInternal } from '../confirm-dialog/confirm-dialog-data.builder';\nimport { CreateDialogDataBuilder, CreateDialogDataInternal } from './create-dialog/create-dialog-data.builder';\nimport { EditDataInternal, EditDialogDataBuilder } from './edit-dialog/edit-data.builder';\nimport { BaseData, BaseTableAction, DisplayColumn, MultiSelectAction, TableData } from './table-data';\n\n/**\n * The internal BaseTableAction. Sets default values.\n */\nexport class BaseTableActionInternal implements BaseTableAction {\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    type: 'default' = 'default';\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    displayName: string;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    action: () => unknown;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    enabled: (() => boolean);\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    requireConfirmDialog: (() => boolean);\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    confirmDialogData: ConfirmDialogDataInternal;\n\n    constructor(data: BaseTableAction) {\n        this.displayName = data.displayName;\n        this.action = data.action;\n        this.enabled = data.enabled ?? (() => true);\n        this.requireConfirmDialog = data.requireConfirmDialog ?? (() => false);\n        this.confirmDialogData = new ConfirmDialogDataBuilder(data.confirmDialogData)\n            .withDefault('text', ['Do you really want to run this action?'])\n            .getResult();\n    }\n}\n\n/**\n * The internal BaseTableAction. Sets default values.\n */\nexport class MultiSelectActionInternal<EntityType extends BaseEntityType<EntityType>> implements MultiSelectAction<EntityType> {\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    type: 'multi-select' = 'multi-select';\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    displayName: string;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    action: (selectedEntities: EntityType[]) => unknown;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    enabled: ((selectedEntities: EntityType[]) => boolean);\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    requireConfirmDialog: ((selectedEntities: EntityType[]) => boolean);\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    confirmDialogData: ConfirmDialogDataInternal;\n\n    constructor(data: MultiSelectAction<EntityType>) {\n        this.displayName = data.displayName;\n        this.action = data.action;\n        this.enabled = data.enabled ?? ((entities: EntityType[]) => !!entities.length);\n        this.requireConfirmDialog = data.requireConfirmDialog ?? (() => false);\n        this.confirmDialogData = new ConfirmDialogDataBuilder(data.confirmDialogData)\n            .withDefault('text', ['Do you really want to run this action?'])\n            .getResult();\n    }\n}\n\n/**\n * The Internal Table Action. Sets default values.\n */\nexport type TableActionInternal<EntityType extends BaseEntityType<EntityType>> =\n    BaseTableActionInternal | MultiSelectActionInternal<EntityType>;\n\n/**\n * The internal TableData. Requires all default values the user can leave out.\n */\nexport class TableDataInternal<EntityType extends BaseEntityType<EntityType>> implements TableData<EntityType> {\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    baseData: BaseDataInternal<EntityType>;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    createDialogData: CreateDialogDataInternal;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    editData: EditDataInternal<EntityType>;\n\n    constructor(\n        baseData: BaseDataInternal<EntityType>,\n        createDialogData: CreateDialogDataInternal,\n        editDialogData: EditDataInternal<EntityType>\n    ) {\n        this.baseData = baseData;\n        this.createDialogData = createDialogData;\n        this.editData = editDialogData;\n    }\n}\n\n/**\n * The Builder for the table BaseData. Sets default values.\n */\nexport class BaseDataBuilder<EntityType extends BaseEntityType<EntityType>>\n    extends BaseBuilder<BaseDataInternal<EntityType>, BaseData<EntityType>> {\n\n    constructor(data: BaseData<EntityType>) {\n        super(data);\n    }\n\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    protected generateBaseData(data: BaseData<EntityType>): BaseDataInternal<EntityType> {\n        return new BaseDataInternal<EntityType>(data);\n    }\n}\n\n/**\n * The internal TableData. Requires all default values the user can leave out.\n */\nexport class BaseDataInternal<EntityType extends BaseEntityType<EntityType>> implements BaseData<EntityType> {\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    title: string;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    displayColumns: DisplayColumn<EntityType>[];\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    EntityServiceClass: new (httpClient: HttpClient) => EntityService<EntityType>;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    searchLabel: string;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    createButtonLabel: string;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    defaultEdit: 'dialog' | 'page';\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    searchString: (entity: EntityType) => string;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    allowCreate: () => boolean;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    allowRead: (entity?: EntityType) => boolean;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    allowUpdate: (entity?: EntityType) => boolean;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    allowDelete: (entity?: EntityType) => boolean;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    tableActions: TableActionInternal<EntityType>[];\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    tableActionsLabel: string;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    displayLoadingSpinner: boolean;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    allowJsonImport: boolean;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    importActionData: Omit<BaseTableActionInternal, 'action'>;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    EntityClass?: EntityClassNewable<EntityType>;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    edit?: (entity: EntityType) => unknown;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    create?: (entity: EntityType) => unknown;\n\n    constructor(data: BaseData<EntityType>) {\n        this.title = data.title;\n        this.displayColumns = data.displayColumns;\n        this.EntityServiceClass = data.EntityServiceClass;\n        this.EntityClass = data.EntityClass;\n        this.searchLabel = data.searchLabel ?? 'Search';\n        this.createButtonLabel = data.createButtonLabel ?? 'Create';\n        this.defaultEdit = data.defaultEdit ?? 'dialog';\n        this.searchString = data.searchString ?? defaultSearchFunction;\n        if (data.tableActions) {\n            this.tableActions = data.tableActions.map(tA => {\n                return tA.type === 'default' ? new BaseTableActionInternal(tA) : new MultiSelectActionInternal(tA);\n            });\n        }\n        else {\n            this.tableActions = [];\n        }\n        this.tableActionsLabel = data.tableActionsLabel ?? 'Actions';\n        this.displayLoadingSpinner = data.displayLoadingSpinner ?? true;\n        this.allowJsonImport = data.allowJsonImport ?? false;\n        this.importActionData = this.buildImportActionData(data.importActionData);\n        this.edit = data.edit;\n        this.create = data.create;\n        this.allowCreate = this.allowDataToFunction(data.allowCreate);\n        this.allowRead = this.allowDataToFunction(data.allowRead);\n        this.allowUpdate = this.allowDataToFunction(data.allowUpdate);\n        this.allowDelete = this.allowDataToFunction(data.allowDelete);\n    }\n\n    private buildImportActionData(\n        importActionData?: Omit<BaseTableAction, 'action' | 'requireConfirmDialog' | 'type'>\n    ): Omit<BaseTableActionInternal, 'action'> {\n        importActionData = importActionData ?? {\n            displayName: 'Import (JSON)',\n            confirmDialogData: new ConfirmDialogDataBuilder()\n                .withDefault('text', ['Do you really want to import entities from the provided file?'])\n                .getResult()\n        };\n        /* istanbul ignore next */\n        const data: Omit<BaseTableActionInternal, 'action'> = {\n            ...importActionData,\n            enabled: importActionData.enabled ?? (() => true),\n            requireConfirmDialog: () => false,\n            confirmDialogData: new ConfirmDialogDataBuilder(importActionData.confirmDialogData).getResult(),\n            type: 'default'\n        };\n        return data;\n    }\n\n    private allowDataToFunction(value?: boolean | ((entity?: EntityType) => boolean)): ((entity?: EntityType) => boolean) {\n        if (value == null) {\n            return defaultTrue;\n        }\n        if (typeof value == 'boolean') {\n            if (value) {\n                return defaultTrue;\n            }\n            return defaultFalse;\n        }\n        return value;\n    }\n}\n\n/**\n * The Builder for the complete TableData. Sets default values and validates user input.\n */\nexport class TableDataBuilder<EntityType extends BaseEntityType<EntityType>>\n    extends BaseBuilder<TableDataInternal<EntityType>, TableData<EntityType>> {\n\n    constructor(data: TableData<EntityType>) {\n        super(data);\n    }\n\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    protected generateBaseData(data: TableData<EntityType>): TableDataInternal<EntityType> {\n        const createDialogData: CreateDialogDataInternal = new CreateDialogDataBuilder(data.createDialogData).getResult();\n        const editDialogData: EditDataInternal<EntityType> = new EditDialogDataBuilder(data.editData).getResult();\n        const baseData: BaseDataInternal<EntityType> = new BaseDataBuilder(data.baseData).getResult();\n        return new TableDataInternal<EntityType>(\n            baseData,\n            createDialogData,\n            editDialogData\n        );\n    }\n\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    protected override validateInput(data: TableData<EntityType>): void {\n        if (data.baseData.tableActions?.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            !data.baseData.EntityClass\n            && (\n                data.baseData.allowCreate !== false\n                || data.baseData.allowRead !== false\n                || data.baseData.allowUpdate !== false\n                || data.baseData.allowDelete !== false\n            )\n        ) {\n            throw new Error(\n                `Missing required Input data \"EntityClass\".\n                You can only omit this value if you can neither create, read, update or delete entities.`\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 */\nexport function defaultSearchFunction<EntityType extends BaseEntityType<EntityType>>(entity: EntityType): string {\n    const searchString: string = Object.keys(entity)\n        .reduce((currentTerm: string, key: string) => {\n            return `${currentTerm}${(entity as Record<string, unknown>)[key]}◬`;\n        }, '')\n        .toLowerCase();\n    return searchString;\n}"]}
|
|
173
|
+
//# 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":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { BaseBuilder, defaultFalse, defaultTrue } from '../../classes/base.builder';\nimport { BaseEntityType, EntityClassNewable } from '../../classes/entity.model';\nimport { EntityService } from '../../services/entity.service';\nimport { ConfirmDialogDataBuilder, ConfirmDialogDataInternal } from '../confirm-dialog/confirm-dialog-data.builder';\nimport { CreateDialogDataBuilder, CreateDialogDataInternal } from './create-dialog/create-dialog-data.builder';\nimport { EditDataInternal, EditDialogDataBuilder } from './edit-dialog/edit-data.builder';\nimport { BaseData, BaseTableAction, DisplayColumn, MultiSelectAction, TableData } from './table-data';\n\n/**\n * The internal BaseTableAction. Sets default values.\n */\nexport class BaseTableActionInternal implements BaseTableAction {\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    type: 'default' = 'default';\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    displayName: string;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    action: () => unknown;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    enabled: (() => boolean);\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    requireConfirmDialog: (() => boolean);\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    confirmDialogData: ConfirmDialogDataInternal;\n\n    constructor(data: BaseTableAction) {\n        this.displayName = data.displayName;\n        this.action = data.action;\n        this.enabled = data.enabled ?? defaultTrue;\n        this.requireConfirmDialog = data.requireConfirmDialog ?? defaultFalse;\n        this.confirmDialogData = new ConfirmDialogDataBuilder(data.confirmDialogData)\n            .withDefault('text', ['Do you really want to run this action?'])\n            .getResult();\n    }\n}\n\n/**\n * The internal BaseTableAction. Sets default values.\n */\nexport class MultiSelectActionInternal<EntityType extends BaseEntityType<EntityType>> implements MultiSelectAction<EntityType> {\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    type: 'multi-select' = 'multi-select';\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    displayName: string;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    action: (selectedEntities: EntityType[]) => unknown;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    enabled: ((selectedEntities: EntityType[]) => boolean);\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    requireConfirmDialog: ((selectedEntities: EntityType[]) => boolean);\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    confirmDialogData: ConfirmDialogDataInternal;\n\n    constructor(data: MultiSelectAction<EntityType>) {\n        this.displayName = data.displayName;\n        this.action = data.action;\n        this.enabled = data.enabled ?? ((entities: EntityType[]) => !!entities.length);\n        this.requireConfirmDialog = data.requireConfirmDialog ?? defaultFalse;\n        this.confirmDialogData = new ConfirmDialogDataBuilder(data.confirmDialogData)\n            .withDefault('text', ['Do you really want to run this action?'])\n            .getResult();\n    }\n}\n\n/**\n * The Internal Table Action. Sets default values.\n */\nexport type TableActionInternal<EntityType extends BaseEntityType<EntityType>> =\n    BaseTableActionInternal | MultiSelectActionInternal<EntityType>;\n\n/**\n * The internal TableData. Requires all default values the user can leave out.\n */\nexport class TableDataInternal<EntityType extends BaseEntityType<EntityType>> implements TableData<EntityType> {\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    baseData: BaseDataInternal<EntityType>;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    createDialogData: CreateDialogDataInternal;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    editData: EditDataInternal<EntityType>;\n\n    constructor(\n        baseData: BaseDataInternal<EntityType>,\n        createDialogData: CreateDialogDataInternal,\n        editDialogData: EditDataInternal<EntityType>\n    ) {\n        this.baseData = baseData;\n        this.createDialogData = createDialogData;\n        this.editData = editDialogData;\n    }\n}\n\n/**\n * The Builder for the table BaseData. Sets default values.\n */\nexport class BaseDataBuilder<EntityType extends BaseEntityType<EntityType>>\n    extends BaseBuilder<BaseDataInternal<EntityType>, BaseData<EntityType>> {\n\n    constructor(data: BaseData<EntityType>) {\n        super(data);\n    }\n\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    protected generateBaseData(data: BaseData<EntityType>): BaseDataInternal<EntityType> {\n        return new BaseDataInternal<EntityType>(data);\n    }\n}\n\n/**\n * The internal TableData. Requires all default values the user can leave out.\n */\nexport class BaseDataInternal<EntityType extends BaseEntityType<EntityType>> implements BaseData<EntityType> {\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    title: string;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    displayColumns: DisplayColumn<EntityType>[];\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    EntityServiceClass: new (httpClient: HttpClient) => EntityService<EntityType>;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    searchLabel: string;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    createButtonLabel: string;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    defaultEdit: 'dialog' | 'page';\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    searchString: (entity: EntityType) => string;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    allowCreate: () => boolean;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    allowRead: (entity?: EntityType) => boolean;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    allowUpdate: (entity?: EntityType) => boolean;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    allowDelete: (entity?: EntityType) => boolean;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    tableActions: TableActionInternal<EntityType>[];\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    tableActionsLabel: string;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    displayLoadingSpinner: boolean;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    allowJsonImport: boolean;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    importActionData: Omit<BaseTableActionInternal, 'action'>;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    EntityClass?: EntityClassNewable<EntityType>;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    edit?: (entity: EntityType) => unknown;\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    create?: (entity: EntityType) => unknown;\n\n    constructor(data: BaseData<EntityType>) {\n        this.title = data.title;\n        this.displayColumns = data.displayColumns;\n        this.EntityServiceClass = data.EntityServiceClass;\n        this.EntityClass = data.EntityClass;\n        this.searchLabel = data.searchLabel ?? 'Search';\n        this.createButtonLabel = data.createButtonLabel ?? 'Create';\n        this.defaultEdit = data.defaultEdit ?? 'dialog';\n        this.searchString = data.searchString ?? defaultSearchFunction;\n        if (data.tableActions) {\n            this.tableActions = data.tableActions.map(tA => {\n                return tA.type === 'default' ? new BaseTableActionInternal(tA) : new MultiSelectActionInternal(tA);\n            });\n        }\n        else {\n            this.tableActions = [];\n        }\n        this.tableActionsLabel = data.tableActionsLabel ?? 'Actions';\n        this.displayLoadingSpinner = data.displayLoadingSpinner ?? true;\n        this.allowJsonImport = data.allowJsonImport ?? false;\n        this.importActionData = this.buildImportActionData(data.importActionData);\n        this.edit = data.edit;\n        this.create = data.create;\n        this.allowCreate = this.allowDataToFunction(data.allowCreate);\n        this.allowRead = this.allowDataToFunction(data.allowRead);\n        this.allowUpdate = this.allowDataToFunction(data.allowUpdate);\n        this.allowDelete = this.allowDataToFunction(data.allowDelete);\n    }\n\n    private buildImportActionData(\n        importActionData?: Omit<BaseTableAction, 'action' | 'requireConfirmDialog' | 'type'>\n    ): Omit<BaseTableActionInternal, 'action'> {\n        importActionData = importActionData ?? {\n            displayName: 'Import (JSON)',\n            confirmDialogData: new ConfirmDialogDataBuilder()\n                .withDefault('text', ['Do you really want to import entities from the provided file?'])\n                .getResult()\n        };\n        /* istanbul ignore next */\n        const data: Omit<BaseTableActionInternal, 'action'> = {\n            ...importActionData,\n            enabled: importActionData.enabled ?? defaultTrue,\n            requireConfirmDialog: defaultFalse,\n            confirmDialogData: new ConfirmDialogDataBuilder(importActionData.confirmDialogData).getResult(),\n            type: 'default'\n        };\n        return data;\n    }\n\n    private allowDataToFunction(value?: boolean | ((entity?: EntityType) => boolean)): ((entity?: EntityType) => boolean) {\n        if (value == null) {\n            return defaultTrue;\n        }\n        if (typeof value == 'boolean') {\n            if (value) {\n                return defaultTrue;\n            }\n            return defaultFalse;\n        }\n        return value;\n    }\n}\n\n/**\n * The Builder for the complete TableData. Sets default values and validates user input.\n */\nexport class TableDataBuilder<EntityType extends BaseEntityType<EntityType>>\n    extends BaseBuilder<TableDataInternal<EntityType>, TableData<EntityType>> {\n\n    constructor(data: TableData<EntityType>) {\n        super(data);\n    }\n\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    protected generateBaseData(data: TableData<EntityType>): TableDataInternal<EntityType> {\n        const createDialogData: CreateDialogDataInternal = new CreateDialogDataBuilder(data.createDialogData).getResult();\n        const editDialogData: EditDataInternal<EntityType> = new EditDialogDataBuilder(data.editData).getResult();\n        const baseData: BaseDataInternal<EntityType> = new BaseDataBuilder(data.baseData).getResult();\n        return new TableDataInternal<EntityType>(\n            baseData,\n            createDialogData,\n            editDialogData\n        );\n    }\n\n    // eslint-disable-next-line jsdoc/require-jsdoc\n    protected override validateInput(data: TableData<EntityType>): void {\n        if (data.baseData.tableActions?.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            !data.baseData.EntityClass\n            && (\n                data.baseData.allowCreate !== false\n                || data.baseData.allowRead !== false\n                || data.baseData.allowUpdate !== false\n                || data.baseData.allowDelete !== false\n            )\n        ) {\n            throw new Error(\n                `Missing required Input data \"EntityClass\".\n                You can only omit this value if you can neither create, read, update or delete entities.`\n            );\n        }\n        if (data.editData && data.baseData.defaultEdit == 'page') {\n            throw new Error(\n                `The configured edit data can't be used, as the entity gets edited on its own page.\n                You need to provide values for the \"NGX_EDIT_DATA\", \"NGX_EDIT_DATA_ENTITY\" and \"NGX_EDIT_DATA_ENTITY_SERVICE\" injection keys\n                on the route where the edit page is used.`\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 */\nexport function defaultSearchFunction<EntityType extends BaseEntityType<EntityType>>(entity: EntityType): string {\n    const searchString: string = Object.keys(entity)\n        .reduce((currentTerm: string, key: string) => {\n            return `${currentTerm}${(entity as Record<string, unknown>)[key]}◬`;\n        }, '')\n        .toLowerCase();\n    return searchString;\n}"]}
|