@trudb/tru-common-lib 0.1.83 → 0.1.84
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/esm2022/lib/base-classes/tru-edit-control-config-base.mjs +1 -1
- package/esm2022/lib/base-classes/tru-list-control-config-base.mjs +1 -1
- package/esm2022/lib/directives/breeze-validator/tru-breeze-validator.mjs +27 -21
- package/fesm2022/trudb-tru-common-lib.mjs +25 -20
- package/fesm2022/trudb-tru-common-lib.mjs.map +1 -1
- package/lib/base-classes/tru-edit-control-config-base.d.ts +1 -0
- package/lib/base-classes/tru-list-control-config-base.d.ts +1 -0
- package/lib/directives/breeze-validator/tru-breeze-validator.d.ts +6 -3
- package/package.json +1 -1
|
@@ -3,4 +3,4 @@ export class TruEditControlConfigBase {
|
|
|
3
3
|
choices;
|
|
4
4
|
choicesEntityType;
|
|
5
5
|
}
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LWVkaXQtY29udHJvbC1jb25maWctYmFzZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RydS1jb21tb24tbGliL3NyYy9saWIvYmFzZS1jbGFzc2VzL3RydS1lZGl0LWNvbnRyb2wtY29uZmlnLWJhc2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBS0EsTUFBTSxPQUFnQix3QkFBd0I7SUFvQjVDLGdCQUFnQixDQUFDO0lBR1AsT0FBTyxDQUFpQztJQUN4QyxpQkFBaUIsQ0FBTztDQUNuQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE9ic2VydmFibGUsIFN1YmplY3QgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgVHJ1UHJvcGVydHlDb25maWdCYXNlIH0gZnJvbSAnLi90cnUtcHJvcGVydHktY29uZmlnLWJhc2UnO1xyXG5pbXBvcnQgeyBUcnVFbnRpdHlCYXNlIH0gZnJvbSAnLi90cnUtZW50aXR5LWJhc2UnO1xyXG5pbXBvcnQgeyBUcnVDaG9pY2UgfSBmcm9tICcuLi9jbGFzc2VzL3RydS1jaG9pY2UnO1xyXG5cclxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIFRydUVkaXRDb250cm9sQ29uZmlnQmFzZTxUPiB7XHJcbiAgYWJzdHJhY3QgbGFiZWw6IHN0cmluZyB8IHVuZGVmaW5lZDtcclxuICBhYnN0cmFjdCBwcm9wZXJ0eU5hbWU6IHN0cmluZyB8IHVuZGVmaW5lZDtcclxuICBhYnN0cmFjdCByb290VGFibGU6IHN0cmluZyB8IHVuZGVmaW5lZDtcclxuICBhYnN0cmFjdCByZWxhdGVkVGFibGVUeXBlOiB0eXBlb2YgVHJ1RW50aXR5QmFzZSB8IHVuZGVmaW5lZDtcclxuICBhYnN0cmFjdCBwcm9wZXJ0eVBhdGg6IHN0cmluZyB8IHVuZGVmaW5lZDtcclxuICBhYnN0cmFjdCBydWxlcyhlbnRpdHk6IGFueSk6IHt9IHwgbnVsbDtcclxuICBhYnN0cmFjdCBzdWJQcm9wZXJ0aWVzOiBBcnJheTxzdHJpbmc+O1xyXG4gIGFic3RyYWN0IGlzU3ViUHJvcGVydHk6IGJvb2xlYW47XHJcblxyXG4gIGFic3RyYWN0IGdldCBwcm9wZXJ0eSgpOiBUcnVQcm9wZXJ0eUNvbmZpZ0Jhc2U7XHJcblxyXG4gIGFic3RyYWN0IHNldCBlbnRpdHkodmFsdWU6IGFueSk7XHJcblxyXG4gIGFic3RyYWN0IGdldCAkKCk6IFQ7XHJcbiAgYWJzdHJhY3Qgc2V0ICQodmFsdWU6IFQpO1xyXG5cclxuICBhYnN0cmFjdCBvbkNoYW5nZSgpOiBTdWJqZWN0PFQ+XHJcbiAgYWJzdHJhY3QgY2hhbmdlKHZhbHVlOiBUKTogdm9pZDtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcbiAgcHJvdGVjdGVkIGhpZD8oZW50aXR5OiBUcnVFbnRpdHlCYXNlKTogc3RyaW5nIHwgbnVsbCB8IHVuZGVmaW5lZDtcclxuICBwcm90ZWN0ZWQgY2hvaWNlcz86ICgpID0+IE9ic2VydmFibGU8VHJ1Q2hvaWNlW10+O1xyXG4gIHByb3RlY3RlZCBjaG9pY2VzRW50aXR5VHlwZT86IGFueTtcclxufVxyXG4iXX0=
|
|
@@ -3,4 +3,4 @@ export class TruListControlConfigBase {
|
|
|
3
3
|
choices;
|
|
4
4
|
choicesEntityType;
|
|
5
5
|
}
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LWxpc3QtY29udHJvbC1jb25maWctYmFzZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RydS1jb21tb24tbGliL3NyYy9saWIvYmFzZS1jbGFzc2VzL3RydS1saXN0LWNvbnRyb2wtY29uZmlnLWJhc2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBS0EsTUFBTSxPQUFnQix3QkFBd0I7SUFvQjVDLGdCQUFnQixDQUFDO0lBR1AsT0FBTyxDQUFpQztJQUN4QyxpQkFBaUIsQ0FBTztDQUNuQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE9ic2VydmFibGUsIFN1YmplY3QgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgVHJ1UHJvcGVydHlDb25maWdCYXNlIH0gZnJvbSAnLi90cnUtcHJvcGVydHktY29uZmlnLWJhc2UnO1xyXG5pbXBvcnQgeyBUcnVFbnRpdHlCYXNlIH0gZnJvbSAnLi90cnUtZW50aXR5LWJhc2UnO1xyXG5pbXBvcnQgeyBUcnVDaG9pY2UgfSBmcm9tICcuLi9jbGFzc2VzL3RydS1jaG9pY2UnO1xyXG5cclxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIFRydUxpc3RDb250cm9sQ29uZmlnQmFzZTxUPiB7XHJcbiAgYWJzdHJhY3QgbGFiZWw6IHN0cmluZyB8IHVuZGVmaW5lZDtcclxuICBhYnN0cmFjdCBwcm9wZXJ0eU5hbWU6IHN0cmluZyB8IHVuZGVmaW5lZDtcclxuICBhYnN0cmFjdCByb290VGFibGU6IHN0cmluZyB8IHVuZGVmaW5lZDtcclxuICBhYnN0cmFjdCByZWxhdGVkVGFibGVUeXBlOiB0eXBlb2YgVHJ1RW50aXR5QmFzZSB8IHVuZGVmaW5lZDtcclxuICBhYnN0cmFjdCBwcm9wZXJ0eVBhdGg6IHN0cmluZyB8IHVuZGVmaW5lZDtcclxuICBhYnN0cmFjdCBydWxlcyhlbnRpdHk6IGFueSk6IHt9IHwgbnVsbDtcclxuICBhYnN0cmFjdCBzdWJQcm9wZXJ0aWVzOiBBcnJheTxzdHJpbmc+O1xyXG4gIGFic3RyYWN0IGlzU3ViUHJvcGVydHk6IGJvb2xlYW47XHJcblxyXG4gIGFic3RyYWN0IGdldCBwcm9wZXJ0eSgpOiBUcnVQcm9wZXJ0eUNvbmZpZ0Jhc2U7XHJcblxyXG4gIGFic3RyYWN0IHNldCBlbnRpdHkodmFsdWU6IGFueSk7XHJcblxyXG4gIGFic3RyYWN0IGdldCAkKCk6IFQ7XHJcbiAgYWJzdHJhY3Qgc2V0ICQodmFsdWU6IFQpO1xyXG5cclxuICBhYnN0cmFjdCBvbkNoYW5nZSgpOiBTdWJqZWN0PFQ+XHJcbiAgYWJzdHJhY3QgY2hhbmdlKHZhbHVlOiBUKTogdm9pZDtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcbiAgcHJvdGVjdGVkIGhpZD8oZW50aXR5OiBUcnVFbnRpdHlCYXNlKTogc3RyaW5nIHwgbnVsbCB8IHVuZGVmaW5lZDtcclxuICBwcm90ZWN0ZWQgY2hvaWNlcz86ICgpID0+IE9ic2VydmFibGU8VHJ1Q2hvaWNlW10+O1xyXG4gIHByb3RlY3RlZCBjaG9pY2VzRW50aXR5VHlwZT86IGFueTtcclxufVxyXG4iXX0=
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { Directive, Input } from '@angular/core';
|
|
2
|
-
import { TruValidationDialog } from '../../components/validation-dialog/tru-validation-dialog';
|
|
3
2
|
import { TruValidationDialogContext } from '../../../public-api';
|
|
3
|
+
import { TruValidationDialog } from '../../components/validation-dialog/tru-validation-dialog';
|
|
4
|
+
import { TruValidationDialogConfig } from '../../components/validation-dialog/tru-validation-dialog-config';
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
6
|
import * as i1 from "../../services/tru-data-context";
|
|
6
7
|
export class TruBreezeValidator {
|
|
@@ -8,6 +9,7 @@ export class TruBreezeValidator {
|
|
|
8
9
|
dataContext;
|
|
9
10
|
viewContainerRef;
|
|
10
11
|
componentFactoryResolver;
|
|
12
|
+
entity;
|
|
11
13
|
config;
|
|
12
14
|
constructor(el, dataContext, viewContainerRef, componentFactoryResolver) {
|
|
13
15
|
this.el = el;
|
|
@@ -20,15 +22,16 @@ export class TruBreezeValidator {
|
|
|
20
22
|
dialogRef = null;
|
|
21
23
|
subs = [];
|
|
22
24
|
currentDialog = null;
|
|
25
|
+
context = TruValidationDialogContext.Control;
|
|
23
26
|
getMergeData = () => {
|
|
24
|
-
if (this.config.
|
|
25
|
-
let propertyNameParts = this.config.
|
|
27
|
+
if (this.config.propertyPath?.includes('/')) {
|
|
28
|
+
let propertyNameParts = this.config.propertyPath.split('/');
|
|
26
29
|
propertyNameParts.pop();
|
|
27
30
|
let targetProperty;
|
|
28
31
|
propertyNameParts.forEach((name) => {
|
|
29
32
|
if (!targetProperty) {
|
|
30
33
|
let targetPropertyName = 'o' + name;
|
|
31
|
-
targetProperty = this.
|
|
34
|
+
targetProperty = this.entity[targetPropertyName];
|
|
32
35
|
}
|
|
33
36
|
else {
|
|
34
37
|
let targetPropertyName = 'o' + name;
|
|
@@ -41,7 +44,7 @@ export class TruBreezeValidator {
|
|
|
41
44
|
return undefined;
|
|
42
45
|
}
|
|
43
46
|
else {
|
|
44
|
-
return this.
|
|
47
|
+
return this.entity.Merge_Data_Set?.get(this.config.propertyName) ? this.entity.Merge_Data_Set : undefined;
|
|
45
48
|
}
|
|
46
49
|
};
|
|
47
50
|
parseErrorMessages = (validationErrors) => {
|
|
@@ -70,54 +73,57 @@ export class TruBreezeValidator {
|
|
|
70
73
|
const entityPkeyName = validationTableName + 'Ref';
|
|
71
74
|
const validationObjectEntitypkeyName = validationTableName + 'Ref';
|
|
72
75
|
let addedPropertyValdations = validationObject.added.filter((v) => {
|
|
73
|
-
return v.propertyName === this.config.
|
|
76
|
+
return v.propertyName === this.config.propertyName;
|
|
74
77
|
});
|
|
75
78
|
let removedPropertyValdations = validationObject.removed.filter((v) => {
|
|
76
|
-
return v.propertyName === this.config.
|
|
79
|
+
return v.propertyName === this.config.propertyName;
|
|
77
80
|
});
|
|
78
81
|
this.mergeData = this.getMergeData();
|
|
79
|
-
if (this.config.
|
|
80
|
-
this.
|
|
82
|
+
if (this.config.rootTable === validationTableName &&
|
|
83
|
+
this.entity[entityPkeyName] === validationObjectEntity[validationObjectEntitypkeyName] &&
|
|
81
84
|
(addedPropertyValdations.length || this.mergeData)) {
|
|
82
85
|
this.removeValidationDialog();
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
this.
|
|
86
|
+
let config = new TruValidationDialogConfig(this.entity, this.config);
|
|
87
|
+
config.propertyName = this.config.propertyName;
|
|
88
|
+
config.mergeData = this.mergeData;
|
|
89
|
+
config.errorMsg = this.parseErrorMessages(addedPropertyValdations);
|
|
90
|
+
this.addValidationDialog(config);
|
|
87
91
|
}
|
|
88
|
-
if (this.config.
|
|
89
|
-
this.
|
|
92
|
+
if (this.config.rootTable === validationTableName &&
|
|
93
|
+
this.entity[entityPkeyName] === validationObjectEntity[validationObjectEntitypkeyName] &&
|
|
90
94
|
(removedPropertyValdations.length)) {
|
|
91
95
|
this.removeValidationDialog();
|
|
92
96
|
}
|
|
93
97
|
};
|
|
94
98
|
ngOnInit() { }
|
|
95
99
|
ngAfterViewInit() {
|
|
96
|
-
if (this.
|
|
100
|
+
if (this.context !== TruValidationDialogContext.Grid && !this.config.isSubProperty) {
|
|
97
101
|
this.subs.push(this.dataContext.validationChangeDetection.subscribe(entities => {
|
|
98
102
|
this.valErrsChanged(entities);
|
|
99
103
|
}));
|
|
100
104
|
}
|
|
101
105
|
}
|
|
102
106
|
ngOnChanges(changes) {
|
|
103
|
-
if (!changes.
|
|
107
|
+
if (!changes.entity.firstChange) {
|
|
104
108
|
this.removeValidationDialog();
|
|
105
|
-
this.
|
|
109
|
+
this.entity.entityAspect.validateEntity();
|
|
106
110
|
}
|
|
107
111
|
}
|
|
108
112
|
ngOnDestroy() {
|
|
109
113
|
this.subs.forEach(s => s.unsubscribe());
|
|
110
114
|
}
|
|
111
115
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruBreezeValidator, deps: [{ token: i0.ElementRef }, { token: i1.TruDataContext }, { token: i0.ViewContainerRef }, { token: i0.ComponentFactoryResolver }], target: i0.ɵɵFactoryTarget.Directive });
|
|
112
|
-
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.5", type: TruBreezeValidator, selector: "[truBreezeValidator]", inputs: {
|
|
116
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.5", type: TruBreezeValidator, selector: "[truBreezeValidator]", inputs: { entity: ["truBreezeValidator", "entity"], config: "config" }, usesOnChanges: true, ngImport: i0 });
|
|
113
117
|
}
|
|
114
118
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruBreezeValidator, decorators: [{
|
|
115
119
|
type: Directive,
|
|
116
120
|
args: [{
|
|
117
121
|
selector: '[truBreezeValidator]'
|
|
118
122
|
}]
|
|
119
|
-
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.TruDataContext }, { type: i0.ViewContainerRef }, { type: i0.ComponentFactoryResolver }], propDecorators: {
|
|
123
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.TruDataContext }, { type: i0.ViewContainerRef }, { type: i0.ComponentFactoryResolver }], propDecorators: { entity: [{
|
|
120
124
|
type: Input,
|
|
121
125
|
args: ['truBreezeValidator']
|
|
126
|
+
}], config: [{
|
|
127
|
+
type: Input
|
|
122
128
|
}] } });
|
|
123
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tru-breeze-validator.js","sourceRoot":"","sources":["../../../../../../projects/tru-common-lib/src/lib/directives/breeze-validator/tru-breeze-validator.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentFactoryResolver, ComponentRef, Directive, ElementRef, Input, OnDestroy, OnInit, SimpleChanges, ViewContainerRef } from '@angular/core';\r\nimport { ValidationError } from 'breeze-client';\r\nimport { Subscription } from 'rxjs';\r\nimport { forEach } from 'underscore';\r\nimport { TruEditControlConfigBase } from '../../base-classes/tru-edit-control-config-base';\r\nimport { TruEntityBase } from '../../base-classes/tru-entity-base';\r\nimport { TruMergeData } from '../../classes/tru-merge-data';\r\nimport { TruMergeDataSet } from '../../classes/tru-merge-data-set';\r\nimport { TruValidationDialog } from '../../components/validation-dialog/tru-validation-dialog';\r\nimport { TruValidationDialogConfig } from '../../components/validation-dialog/tru-validation-dialog-config';\r\nimport { TruDataContext } from '../../services/tru-data-context';\r\nimport { TruValidationDialogContext } from '../../../public-api';\r\n\r\n@Directive({\r\n  selector: '[truBreezeValidator]'\r\n})\r\nexport class TruBreezeValidator implements OnInit, OnDestroy {\r\n  @Input('truBreezeValidator') config!: TruValidationDialogConfig;\r\n\r\n  constructor(\r\n    private el: ElementRef,\r\n    private dataContext: TruDataContext,\r\n    private viewContainerRef: ViewContainerRef,\r\n    private componentFactoryResolver: ComponentFactoryResolver) {\r\n  }\r\n\r\n  configModel: any = {};\r\n  mergeData: any;\r\n\r\n  private dialogRef: ComponentRef<any> | null = null;\r\n  private subs: Array<Subscription> = [];\r\n  private currentDialog: ComponentRef<TruValidationDialog> | null = null\r\n\r\n  private getMergeData = (): TruMergeDataSet | undefined => {\r\n    if (this.config.propertyConfig.propertyPath?.includes('/')) {\r\n      let propertyNameParts = this.config.propertyConfig.propertyPath.split('/');\r\n      propertyNameParts.pop();\r\n      let targetProperty: any;\r\n      propertyNameParts.forEach((name) => {\r\n        if (!targetProperty) {\r\n          let targetPropertyName = 'o' + name as keyof typeof this.config.entity;\r\n          targetProperty = this.config.entity[targetPropertyName];\r\n        } else {\r\n          let targetPropertyName = 'o' + name as keyof typeof this.config.entity;\r\n          targetProperty = targetProperty[targetPropertyName];\r\n        }\r\n      });\r\n      if (targetProperty && targetProperty.Merge_Data) {\r\n        return targetProperty.Merge_Data_Set;\r\n      }\r\n      return undefined;\r\n    } else {\r\n      return this.config.entity.Merge_Data_Set?.get(this.config.propertyName as string) ? this.config.entity.Merge_Data_Set : undefined;\r\n    }\r\n  }\r\n\r\n  private parseErrorMessages = (validationErrors: Array<ValidationError>): string => {\r\n    let errorMsg: string = '';\r\n    validationErrors.forEach((error) => {\r\n      errorMsg += error.errorMessage + '; ';\r\n    });\r\n    return errorMsg;\r\n  }\r\n\r\n  private addValidationDialog = (config: TruValidationDialogConfig) => {\r\n    let componentFactory = this.componentFactoryResolver.resolveComponentFactory(TruValidationDialog);\r\n    let component = this.viewContainerRef.createComponent<TruValidationDialog>(componentFactory, 0, this.viewContainerRef.injector);\r\n    component.instance.config = config;\r\n    this.currentDialog = component;\r\n    this.dialogRef = component;\r\n  }\r\n\r\n  private removeValidationDialog = () => {\r\n    if (this.currentDialog) {\r\n      this.currentDialog.destroy();\r\n      this.currentDialog = null;\r\n    }\r\n  }\r\n\r\n  valErrsChanged = (validationObject: any) => {\r\n    let validationObjectEntity = validationObject.entity\r\n    let validationTableName = validationObjectEntity.constructor.name;\r\n\r\n    type EntityObjectKey = keyof typeof this.config.entity;\r\n    const entityPkeyName = validationTableName + 'Ref' as EntityObjectKey;\r\n\r\n    type ValidationObjectEntityObjectKey = keyof typeof validationObjectEntity;\r\n    const validationObjectEntitypkeyName = validationTableName + 'Ref' as ValidationObjectEntityObjectKey;\r\n\r\n    let addedPropertyValdations = validationObject.added.filter((v: any) => {\r\n      return v.propertyName === this.config.propertyConfig.propertyName\r\n    });\r\n\r\n    let removedPropertyValdations = validationObject.removed.filter((v: any) => {\r\n      return v.propertyName === this.config.propertyConfig.propertyName\r\n    });\r\n\r\n    this.mergeData = this.getMergeData();\r\n\r\n    if (\r\n      this.config.propertyConfig.rootTable === validationTableName &&\r\n      this.config.entity[entityPkeyName] === validationObjectEntity[validationObjectEntitypkeyName] &&\r\n      (addedPropertyValdations.length || this.mergeData)) {\r\n      this.removeValidationDialog();\r\n      this.config.propertyName = this.config.propertyConfig.propertyName as string;\r\n      this.config.mergeData = this.mergeData;\r\n      this.config.errorMsg = this.parseErrorMessages(addedPropertyValdations);\r\n      this.addValidationDialog(this.config);\r\n    }\r\n\r\n    if (\r\n      this.config.propertyConfig.rootTable === validationTableName &&\r\n      this.config.entity[entityPkeyName] === validationObjectEntity[validationObjectEntitypkeyName] &&\r\n      (removedPropertyValdations.length)) {\r\n      this.removeValidationDialog();\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void { }\r\n\r\n  ngAfterViewInit(): void {\r\n    if (this.config.context !== TruValidationDialogContext.Grid && !this.config.isSubProperty) {\r\n      this.subs.push(this.dataContext.validationChangeDetection.subscribe(entities => {\r\n        this.valErrsChanged(entities);\r\n      }));\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (!changes.config.firstChange) {\r\n      this.removeValidationDialog();\r\n      this.config.entity.entityAspect.validateEntity();\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subs.forEach(s => s.unsubscribe());\r\n  }\r\n}\r\n"]}
|
|
129
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tru-breeze-validator.js","sourceRoot":"","sources":["../../../../../../projects/tru-common-lib/src/lib/directives/breeze-validator/tru-breeze-validator.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentFactoryResolver, ComponentRef, Directive, ElementRef, Input, OnDestroy, OnInit, SimpleChanges, ViewContainerRef } from '@angular/core';\r\nimport { ValidationError } from 'breeze-client';\r\nimport { Subscription } from 'rxjs';\r\nimport { TruValidationDialogContext } from '../../../public-api';\r\nimport { TruEditControlConfigBase } from '../../base-classes/tru-edit-control-config-base';\r\nimport { TruListControlConfigBase } from '../../base-classes/tru-list-control-config-base';\r\nimport { TruMergeDataSet } from '../../classes/tru-merge-data-set';\r\nimport { TruValidationDialog } from '../../components/validation-dialog/tru-validation-dialog';\r\nimport { TruValidationDialogConfig } from '../../components/validation-dialog/tru-validation-dialog-config';\r\nimport { TruDataContext } from '../../services/tru-data-context';\r\n\r\n@Directive({\r\n  selector: '[truBreezeValidator]'\r\n})\r\nexport class TruBreezeValidator implements OnInit, OnDestroy {\r\n  @Input('truBreezeValidator') entity!: any;\r\n  @Input() config!: TruEditControlConfigBase<any> | TruListControlConfigBase<any>;\r\n\r\n  constructor(\r\n    private el: ElementRef,\r\n    private dataContext: TruDataContext,\r\n    private viewContainerRef: ViewContainerRef,\r\n    private componentFactoryResolver: ComponentFactoryResolver) {\r\n  }\r\n\r\n  configModel: any = {};\r\n  mergeData: any;\r\n\r\n  private dialogRef: ComponentRef<any> | null = null;\r\n  private subs: Array<Subscription> = [];\r\n  private currentDialog: ComponentRef<TruValidationDialog> | null = null;\r\n  private context: TruValidationDialogContext = TruValidationDialogContext.Control;\r\n\r\n  private getMergeData = (): TruMergeDataSet | undefined => {\r\n    if (this.config.propertyPath?.includes('/')) {\r\n      let propertyNameParts = this.config.propertyPath.split('/');\r\n      propertyNameParts.pop();\r\n      let targetProperty: any;\r\n      propertyNameParts.forEach((name) => {\r\n        if (!targetProperty) {\r\n          let targetPropertyName = 'o' + name as keyof typeof this.entity;\r\n          targetProperty = this.entity[targetPropertyName];\r\n        } else {\r\n          let targetPropertyName = 'o' + name as keyof typeof this.entity;\r\n          targetProperty = targetProperty[targetPropertyName];\r\n        }\r\n      });\r\n      if (targetProperty && targetProperty.Merge_Data) {\r\n        return targetProperty.Merge_Data_Set;\r\n      }\r\n      return undefined;\r\n    } else {\r\n      return this.entity.Merge_Data_Set?.get(this.config.propertyName as string) ? this.entity.Merge_Data_Set : undefined;\r\n    }\r\n  }\r\n\r\n  private parseErrorMessages = (validationErrors: Array<ValidationError>): string => {\r\n    let errorMsg: string = '';\r\n    validationErrors.forEach((error) => {\r\n      errorMsg += error.errorMessage + '; ';\r\n    });\r\n    return errorMsg;\r\n  }\r\n\r\n  private addValidationDialog = (config: TruValidationDialogConfig) => {\r\n    let componentFactory = this.componentFactoryResolver.resolveComponentFactory(TruValidationDialog);\r\n    let component = this.viewContainerRef.createComponent<TruValidationDialog>(componentFactory, 0, this.viewContainerRef.injector);\r\n    component.instance.config = config;\r\n    this.currentDialog = component;\r\n    this.dialogRef = component;\r\n  }\r\n\r\n  private removeValidationDialog = () => {\r\n    if (this.currentDialog) {\r\n      this.currentDialog.destroy();\r\n      this.currentDialog = null;\r\n    }\r\n  }\r\n\r\n  valErrsChanged = (validationObject: any) => {\r\n    let validationObjectEntity = validationObject.entity\r\n    let validationTableName = validationObjectEntity.constructor.name;\r\n\r\n    type EntityObjectKey = keyof typeof this.entity;\r\n    const entityPkeyName = validationTableName + 'Ref' as EntityObjectKey;\r\n\r\n    type ValidationObjectEntityObjectKey = keyof typeof validationObjectEntity;\r\n    const validationObjectEntitypkeyName = validationTableName + 'Ref' as ValidationObjectEntityObjectKey;\r\n\r\n    let addedPropertyValdations = validationObject.added.filter((v: any) => {\r\n      return v.propertyName === this.config.propertyName\r\n    });\r\n\r\n    let removedPropertyValdations = validationObject.removed.filter((v: any) => {\r\n      return v.propertyName === this.config.propertyName\r\n    });\r\n\r\n    this.mergeData = this.getMergeData();\r\n\r\n    if (\r\n      this.config.rootTable === validationTableName &&\r\n      this.entity[entityPkeyName] === validationObjectEntity[validationObjectEntitypkeyName] &&\r\n      (addedPropertyValdations.length || this.mergeData)) {\r\n      this.removeValidationDialog();\r\n      let config = new TruValidationDialogConfig(this.entity, this.config);\r\n      config.propertyName = this.config.propertyName as string;\r\n      config.mergeData = this.mergeData;\r\n      config.errorMsg = this.parseErrorMessages(addedPropertyValdations);\r\n      this.addValidationDialog(config);\r\n    }\r\n\r\n    if (\r\n      this.config.rootTable === validationTableName &&\r\n      this.entity[entityPkeyName] === validationObjectEntity[validationObjectEntitypkeyName] &&\r\n      (removedPropertyValdations.length)) {\r\n      this.removeValidationDialog();\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void { }\r\n\r\n  ngAfterViewInit(): void {\r\n    if (this.context !== TruValidationDialogContext.Grid && !this.config.isSubProperty) {\r\n      this.subs.push(this.dataContext.validationChangeDetection.subscribe(entities => {\r\n        this.valErrsChanged(entities);\r\n      }));\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (!changes.entity.firstChange) {\r\n      this.removeValidationDialog();\r\n      this.entity.entityAspect.validateEntity();\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subs.forEach(s => s.unsubscribe());\r\n  }\r\n}\r\n"]}
|
|
@@ -7118,6 +7118,7 @@ class TruBreezeValidator {
|
|
|
7118
7118
|
dataContext;
|
|
7119
7119
|
viewContainerRef;
|
|
7120
7120
|
componentFactoryResolver;
|
|
7121
|
+
entity;
|
|
7121
7122
|
config;
|
|
7122
7123
|
constructor(el, dataContext, viewContainerRef, componentFactoryResolver) {
|
|
7123
7124
|
this.el = el;
|
|
@@ -7130,15 +7131,16 @@ class TruBreezeValidator {
|
|
|
7130
7131
|
dialogRef = null;
|
|
7131
7132
|
subs = [];
|
|
7132
7133
|
currentDialog = null;
|
|
7134
|
+
context = TruValidationDialogContext.Control;
|
|
7133
7135
|
getMergeData = () => {
|
|
7134
|
-
if (this.config.
|
|
7135
|
-
let propertyNameParts = this.config.
|
|
7136
|
+
if (this.config.propertyPath?.includes('/')) {
|
|
7137
|
+
let propertyNameParts = this.config.propertyPath.split('/');
|
|
7136
7138
|
propertyNameParts.pop();
|
|
7137
7139
|
let targetProperty;
|
|
7138
7140
|
propertyNameParts.forEach((name) => {
|
|
7139
7141
|
if (!targetProperty) {
|
|
7140
7142
|
let targetPropertyName = 'o' + name;
|
|
7141
|
-
targetProperty = this.
|
|
7143
|
+
targetProperty = this.entity[targetPropertyName];
|
|
7142
7144
|
}
|
|
7143
7145
|
else {
|
|
7144
7146
|
let targetPropertyName = 'o' + name;
|
|
@@ -7151,7 +7153,7 @@ class TruBreezeValidator {
|
|
|
7151
7153
|
return undefined;
|
|
7152
7154
|
}
|
|
7153
7155
|
else {
|
|
7154
|
-
return this.
|
|
7156
|
+
return this.entity.Merge_Data_Set?.get(this.config.propertyName) ? this.entity.Merge_Data_Set : undefined;
|
|
7155
7157
|
}
|
|
7156
7158
|
};
|
|
7157
7159
|
parseErrorMessages = (validationErrors) => {
|
|
@@ -7180,55 +7182,58 @@ class TruBreezeValidator {
|
|
|
7180
7182
|
const entityPkeyName = validationTableName + 'Ref';
|
|
7181
7183
|
const validationObjectEntitypkeyName = validationTableName + 'Ref';
|
|
7182
7184
|
let addedPropertyValdations = validationObject.added.filter((v) => {
|
|
7183
|
-
return v.propertyName === this.config.
|
|
7185
|
+
return v.propertyName === this.config.propertyName;
|
|
7184
7186
|
});
|
|
7185
7187
|
let removedPropertyValdations = validationObject.removed.filter((v) => {
|
|
7186
|
-
return v.propertyName === this.config.
|
|
7188
|
+
return v.propertyName === this.config.propertyName;
|
|
7187
7189
|
});
|
|
7188
7190
|
this.mergeData = this.getMergeData();
|
|
7189
|
-
if (this.config.
|
|
7190
|
-
this.
|
|
7191
|
+
if (this.config.rootTable === validationTableName &&
|
|
7192
|
+
this.entity[entityPkeyName] === validationObjectEntity[validationObjectEntitypkeyName] &&
|
|
7191
7193
|
(addedPropertyValdations.length || this.mergeData)) {
|
|
7192
7194
|
this.removeValidationDialog();
|
|
7193
|
-
|
|
7194
|
-
|
|
7195
|
-
|
|
7196
|
-
this.
|
|
7197
|
-
|
|
7198
|
-
|
|
7199
|
-
|
|
7195
|
+
let config = new TruValidationDialogConfig(this.entity, this.config);
|
|
7196
|
+
config.propertyName = this.config.propertyName;
|
|
7197
|
+
config.mergeData = this.mergeData;
|
|
7198
|
+
config.errorMsg = this.parseErrorMessages(addedPropertyValdations);
|
|
7199
|
+
this.addValidationDialog(config);
|
|
7200
|
+
}
|
|
7201
|
+
if (this.config.rootTable === validationTableName &&
|
|
7202
|
+
this.entity[entityPkeyName] === validationObjectEntity[validationObjectEntitypkeyName] &&
|
|
7200
7203
|
(removedPropertyValdations.length)) {
|
|
7201
7204
|
this.removeValidationDialog();
|
|
7202
7205
|
}
|
|
7203
7206
|
};
|
|
7204
7207
|
ngOnInit() { }
|
|
7205
7208
|
ngAfterViewInit() {
|
|
7206
|
-
if (this.
|
|
7209
|
+
if (this.context !== TruValidationDialogContext.Grid && !this.config.isSubProperty) {
|
|
7207
7210
|
this.subs.push(this.dataContext.validationChangeDetection.subscribe(entities => {
|
|
7208
7211
|
this.valErrsChanged(entities);
|
|
7209
7212
|
}));
|
|
7210
7213
|
}
|
|
7211
7214
|
}
|
|
7212
7215
|
ngOnChanges(changes) {
|
|
7213
|
-
if (!changes.
|
|
7216
|
+
if (!changes.entity.firstChange) {
|
|
7214
7217
|
this.removeValidationDialog();
|
|
7215
|
-
this.
|
|
7218
|
+
this.entity.entityAspect.validateEntity();
|
|
7216
7219
|
}
|
|
7217
7220
|
}
|
|
7218
7221
|
ngOnDestroy() {
|
|
7219
7222
|
this.subs.forEach(s => s.unsubscribe());
|
|
7220
7223
|
}
|
|
7221
7224
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruBreezeValidator, deps: [{ token: i0.ElementRef }, { token: TruDataContext }, { token: i0.ViewContainerRef }, { token: i0.ComponentFactoryResolver }], target: i0.ɵɵFactoryTarget.Directive });
|
|
7222
|
-
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.5", type: TruBreezeValidator, selector: "[truBreezeValidator]", inputs: {
|
|
7225
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.5", type: TruBreezeValidator, selector: "[truBreezeValidator]", inputs: { entity: ["truBreezeValidator", "entity"], config: "config" }, usesOnChanges: true, ngImport: i0 });
|
|
7223
7226
|
}
|
|
7224
7227
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruBreezeValidator, decorators: [{
|
|
7225
7228
|
type: Directive,
|
|
7226
7229
|
args: [{
|
|
7227
7230
|
selector: '[truBreezeValidator]'
|
|
7228
7231
|
}]
|
|
7229
|
-
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: TruDataContext }, { type: i0.ViewContainerRef }, { type: i0.ComponentFactoryResolver }], propDecorators: {
|
|
7232
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: TruDataContext }, { type: i0.ViewContainerRef }, { type: i0.ComponentFactoryResolver }], propDecorators: { entity: [{
|
|
7230
7233
|
type: Input,
|
|
7231
7234
|
args: ['truBreezeValidator']
|
|
7235
|
+
}], config: [{
|
|
7236
|
+
type: Input
|
|
7232
7237
|
}] } });
|
|
7233
7238
|
|
|
7234
7239
|
class TruBreezeValidatorModule {
|