ngx-material-entity 16.0.7 → 16.0.9
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/input/array/array-string-autocomplete-chips/array-string-autocomplete-chips.component.d.ts +10 -5
- package/components/input/array/array-string-chips-input/array-string-chips-input.component.d.ts +4 -2
- package/components/input/input.component.d.ts +28 -8
- package/components/input/number/number-dropdown-input/number-dropdown-input.component.d.ts +12 -2
- package/components/input/relations/references-many-input/references-many-input.component.d.ts +10 -2
- package/components/input/string/string-autocomplete-input/string-autocomplete-input.component.d.ts +4 -2
- package/components/input/string/string-dropdown-input/string-dropdown-input.component.d.ts +12 -2
- package/components/input/string/string-password-input/string-password-input.component.d.ts +12 -0
- package/components/table/create-dialog/create-entity-dialog.component.d.ts +1 -1
- package/components/table/edit-dialog/edit-entity-dialog.component.d.ts +1 -1
- package/components/table/table-data.builder.d.ts +2 -1
- package/components/table/table-data.d.ts +10 -0
- package/decorators/array/array-decorator-internal.data.d.ts +2 -1
- package/decorators/array/array-decorator.data.d.ts +3 -1
- package/decorators/string/string-decorator-internal.data.d.ts +3 -1
- package/decorators/string/string-decorator.data.d.ts +7 -1
- package/directives/dynamic-style-class.directive.d.ts +25 -0
- package/directives/included-in.directive.d.ts +1 -1
- package/directives/tooltip.directive.d.ts +9 -0
- package/esm2022/classes/entity.model.mjs +1 -1
- package/esm2022/components/confirm-dialog/confirm-dialog-data.builder.mjs +1 -2
- package/esm2022/components/create-page/create-data.route.mjs +1 -1
- package/esm2022/components/create-page/create-page.component.mjs +11 -10
- package/esm2022/components/create-page/page-create-data.builder.mjs +1 -2
- package/esm2022/components/edit-page/edit-data.route.mjs +1 -1
- package/esm2022/components/edit-page/edit-page.component.mjs +11 -10
- package/esm2022/components/edit-page/page-edit-data.builder.mjs +1 -2
- package/esm2022/components/input/array/array-date-input/array-date-input.component.mjs +1 -1
- package/esm2022/components/input/array/array-date-range-input/array-date-range-input.component.mjs +1 -1
- package/esm2022/components/input/array/array-date-time-input/array-date-time-input.component.mjs +1 -1
- package/esm2022/components/input/array/array-string-autocomplete-chips/array-string-autocomplete-chips.component.mjs +28 -15
- package/esm2022/components/input/array/array-string-chips-input/array-string-chips-input.component.mjs +14 -19
- package/esm2022/components/input/base-input.component.mjs +6 -2
- package/esm2022/components/input/boolean/boolean-checkbox-input/boolean-checkbox-input.component.mjs +1 -1
- package/esm2022/components/input/boolean/boolean-dropdown-input/boolean-dropdown-input.component.mjs +1 -1
- package/esm2022/components/input/boolean/boolean-toggle-input/boolean-toggle-input.component.mjs +1 -1
- package/esm2022/components/input/custom/custom.component.mjs +1 -1
- package/esm2022/components/input/date/date-input/date-input.component.mjs +1 -1
- package/esm2022/components/input/date/date-range-input/date-range-input.component.mjs +1 -1
- package/esm2022/components/input/date/date-time-input/date-time-input.component.mjs +1 -1
- package/esm2022/components/input/file/file-default-input/file-default-input.component.mjs +1 -1
- package/esm2022/components/input/file/file-image-input/file-image-input.component.mjs +1 -1
- package/esm2022/components/input/file/file-input/file-input.component.mjs +1 -2
- package/esm2022/components/input/input.component.mjs +72 -40
- package/esm2022/components/input/number/number-dropdown-input/number-dropdown-input.component.mjs +36 -8
- package/esm2022/components/input/number/number-input/number-input.component.mjs +1 -1
- package/esm2022/components/input/number/number-slider-input/number-slider-input.component.mjs +1 -1
- package/esm2022/components/input/relations/references-many-input/references-many-input.component.mjs +29 -5
- package/esm2022/components/input/string/string-autocomplete-input/string-autocomplete-input.component.mjs +17 -10
- package/esm2022/components/input/string/string-dropdown-input/string-dropdown-input.component.mjs +36 -8
- package/esm2022/components/input/string/string-input/string-input.component.mjs +1 -1
- package/esm2022/components/input/string/string-password-input/string-password-input.component.mjs +57 -3
- package/esm2022/components/input/string/string-textbox-input/string-textbox-input.component.mjs +1 -1
- package/esm2022/components/table/create-dialog/create-data.builder.mjs +1 -2
- package/esm2022/components/table/create-dialog/create-entity-dialog.component.mjs +4 -4
- package/esm2022/components/table/display-column-value/display-column-value.component.mjs +1 -1
- package/esm2022/components/table/edit-dialog/edit-data.builder.mjs +1 -2
- package/esm2022/components/table/edit-dialog/edit-entity-dialog.component.mjs +8 -7
- package/esm2022/components/table/table-data.builder.mjs +5 -3
- package/esm2022/components/table/table-data.mjs +1 -1
- package/esm2022/components/table/table.component.mjs +6 -4
- package/esm2022/decorators/array/array-decorator-internal.data.mjs +11 -3
- package/esm2022/decorators/array/array-decorator.data.mjs +1 -1
- package/esm2022/decorators/base/base-property.decorator.mjs +1 -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/file/file-decorator-internal.data.mjs +1 -3
- package/esm2022/decorators/has-many/has-many-decorator-internal.data.mjs +1 -2
- package/esm2022/decorators/string/string-decorator-internal.data.mjs +14 -3
- package/esm2022/decorators/string/string-decorator.data.mjs +1 -1
- package/esm2022/default-global-configuration-values.mjs +1 -2
- package/esm2022/directives/dynamic-style-class.directive.mjs +51 -0
- package/esm2022/directives/included-in.directive.mjs +2 -3
- package/esm2022/directives/tooltip.directive.mjs +36 -9
- package/esm2022/encapsulation/reflect.utilities.mjs +6 -2
- package/esm2022/functions/default-style-classes.function.mjs +7 -0
- package/esm2022/functions/get-validation-error-message.function.mjs +1 -2
- package/esm2022/global-configuration-values.mjs +1 -2
- package/esm2022/mocks/placeholder-data.png.mjs +2 -2
- package/esm2022/public-api.mjs +6 -1
- package/esm2022/services/entity.service.mjs +1 -1
- package/esm2022/utilities/date.utilities.mjs +1 -2
- package/esm2022/utilities/entity.utilities.mjs +36 -35
- package/esm2022/utilities/validation.utilities.mjs +45 -15
- package/fesm2022/ngx-material-entity.mjs +521 -214
- package/fesm2022/ngx-material-entity.mjs.map +1 -1
- package/functions/default-style-classes.function.d.ts +6 -0
- package/package.json +1 -2
- package/public-api.d.ts +4 -0
- package/utilities/entity.utilities.d.ts +4 -3
- package/utilities/validation.utilities.d.ts +7 -3
|
@@ -14,4 +14,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImpor
|
|
|
14
14
|
type: Component,
|
|
15
15
|
args: [{ selector: 'string-input', template: "<!-- eslint-disable angular/no-call-expression -->\n<mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <input\n #model=\"ngModel\"\n matInput\n [name]=\"name\"\n [required]=\"metadata.required(entity)\"\n [pattern]=\"metadata.regex ?? '[\\\\s\\\\S]*'\"\n [minlength]=\"metadata.minLength ?? null\"\n [maxlength]=\"metadata.maxLength ?? null\"\n [disabled]=\"isReadOnly\"\n [(ngModel)]=\"propertyValue\"\n (ngModelChange)=\"emitChange()\"\n >\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n</mat-form-field>", styles: ["mat-form-field{width:100%}\n"] }]
|
|
16
16
|
}] });
|
|
17
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RyaW5nLWlucHV0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1tYXRlcmlhbC1lbnRpdHkvc3JjL2NvbXBvbmVudHMvaW5wdXQvc3RyaW5nL3N0cmluZy1pbnB1dC9zdHJpbmctaW5wdXQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW1hdGVyaWFsLWVudGl0eS9zcmMvY29tcG9uZW50cy9pbnB1dC9zdHJpbmcvc3RyaW5nLWlucHV0L3N0cmluZy1pbnB1dC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSx3Q0FBd0M7QUFDeEMsT0FBTyxFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUdsRCxPQUFPLEVBQUUsOEJBQThCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7Ozs7QUFFNUUsK0RBQStEO0FBTy9ELE1BQU0sT0FBTyxvQkFDVCxTQUFRLDhCQUF5RTt1R0FEeEUsb0JBQW9COzJGQUFwQixvQkFBb0IsMkVDYmpDLGduQkFnQmlCOzsyRkRISixvQkFBb0I7a0JBTmhDLFNBQVM7K0JBRUksY0FBYyIsInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIGpzZG9jL3JlcXVpcmUtanNkb2MgKi9cbmltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBCYXNlRW50aXR5VHlwZSB9IGZyb20gJy4uLy4uLy4uLy4uL2NsYXNzZXMvZW50aXR5Lm1vZGVsJztcbmltcG9ydCB7IERlY29yYXRvclR5cGVzIH0gZnJvbSAnLi4vLi4vLi4vLi4vZGVjb3JhdG9ycy9iYXNlL2RlY29yYXRvci10eXBlcy5lbnVtJztcbmltcG9ydCB7IE5neE1hdEVudGl0eUJhc2VJbnB1dENvbXBvbmVudCB9IGZyb20gJy4uLy4uL2Jhc2UtaW5wdXQuY29tcG9uZW50JztcblxuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGFuZ3VsYXIvcHJlZmVyLXN0YW5kYWxvbmUtY29tcG9uZW50XG5AQ29tcG9uZW50KHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgYW5ndWxhci9jb21wb25lbnQtc2VsZWN0b3JcbiAgICBzZWxlY3RvcjogJ3N0cmluZy1pbnB1dCcsXG4gICAgdGVtcGxhdGVVcmw6ICcuL3N0cmluZy1pbnB1dC5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vc3RyaW5nLWlucHV0LmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgU3RyaW5nSW5wdXRDb21wb25lbnQ8RW50aXR5VHlwZSBleHRlbmRzIEJhc2VFbnRpdHlUeXBlPEVudGl0eVR5cGU+PlxuICAgIGV4dGVuZHMgTmd4TWF0RW50aXR5QmFzZUlucHV0Q29tcG9uZW50PEVudGl0eVR5cGUsIERlY29yYXRvclR5cGVzLlNUUklORywgc3RyaW5nPiBpbXBsZW1lbnRzIE9uSW5pdCB7XG59IiwiPCEtLSBlc2xpbnQtZGlzYWJsZSBhbmd1bGFyL25vLWNhbGwtZXhwcmVzc2lvbiAtLT5cbjxtYXQtZm9ybS1maWVsZD5cbiAgICA8bWF0LWxhYmVsPnt7bWV0YWRhdGEuZGlzcGxheU5hbWV9fTwvbWF0LWxhYmVsPlxuICAgIDxpbnB1dFxuICAgICAgICAjbW9kZWw9XCJuZ01vZGVsXCJcbiAgICAgICAgbWF0SW5wdXRcbiAgICAgICAgW25hbWVdPVwibmFtZVwiXG4gICAgICAgIFtyZXF1aXJlZF09XCJtZXRhZGF0YS5yZXF1aXJlZChlbnRpdHkpXCJcbiAgICAgICAgW3BhdHRlcm5dPVwibWV0YWRhdGEucmVnZXggPz8gJ1tcXFxcc1xcXFxTXSonXCJcbiAgICAgICAgW21pbmxlbmd0aF09XCJtZXRhZGF0YS5taW5MZW5ndGggPz8gbnVsbFwiXG4gICAgICAgIFttYXhsZW5ndGhdPVwibWV0YWRhdGEubWF4TGVuZ3RoID8/IG51bGxcIlxuICAgICAgICBbZGlzYWJsZWRdPVwiaXNSZWFkT25seVwiXG4gICAgICAgIFsobmdNb2RlbCldPVwicHJvcGVydHlWYWx1ZVwiXG4gICAgICAgIChuZ01vZGVsQ2hhbmdlKT1cImVtaXRDaGFuZ2UoKVwiXG4gICAgPlxuICAgIDxtYXQtZXJyb3I+e3tnZXRWYWxpZGF0aW9uRXJyb3JNZXNzYWdlKG1vZGVsKX19PC9tYXQtZXJyb3I+XG48L21hdC1mb3JtLWZpZWxkPiJdfQ==
|
package/esm2022/components/input/string/string-password-input/string-password-input.component.mjs
CHANGED
|
@@ -11,11 +11,19 @@ import * as i3 from "@angular/material/button";
|
|
|
11
11
|
import * as i4 from "@angular/material/form-field";
|
|
12
12
|
import * as i5 from "@angular/material/input";
|
|
13
13
|
import * as i6 from "../../../../directives/password-match.directive";
|
|
14
|
+
export var PasswordStrength;
|
|
15
|
+
(function (PasswordStrength) {
|
|
16
|
+
PasswordStrength["WEAK"] = "weak";
|
|
17
|
+
PasswordStrength["MEDIUM"] = "medium";
|
|
18
|
+
PasswordStrength["STRONG"] = "strong";
|
|
19
|
+
})(PasswordStrength || (PasswordStrength = {}));
|
|
14
20
|
// eslint-disable-next-line angular/prefer-standalone-component
|
|
15
21
|
export class StringPasswordInputComponent extends NgxMatEntityBaseInputComponent {
|
|
16
22
|
hide = true;
|
|
17
23
|
hideConfirm = true;
|
|
18
24
|
confirmRequired = false;
|
|
25
|
+
passwordStrength;
|
|
26
|
+
PasswordStrength = PasswordStrength;
|
|
19
27
|
get confirmPassword() {
|
|
20
28
|
return ReflectUtilities.getMetadata(EntityUtilities.CONFIRM_PASSWORD_KEY, this.entity, this.key);
|
|
21
29
|
}
|
|
@@ -29,13 +37,59 @@ export class StringPasswordInputComponent extends NgxMatEntityBaseInputComponent
|
|
|
29
37
|
}
|
|
30
38
|
passwordInput() {
|
|
31
39
|
this.confirmRequired = Boolean(this.propertyValue);
|
|
40
|
+
this.setPasswordStrength();
|
|
32
41
|
this.emitChange();
|
|
33
42
|
}
|
|
43
|
+
setPasswordStrength() {
|
|
44
|
+
if (this.isPasswordStrong()) {
|
|
45
|
+
this.passwordStrength = PasswordStrength.STRONG;
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
if (this.isPasswordMedium()) {
|
|
49
|
+
this.passwordStrength = PasswordStrength.MEDIUM;
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
if (this.isPasswordWeak()) {
|
|
53
|
+
this.passwordStrength = PasswordStrength.WEAK;
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
56
|
+
this.passwordStrength = undefined;
|
|
57
|
+
}
|
|
58
|
+
// long AND complex
|
|
59
|
+
isPasswordStrong() {
|
|
60
|
+
if (!this.propertyValue) {
|
|
61
|
+
return false;
|
|
62
|
+
}
|
|
63
|
+
return this.propertyValue?.length >= 15 && this.isPasswordComplex();
|
|
64
|
+
}
|
|
65
|
+
// long OR complex
|
|
66
|
+
isPasswordMedium() {
|
|
67
|
+
if (!this.propertyValue) {
|
|
68
|
+
return false;
|
|
69
|
+
}
|
|
70
|
+
return this.propertyValue?.length >= 15 || this.isPasswordComplex();
|
|
71
|
+
}
|
|
72
|
+
// exists
|
|
73
|
+
isPasswordWeak() {
|
|
74
|
+
if (!this.propertyValue) {
|
|
75
|
+
return false;
|
|
76
|
+
}
|
|
77
|
+
return true;
|
|
78
|
+
}
|
|
79
|
+
isPasswordComplex() {
|
|
80
|
+
if (!this.propertyValue) {
|
|
81
|
+
return false;
|
|
82
|
+
}
|
|
83
|
+
return /[A-Z]/g.test(this.propertyValue)
|
|
84
|
+
&& /[a-z]/g.test(this.propertyValue)
|
|
85
|
+
&& /[0-9]/g.test(this.propertyValue)
|
|
86
|
+
&& /[!@#$%^&*(),.?":{}|<>]/.test(this.propertyValue);
|
|
87
|
+
}
|
|
34
88
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: StringPasswordInputComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
35
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.0", type: StringPasswordInputComponent, selector: "string-password-input", usesInheritance: true, ngImport: i0, template: "<!-- eslint-disable angular/no-call-expression -->\n<div class=\"password-row\">\n <mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <input\n #model=\"ngModel\"\n matInput\n [type]=\"hide ? 'password' : 'text'\"\n [name]=\"name\"\n [required]=\"metadata.required(entity)\"\n [pattern]=\"metadata.regex ?? '[\\\\s\\\\S]*'\"\n [minlength]=\"metadata.minLength ?? null\"\n [maxlength]=\"metadata.maxLength ?? null\"\n [disabled]=\"isReadOnly\"\n [(ngModel)]=\"propertyValue\"\n (ngModelChange)=\"passwordInput()\"\n >\n <button type=\"button\" mat-icon-button matSuffix (click)=\"hide = !hide\">\n <div class=\"d-flex justify-content-center align-items-center\">\n <i *ngIf=\"hide\" class=\"fas fa-eye-slash\"></i>\n <i *ngIf=\"!hide\" class=\"fas fa-eye\"></i>\n </div>\n </button>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n </mat-form-field>\n <mat-form-field *ngIf=\"metadata.needsConfirmation\">\n <mat-label>{{metadata.confirmationDisplayName}}</mat-label>\n <input\n #confirmModel=\"ngModel\"\n matInput\n [type]=\"hideConfirm ? 'password' : 'text'\"\n [name]=\"name + 'confirmPassword'\"\n [required]=\"confirmRequired\"\n [disabled]=\"isReadOnly\"\n [passwordMatch]=\"propertyValue\"\n [(ngModel)]=\"confirmPassword\"\n (ngModelChange)=\"passwordInput()\"\n >\n <button type=\"button\" mat-icon-button matSuffix (click)=\"hideConfirm = !hideConfirm\">\n <div class=\"d-flex justify-content-center align-items-center\">\n <i *ngIf=\"hideConfirm\" class=\"fas fa-eye-slash\"></i>\n <i *ngIf=\"!hideConfirm\" class=\"fas fa-eye\"></i>\n </div>\n </button>\n <mat-error>{{getValidationErrorMessage(confirmModel)}}</mat-error>\n </mat-form-field>\n</div>", styles: [".password-row{display:flex;justify-content:space-evenly;column-gap:24px}.password-row mat-form-field{flex:1 1 0}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i2.MinLengthValidator, selector: "[minlength][formControlName],[minlength][formControl],[minlength][ngModel]", inputs: ["minlength"] }, { kind: "directive", type: i2.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i2.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLabel, selector: "mat-label" }, { kind: "directive", type: i4.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i4.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "directive", type: i5.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i6.PasswordMatchValidatorDirective, selector: "[passwordMatch]", inputs: ["passwordMatch"] }] });
|
|
89
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.0", type: StringPasswordInputComponent, selector: "string-password-input", usesInheritance: true, ngImport: i0, template: "<!-- eslint-disable angular/no-call-expression -->\n<div class=\"password-row\">\n <mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <input\n #model=\"ngModel\"\n matInput\n [type]=\"hide ? 'password' : 'text'\"\n [name]=\"name\"\n [required]=\"metadata.required(entity)\"\n [pattern]=\"metadata.regex ?? '[\\\\s\\\\S]*'\"\n [minlength]=\"metadata.minLength ?? null\"\n [maxlength]=\"metadata.maxLength ?? null\"\n [disabled]=\"isReadOnly\"\n [(ngModel)]=\"propertyValue\"\n (ngModelChange)=\"passwordInput()\"\n >\n <button type=\"button\" mat-icon-button matSuffix (click)=\"hide = !hide\">\n <div class=\"d-flex justify-content-center align-items-center\">\n <i *ngIf=\"hide\" class=\"fas fa-eye-slash\"></i>\n <i *ngIf=\"!hide\" class=\"fas fa-eye\"></i>\n </div>\n </button>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n <div *ngIf=\"passwordStrength\" class=\"password-strength-indicator\"\n [class.green]=\"passwordStrength === PasswordStrength.STRONG\"\n [class.yellow]=\"passwordStrength === PasswordStrength.MEDIUM\"\n [class.red]=\"passwordStrength === PasswordStrength.WEAK\"\n >\n </div>\n </mat-form-field>\n <mat-form-field *ngIf=\"metadata.needsConfirmation\">\n <mat-label>{{metadata.confirmationDisplayName}}</mat-label>\n <input\n #confirmModel=\"ngModel\"\n matInput\n [type]=\"hideConfirm ? 'password' : 'text'\"\n [name]=\"name + 'confirmPassword'\"\n [required]=\"confirmRequired\"\n [disabled]=\"isReadOnly\"\n [passwordMatch]=\"propertyValue\"\n [(ngModel)]=\"confirmPassword\"\n (ngModelChange)=\"passwordInput()\"\n >\n <button type=\"button\" mat-icon-button matSuffix (click)=\"hideConfirm = !hideConfirm\">\n <div class=\"d-flex justify-content-center align-items-center\">\n <i *ngIf=\"hideConfirm\" class=\"fas fa-eye-slash\"></i>\n <!-- eslint-disable-next-line angular/cyclomatic-complexity -->\n <i *ngIf=\"!hideConfirm\" class=\"fas fa-eye\"></i>\n </div>\n </button>\n <mat-error>{{getValidationErrorMessage(confirmModel)}}</mat-error>\n </mat-form-field>\n</div>", styles: [".password-row{display:flex;justify-content:space-evenly;column-gap:24px}.password-row mat-form-field{flex:1 1 0}.password-strength-indicator{height:5px;width:100%}.green{background-color:green}.yellow{background-color:#b3b30f}.red{background-color:red}@media (max-width: 767px){.password-row{flex-wrap:wrap}.password-row mat-form-field{min-width:100%}}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i2.MinLengthValidator, selector: "[minlength][formControlName],[minlength][formControl],[minlength][ngModel]", inputs: ["minlength"] }, { kind: "directive", type: i2.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i2.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLabel, selector: "mat-label" }, { kind: "directive", type: i4.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i4.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "directive", type: i5.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i6.PasswordMatchValidatorDirective, selector: "[passwordMatch]", inputs: ["passwordMatch"] }] });
|
|
36
90
|
}
|
|
37
91
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: StringPasswordInputComponent, decorators: [{
|
|
38
92
|
type: Component,
|
|
39
|
-
args: [{ selector: 'string-password-input', template: "<!-- eslint-disable angular/no-call-expression -->\n<div class=\"password-row\">\n <mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <input\n #model=\"ngModel\"\n matInput\n [type]=\"hide ? 'password' : 'text'\"\n [name]=\"name\"\n [required]=\"metadata.required(entity)\"\n [pattern]=\"metadata.regex ?? '[\\\\s\\\\S]*'\"\n [minlength]=\"metadata.minLength ?? null\"\n [maxlength]=\"metadata.maxLength ?? null\"\n [disabled]=\"isReadOnly\"\n [(ngModel)]=\"propertyValue\"\n (ngModelChange)=\"passwordInput()\"\n >\n <button type=\"button\" mat-icon-button matSuffix (click)=\"hide = !hide\">\n <div class=\"d-flex justify-content-center align-items-center\">\n <i *ngIf=\"hide\" class=\"fas fa-eye-slash\"></i>\n <i *ngIf=\"!hide\" class=\"fas fa-eye\"></i>\n </div>\n </button>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n </mat-form-field>\n <mat-form-field *ngIf=\"metadata.needsConfirmation\">\n <mat-label>{{metadata.confirmationDisplayName}}</mat-label>\n <input\n #confirmModel=\"ngModel\"\n matInput\n [type]=\"hideConfirm ? 'password' : 'text'\"\n [name]=\"name + 'confirmPassword'\"\n [required]=\"confirmRequired\"\n [disabled]=\"isReadOnly\"\n [passwordMatch]=\"propertyValue\"\n [(ngModel)]=\"confirmPassword\"\n (ngModelChange)=\"passwordInput()\"\n >\n <button type=\"button\" mat-icon-button matSuffix (click)=\"hideConfirm = !hideConfirm\">\n <div class=\"d-flex justify-content-center align-items-center\">\n <i *ngIf=\"hideConfirm\" class=\"fas fa-eye-slash\"></i>\n <i *ngIf=\"!hideConfirm\" class=\"fas fa-eye\"></i>\n </div>\n </button>\n <mat-error>{{getValidationErrorMessage(confirmModel)}}</mat-error>\n </mat-form-field>\n</div>", styles: [".password-row{display:flex;justify-content:space-evenly;column-gap:24px}.password-row mat-form-field{flex:1 1 0}\n"] }]
|
|
93
|
+
args: [{ selector: 'string-password-input', template: "<!-- eslint-disable angular/no-call-expression -->\n<div class=\"password-row\">\n <mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <input\n #model=\"ngModel\"\n matInput\n [type]=\"hide ? 'password' : 'text'\"\n [name]=\"name\"\n [required]=\"metadata.required(entity)\"\n [pattern]=\"metadata.regex ?? '[\\\\s\\\\S]*'\"\n [minlength]=\"metadata.minLength ?? null\"\n [maxlength]=\"metadata.maxLength ?? null\"\n [disabled]=\"isReadOnly\"\n [(ngModel)]=\"propertyValue\"\n (ngModelChange)=\"passwordInput()\"\n >\n <button type=\"button\" mat-icon-button matSuffix (click)=\"hide = !hide\">\n <div class=\"d-flex justify-content-center align-items-center\">\n <i *ngIf=\"hide\" class=\"fas fa-eye-slash\"></i>\n <i *ngIf=\"!hide\" class=\"fas fa-eye\"></i>\n </div>\n </button>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n <div *ngIf=\"passwordStrength\" class=\"password-strength-indicator\"\n [class.green]=\"passwordStrength === PasswordStrength.STRONG\"\n [class.yellow]=\"passwordStrength === PasswordStrength.MEDIUM\"\n [class.red]=\"passwordStrength === PasswordStrength.WEAK\"\n >\n </div>\n </mat-form-field>\n <mat-form-field *ngIf=\"metadata.needsConfirmation\">\n <mat-label>{{metadata.confirmationDisplayName}}</mat-label>\n <input\n #confirmModel=\"ngModel\"\n matInput\n [type]=\"hideConfirm ? 'password' : 'text'\"\n [name]=\"name + 'confirmPassword'\"\n [required]=\"confirmRequired\"\n [disabled]=\"isReadOnly\"\n [passwordMatch]=\"propertyValue\"\n [(ngModel)]=\"confirmPassword\"\n (ngModelChange)=\"passwordInput()\"\n >\n <button type=\"button\" mat-icon-button matSuffix (click)=\"hideConfirm = !hideConfirm\">\n <div class=\"d-flex justify-content-center align-items-center\">\n <i *ngIf=\"hideConfirm\" class=\"fas fa-eye-slash\"></i>\n <!-- eslint-disable-next-line angular/cyclomatic-complexity -->\n <i *ngIf=\"!hideConfirm\" class=\"fas fa-eye\"></i>\n </div>\n </button>\n <mat-error>{{getValidationErrorMessage(confirmModel)}}</mat-error>\n </mat-form-field>\n</div>", styles: [".password-row{display:flex;justify-content:space-evenly;column-gap:24px}.password-row mat-form-field{flex:1 1 0}.password-strength-indicator{height:5px;width:100%}.green{background-color:green}.yellow{background-color:#b3b30f}.red{background-color:red}@media (max-width: 767px){.password-row{flex-wrap:wrap}.password-row mat-form-field{min-width:100%}}\n"] }]
|
|
40
94
|
}] });
|
|
41
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RyaW5nLXBhc3N3b3JkLWlucHV0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1tYXRlcmlhbC1lbnRpdHkvc3JjL2NvbXBvbmVudHMvaW5wdXQvc3RyaW5nL3N0cmluZy1wYXNzd29yZC1pbnB1dC9zdHJpbmctcGFzc3dvcmQtaW5wdXQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW1hdGVyaWFsLWVudGl0eS9zcmMvY29tcG9uZW50cy9pbnB1dC9zdHJpbmcvc3RyaW5nLXBhc3N3b3JkLWlucHV0L3N0cmluZy1wYXNzd29yZC1pbnB1dC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSx3Q0FBd0M7QUFDeEMsT0FBTyxFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUdsRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sNENBQTRDLENBQUM7QUFDN0UsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sNkNBQTZDLENBQUM7QUFDL0UsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHdDQUF3QyxDQUFDO0FBQ3pFLE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLDRCQUE0QixDQUFDOzs7Ozs7OztBQUU1RSwrREFBK0Q7QUFNL0QsTUFBTSxPQUFPLDRCQUNULFNBQVEsOEJBQWtGO0lBRTFGLElBQUksR0FBWSxJQUFJLENBQUM7SUFDckIsV0FBVyxHQUFZLElBQUksQ0FBQztJQUU1QixlQUFlLEdBQVksS0FBSyxDQUFDO0lBRWpDLElBQUksZUFBZTtRQUNmLE9BQU8sZ0JBQWdCLENBQUMsV0FBVyxDQUFDLGVBQWUsQ0FBQyxvQkFBb0IsRUFBRSxJQUFJLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxHQUFHLENBQXVCLENBQUM7SUFDM0gsQ0FBQztJQUVELElBQUksZUFBZSxDQUFDLEtBQXlCO1FBQ3pDLGdCQUFnQixDQUFDLGNBQWMsQ0FBQyxlQUFlLENBQUMsb0JBQW9CLEVBQUUsS0FBSyxFQUFFLElBQUksQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3hHLENBQUM7SUFFUSxRQUFRO1FBQ2IsS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQ2pCLElBQUksQ0FBQyxlQUFlLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUNuRCxJQUFJLENBQUMsZUFBZSxHQUFHLGVBQWUsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxDQUFDO0lBQ3pFLENBQUM7SUFFRCxhQUFhO1FBQ1QsSUFBSSxDQUFDLGVBQWUsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQ25ELElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUN0QixDQUFDO3VHQXpCUSw0QkFBNEI7MkZBQTVCLDRCQUE0QixvRkNmekMsb2tFQThDTTs7MkZEL0JPLDRCQUE0QjtrQkFMeEMsU0FBUzsrQkFDSSx1QkFBdUIiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBqc2RvYy9yZXF1aXJlLWpzZG9jICovXG5pbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQmFzZUVudGl0eVR5cGUgfSBmcm9tICcuLi8uLi8uLi8uLi9jbGFzc2VzL2VudGl0eS5tb2RlbCc7XG5pbXBvcnQgeyBEZWNvcmF0b3JUeXBlcyB9IGZyb20gJy4uLy4uLy4uLy4uL2RlY29yYXRvcnMvYmFzZS9kZWNvcmF0b3ItdHlwZXMuZW51bSc7XG5pbXBvcnQgeyBMb2Rhc2hVdGlsaXRpZXMgfSBmcm9tICcuLi8uLi8uLi8uLi9lbmNhcHN1bGF0aW9uL2xvZGFzaC51dGlsaXRpZXMnO1xuaW1wb3J0IHsgUmVmbGVjdFV0aWxpdGllcyB9IGZyb20gJy4uLy4uLy4uLy4uL2VuY2Fwc3VsYXRpb24vcmVmbGVjdC51dGlsaXRpZXMnO1xuaW1wb3J0IHsgRW50aXR5VXRpbGl0aWVzIH0gZnJvbSAnLi4vLi4vLi4vLi4vdXRpbGl0aWVzL2VudGl0eS51dGlsaXRpZXMnO1xuaW1wb3J0IHsgTmd4TWF0RW50aXR5QmFzZUlucHV0Q29tcG9uZW50IH0gZnJvbSAnLi4vLi4vYmFzZS1pbnB1dC5jb21wb25lbnQnO1xuXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgYW5ndWxhci9wcmVmZXItc3RhbmRhbG9uZS1jb21wb25lbnRcbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnc3RyaW5nLXBhc3N3b3JkLWlucHV0JyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vc3RyaW5nLXBhc3N3b3JkLWlucHV0LmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9zdHJpbmctcGFzc3dvcmQtaW5wdXQuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBTdHJpbmdQYXNzd29yZElucHV0Q29tcG9uZW50PEVudGl0eVR5cGUgZXh0ZW5kcyBCYXNlRW50aXR5VHlwZTxFbnRpdHlUeXBlPj5cbiAgICBleHRlbmRzIE5neE1hdEVudGl0eUJhc2VJbnB1dENvbXBvbmVudDxFbnRpdHlUeXBlLCBEZWNvcmF0b3JUeXBlcy5TVFJJTkdfUEFTU1dPUkQsIHN0cmluZz4gaW1wbGVtZW50cyBPbkluaXQge1xuXG4gICAgaGlkZTogYm9vbGVhbiA9IHRydWU7XG4gICAgaGlkZUNvbmZpcm06IGJvb2xlYW4gPSB0cnVlO1xuXG4gICAgY29uZmlybVJlcXVpcmVkOiBib29sZWFuID0gZmFsc2U7XG5cbiAgICBnZXQgY29uZmlybVBhc3N3b3JkKCk6IHN0cmluZyB8IHVuZGVmaW5lZCB7XG4gICAgICAgIHJldHVybiBSZWZsZWN0VXRpbGl0aWVzLmdldE1ldGFkYXRhKEVudGl0eVV0aWxpdGllcy5DT05GSVJNX1BBU1NXT1JEX0tFWSwgdGhpcy5lbnRpdHksIHRoaXMua2V5KSBhcyBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gICAgfVxuXG4gICAgc2V0IGNvbmZpcm1QYXNzd29yZCh2YWx1ZTogc3RyaW5nIHwgdW5kZWZpbmVkKSB7XG4gICAgICAgIFJlZmxlY3RVdGlsaXRpZXMuZGVmaW5lTWV0YWRhdGEoRW50aXR5VXRpbGl0aWVzLkNPTkZJUk1fUEFTU1dPUkRfS0VZLCB2YWx1ZSwgdGhpcy5lbnRpdHksIHRoaXMua2V5KTtcbiAgICB9XG5cbiAgICBvdmVycmlkZSBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAgICAgc3VwZXIubmdPbkluaXQoKTtcbiAgICAgICAgdGhpcy5jb25maXJtUmVxdWlyZWQgPSBCb29sZWFuKHRoaXMucHJvcGVydHlWYWx1ZSk7XG4gICAgICAgIHRoaXMuY29uZmlybVBhc3N3b3JkID0gTG9kYXNoVXRpbGl0aWVzLmNsb25lRGVlcCh0aGlzLnByb3BlcnR5VmFsdWUpO1xuICAgIH1cblxuICAgIHBhc3N3b3JkSW5wdXQoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuY29uZmlybVJlcXVpcmVkID0gQm9vbGVhbih0aGlzLnByb3BlcnR5VmFsdWUpO1xuICAgICAgICB0aGlzLmVtaXRDaGFuZ2UoKTtcbiAgICB9XG59IiwiPCEtLSBlc2xpbnQtZGlzYWJsZSBhbmd1bGFyL25vLWNhbGwtZXhwcmVzc2lvbiAtLT5cbjxkaXYgY2xhc3M9XCJwYXNzd29yZC1yb3dcIj5cbiAgICA8bWF0LWZvcm0tZmllbGQ+XG4gICAgICAgIDxtYXQtbGFiZWw+e3ttZXRhZGF0YS5kaXNwbGF5TmFtZX19PC9tYXQtbGFiZWw+XG4gICAgICAgIDxpbnB1dFxuICAgICAgICAgICAgI21vZGVsPVwibmdNb2RlbFwiXG4gICAgICAgICAgICBtYXRJbnB1dFxuICAgICAgICAgICAgW3R5cGVdPVwiaGlkZSA/ICdwYXNzd29yZCcgOiAndGV4dCdcIlxuICAgICAgICAgICAgW25hbWVdPVwibmFtZVwiXG4gICAgICAgICAgICBbcmVxdWlyZWRdPVwibWV0YWRhdGEucmVxdWlyZWQoZW50aXR5KVwiXG4gICAgICAgICAgICBbcGF0dGVybl09XCJtZXRhZGF0YS5yZWdleCA/PyAnW1xcXFxzXFxcXFNdKidcIlxuICAgICAgICAgICAgW21pbmxlbmd0aF09XCJtZXRhZGF0YS5taW5MZW5ndGggPz8gbnVsbFwiXG4gICAgICAgICAgICBbbWF4bGVuZ3RoXT1cIm1ldGFkYXRhLm1heExlbmd0aCA/PyBudWxsXCJcbiAgICAgICAgICAgIFtkaXNhYmxlZF09XCJpc1JlYWRPbmx5XCJcbiAgICAgICAgICAgIFsobmdNb2RlbCldPVwicHJvcGVydHlWYWx1ZVwiXG4gICAgICAgICAgICAobmdNb2RlbENoYW5nZSk9XCJwYXNzd29yZElucHV0KClcIlxuICAgICAgICA+XG4gICAgICAgIDxidXR0b24gdHlwZT1cImJ1dHRvblwiIG1hdC1pY29uLWJ1dHRvbiBtYXRTdWZmaXggKGNsaWNrKT1cImhpZGUgPSAhaGlkZVwiPlxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImQtZmxleCBqdXN0aWZ5LWNvbnRlbnQtY2VudGVyIGFsaWduLWl0ZW1zLWNlbnRlclwiPlxuICAgICAgICAgICAgICAgIDxpICpuZ0lmPVwiaGlkZVwiIGNsYXNzPVwiZmFzIGZhLWV5ZS1zbGFzaFwiPjwvaT5cbiAgICAgICAgICAgICAgICA8aSAqbmdJZj1cIiFoaWRlXCIgY2xhc3M9XCJmYXMgZmEtZXllXCI+PC9pPlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvYnV0dG9uPlxuICAgICAgICA8bWF0LWVycm9yPnt7Z2V0VmFsaWRhdGlvbkVycm9yTWVzc2FnZShtb2RlbCl9fTwvbWF0LWVycm9yPlxuICAgIDwvbWF0LWZvcm0tZmllbGQ+XG4gICAgPG1hdC1mb3JtLWZpZWxkICpuZ0lmPVwibWV0YWRhdGEubmVlZHNDb25maXJtYXRpb25cIj5cbiAgICAgICAgPG1hdC1sYWJlbD57e21ldGFkYXRhLmNvbmZpcm1hdGlvbkRpc3BsYXlOYW1lfX08L21hdC1sYWJlbD5cbiAgICAgICAgPGlucHV0XG4gICAgICAgICAgICAjY29uZmlybU1vZGVsPVwibmdNb2RlbFwiXG4gICAgICAgICAgICBtYXRJbnB1dFxuICAgICAgICAgICAgW3R5cGVdPVwiaGlkZUNvbmZpcm0gPyAncGFzc3dvcmQnIDogJ3RleHQnXCJcbiAgICAgICAgICAgIFtuYW1lXT1cIm5hbWUgKyAnY29uZmlybVBhc3N3b3JkJ1wiXG4gICAgICAgICAgICBbcmVxdWlyZWRdPVwiY29uZmlybVJlcXVpcmVkXCJcbiAgICAgICAgICAgIFtkaXNhYmxlZF09XCJpc1JlYWRPbmx5XCJcbiAgICAgICAgICAgIFtwYXNzd29yZE1hdGNoXT1cInByb3BlcnR5VmFsdWVcIlxuICAgICAgICAgICAgWyhuZ01vZGVsKV09XCJjb25maXJtUGFzc3dvcmRcIlxuICAgICAgICAgICAgKG5nTW9kZWxDaGFuZ2UpPVwicGFzc3dvcmRJbnB1dCgpXCJcbiAgICAgICAgPlxuICAgICAgICA8YnV0dG9uIHR5cGU9XCJidXR0b25cIiBtYXQtaWNvbi1idXR0b24gbWF0U3VmZml4IChjbGljayk9XCJoaWRlQ29uZmlybSA9ICFoaWRlQ29uZmlybVwiPlxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImQtZmxleCBqdXN0aWZ5LWNvbnRlbnQtY2VudGVyIGFsaWduLWl0ZW1zLWNlbnRlclwiPlxuICAgICAgICAgICAgICAgIDxpICpuZ0lmPVwiaGlkZUNvbmZpcm1cIiBjbGFzcz1cImZhcyBmYS1leWUtc2xhc2hcIj48L2k+XG4gICAgICAgICAgICAgICAgPGkgKm5nSWY9XCIhaGlkZUNvbmZpcm1cIiBjbGFzcz1cImZhcyBmYS1leWVcIj48L2k+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9idXR0b24+XG4gICAgICAgIDxtYXQtZXJyb3I+e3tnZXRWYWxpZGF0aW9uRXJyb3JNZXNzYWdlKGNvbmZpcm1Nb2RlbCl9fTwvbWF0LWVycm9yPlxuICAgIDwvbWF0LWZvcm0tZmllbGQ+XG48L2Rpdj4iXX0=
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"string-password-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-material-entity/src/components/input/string/string-password-input/string-password-input.component.ts","../../../../../../../projects/ngx-material-entity/src/components/input/string/string-password-input/string-password-input.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable jsdoc/require-jsdoc */\nimport { Component, OnInit } from '@angular/core';\nimport { BaseEntityType } from '../../../../classes/entity.model';\nimport { DecoratorTypes } from '../../../../decorators/base/decorator-types.enum';\nimport { LodashUtilities } from '../../../../encapsulation/lodash.utilities';\nimport { ReflectUtilities } from '../../../../encapsulation/reflect.utilities';\nimport { EntityUtilities } from '../../../../utilities/entity.utilities';\nimport { NgxMatEntityBaseInputComponent } from '../../base-input.component';\n\nexport enum PasswordStrength {\n    WEAK = 'weak',\n    MEDIUM = 'medium',\n    STRONG = 'strong'\n}\n\n// eslint-disable-next-line angular/prefer-standalone-component\n@Component({\n    // eslint-disable-next-line angular/component-selector\n    selector: 'string-password-input',\n    templateUrl: './string-password-input.component.html',\n    styleUrls: ['./string-password-input.component.scss']\n})\nexport class StringPasswordInputComponent<EntityType extends BaseEntityType<EntityType>>\n    extends NgxMatEntityBaseInputComponent<EntityType, DecoratorTypes.STRING_PASSWORD, string> implements OnInit {\n\n    hide: boolean = true;\n    hideConfirm: boolean = true;\n\n    confirmRequired: boolean = false;\n\n    passwordStrength?: PasswordStrength;\n\n    PasswordStrength: typeof PasswordStrength = PasswordStrength;\n\n    get confirmPassword(): string | undefined {\n        return ReflectUtilities.getMetadata(EntityUtilities.CONFIRM_PASSWORD_KEY, this.entity, this.key) as string | undefined;\n    }\n\n    set confirmPassword(value: string | undefined) {\n        ReflectUtilities.defineMetadata(EntityUtilities.CONFIRM_PASSWORD_KEY, value, this.entity, this.key);\n    }\n\n    override ngOnInit(): void {\n        super.ngOnInit();\n        this.confirmRequired = Boolean(this.propertyValue);\n        this.confirmPassword = LodashUtilities.cloneDeep(this.propertyValue);\n    }\n\n    passwordInput(): void {\n        this.confirmRequired = Boolean(this.propertyValue);\n        this.setPasswordStrength();\n        this.emitChange();\n    }\n\n    private setPasswordStrength(): void {\n        if (this.isPasswordStrong()) {\n            this.passwordStrength = PasswordStrength.STRONG;\n            return;\n        }\n        if (this.isPasswordMedium()) {\n            this.passwordStrength = PasswordStrength.MEDIUM;\n            return;\n        }\n        if (this.isPasswordWeak()) {\n            this.passwordStrength = PasswordStrength.WEAK;\n            return;\n        }\n        this.passwordStrength = undefined;\n    }\n\n    // long AND complex\n    private isPasswordStrong(): boolean {\n        if (!this.propertyValue) {\n            return false;\n        }\n        return this.propertyValue?.length >= 15 && this.isPasswordComplex();\n    }\n\n    // long OR complex\n    private isPasswordMedium(): boolean {\n        if (!this.propertyValue) {\n            return false;\n        }\n        return this.propertyValue?.length >= 15 || this.isPasswordComplex();\n    }\n\n    // exists\n    private isPasswordWeak(): boolean {\n        if (!this.propertyValue) {\n            return false;\n        }\n        return true;\n    }\n\n    private isPasswordComplex(): boolean {\n        if (!this.propertyValue) {\n            return false;\n        }\n        return /[A-Z]/g.test(this.propertyValue)\n            && /[a-z]/g.test(this.propertyValue)\n            && /[0-9]/g.test(this.propertyValue)\n            && /[!@#$%^&*(),.?\":{}|<>]/.test(this.propertyValue);\n    }\n}","<!-- eslint-disable angular/no-call-expression -->\n<div class=\"password-row\">\n    <mat-form-field>\n        <mat-label>{{metadata.displayName}}</mat-label>\n        <input\n            #model=\"ngModel\"\n            matInput\n            [type]=\"hide ? 'password' : 'text'\"\n            [name]=\"name\"\n            [required]=\"metadata.required(entity)\"\n            [pattern]=\"metadata.regex ?? '[\\\\s\\\\S]*'\"\n            [minlength]=\"metadata.minLength ?? null\"\n            [maxlength]=\"metadata.maxLength ?? null\"\n            [disabled]=\"isReadOnly\"\n            [(ngModel)]=\"propertyValue\"\n            (ngModelChange)=\"passwordInput()\"\n        >\n        <button type=\"button\" mat-icon-button matSuffix (click)=\"hide = !hide\">\n            <div class=\"d-flex justify-content-center align-items-center\">\n                <i *ngIf=\"hide\" class=\"fas fa-eye-slash\"></i>\n                <i *ngIf=\"!hide\" class=\"fas fa-eye\"></i>\n            </div>\n        </button>\n        <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n        <div *ngIf=\"passwordStrength\" class=\"password-strength-indicator\"\n            [class.green]=\"passwordStrength === PasswordStrength.STRONG\"\n            [class.yellow]=\"passwordStrength === PasswordStrength.MEDIUM\"\n            [class.red]=\"passwordStrength === PasswordStrength.WEAK\"\n        >\n        </div>\n    </mat-form-field>\n    <mat-form-field *ngIf=\"metadata.needsConfirmation\">\n        <mat-label>{{metadata.confirmationDisplayName}}</mat-label>\n        <input\n            #confirmModel=\"ngModel\"\n            matInput\n            [type]=\"hideConfirm ? 'password' : 'text'\"\n            [name]=\"name + 'confirmPassword'\"\n            [required]=\"confirmRequired\"\n            [disabled]=\"isReadOnly\"\n            [passwordMatch]=\"propertyValue\"\n            [(ngModel)]=\"confirmPassword\"\n            (ngModelChange)=\"passwordInput()\"\n        >\n        <button type=\"button\" mat-icon-button matSuffix (click)=\"hideConfirm = !hideConfirm\">\n            <div class=\"d-flex justify-content-center align-items-center\">\n                <i *ngIf=\"hideConfirm\" class=\"fas fa-eye-slash\"></i>\n                <!-- eslint-disable-next-line angular/cyclomatic-complexity -->\n                <i *ngIf=\"!hideConfirm\" class=\"fas fa-eye\"></i>\n            </div>\n        </button>\n        <mat-error>{{getValidationErrorMessage(confirmModel)}}</mat-error>\n    </mat-form-field>\n</div>"]}
|
package/esm2022/components/input/string/string-textbox-input/string-textbox-input.component.mjs
CHANGED
|
@@ -15,4 +15,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImpor
|
|
|
15
15
|
type: Component,
|
|
16
16
|
args: [{ selector: 'string-textbox-input', template: "<!-- eslint-disable angular/no-call-expression -->\n<mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <textarea\n #model=\"ngModel\"\n matInput\n cdkTextareaAutosize\n cdkAutosizeMinRows=\"10\"\n [name]=\"name\"\n [required]=\"metadata.required(entity)\"\n [minlength]=\"metadata.minLength ?? null\"\n [maxlength]=\"metadata.maxLength ?? null\"\n [disabled]=\"isReadOnly\"\n [(ngModel)]=\"propertyValue\"\n (ngModelChange)=\"emitChange()\"\n >\n </textarea>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n</mat-form-field>", styles: ["mat-form-field{width:100%}\n"] }]
|
|
17
17
|
}] });
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RyaW5nLXRleHRib3gtaW5wdXQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW1hdGVyaWFsLWVudGl0eS9zcmMvY29tcG9uZW50cy9pbnB1dC9zdHJpbmcvc3RyaW5nLXRleHRib3gtaW5wdXQvc3RyaW5nLXRleHRib3gtaW5wdXQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW1hdGVyaWFsLWVudGl0eS9zcmMvY29tcG9uZW50cy9pbnB1dC9zdHJpbmcvc3RyaW5nLXRleHRib3gtaW5wdXQvc3RyaW5nLXRleHRib3gtaW5wdXQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsd0NBQXdDO0FBQ3hDLE9BQU8sRUFBRSxTQUFTLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFHbEQsT0FBTyxFQUFFLDhCQUE4QixFQUFFLE1BQU0sNEJBQTRCLENBQUM7Ozs7OztBQUU1RSwrREFBK0Q7QUFPL0QsTUFBTSxPQUFPLDJCQUNULFNBQVEsOEJBQWlGO3VHQURoRiwyQkFBMkI7MkZBQTNCLDJCQUEyQixtRkNieEMsMm9CQWtCaUI7OzJGRExKLDJCQUEyQjtrQkFOdkMsU0FBUzsrQkFFSSxzQkFBc0IiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBqc2RvYy9yZXF1aXJlLWpzZG9jICovXG5pbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQmFzZUVudGl0eVR5cGUgfSBmcm9tICcuLi8uLi8uLi8uLi9jbGFzc2VzL2VudGl0eS5tb2RlbCc7XG5pbXBvcnQgeyBEZWNvcmF0b3JUeXBlcyB9IGZyb20gJy4uLy4uLy4uLy4uL2RlY29yYXRvcnMvYmFzZS9kZWNvcmF0b3ItdHlwZXMuZW51bSc7XG5pbXBvcnQgeyBOZ3hNYXRFbnRpdHlCYXNlSW5wdXRDb21wb25lbnQgfSBmcm9tICcuLi8uLi9iYXNlLWlucHV0LmNvbXBvbmVudCc7XG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBhbmd1bGFyL3ByZWZlci1zdGFuZGFsb25lLWNvbXBvbmVudFxuQENvbXBvbmVudCh7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGFuZ3VsYXIvY29tcG9uZW50LXNlbGVjdG9yXG4gICAgc2VsZWN0b3I6ICdzdHJpbmctdGV4dGJveC1pbnB1dCcsXG4gICAgdGVtcGxhdGVVcmw6ICcuL3N0cmluZy10ZXh0Ym94LWlucHV0LmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9zdHJpbmctdGV4dGJveC1pbnB1dC5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIFN0cmluZ1RleHRib3hJbnB1dENvbXBvbmVudDxFbnRpdHlUeXBlIGV4dGVuZHMgQmFzZUVudGl0eVR5cGU8RW50aXR5VHlwZT4+XG4gICAgZXh0ZW5kcyBOZ3hNYXRFbnRpdHlCYXNlSW5wdXRDb21wb25lbnQ8RW50aXR5VHlwZSwgRGVjb3JhdG9yVHlwZXMuU1RSSU5HX1RFWFRCT1gsIHN0cmluZz4gaW1wbGVtZW50cyBPbkluaXQge1xufSIsIjwhLS0gZXNsaW50LWRpc2FibGUgYW5ndWxhci9uby1jYWxsLWV4cHJlc3Npb24gLS0+XG48bWF0LWZvcm0tZmllbGQ+XG4gICAgPG1hdC1sYWJlbD57e21ldGFkYXRhLmRpc3BsYXlOYW1lfX08L21hdC1sYWJlbD5cbiAgICA8dGV4dGFyZWFcbiAgICAgICAgI21vZGVsPVwibmdNb2RlbFwiXG4gICAgICAgIG1hdElucHV0XG4gICAgICAgIGNka1RleHRhcmVhQXV0b3NpemVcbiAgICAgICAgY2RrQXV0b3NpemVNaW5Sb3dzPVwiMTBcIlxuICAgICAgICBbbmFtZV09XCJuYW1lXCJcbiAgICAgICAgW3JlcXVpcmVkXT1cIm1ldGFkYXRhLnJlcXVpcmVkKGVudGl0eSlcIlxuICAgICAgICBbbWlubGVuZ3RoXT1cIm1ldGFkYXRhLm1pbkxlbmd0aCA/PyBudWxsXCJcbiAgICAgICAgW21heGxlbmd0aF09XCJtZXRhZGF0YS5tYXhMZW5ndGggPz8gbnVsbFwiXG4gICAgICAgIFtkaXNhYmxlZF09XCJpc1JlYWRPbmx5XCJcbiAgICAgICAgWyhuZ01vZGVsKV09XCJwcm9wZXJ0eVZhbHVlXCJcbiAgICAgICAgKG5nTW9kZWxDaGFuZ2UpPVwiZW1pdENoYW5nZSgpXCJcbiAgICA+XG4gICAgPC90ZXh0YXJlYT5cbiAgICA8bWF0LWVycm9yPnt7Z2V0VmFsaWRhdGlvbkVycm9yTWVzc2FnZShtb2RlbCl9fTwvbWF0LWVycm9yPlxuPC9tYXQtZm9ybS1maWVsZD4iXX0=
|
|
@@ -32,7 +32,6 @@ export class CreateDataBuilder extends BaseBuilder {
|
|
|
32
32
|
}
|
|
33
33
|
// eslint-disable-next-line jsdoc/require-jsdoc
|
|
34
34
|
generateBaseData(data) {
|
|
35
|
-
// eslint-disable-next-line max-len
|
|
36
35
|
const confirmCreateDialogData = new ConfirmDialogDataBuilder(this.globalConfig, data?.confirmCreateDialogData)
|
|
37
36
|
.withDefault('confirmButtonLabel', this.globalConfig.createLabel)
|
|
38
37
|
.withDefault('text', this.globalConfig.confirmCreateText)
|
|
@@ -41,4 +40,4 @@ export class CreateDataBuilder extends BaseBuilder {
|
|
|
41
40
|
return new CreateDataInternal(getConfigValue(this.globalConfig.createLabel, data?.title), getConfigValue(this.globalConfig.createLabel, data?.createButtonLabel), getConfigValue(this.globalConfig.cancelLabel, data?.cancelButtonLabel), data?.createRequiresConfirmDialog ?? false, confirmCreateDialogData);
|
|
42
41
|
}
|
|
43
42
|
}
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLWRhdGEuYnVpbGRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1tYXRlcmlhbC1lbnRpdHkvc3JjL2NvbXBvbmVudHMvdGFibGUvY3JlYXRlLWRpYWxvZy9jcmVhdGUtZGF0YS5idWlsZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUM1RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sOENBQThDLENBQUM7QUFFOUUsT0FBTyxFQUFFLHdCQUF3QixFQUE2QixNQUFNLGtEQUFrRCxDQUFDO0FBR3ZIOztHQUVHO0FBQ0gsTUFBTSxPQUFPLGtCQUFrQjtJQUMzQiwrQ0FBK0M7SUFDL0MsS0FBSyxDQUFTO0lBQ2QsK0NBQStDO0lBQy9DLGlCQUFpQixDQUFTO0lBQzFCLCtDQUErQztJQUMvQyxpQkFBaUIsQ0FBUztJQUMxQiwrQ0FBK0M7SUFDL0MsMkJBQTJCLENBQVU7SUFDckMsK0NBQStDO0lBQy9DLHVCQUF1QixDQUE0QjtJQUVuRCxZQUNJLEtBQWEsRUFDYixpQkFBeUIsRUFDekIsaUJBQXlCLEVBQ3pCLDJCQUFvQyxFQUNwQyx1QkFBa0Q7UUFFbEQsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7UUFDbkIsSUFBSSxDQUFDLGlCQUFpQixHQUFHLGlCQUFpQixDQUFDO1FBQzNDLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxpQkFBaUIsQ0FBQztRQUMzQyxJQUFJLENBQUMsMkJBQTJCLEdBQUcsMkJBQTJCLENBQUM7UUFDL0QsSUFBSSxDQUFDLHVCQUF1QixHQUFHLHVCQUF1QixDQUFDO0lBQzNELENBQUM7Q0FDSjtBQUVEOztHQUVHO0FBQ0gsTUFBTSxPQUFPLGlCQUFrQixTQUFRLFdBQTJDO0lBRTlFLFlBQVksWUFBb0MsRUFBRSxJQUFpQjtRQUMvRCxLQUFLLENBQUMsWUFBWSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQzlCLENBQUM7SUFFRCwrQ0FBK0M7SUFDckMsZ0JBQWdCLENBQUMsSUFBaUI7UUFFeEMsTUFBTSx1QkFBdUIsR0FBOEIsSUFBSSx3QkFBd0IsQ0FBQyxJQUFJLENBQUMsWUFBWSxFQUFFLElBQUksRUFBRSx1QkFBdUIsQ0FBQzthQUNwSSxXQUFXLENBQUMsb0JBQW9CLEVBQUUsSUFBSSxDQUFDLFlBQVksQ0FBQyxXQUFXLENBQUM7YUFDaEUsV0FBVyxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsWUFBWSxDQUFDLGlCQUFpQixDQUFDO2FBQ3hELFdBQVcsQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLFlBQVksQ0FBQyxXQUFXLENBQUM7YUFDbkQsU0FBUyxFQUFFLENBQUM7UUFDakIsT0FBTyxJQUFJLGtCQUFrQixDQUN6QixjQUFjLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxXQUFXLEVBQUUsSUFBSSxFQUFFLEtBQUssQ0FBQyxFQUMxRCxjQUFjLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxXQUFXLEVBQUUsSUFBSSxFQUFFLGlCQUFpQixDQUFDLEVBQ3RFLGNBQWMsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLFdBQVcsRUFBRSxJQUFJLEVBQUUsaUJBQWlCLENBQUMsRUFDdEUsSUFBSSxFQUFFLDJCQUEyQixJQUFJLEtBQUssRUFDMUMsdUJBQXVCLENBQzFCLENBQUM7SUFDTixDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCYXNlQnVpbGRlciB9IGZyb20gJy4uLy4uLy4uL2NsYXNzZXMvYmFzZS5idWlsZGVyJztcbmltcG9ydCB7IGdldENvbmZpZ1ZhbHVlIH0gZnJvbSAnLi4vLi4vLi4vZnVuY3Rpb25zL2dldC1jb25maWctdmFsdWUuZnVuY3Rpb24nO1xuaW1wb3J0IHsgTmd4R2xvYmFsRGVmYXVsdFZhbHVlcyB9IGZyb20gJy4uLy4uLy4uL2dsb2JhbC1jb25maWd1cmF0aW9uLXZhbHVlcyc7XG5pbXBvcnQgeyBDb25maXJtRGlhbG9nRGF0YUJ1aWxkZXIsIENvbmZpcm1EaWFsb2dEYXRhSW50ZXJuYWwgfSBmcm9tICcuLi8uLi9jb25maXJtLWRpYWxvZy9jb25maXJtLWRpYWxvZy1kYXRhLmJ1aWxkZXInO1xuaW1wb3J0IHsgQ3JlYXRlRGF0YSB9IGZyb20gJy4uL3RhYmxlLWRhdGEnO1xuXG4vKipcbiAqIFRoZSBpbnRlcm5hbCBDcmVhdGVEYXRhLiBSZXF1aXJlcyBhbGwgZGVmYXVsdCB2YWx1ZXMgdGhlIHVzZXIgY2FuIGxlYXZlIG91dC5cbiAqL1xuZXhwb3J0IGNsYXNzIENyZWF0ZURhdGFJbnRlcm5hbCBpbXBsZW1lbnRzIENyZWF0ZURhdGEge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBqc2RvYy9yZXF1aXJlLWpzZG9jXG4gICAgdGl0bGU6IHN0cmluZztcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUganNkb2MvcmVxdWlyZS1qc2RvY1xuICAgIGNyZWF0ZUJ1dHRvbkxhYmVsOiBzdHJpbmc7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGpzZG9jL3JlcXVpcmUtanNkb2NcbiAgICBjYW5jZWxCdXR0b25MYWJlbDogc3RyaW5nO1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBqc2RvYy9yZXF1aXJlLWpzZG9jXG4gICAgY3JlYXRlUmVxdWlyZXNDb25maXJtRGlhbG9nOiBib29sZWFuO1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBqc2RvYy9yZXF1aXJlLWpzZG9jXG4gICAgY29uZmlybUNyZWF0ZURpYWxvZ0RhdGE6IENvbmZpcm1EaWFsb2dEYXRhSW50ZXJuYWw7XG5cbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgdGl0bGU6IHN0cmluZyxcbiAgICAgICAgY3JlYXRlQnV0dG9uTGFiZWw6IHN0cmluZyxcbiAgICAgICAgY2FuY2VsQnV0dG9uTGFiZWw6IHN0cmluZyxcbiAgICAgICAgY3JlYXRlUmVxdWlyZXNDb25maXJtRGlhbG9nOiBib29sZWFuLFxuICAgICAgICBjb25maXJtQ3JlYXRlRGlhbG9nRGF0YTogQ29uZmlybURpYWxvZ0RhdGFJbnRlcm5hbFxuICAgICkge1xuICAgICAgICB0aGlzLnRpdGxlID0gdGl0bGU7XG4gICAgICAgIHRoaXMuY3JlYXRlQnV0dG9uTGFiZWwgPSBjcmVhdGVCdXR0b25MYWJlbDtcbiAgICAgICAgdGhpcy5jYW5jZWxCdXR0b25MYWJlbCA9IGNhbmNlbEJ1dHRvbkxhYmVsO1xuICAgICAgICB0aGlzLmNyZWF0ZVJlcXVpcmVzQ29uZmlybURpYWxvZyA9IGNyZWF0ZVJlcXVpcmVzQ29uZmlybURpYWxvZztcbiAgICAgICAgdGhpcy5jb25maXJtQ3JlYXRlRGlhbG9nRGF0YSA9IGNvbmZpcm1DcmVhdGVEaWFsb2dEYXRhO1xuICAgIH1cbn1cblxuLyoqXG4gKiBUaGUgQnVpbGRlciBmb3IgdGhlIENyZWF0ZURhdGEuIFNldHMgZGVmYXVsdCB2YWx1ZXMuXG4gKi9cbmV4cG9ydCBjbGFzcyBDcmVhdGVEYXRhQnVpbGRlciBleHRlbmRzIEJhc2VCdWlsZGVyPENyZWF0ZURhdGFJbnRlcm5hbCwgQ3JlYXRlRGF0YT4ge1xuXG4gICAgY29uc3RydWN0b3IoZ2xvYmFsQ29uZmlnOiBOZ3hHbG9iYWxEZWZhdWx0VmFsdWVzLCBkYXRhPzogQ3JlYXRlRGF0YSkge1xuICAgICAgICBzdXBlcihnbG9iYWxDb25maWcsIGRhdGEpO1xuICAgIH1cblxuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBqc2RvYy9yZXF1aXJlLWpzZG9jXG4gICAgcHJvdGVjdGVkIGdlbmVyYXRlQmFzZURhdGEoZGF0YT86IENyZWF0ZURhdGEpOiBDcmVhdGVEYXRhSW50ZXJuYWwge1xuXG4gICAgICAgIGNvbnN0IGNvbmZpcm1DcmVhdGVEaWFsb2dEYXRhOiBDb25maXJtRGlhbG9nRGF0YUludGVybmFsID0gbmV3IENvbmZpcm1EaWFsb2dEYXRhQnVpbGRlcih0aGlzLmdsb2JhbENvbmZpZywgZGF0YT8uY29uZmlybUNyZWF0ZURpYWxvZ0RhdGEpXG4gICAgICAgICAgICAud2l0aERlZmF1bHQoJ2NvbmZpcm1CdXR0b25MYWJlbCcsIHRoaXMuZ2xvYmFsQ29uZmlnLmNyZWF0ZUxhYmVsKVxuICAgICAgICAgICAgLndpdGhEZWZhdWx0KCd0ZXh0JywgdGhpcy5nbG9iYWxDb25maWcuY29uZmlybUNyZWF0ZVRleHQpXG4gICAgICAgICAgICAud2l0aERlZmF1bHQoJ3RpdGxlJywgdGhpcy5nbG9iYWxDb25maWcuY3JlYXRlTGFiZWwpXG4gICAgICAgICAgICAuZ2V0UmVzdWx0KCk7XG4gICAgICAgIHJldHVybiBuZXcgQ3JlYXRlRGF0YUludGVybmFsKFxuICAgICAgICAgICAgZ2V0Q29uZmlnVmFsdWUodGhpcy5nbG9iYWxDb25maWcuY3JlYXRlTGFiZWwsIGRhdGE/LnRpdGxlKSxcbiAgICAgICAgICAgIGdldENvbmZpZ1ZhbHVlKHRoaXMuZ2xvYmFsQ29uZmlnLmNyZWF0ZUxhYmVsLCBkYXRhPy5jcmVhdGVCdXR0b25MYWJlbCksXG4gICAgICAgICAgICBnZXRDb25maWdWYWx1ZSh0aGlzLmdsb2JhbENvbmZpZy5jYW5jZWxMYWJlbCwgZGF0YT8uY2FuY2VsQnV0dG9uTGFiZWwpLFxuICAgICAgICAgICAgZGF0YT8uY3JlYXRlUmVxdWlyZXNDb25maXJtRGlhbG9nID8/IGZhbHNlLFxuICAgICAgICAgICAgY29uZmlybUNyZWF0ZURpYWxvZ0RhdGFcbiAgICAgICAgKTtcbiAgICB9XG59Il19
|
|
@@ -73,13 +73,13 @@ export class NgxMatEntityCreateDialogComponent {
|
|
|
73
73
|
this.dialogRef.disableClose = true;
|
|
74
74
|
this.entityTabs = EntityUtilities.getEntityTabs(this.data.entity, this.injector, true);
|
|
75
75
|
this.entityService = this.injector.get(this.data.EntityServiceClass);
|
|
76
|
-
setTimeout(() => this.checkIsEntityValid(), 1);
|
|
76
|
+
setTimeout(() => void this.checkIsEntityValid(), 1);
|
|
77
77
|
}
|
|
78
78
|
/**
|
|
79
79
|
* Checks if the entity is valid.
|
|
80
80
|
*/
|
|
81
|
-
checkIsEntityValid() {
|
|
82
|
-
this.validationErrors = ValidationUtilities.getEntityValidationErrors(this.data.entity, 'create');
|
|
81
|
+
async checkIsEntityValid() {
|
|
82
|
+
this.validationErrors = await ValidationUtilities.getEntityValidationErrors(this.data.entity, this.injector, 'create');
|
|
83
83
|
this.tooltipContent = runInInjectionContext(this.injector, () => getValidationErrorsTooltipContent(this.validationErrors));
|
|
84
84
|
this.isEntityValid = this.validationErrors.length === 0;
|
|
85
85
|
}
|
|
@@ -143,4 +143,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImpor
|
|
|
143
143
|
type: Inject,
|
|
144
144
|
args: [NGX_INTERNAL_GLOBAL_DEFAULT_VALUES]
|
|
145
145
|
}] }]; } });
|
|
146
|
-
//# 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, EnvironmentInjector, Inject, 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 { CreateEntityData } from './create-entity-dialog-data';\nimport { CreateEntityDataInternal, CreateEntityDialogDataBuilder } 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    /**\n     * Contains HelperMethods around handling Entities and their property-metadata.\n     */\n    EntityUtilities: typeof EntityUtilities = EntityUtilities;\n\n    /**\n     * The tabs of the entity.\n     */\n    entityTabs!: EntityTab<EntityType>[];\n\n    /**\n     * The services that handles the entity.\n     */\n    entityService!: EntityService<EntityType>;\n\n    /**\n     * The internal configuration data.\n     */\n    data!: CreateEntityDataInternal<EntityType>;\n\n    /**\n     * Whether or not the entity is valid.\n     */\n    isEntityValid: boolean = false;\n    /**\n     * The validation errors of the entity.\n     */\n    validationErrors: ValidationError[] = [];\n    /**\n     * What to display inside the tooltip.\n     */\n    tooltipContent: string = '';\n\n    constructor(\n        @Inject(MAT_DIALOG_DATA)\n        private readonly inputData: CreateEntityData<EntityType>,\n        public dialogRef: MatDialogRef<NgxMatEntityCreateDialogComponent<EntityType>>,\n        private readonly injector: EnvironmentInjector,\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, this.injector, 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.createData.createRequiresConfirmDialog) {\n            this.confirmCreate();\n            return;\n        }\n        const dialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(\n            this.globalConfig,\n            this.data.createData.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}","<!-- eslint-disable angular/cyclomatic-complexity -->\n<!-- eslint-disable angular/no-call-expression -->\n \n<div class=\"mat-dialog-title\">\n    <div>{{data.createData.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 *ngFor=\"let row of tab.rows\" class=\"row\">\n                    <ngx-mat-entity-input\n                        *ngFor=\"let key of row.keys\"\n                        [entity]=\"data.entity\"\n                        [propertyKey]=\"key\"\n                        [hideOmitForCreate]=\"true\"\n                        [class]=\"EntityUtilities.getWidthClasses(data.entity, key)\"\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 *ngIf=\"!entityTabs.length\" class=\"no-entity-tabs\">\n                ERROR: No Inputs. Did you correctly assign all values in the model constructor?\n            </span>\n            <div *ngFor=\"let row of entityTabs[0]?.rows\" class=\"row\">\n                <ngx-mat-entity-input\n                    *ngFor=\"let key of row.keys\"\n                    [entity]=\"data.entity\"\n                    [propertyKey]=\"key\"\n                    [hideOmitForCreate]=\"true\"\n                    [class]=\"EntityUtilities.getWidthClasses(data.entity, key)\"\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\" mat-raised-button matBadgeColor=\"warn\"\n                [disabled]=\"!isEntityValid\"\n                [matBadge]=\"validationErrors.length\"\n                [matBadgeHidden]=\"!validationErrors.length\"\n                (click)=\"create()\"\n            >\n                {{data.createData.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 class=\"cancel-button\" (click)=\"cancel()\">\n            {{data.createData.cancelButtonLabel}}\n        </button>\n    </mat-dialog-actions>\n</form>\n"]}
|
|
146
|
+
//# 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, EnvironmentInjector, Inject, 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 { CreateEntityData } from './create-entity-dialog-data';\nimport { CreateEntityDataInternal, CreateEntityDialogDataBuilder } 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    /**\n     * Contains HelperMethods around handling Entities and their property-metadata.\n     */\n    EntityUtilities: typeof EntityUtilities = EntityUtilities;\n\n    /**\n     * The tabs of the entity.\n     */\n    entityTabs!: EntityTab<EntityType>[];\n\n    /**\n     * The services that handles the entity.\n     */\n    entityService!: EntityService<EntityType>;\n\n    /**\n     * The internal configuration data.\n     */\n    data!: CreateEntityDataInternal<EntityType>;\n\n    /**\n     * Whether or not the entity is valid.\n     */\n    isEntityValid: boolean = false;\n    /**\n     * The validation errors of the entity.\n     */\n    validationErrors: ValidationError[] = [];\n    /**\n     * What to display inside the tooltip.\n     */\n    tooltipContent: string = '';\n\n    constructor(\n        @Inject(MAT_DIALOG_DATA)\n        private readonly inputData: CreateEntityData<EntityType>,\n        public dialogRef: MatDialogRef<NgxMatEntityCreateDialogComponent<EntityType>>,\n        private readonly injector: EnvironmentInjector,\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, this.injector, true);\n        this.entityService = this.injector.get(this.data.EntityServiceClass) as EntityService<EntityType>;\n        setTimeout(() => void this.checkIsEntityValid(), 1);\n    }\n\n    /**\n     * Checks if the entity is valid.\n     */\n    async checkIsEntityValid(): Promise<void> {\n        this.validationErrors = await ValidationUtilities.getEntityValidationErrors(this.data.entity, this.injector, '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.createData.createRequiresConfirmDialog) {\n            this.confirmCreate();\n            return;\n        }\n        const dialogData: ConfirmDialogDataInternal = new ConfirmDialogDataBuilder(\n            this.globalConfig,\n            this.data.createData.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}","<!-- eslint-disable angular/cyclomatic-complexity -->\n<!-- eslint-disable angular/no-call-expression -->\n \n<div class=\"mat-dialog-title\">\n    <div>{{data.createData.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 *ngFor=\"let row of tab.rows\" class=\"row\">\n                    <ngx-mat-entity-input\n                        *ngFor=\"let key of row.keys\"\n                        [entity]=\"data.entity\"\n                        [propertyKey]=\"key\"\n                        [hideOmitForCreate]=\"true\"\n                        [class]=\"EntityUtilities.getWidthClasses(data.entity, key)\"\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 *ngIf=\"!entityTabs.length\" class=\"no-entity-tabs\">\n                ERROR: No Inputs. Did you correctly assign all values in the model constructor?\n            </span>\n            <div *ngFor=\"let row of entityTabs[0]?.rows\" class=\"row\">\n                <ngx-mat-entity-input\n                    *ngFor=\"let key of row.keys\"\n                    [entity]=\"data.entity\"\n                    [propertyKey]=\"key\"\n                    [hideOmitForCreate]=\"true\"\n                    [class]=\"EntityUtilities.getWidthClasses(data.entity, key)\"\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\" mat-raised-button matBadgeColor=\"warn\"\n                [disabled]=\"!isEntityValid\"\n                [matBadge]=\"validationErrors.length\"\n                [matBadgeHidden]=\"!validationErrors.length\"\n                (click)=\"create()\"\n            >\n                {{data.createData.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 class=\"cancel-button\" (click)=\"cancel()\">\n            {{data.createData.cancelButtonLabel}}\n        </button>\n    </mat-dialog-actions>\n</form>\n"]}
|
|
@@ -42,4 +42,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImpor
|
|
|
42
42
|
}], ComponentClass: [{
|
|
43
43
|
type: Input
|
|
44
44
|
}] } });
|
|
45
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlzcGxheS1jb2x1bW4tdmFsdWUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW1hdGVyaWFsLWVudGl0eS9zcmMvY29tcG9uZW50cy90YWJsZS9kaXNwbGF5LWNvbHVtbi12YWx1ZS9kaXNwbGF5LWNvbHVtbi12YWx1ZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtbWF0ZXJpYWwtZW50aXR5L3NyYy9jb21wb25lbnRzL3RhYmxlL2Rpc3BsYXktY29sdW1uLXZhbHVlL2Rpc3BsYXktY29sdW1uLXZhbHVlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWdCLEtBQUssRUFBVSxJQUFJLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBSS9GOztHQUVHO0FBU0gsTUFBTSxPQUFPLDJCQUEyQjtJQW1CUDtJQWpCN0I7O09BRUc7SUFFSCxNQUFNLENBQWM7SUFFcEI7O09BRUc7SUFFSCxjQUFjLENBQWlFO0lBRS9FOztPQUVHO0lBQ0gsU0FBUyxDQUF5RTtJQUVsRixZQUE2QixnQkFBa0M7UUFBbEMscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFrQjtJQUFHLENBQUM7SUFFbkUsUUFBUTtRQUNKLElBQUksSUFBSSxDQUFDLGNBQWMsSUFBSSxJQUFJLEVBQUU7WUFDN0IsTUFBTSxJQUFJLEtBQUssQ0FBQyxzQ0FBc0MsQ0FBQyxDQUFDO1NBQzNEO1FBQ0QsSUFBSSxJQUFJLENBQUMsTUFBTSxJQUFJLElBQUksRUFBRTtZQUNyQixNQUFNLElBQUksS0FBSyxDQUFDLG9DQUFvQyxDQUFDLENBQUM7U0FDekQ7UUFDRCxJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBQzVFLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDO1FBQzVDLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLGFBQTZCLENBQUMsWUFBWSxDQUFDLE9BQU8sRUFBRSxhQUFhLENBQUMsQ0FBQztJQUNoRyxDQUFDO3VHQS9CUSwyQkFBMkI7MkZBQTNCLDJCQUEyQixnSkNmeEMsRUFBQTs7MkZEZWEsMkJBQTJCO2tCQVJ2QyxTQUFTOytCQUVJLHNCQUFzQixjQUdwQixJQUFJLFdBQ1AsRUFBRTt1R0FRWCxNQUFNO3NCQURMLEtBQUs7Z0JBT04sY0FBYztzQkFEYixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBDb21wb25lbnRSZWYsIElucHV0LCBPbkluaXQsIFR5cGUsIFZpZXdDb250YWluZXJSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJhc2VFbnRpdHlUeXBlIH0gZnJvbSAnLi4vLi4vLi4vY2xhc3Nlcy9lbnRpdHkubW9kZWwnO1xuaW1wb3J0IHsgTmd4TWF0RW50aXR5QmFzZURpc3BsYXlDb2x1bW5WYWx1ZUNvbXBvbmVudCB9IGZyb20gJy4vYmFzZS1kaXNwbGF5LWNvbHVtbi12YWx1ZS5jb21wb25lbnQnO1xuXG4vKipcbiAqIFRoZSBjb21wb25lbnQgdGhhdCBkaXNwbGF5cyB0aGUgY3VzdG9tIGRpc3BsYXkgY29sdW1uIHZhbHVlLlxuICovXG5AQ29tcG9uZW50KHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgYW5ndWxhci9jb21wb25lbnQtc2VsZWN0b3JcbiAgICBzZWxlY3RvcjogJ2Rpc3BsYXktY29sdW1uLXZhbHVlJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vZGlzcGxheS1jb2x1bW4tdmFsdWUuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL2Rpc3BsYXktY29sdW1uLXZhbHVlLmNvbXBvbmVudC5zY3NzJ10sXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbXVxufSlcbmV4cG9ydCBjbGFzcyBEaXNwbGF5Q29sdW1uVmFsdWVDb21wb25lbnQ8RW50aXR5VHlwZSBleHRlbmRzIEJhc2VFbnRpdHlUeXBlPEVudGl0eVR5cGU+PiBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgICAvKipcbiAgICAgKiBUaGUgZW50aXR5IGZvciB3aGljaCB0aGUgY29sdW1uIHNob3VsZCBiZSBkaXNwbGF5ZWQuXG4gICAgICovXG4gICAgQElucHV0KClcbiAgICBlbnRpdHkhOiBFbnRpdHlUeXBlO1xuXG4gICAgLyoqXG4gICAgICogVGhlIGNsYXNzIG9mIHRoZSBjb21wb25lbnQgdGhhdCBzaG91bGQgYmUgdXNlZCBpbnNpZGUgdGhlIGN1c3RvbSBkaXNwbGF5IGNvbHVtbi5cbiAgICAgKi9cbiAgICBASW5wdXQoKVxuICAgIENvbXBvbmVudENsYXNzITogVHlwZTxOZ3hNYXRFbnRpdHlCYXNlRGlzcGxheUNvbHVtblZhbHVlQ29tcG9uZW50PEVudGl0eVR5cGU+PjtcblxuICAgIC8qKlxuICAgICAqIFRoZSBhY3R1YWwgY29tcG9uZW50IHRoYXQgaXMgdXNlZCBpbnNpZGUgdGhlIGN1c3RvbSBkaXNwbGF5IGNvbHVtbi5cbiAgICAgKi9cbiAgICBjb21wb25lbnQhOiBDb21wb25lbnRSZWY8Tmd4TWF0RW50aXR5QmFzZURpc3BsYXlDb2x1bW5WYWx1ZUNvbXBvbmVudDxFbnRpdHlUeXBlPj47XG5cbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IHZpZXdDb250YWluZXJSZWY6IFZpZXdDb250YWluZXJSZWYpIHt9XG5cbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAgICAgaWYgKHRoaXMuQ29tcG9uZW50Q2xhc3MgPT0gbnVsbCkge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdObyBDb21wb25lbnRDbGFzcyBoYXMgYmVlbiBwcm92aWRlZC4nKTtcbiAgICAgICAgfVxuICAgICAgICBpZiAodGhpcy5lbnRpdHkgPT0gbnVsbCkge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdObyBlbnRpdHkgdmFsdWUgaGFzIGJlZW4gcHJvdmlkZWQuJyk7XG4gICAgICAgIH1cbiAgICAgICAgdGhpcy5jb21wb25lbnQgPSB0aGlzLnZpZXdDb250YWluZXJSZWYuY3JlYXRlQ29tcG9uZW50KHRoaXMuQ29tcG9uZW50Q2xhc3MpO1xuICAgICAgICB0aGlzLmNvbXBvbmVudC5pbnN0YW5jZS5lbnRpdHkgPSB0aGlzLmVudGl0eTtcbiAgICAgICAgKHRoaXMuY29tcG9uZW50LmxvY2F0aW9uLm5hdGl2ZUVsZW1lbnQgYXMgSFRNTEVsZW1lbnQpLnNldEF0dHJpYnV0ZSgnc3R5bGUnLCAnd2lkdGg6IDEwMCUnKTtcbiAgICB9XG59IiwiIl19
|
|
@@ -33,7 +33,6 @@ export let EditActionInternal = class EditActionInternal {
|
|
|
33
33
|
.withDefault('text', globalConfig.confirmBaseActionText)
|
|
34
34
|
.getResult();
|
|
35
35
|
}
|
|
36
|
-
// eslint-disable-next-line max-len
|
|
37
36
|
functionToAsync(originalFunction) {
|
|
38
37
|
if (isAsyncFunction(originalFunction)) {
|
|
39
38
|
return originalFunction;
|
|
@@ -117,4 +116,4 @@ export class EditDataBuilder extends BaseBuilder {
|
|
|
117
116
|
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);
|
|
118
117
|
}
|
|
119
118
|
}
|
|
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 { ConfirmDialogData } from '../../confirm-dialog/confirm-dialog-data';\nimport { ConfirmDialogDataBuilder, ConfirmDialogDataInternal } from '../../confirm-dialog/confirm-dialog-data.builder';\nimport { EditAction, EditData } from '../table-data';\nimport { NgxGlobalDefaultValues } from '../../../global-configuration-values';\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 EditData. Sets default values.\n */\nexport class EditDataBuilder<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}"]}
|
|
119
|
+
//# 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":";AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvC,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAE5D,OAAO,EAAE,kCAAkC,EAAE,MAAM,8CAA8C,CAAC;AAClG,OAAO,EAAE,YAAY,EAAE,MAAM,2CAA2C,CAAC;AACzE,OAAO,EAAE,WAAW,EAAE,MAAM,0CAA0C,CAAC;AACvE,OAAO,EAAE,cAAc,EAAE,MAAM,8CAA8C,CAAC;AAC9E,OAAO,EAAE,eAAe,EAAE,MAAM,+CAA+C,CAAC;AAEhF,OAAO,EAAE,wBAAwB,EAA6B,MAAM,kDAAkD,CAAC;AAIvH;;;GAGG;AACH,WAAa,kBAAkB,GAA/B,MAAa,kBAAkB;IAeJ;IAdvB,+CAA+C;IAC/C,WAAW,CAAS;IACpB,+CAA+C;IAC/C,MAAM,CAA2E;IACjF,+CAA+C;IAC/C,OAAO,CAA+B;IACtC,+CAA+C;IAC/C,oBAAoB,CAA+B;IACnD,+CAA+C;IAC/C,iBAAiB,CAAoB;IAErC,YACI,IAA4B,EAET,YAAoC;QAApC,iBAAY,GAAZ,YAAY,CAAwB;QAEvD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;QACpC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAChD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,IAAI,WAAW,CAAC;QAC3C,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,oBAAoB,IAAI,YAAY,CAAC;QACtE,IAAI,CAAC,iBAAiB,GAAG,IAAI,wBAAwB,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,iBAAiB,CAAC;aAC3F,WAAW,CAAC,MAAM,EAAE,YAAY,CAAC,qBAAqB,CAAC;aACvD,SAAS,EAAE,CAAC;IACrB,CAAC;IAGO,eAAe,CAAC,gBAA4I;QAChK,IAAI,eAAe,CAAC,gBAAgB,CAAC,EAAE;YACnC,OAAO,gBAAuD,CAAC;SAClE;QAED,0BAA0B;QAC1B,OAAO,CAAC,CAAa,EAAE,aAAyB,EAAE,EAAE,CAAC,IAAI,OAAO,CAAU,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC1F,IAAI;gBACA,OAAO,CAAC,gBAAgB,CAAC,CAAC,EAAE,aAAa,CAAC,CAAC,CAAC;aAC/C;YACD,OAAO,KAAK,EAAE;gBACV,MAAM,CAAC,KAAK,CAAC,CAAC;aACjB;QACL,CAAC,CAAC,CAAC;IACP,CAAC;CACJ,CAAA;AA1CY,kBAAkB;IActB,WAAA,MAAM,CAAC,kCAAkC,CAAC,CAAA;;GAdtC,kBAAkB,CA0C9B;AAED;;GAEG;AACH,WAAa,gBAAgB,GAA7B,MAAa,gBAAgB;IACzB,+CAA+C;IAC/C,KAAK,CAAiC;IACtC,+CAA+C;IAC/C,kBAAkB,CAAS;IAC3B,+CAA+C;IAC/C,iBAAiB,CAAS;IAC1B,+CAA+C;IAC/C,iBAAiB,CAAS;IAC1B,+CAA+C;IAC/C,2BAA2B,CAAU;IACrC,+CAA+C;IAC/C,yBAAyB,CAAU;IACnC,+CAA+C;IAC/C,uBAAuB,CAAoB;IAC3C,+CAA+C;IAC/C,qBAAqB,CAAoB;IACzC,+CAA+C;IAC/C,YAAY,CAAS;IACrB,+CAA+C;IAC/C,OAAO,CAAmC;IAE1C,YACI,KAAqC,EACrC,kBAA0B,EAC1B,iBAAyB,EACzB,iBAAyB,EACzB,2BAAoC,EACpC,yBAAkC,EAClC,uBAA0C,EAC1C,qBAAwC,EACxC,YAAoB,EACpB,OAAiC,EAEjC,YAAoC;QAEpC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,kBAAkB,GAAG,kBAAkB,CAAC;QAC7C,IAAI,CAAC,iBAAiB,GAAG,iBAAiB,CAAC;QAC3C,IAAI,CAAC,iBAAiB,GAAG,iBAAiB,CAAC;QAC3C,IAAI,CAAC,2BAA2B,GAAG,2BAA2B,CAAC;QAC/D,IAAI,CAAC,yBAAyB,GAAG,yBAAyB,CAAC;QAC3D,IAAI,CAAC,uBAAuB,GAAG,uBAAuB,CAAC;QACvD,IAAI,CAAC,qBAAqB,GAAG,qBAAqB,CAAC;QACnD,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;QACjC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,kBAAkB,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC,CAAC;IAC7E,CAAC;CACJ,CAAA;AA/CY,gBAAgB;IAiCpB,YAAA,MAAM,CAAC,kCAAkC,CAAC,CAAA;;GAjCtC,gBAAgB,CA+C5B;AAED;;GAEG;AACH,MAAM,OAAO,eACT,SAAQ,WAA+D;IAEvE,YAAY,YAAoC,EAAE,IAA2B;QACzE,KAAK,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED,+CAA+C;IACrC,gBAAgB,CAAC,IAA2B;QAClD,MAAM,qBAAqB,GAA8B,IAAI,wBAAwB,CACjF,IAAI,CAAC,YAAY,EACjB,IAAI,EAAE,qBAAqB,CAC9B;aACI,WAAW,CAAC,oBAAoB,EAAE,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC;aAC9D,WAAW,CAAC,MAAM,EAAE,IAAI,CAAC,YAAY,CAAC,eAAe,CAAC;aACtD,WAAW,CAAC,OAAO,EAAE,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC;aACjD,SAAS,EAAE,CAAC;QAEjB,MAAM,uBAAuB,GAA8B,IAAI,wBAAwB,CACnF,IAAI,CAAC,YAAY,EACjB,IAAI,EAAE,uBAAuB,CAChC;aACI,WAAW,CAAC,oBAAoB,EAAE,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC;aAChE,WAAW,CAAC,MAAM,EAAE,QAAQ,CAAC;aAC7B,WAAW,CAAC,MAAM,EAAE,IAAI,CAAC,YAAY,CAAC,iBAAiB,CAAC;aACxD,WAAW,CAAC,OAAO,EAAE,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC;aACnD,SAAS,EAAE,CAAC;QAEjB,OAAO,IAAI,gBAAgB,CACvB,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,IAAI,EAAE,KAAK,CAAC,EACxD,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,IAAI,EAAE,kBAAkB,CAAC,EACrE,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,IAAI,EAAE,iBAAiB,CAAC,EACtE,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,IAAI,EAAE,iBAAiB,CAAC,EACtE,IAAI,EAAE,2BAA2B,IAAI,IAAI,EACzC,IAAI,EAAE,yBAAyB,IAAI,KAAK,EACxC,uBAAuB,EACvB,qBAAqB,EACrB,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,YAAY,EAAE,IAAI,EAAE,YAAY,CAAC,EAClE,IAAI,EAAE,OAAO,IAAI,EAAE,EACnB,IAAI,CAAC,YAAY,CACpB,CAAC;IACN,CAAC;CACJ","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 { ConfirmDialogData } from '../../confirm-dialog/confirm-dialog-data';\nimport { ConfirmDialogDataBuilder, ConfirmDialogDataInternal } from '../../confirm-dialog/confirm-dialog-data.builder';\nimport { EditAction, EditData } from '../table-data';\nimport { NgxGlobalDefaultValues } from '../../../global-configuration-values';\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\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 EditData. Sets default values.\n */\nexport class EditDataBuilder<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}"]}
|