ngx-material-entity 16.0.2 → 16.0.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/classes/base.builder.d.ts +6 -1
- package/components/confirm-dialog/confirm-dialog-data.builder.d.ts +2 -1
- package/components/confirm-dialog/confirm-dialog.component.d.ts +3 -1
- package/components/edit-page/edit-page.component.d.ts +15 -2
- package/components/edit-page/page-edit-data.builder.d.ts +2 -1
- package/components/input/array/array-date-input/array-date-input.component.d.ts +7 -1
- package/components/input/array/array-date-range-input/array-date-range-input.component.d.ts +6 -1
- package/components/input/array/array-date-time-input/array-date-time-input.component.d.ts +6 -1
- package/components/input/boolean/boolean-checkbox-input/boolean-checkbox-input.component.d.ts +1 -0
- package/components/input/boolean/boolean-dropdown-input/boolean-dropdown-input.component.d.ts +4 -0
- package/components/input/boolean/boolean-toggle-input/boolean-toggle-input.component.d.ts +2 -1
- package/components/input/date/date-range-input/date-range-input.component.d.ts +3 -0
- package/components/input/date/date-time-input/date-time-input.component.d.ts +3 -0
- package/components/input/input.component.d.ts +10 -3
- package/components/input/input.module.d.ts +6 -2
- package/components/input/number/number-slider-input/number-slider-input.component.d.ts +2 -1
- package/components/input/relations/references-many-input/references-many-input.component.d.ts +3 -1
- package/components/table/create-dialog/create-dialog-data.builder.d.ts +2 -1
- package/components/table/create-dialog/create-entity-dialog-data.builder.d.ts +2 -1
- package/components/table/create-dialog/create-entity-dialog.component.d.ts +6 -1
- package/components/table/edit-dialog/edit-data.builder.d.ts +5 -3
- package/components/table/edit-dialog/edit-entity-dialog.component.d.ts +7 -1
- package/components/table/edit-dialog/edit-entity.builder.d.ts +2 -1
- package/components/table/table-data.builder.d.ts +9 -5
- package/components/table/table.component.d.ts +3 -1
- package/components/tooltip/tooltip.component.d.ts +9 -0
- package/decorators/array/array-decorator-internal.data.d.ts +14 -13
- package/decorators/array/array-decorator.data.d.ts +7 -7
- package/decorators/base/property-decorator-internal.data.d.ts +11 -2
- package/decorators/base/property-decorator.data.d.ts +9 -1
- package/decorators/boolean/boolean-decorator-internal.data.d.ts +5 -4
- package/decorators/boolean/boolean-decorator.data.d.ts +1 -1
- package/decorators/custom/custom-decorator-internal.data.d.ts +2 -2
- package/decorators/custom/custom-decorator.data.d.ts +4 -4
- package/decorators/date/date-decorator-internal.data.d.ts +7 -6
- package/decorators/date/date-decorator.data.d.ts +5 -5
- package/decorators/file/file-decorator-internal.data.d.ts +3 -3
- package/decorators/file/file-decorator.data.d.ts +1 -1
- package/decorators/has-many/has-many-decorator-internal.data.d.ts +3 -2
- package/decorators/has-many/has-many-decorator.data.d.ts +1 -1
- package/decorators/number/number-decorator-internal.data.d.ts +3 -3
- package/decorators/number/number-decorator.data.d.ts +1 -1
- package/decorators/object/object-decorator-internal.data.d.ts +1 -1
- package/decorators/object/object-decorator.data.d.ts +1 -1
- package/decorators/references-many/references-many-decorator-internal.data.d.ts +3 -2
- package/decorators/references-many/references-many-decorator.data.d.ts +1 -1
- package/decorators/references-one/references-one-decorator-internal.data.d.ts +1 -1
- package/decorators/references-one/references-one-decorator.data.d.ts +1 -1
- package/decorators/string/string-decorator-internal.data.d.ts +5 -6
- package/decorators/string/string-decorator.data.d.ts +1 -7
- package/default-global-configuration-values.d.ts +6 -0
- package/directives/number.directive.d.ts +17 -0
- package/directives/password-match.directive.d.ts +14 -0
- package/directives/tooltip.directive.d.ts +32 -0
- package/esm2022/classes/base.builder.mjs +9 -3
- package/esm2022/components/confirm-dialog/confirm-dialog-data.builder.mjs +7 -5
- package/esm2022/components/confirm-dialog/confirm-dialog.component.mjs +13 -7
- package/esm2022/components/edit-page/edit-page.component.mjs +75 -25
- package/esm2022/components/edit-page/page-edit-data.builder.mjs +9 -9
- package/esm2022/components/input/array/array-date-input/array-date-input.component.mjs +33 -13
- package/esm2022/components/input/array/array-date-range-input/array-date-range-input.component.mjs +29 -12
- package/esm2022/components/input/array/array-date-time-input/array-date-time-input.component.mjs +32 -15
- package/esm2022/components/input/base-input.component.mjs +2 -1
- package/esm2022/components/input/boolean/boolean-checkbox-input/boolean-checkbox-input.component.mjs +6 -3
- package/esm2022/components/input/boolean/boolean-dropdown-input/boolean-dropdown-input.component.mjs +18 -4
- package/esm2022/components/input/boolean/boolean-toggle-input/boolean-toggle-input.component.mjs +6 -3
- package/esm2022/components/input/date/date-range-input/date-range-input.component.mjs +18 -4
- package/esm2022/components/input/date/date-time-input/date-time-input.component.mjs +17 -5
- package/esm2022/components/input/file/file-image-input/file-image-input.component.mjs +3 -3
- package/esm2022/components/input/file/file-input/file-input.component.mjs +1 -1
- package/esm2022/components/input/input.component.mjs +91 -61
- package/esm2022/components/input/input.module.mjs +18 -5
- package/esm2022/components/input/number/number-input/number-input.component.mjs +4 -3
- package/esm2022/components/input/number/number-slider-input/number-slider-input.component.mjs +6 -3
- package/esm2022/components/input/relations/references-many-input/references-many-input.component.mjs +15 -5
- package/esm2022/components/input/string/string-password-input/string-password-input.component.mjs +4 -3
- package/esm2022/components/table/create-dialog/create-dialog-data.builder.mjs +10 -8
- package/esm2022/components/table/create-dialog/create-entity-dialog-data.builder.mjs +5 -4
- package/esm2022/components/table/create-dialog/create-entity-dialog.component.mjs +32 -14
- package/esm2022/components/table/edit-dialog/edit-data.builder.mjs +35 -21
- package/esm2022/components/table/edit-dialog/edit-entity-dialog.component.mjs +46 -25
- package/esm2022/components/table/edit-dialog/edit-entity.builder.mjs +4 -4
- package/esm2022/components/table/table-data.builder.mjs +54 -30
- package/esm2022/components/table/table.component.mjs +24 -15
- package/esm2022/components/tooltip/tooltip.component.mjs +20 -0
- package/esm2022/decorators/array/array-decorator-internal.data.mjs +42 -43
- package/esm2022/decorators/array/array-decorator.data.mjs +1 -1
- package/esm2022/decorators/array/array.decorator.mjs +8 -7
- package/esm2022/decorators/base/property-decorator-internal.data.mjs +25 -4
- package/esm2022/decorators/base/property-decorator.data.mjs +10 -1
- package/esm2022/decorators/boolean/boolean-decorator-internal.data.mjs +5 -4
- package/esm2022/decorators/boolean/boolean-decorator.data.mjs +1 -1
- package/esm2022/decorators/boolean/boolean.decorator.mjs +3 -2
- package/esm2022/decorators/custom/custom-decorator-internal.data.mjs +2 -2
- package/esm2022/decorators/custom/custom-decorator.data.mjs +1 -1
- package/esm2022/decorators/date/date-decorator-internal.data.mjs +8 -6
- package/esm2022/decorators/date/date-decorator.data.mjs +1 -1
- package/esm2022/decorators/date/date.decorator.mjs +4 -3
- package/esm2022/decorators/file/file-decorator-internal.data.mjs +1 -1
- package/esm2022/decorators/file/file-decorator.data.mjs +1 -1
- package/esm2022/decorators/has-many/has-many-decorator-internal.data.mjs +4 -4
- package/esm2022/decorators/has-many/has-many-decorator.data.mjs +1 -1
- package/esm2022/decorators/has-many/has-many.decorator.mjs +3 -2
- package/esm2022/decorators/number/number-decorator-internal.data.mjs +1 -1
- package/esm2022/decorators/number/number-decorator.data.mjs +1 -1
- package/esm2022/decorators/object/object-decorator-internal.data.mjs +1 -1
- package/esm2022/decorators/object/object-decorator.data.mjs +1 -1
- package/esm2022/decorators/references-many/references-many-decorator-internal.data.mjs +7 -6
- package/esm2022/decorators/references-many/references-many-decorator.data.mjs +1 -1
- package/esm2022/decorators/references-many/references-many.decorator.mjs +3 -2
- package/esm2022/decorators/references-one/references-one-decorator-internal.data.mjs +1 -1
- package/esm2022/decorators/references-one/references-one-decorator.data.mjs +1 -1
- package/esm2022/decorators/string/string-decorator-internal.data.mjs +1 -4
- package/esm2022/decorators/string/string-decorator.data.mjs +1 -1
- package/esm2022/default-global-configuration-values.mjs +89 -0
- package/esm2022/directives/drag-drop.directive.mjs +62 -0
- package/esm2022/directives/number.directive.mjs +38 -0
- package/esm2022/directives/password-match.directive.mjs +30 -0
- package/esm2022/directives/tooltip.directive.mjs +106 -0
- package/esm2022/functions/get-config-value.function.mjs +15 -0
- package/esm2022/functions/get-validation-error-message.function.mjs +49 -0
- package/esm2022/functions/get-validation-errors-tooltip-content.function.ts.mjs +21 -0
- package/esm2022/global-configuration-values.mjs +10 -0
- package/esm2022/public-api.mjs +8 -2
- package/esm2022/utilities/entity.utilities.mjs +80 -405
- package/esm2022/utilities/validation.utilities.mjs +455 -0
- package/fesm2022/ngx-material-entity.mjs +2119 -1412
- package/fesm2022/ngx-material-entity.mjs.map +1 -1
- package/functions/get-config-value.function.d.ts +8 -0
- package/functions/get-validation-errors-tooltip-content.function.ts.d.ts +10 -0
- package/global-configuration-values.d.ts +216 -0
- package/package.json +1 -1
- package/public-api.d.ts +5 -1
- package/utilities/entity.utilities.d.ts +30 -34
- package/utilities/validation.utilities.d.ts +56 -0
- package/esm2022/components/get-validation-error-message.function.mjs +0 -42
- package/esm2022/components/input/file/file-input/dragDrop.directive.mjs +0 -62
- /package/{components/input/file/file-input/dragDrop.directive.d.ts → directives/drag-drop.directive.d.ts} +0 -0
- /package/{components → functions}/get-validation-error-message.function.d.ts +0 -0
|
@@ -1,13 +1,18 @@
|
|
|
1
1
|
import { NgFor, NgIf } from '@angular/common';
|
|
2
|
-
import { Component, Inject, Injector } from '@angular/core';
|
|
2
|
+
import { Component, Inject, Injector, runInInjectionContext } from '@angular/core';
|
|
3
3
|
import { FormsModule } from '@angular/forms';
|
|
4
|
+
import { MatBadgeModule } from '@angular/material/badge';
|
|
4
5
|
import { MatButtonModule } from '@angular/material/button';
|
|
5
6
|
import { MAT_DIALOG_DATA, MatDialog, MatDialogModule, MatDialogRef } from '@angular/material/dialog';
|
|
6
7
|
import { MatTabsModule } from '@angular/material/tabs';
|
|
8
|
+
import { NGX_INTERNAL_GLOBAL_DEFAULT_VALUES } from '../../../default-global-configuration-values';
|
|
9
|
+
import { getValidationErrorsTooltipContent } from '../../../functions/get-validation-errors-tooltip-content.function.ts';
|
|
7
10
|
import { EntityUtilities } from '../../../utilities/entity.utilities';
|
|
11
|
+
import { ValidationUtilities } from '../../../utilities/validation.utilities';
|
|
8
12
|
import { ConfirmDialogDataBuilder } from '../../confirm-dialog/confirm-dialog-data.builder';
|
|
9
13
|
import { NgxMatEntityConfirmDialogComponent } from '../../confirm-dialog/confirm-dialog.component';
|
|
10
14
|
import { NgxMatEntityInputModule } from '../../input/input.module';
|
|
15
|
+
import { TooltipComponent } from '../../tooltip/tooltip.component';
|
|
11
16
|
import { CreateEntityDialogDataBuilder } from './create-entity-dialog-data.builder';
|
|
12
17
|
import * as i0 from "@angular/core";
|
|
13
18
|
import * as i1 from "@angular/material/dialog";
|
|
@@ -15,6 +20,7 @@ import * as i2 from "../../input/input.component";
|
|
|
15
20
|
import * as i3 from "@angular/forms";
|
|
16
21
|
import * as i4 from "@angular/material/button";
|
|
17
22
|
import * as i5 from "@angular/material/tabs";
|
|
23
|
+
import * as i6 from "@angular/material/badge";
|
|
18
24
|
/**
|
|
19
25
|
* The default dialog used to create new entities based on the configuration passed in the MAT_DIALOG_DATA "inputData".
|
|
20
26
|
* Used by the ngx-mat-entity-table.
|
|
@@ -26,28 +32,35 @@ export class NgxMatEntityCreateDialogComponent {
|
|
|
26
32
|
dialogRef;
|
|
27
33
|
injector;
|
|
28
34
|
dialog;
|
|
35
|
+
globalConfig;
|
|
29
36
|
EntityUtilities = EntityUtilities;
|
|
30
37
|
entityTabs;
|
|
31
38
|
entityService;
|
|
32
39
|
data;
|
|
33
40
|
isEntityValid = false;
|
|
34
|
-
|
|
41
|
+
validationErrors = [];
|
|
42
|
+
tooltipContent = '';
|
|
43
|
+
constructor(inputData, dialogRef, injector, dialog, globalConfig) {
|
|
35
44
|
this.inputData = inputData;
|
|
36
45
|
this.dialogRef = dialogRef;
|
|
37
46
|
this.injector = injector;
|
|
38
47
|
this.dialog = dialog;
|
|
48
|
+
this.globalConfig = globalConfig;
|
|
39
49
|
}
|
|
40
50
|
ngOnInit() {
|
|
41
|
-
this.data = new CreateEntityDialogDataBuilder(this.inputData).getResult();
|
|
51
|
+
this.data = new CreateEntityDialogDataBuilder(this.inputData, this.globalConfig).getResult();
|
|
42
52
|
this.dialogRef.disableClose = true;
|
|
43
53
|
this.entityTabs = EntityUtilities.getEntityTabs(this.data.entity, true);
|
|
44
54
|
this.entityService = this.injector.get(this.data.EntityServiceClass);
|
|
55
|
+
setTimeout(() => this.checkIsEntityValid(), 1);
|
|
45
56
|
}
|
|
46
57
|
/**
|
|
47
58
|
* Checks if the entity is valid.
|
|
48
59
|
*/
|
|
49
60
|
checkIsEntityValid() {
|
|
50
|
-
this.
|
|
61
|
+
this.validationErrors = ValidationUtilities.getEntityValidationErrors(this.data.entity, 'create');
|
|
62
|
+
this.tooltipContent = runInInjectionContext(this.injector, () => getValidationErrorsTooltipContent(this.validationErrors));
|
|
63
|
+
this.isEntityValid = this.validationErrors.length === 0;
|
|
51
64
|
}
|
|
52
65
|
/**
|
|
53
66
|
* Tries add the new entity and close the dialog afterwards.
|
|
@@ -61,10 +74,10 @@ export class NgxMatEntityCreateDialogComponent {
|
|
|
61
74
|
this.confirmCreate();
|
|
62
75
|
return;
|
|
63
76
|
}
|
|
64
|
-
const dialogData = new ConfirmDialogDataBuilder(this.data.createDialogData.confirmCreateDialogData)
|
|
65
|
-
.withDefault('text',
|
|
66
|
-
.withDefault('confirmButtonLabel',
|
|
67
|
-
.withDefault('title',
|
|
77
|
+
const dialogData = new ConfirmDialogDataBuilder(this.globalConfig, this.data.createDialogData.confirmCreateDialogData)
|
|
78
|
+
.withDefault('text', this.globalConfig.confirmCreateText)
|
|
79
|
+
.withDefault('confirmButtonLabel', this.globalConfig.createLabel)
|
|
80
|
+
.withDefault('title', this.globalConfig.createLabel)
|
|
68
81
|
.getResult();
|
|
69
82
|
const dialogRef = this.dialog.open(NgxMatEntityConfirmDialogComponent, {
|
|
70
83
|
data: dialogData,
|
|
@@ -86,8 +99,8 @@ export class NgxMatEntityCreateDialogComponent {
|
|
|
86
99
|
cancel() {
|
|
87
100
|
this.dialogRef.close();
|
|
88
101
|
}
|
|
89
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: NgxMatEntityCreateDialogComponent, deps: [{ token: MAT_DIALOG_DATA }, { token: i1.MatDialogRef }, { token: i0.Injector }, { token: i1.MatDialog }], target: i0.ɵɵFactoryTarget.Component });
|
|
90
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.0", 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
|
|
102
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: NgxMatEntityCreateDialogComponent, deps: [{ token: MAT_DIALOG_DATA }, { token: i1.MatDialogRef }, { token: i0.Injector }, { token: i1.MatDialog }, { token: NGX_INTERNAL_GLOBAL_DEFAULT_VALUES }], target: i0.ɵɵFactoryTarget.Component });
|
|
103
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.0", 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\n <div class=\"d-flex align-items-center gap-3\" style=\"margin-top: 10px;\">\n <button type=\"submit\" (click)=\"create()\" mat-raised-button\n [disabled]=\"!isEntityValid\"\n [matBadge]=\"validationErrors.length\"\n [matBadgeHidden]=\"!validationErrors.length\"\n matBadgeColor=\"warn\"\n >\n {{data.createDialogData.createButtonLabel}}\n </button>\n <ngx-mat-entity-tooltip *ngIf=\"validationErrors.length\" [tooltipContent]=\"tooltipContent\"></ngx-mat-entity-tooltip>\n </div>\n\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"] }, { kind: "ngmodule", type: MatBadgeModule }, { kind: "directive", type: i6.MatBadge, selector: "[matBadge]", inputs: ["matBadgeDisabled", "matBadgeColor", "matBadgeOverlap", "matBadgePosition", "matBadge", "matBadgeDescription", "matBadgeSize", "matBadgeHidden"] }, { kind: "component", type: TooltipComponent, selector: "ngx-mat-entity-tooltip", inputs: ["tooltipContent"] }] });
|
|
91
104
|
}
|
|
92
105
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: NgxMatEntityCreateDialogComponent, decorators: [{
|
|
93
106
|
type: Component,
|
|
@@ -98,10 +111,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImpor
|
|
|
98
111
|
MatDialogModule,
|
|
99
112
|
FormsModule,
|
|
100
113
|
MatButtonModule,
|
|
101
|
-
MatTabsModule
|
|
102
|
-
|
|
114
|
+
MatTabsModule,
|
|
115
|
+
MatBadgeModule,
|
|
116
|
+
TooltipComponent
|
|
117
|
+
], 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\n <div class=\"d-flex align-items-center gap-3\" style=\"margin-top: 10px;\">\n <button type=\"submit\" (click)=\"create()\" mat-raised-button\n [disabled]=\"!isEntityValid\"\n [matBadge]=\"validationErrors.length\"\n [matBadgeHidden]=\"!validationErrors.length\"\n matBadgeColor=\"warn\"\n >\n {{data.createDialogData.createButtonLabel}}\n </button>\n <ngx-mat-entity-tooltip *ngIf=\"validationErrors.length\" [tooltipContent]=\"tooltipContent\"></ngx-mat-entity-tooltip>\n </div>\n\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"] }]
|
|
103
118
|
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
104
119
|
type: Inject,
|
|
105
120
|
args: [MAT_DIALOG_DATA]
|
|
106
|
-
}] }, { type: i1.MatDialogRef }, { type: i0.Injector }, { type: i1.MatDialog }
|
|
107
|
-
//# 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"]}
|
|
121
|
+
}] }, { type: i1.MatDialogRef }, { type: i0.Injector }, { type: i1.MatDialog }, { type: undefined, decorators: [{
|
|
122
|
+
type: Inject,
|
|
123
|
+
args: [NGX_INTERNAL_GLOBAL_DEFAULT_VALUES]
|
|
124
|
+
}] }]; } });
|
|
125
|
+
//# 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, runInInjectionContext } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { MatBadgeModule } from '@angular/material/badge';\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 { NGX_INTERNAL_GLOBAL_DEFAULT_VALUES } from '../../../default-global-configuration-values';\nimport { getValidationErrorsTooltipContent } from '../../../functions/get-validation-errors-tooltip-content.function.ts';\nimport { NgxGlobalDefaultValues } from '../../../global-configuration-values';\nimport { EntityService } from '../../../services/entity.service';\nimport { EntityTab, EntityUtilities } from '../../../utilities/entity.utilities';\nimport { ValidationError, ValidationUtilities } from '../../../utilities/validation.utilities';\nimport { ConfirmDialogDataBuilder, ConfirmDialogDataInternal } from '../../confirm-dialog/confirm-dialog-data.builder';\nimport { NgxMatEntityConfirmDialogComponent } from '../../confirm-dialog/confirm-dialog.component';\nimport { NgxMatEntityInputModule } from '../../input/input.module';\nimport { TooltipComponent } from '../../tooltip/tooltip.component';\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        MatBadgeModule,\n        TooltipComponent\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    validationErrors: ValidationError[] = [];\n    tooltipContent: string = '';\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        @Inject(NGX_INTERNAL_GLOBAL_DEFAULT_VALUES)\n        protected readonly globalConfig: NgxGlobalDefaultValues\n    ) {}\n\n    ngOnInit(): void {\n        this.data = new CreateEntityDialogDataBuilder(this.inputData, this.globalConfig).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        setTimeout(() => this.checkIsEntityValid(), 1);\n    }\n\n    /**\n     * Checks if the entity is valid.\n     */\n    checkIsEntityValid(): void {\n        this.validationErrors = ValidationUtilities.getEntityValidationErrors(this.data.entity, 'create');\n        this.tooltipContent = runInInjectionContext(this.injector, () => getValidationErrorsTooltipContent(this.validationErrors));\n        this.isEntityValid = this.validationErrors.length === 0;\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(\n            this.globalConfig,\n            this.data.createDialogData.confirmCreateDialogData\n        )\n            .withDefault('text', this.globalConfig.confirmCreateText)\n            .withDefault('confirmButtonLabel', this.globalConfig.createLabel)\n            .withDefault('title', this.globalConfig.createLabel)\n            .getResult();\n        const dialogRef: MatDialogRef<NgxMatEntityConfirmDialogComponent, boolean> = this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n            data: dialogData,\n            autoFocus: false,\n            restoreFocus: false\n        });\n        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\n        <div class=\"d-flex align-items-center gap-3\" style=\"margin-top: 10px;\">\n            <button type=\"submit\" (click)=\"create()\" mat-raised-button\n                [disabled]=\"!isEntityValid\"\n                [matBadge]=\"validationErrors.length\"\n                [matBadgeHidden]=\"!validationErrors.length\"\n                matBadgeColor=\"warn\"\n            >\n                {{data.createDialogData.createButtonLabel}}\n            </button>\n            <ngx-mat-entity-tooltip *ngIf=\"validationErrors.length\" [tooltipContent]=\"tooltipContent\"></ngx-mat-entity-tooltip>\n        </div>\n\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,13 +1,18 @@
|
|
|
1
|
+
import { __decorate, __metadata, __param } from "tslib";
|
|
2
|
+
import { Inject } from '@angular/core';
|
|
1
3
|
import { BaseBuilder } from '../../../classes/base.builder';
|
|
4
|
+
import { NGX_INTERNAL_GLOBAL_DEFAULT_VALUES } from '../../../default-global-configuration-values';
|
|
2
5
|
import { defaultFalse } from '../../../functions/default-false.function';
|
|
3
6
|
import { defaultTrue } from '../../../functions/default-true.function';
|
|
7
|
+
import { getConfigValue } from '../../../functions/get-config-value.function';
|
|
4
8
|
import { isAsyncFunction } from '../../../functions/is-async-function.function';
|
|
5
9
|
import { ConfirmDialogDataBuilder } from '../../confirm-dialog/confirm-dialog-data.builder';
|
|
6
10
|
/**
|
|
7
11
|
* The internal edit action.
|
|
8
12
|
* Sets default values.
|
|
9
13
|
*/
|
|
10
|
-
export class EditActionInternal {
|
|
14
|
+
export let EditActionInternal = class EditActionInternal {
|
|
15
|
+
globalConfig;
|
|
11
16
|
// eslint-disable-next-line jsdoc/require-jsdoc
|
|
12
17
|
displayName;
|
|
13
18
|
// eslint-disable-next-line jsdoc/require-jsdoc
|
|
@@ -18,13 +23,14 @@ export class EditActionInternal {
|
|
|
18
23
|
requireConfirmDialog;
|
|
19
24
|
// eslint-disable-next-line jsdoc/require-jsdoc
|
|
20
25
|
confirmDialogData;
|
|
21
|
-
constructor(data) {
|
|
26
|
+
constructor(data, globalConfig) {
|
|
27
|
+
this.globalConfig = globalConfig;
|
|
22
28
|
this.displayName = data.displayName;
|
|
23
29
|
this.action = this.functionToAsync(data.action);
|
|
24
30
|
this.enabled = data.enabled ?? defaultTrue;
|
|
25
31
|
this.requireConfirmDialog = data.requireConfirmDialog ?? defaultFalse;
|
|
26
|
-
this.confirmDialogData = new ConfirmDialogDataBuilder(data.confirmDialogData)
|
|
27
|
-
.withDefault('text',
|
|
32
|
+
this.confirmDialogData = new ConfirmDialogDataBuilder(this.globalConfig, data.confirmDialogData)
|
|
33
|
+
.withDefault('text', globalConfig.confirmBaseActionText)
|
|
28
34
|
.getResult();
|
|
29
35
|
}
|
|
30
36
|
// eslint-disable-next-line max-len
|
|
@@ -42,11 +48,15 @@ export class EditActionInternal {
|
|
|
42
48
|
}
|
|
43
49
|
});
|
|
44
50
|
}
|
|
45
|
-
}
|
|
51
|
+
};
|
|
52
|
+
EditActionInternal = __decorate([
|
|
53
|
+
__param(1, Inject(NGX_INTERNAL_GLOBAL_DEFAULT_VALUES)),
|
|
54
|
+
__metadata("design:paramtypes", [Object, Object])
|
|
55
|
+
], EditActionInternal);
|
|
46
56
|
/**
|
|
47
57
|
* The internal EditData. Requires all default values the user can leave out.
|
|
48
58
|
*/
|
|
49
|
-
export class EditDataInternal {
|
|
59
|
+
export let EditDataInternal = class EditDataInternal {
|
|
50
60
|
// eslint-disable-next-line jsdoc/require-jsdoc
|
|
51
61
|
title;
|
|
52
62
|
// eslint-disable-next-line jsdoc/require-jsdoc
|
|
@@ -67,7 +77,7 @@ export class EditDataInternal {
|
|
|
67
77
|
actionsLabel;
|
|
68
78
|
// eslint-disable-next-line jsdoc/require-jsdoc
|
|
69
79
|
actions;
|
|
70
|
-
constructor(title, confirmButtonLabel, deleteButtonLabel, cancelButtonLabel, deleteRequiresConfirmDialog, editRequiresConfirmDialog, confirmDeleteDialogData, confirmEditDialogData, actionsLabel, actions) {
|
|
80
|
+
constructor(title, confirmButtonLabel, deleteButtonLabel, cancelButtonLabel, deleteRequiresConfirmDialog, editRequiresConfirmDialog, confirmDeleteDialogData, confirmEditDialogData, actionsLabel, actions, globalConfig) {
|
|
71
81
|
this.title = title;
|
|
72
82
|
this.confirmButtonLabel = confirmButtonLabel;
|
|
73
83
|
this.deleteButtonLabel = deleteButtonLabel;
|
|
@@ -77,30 +87,34 @@ export class EditDataInternal {
|
|
|
77
87
|
this.confirmDeleteDialogData = confirmDeleteDialogData;
|
|
78
88
|
this.confirmEditDialogData = confirmEditDialogData;
|
|
79
89
|
this.actionsLabel = actionsLabel;
|
|
80
|
-
this.actions = actions.map(a => new EditActionInternal(a));
|
|
90
|
+
this.actions = actions.map(a => new EditActionInternal(a, globalConfig));
|
|
81
91
|
}
|
|
82
|
-
}
|
|
92
|
+
};
|
|
93
|
+
EditDataInternal = __decorate([
|
|
94
|
+
__param(10, Inject(NGX_INTERNAL_GLOBAL_DEFAULT_VALUES)),
|
|
95
|
+
__metadata("design:paramtypes", [Function, String, String, String, Boolean, Boolean, Object, Object, String, Array, Object])
|
|
96
|
+
], EditDataInternal);
|
|
83
97
|
/**
|
|
84
98
|
* The Builder for the EditDialogData. Sets default values.
|
|
85
99
|
*/
|
|
86
100
|
export class EditDialogDataBuilder extends BaseBuilder {
|
|
87
|
-
constructor(data) {
|
|
88
|
-
super(data);
|
|
101
|
+
constructor(globalConfig, data) {
|
|
102
|
+
super(globalConfig, data);
|
|
89
103
|
}
|
|
90
104
|
// eslint-disable-next-line jsdoc/require-jsdoc
|
|
91
105
|
generateBaseData(data) {
|
|
92
|
-
const confirmEditDialogData = new ConfirmDialogDataBuilder(data?.confirmEditDialogData)
|
|
93
|
-
.withDefault('confirmButtonLabel',
|
|
94
|
-
.withDefault('text',
|
|
95
|
-
.withDefault('title',
|
|
106
|
+
const confirmEditDialogData = new ConfirmDialogDataBuilder(this.globalConfig, data?.confirmEditDialogData)
|
|
107
|
+
.withDefault('confirmButtonLabel', this.globalConfig.saveLabel)
|
|
108
|
+
.withDefault('text', this.globalConfig.confirmSaveText)
|
|
109
|
+
.withDefault('title', this.globalConfig.editLabel)
|
|
96
110
|
.getResult();
|
|
97
|
-
const confirmDeleteDialogData = new ConfirmDialogDataBuilder(data?.confirmDeleteDialogData)
|
|
98
|
-
.withDefault('confirmButtonLabel',
|
|
111
|
+
const confirmDeleteDialogData = new ConfirmDialogDataBuilder(this.globalConfig, data?.confirmDeleteDialogData)
|
|
112
|
+
.withDefault('confirmButtonLabel', this.globalConfig.deleteLabel)
|
|
99
113
|
.withDefault('type', 'delete')
|
|
100
|
-
.withDefault('text',
|
|
101
|
-
.withDefault('title',
|
|
114
|
+
.withDefault('text', this.globalConfig.confirmDeleteText)
|
|
115
|
+
.withDefault('title', this.globalConfig.deleteLabel)
|
|
102
116
|
.getResult();
|
|
103
|
-
return new EditDataInternal(data?.title
|
|
117
|
+
return new EditDataInternal(getConfigValue(this.globalConfig.editTitle, data?.title), getConfigValue(this.globalConfig.saveLabel, data?.confirmButtonLabel), getConfigValue(this.globalConfig.deleteLabel, data?.deleteButtonLabel), getConfigValue(this.globalConfig.cancelLabel, data?.cancelButtonLabel), data?.deleteRequiresConfirmDialog ?? true, data?.editRequiresConfirmDialog ?? false, confirmDeleteDialogData, confirmEditDialogData, getConfigValue(this.globalConfig.actionsLabel, data?.actionsLabel), data?.actions ?? [], this.globalConfig);
|
|
104
118
|
}
|
|
105
119
|
}
|
|
106
|
-
//# 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 } from '../../../classes/base.builder';\nimport { BaseEntityType } from '../../../classes/entity.model';\nimport { defaultFalse } from '../../../functions/default-false.function';\nimport { defaultTrue } from '../../../functions/default-true.function';\nimport { isAsyncFunction } from '../../../functions/is-async-function.function';\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: (entity: EntityType, entityPriorChanges: EntityType) => Promise<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 = this.functionToAsync(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    // eslint-disable-next-line max-len\n    private functionToAsync(originalFunction: ((e: EntityType, ePriorChanges: EntityType) => unknown) | ((e: EntityType, ePriorChanges: EntityType) => Promise<unknown>)): (e: EntityType, ePriorChanges: EntityType) => Promise<unknown> {\n        if (isAsyncFunction(originalFunction)) {\n            return originalFunction as (e: EntityType) => Promise<unknown>;\n        }\n\n        /* istanbul ignore next */\n        return (e: EntityType, ePriorChanges: EntityType) => new Promise<unknown>((resolve, reject) => {\n            try {\n                resolve(originalFunction(e, ePriorChanges));\n            }\n            catch (error) {\n                reject(error);\n            }\n        });\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}"]}
|
|
120
|
+
//# 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 { Inject } from '@angular/core';\nimport { BaseBuilder } from '../../../classes/base.builder';\nimport { BaseEntityType } from '../../../classes/entity.model';\nimport { NGX_INTERNAL_GLOBAL_DEFAULT_VALUES } from '../../../default-global-configuration-values';\nimport { defaultFalse } from '../../../functions/default-false.function';\nimport { defaultTrue } from '../../../functions/default-true.function';\nimport { getConfigValue } from '../../../functions/get-config-value.function';\nimport { isAsyncFunction } from '../../../functions/is-async-function.function';\nimport { NgxGlobalDefaultValues } from '../../../global-configuration-values';\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: (entity: EntityType, entityPriorChanges: EntityType) => Promise<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(\n        data: EditAction<EntityType>,\n        @Inject(NGX_INTERNAL_GLOBAL_DEFAULT_VALUES)\n        protected readonly globalConfig: NgxGlobalDefaultValues\n    ) {\n        this.displayName = data.displayName;\n        this.action = this.functionToAsync(data.action);\n        this.enabled = data.enabled ?? defaultTrue;\n        this.requireConfirmDialog = data.requireConfirmDialog ?? defaultFalse;\n        this.confirmDialogData = new ConfirmDialogDataBuilder(this.globalConfig, data.confirmDialogData)\n            .withDefault('text', globalConfig.confirmBaseActionText)\n            .getResult();\n    }\n\n    // eslint-disable-next-line max-len\n    private functionToAsync(originalFunction: ((e: EntityType, ePriorChanges: EntityType) => unknown) | ((e: EntityType, ePriorChanges: EntityType) => Promise<unknown>)): (e: EntityType, ePriorChanges: EntityType) => Promise<unknown> {\n        if (isAsyncFunction(originalFunction)) {\n            return originalFunction as (e: EntityType) => Promise<unknown>;\n        }\n\n        /* istanbul ignore next */\n        return (e: EntityType, ePriorChanges: EntityType) => new Promise<unknown>((resolve, reject) => {\n            try {\n                resolve(originalFunction(e, ePriorChanges));\n            }\n            catch (error) {\n                reject(error);\n            }\n        });\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        @Inject(NGX_INTERNAL_GLOBAL_DEFAULT_VALUES)\n        globalConfig: NgxGlobalDefaultValues\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, globalConfig));\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(globalConfig: NgxGlobalDefaultValues, data?: EditData<EntityType>) {\n        super(globalConfig, 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(\n            this.globalConfig,\n            data?.confirmEditDialogData\n        )\n            .withDefault('confirmButtonLabel', this.globalConfig.saveLabel)\n            .withDefault('text', this.globalConfig.confirmSaveText)\n            .withDefault('title', this.globalConfig.editLabel)\n            .getResult();\n\n        const confirmDeleteDialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(\n            this.globalConfig,\n            data?.confirmDeleteDialogData\n        )\n            .withDefault('confirmButtonLabel', this.globalConfig.deleteLabel)\n            .withDefault('type', 'delete')\n            .withDefault('text', this.globalConfig.confirmDeleteText)\n            .withDefault('title', this.globalConfig.deleteLabel)\n            .getResult();\n\n        return new EditDataInternal(\n            getConfigValue(this.globalConfig.editTitle, data?.title),\n            getConfigValue(this.globalConfig.saveLabel, data?.confirmButtonLabel),\n            getConfigValue(this.globalConfig.deleteLabel, data?.deleteButtonLabel),\n            getConfigValue(this.globalConfig.cancelLabel, data?.cancelButtonLabel),\n            data?.deleteRequiresConfirmDialog ?? true,\n            data?.editRequiresConfirmDialog ?? false,\n            confirmDeleteDialogData,\n            confirmEditDialogData,\n            getConfigValue(this.globalConfig.actionsLabel, data?.actionsLabel),\n            data?.actions ?? [],\n            this.globalConfig\n        );\n    }\n}"]}
|