@trudb/tru-common-lib 0.1.82 → 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.
@@ -3,4 +3,4 @@ export class TruEditControlConfigBase {
3
3
  choices;
4
4
  choicesEntityType;
5
5
  }
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LWVkaXQtY29udHJvbC1jb25maWctYmFzZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RydS1jb21tb24tbGliL3NyYy9saWIvYmFzZS1jbGFzc2VzL3RydS1lZGl0LWNvbnRyb2wtY29uZmlnLWJhc2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBS0EsTUFBTSxPQUFnQix3QkFBd0I7SUFrQjVDLGdCQUFnQixDQUFDO0lBR1AsT0FBTyxDQUFpQztJQUN4QyxpQkFBaUIsQ0FBTztDQUNuQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE9ic2VydmFibGUsIFN1YmplY3QgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgVHJ1UHJvcGVydHlDb25maWdCYXNlIH0gZnJvbSAnLi90cnUtcHJvcGVydHktY29uZmlnLWJhc2UnO1xyXG5pbXBvcnQgeyBUcnVFbnRpdHlCYXNlIH0gZnJvbSAnLi90cnUtZW50aXR5LWJhc2UnO1xyXG5pbXBvcnQgeyBUcnVDaG9pY2UgfSBmcm9tICcuLi9jbGFzc2VzL3RydS1jaG9pY2UnO1xyXG5cclxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIFRydUVkaXRDb250cm9sQ29uZmlnQmFzZTxUPiB7XHJcbiAgYWJzdHJhY3QgbGFiZWw6IHN0cmluZyB8IHVuZGVmaW5lZDtcclxuICBhYnN0cmFjdCBwcm9wZXJ0eU5hbWU6IHN0cmluZyB8IHVuZGVmaW5lZDtcclxuICBhYnN0cmFjdCByb290VGFibGU6IHN0cmluZyB8IHVuZGVmaW5lZDtcclxuICBhYnN0cmFjdCByZWxhdGVkVGFibGVUeXBlOiB0eXBlb2YgVHJ1RW50aXR5QmFzZSB8IHVuZGVmaW5lZDtcclxuICBhYnN0cmFjdCBwcm9wZXJ0eVBhdGg6IHN0cmluZyB8IHVuZGVmaW5lZDtcclxuICBhYnN0cmFjdCBydWxlcyhlbnRpdHk6IGFueSk6IHt9IHwgbnVsbDtcclxuICBhYnN0cmFjdCBzdWJQcm9wZXJ0aWVzOiBBcnJheTxzdHJpbmc+O1xyXG4gIGFic3RyYWN0IGdldCBwcm9wZXJ0eSgpOiBUcnVQcm9wZXJ0eUNvbmZpZ0Jhc2U7XHJcblxyXG4gIGFic3RyYWN0IHNldCBlbnRpdHkodmFsdWU6IGFueSk7XHJcblxyXG4gIGFic3RyYWN0IGdldCAkKCk6IFQ7XHJcbiAgYWJzdHJhY3Qgc2V0ICQodmFsdWU6IFQpO1xyXG5cclxuICBhYnN0cmFjdCBvbkNoYW5nZSgpOiBTdWJqZWN0PFQ+XHJcbiAgYWJzdHJhY3QgY2hhbmdlKHZhbHVlOiBUKTogdm9pZDtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcbiAgcHJvdGVjdGVkIGhpZD8oZW50aXR5OiBUcnVFbnRpdHlCYXNlKTogc3RyaW5nIHwgbnVsbCB8IHVuZGVmaW5lZDtcclxuICBwcm90ZWN0ZWQgY2hvaWNlcz86ICgpID0+IE9ic2VydmFibGU8VHJ1Q2hvaWNlW10+O1xyXG4gIHByb3RlY3RlZCBjaG9pY2VzRW50aXR5VHlwZT86IGFueTtcclxufVxyXG4iXX0=
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LWxpc3QtY29udHJvbC1jb25maWctYmFzZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RydS1jb21tb24tbGliL3NyYy9saWIvYmFzZS1jbGFzc2VzL3RydS1saXN0LWNvbnRyb2wtY29uZmlnLWJhc2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBS0EsTUFBTSxPQUFnQix3QkFBd0I7SUFrQjVDLGdCQUFnQixDQUFDO0lBR1AsT0FBTyxDQUFpQztJQUN4QyxpQkFBaUIsQ0FBTztDQUNuQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE9ic2VydmFibGUsIFN1YmplY3QgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgVHJ1UHJvcGVydHlDb25maWdCYXNlIH0gZnJvbSAnLi90cnUtcHJvcGVydHktY29uZmlnLWJhc2UnO1xyXG5pbXBvcnQgeyBUcnVFbnRpdHlCYXNlIH0gZnJvbSAnLi90cnUtZW50aXR5LWJhc2UnO1xyXG5pbXBvcnQgeyBUcnVDaG9pY2UgfSBmcm9tICcuLi9jbGFzc2VzL3RydS1jaG9pY2UnO1xyXG5cclxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIFRydUxpc3RDb250cm9sQ29uZmlnQmFzZTxUPiB7XHJcbiAgYWJzdHJhY3QgbGFiZWw6IHN0cmluZyB8IHVuZGVmaW5lZDtcclxuICBhYnN0cmFjdCBwcm9wZXJ0eU5hbWU6IHN0cmluZyB8IHVuZGVmaW5lZDtcclxuICBhYnN0cmFjdCByb290VGFibGU6IHN0cmluZyB8IHVuZGVmaW5lZDtcclxuICBhYnN0cmFjdCByZWxhdGVkVGFibGVUeXBlOiB0eXBlb2YgVHJ1RW50aXR5QmFzZSB8IHVuZGVmaW5lZDtcclxuICBhYnN0cmFjdCBwcm9wZXJ0eVBhdGg6IHN0cmluZyB8IHVuZGVmaW5lZDtcclxuICBhYnN0cmFjdCBydWxlcyhlbnRpdHk6IGFueSk6IHt9IHwgbnVsbDtcclxuICBhYnN0cmFjdCBzdWJQcm9wZXJ0aWVzOiBBcnJheTxzdHJpbmc+O1xyXG4gIGFic3RyYWN0IGdldCBwcm9wZXJ0eSgpOiBUcnVQcm9wZXJ0eUNvbmZpZ0Jhc2U7XHJcblxyXG4gIGFic3RyYWN0IHNldCBlbnRpdHkodmFsdWU6IGFueSk7XHJcblxyXG4gIGFic3RyYWN0IGdldCAkKCk6IFQ7XHJcbiAgYWJzdHJhY3Qgc2V0ICQodmFsdWU6IFQpO1xyXG5cclxuICBhYnN0cmFjdCBvbkNoYW5nZSgpOiBTdWJqZWN0PFQ+XHJcbiAgYWJzdHJhY3QgY2hhbmdlKHZhbHVlOiBUKTogdm9pZDtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcbiAgcHJvdGVjdGVkIGhpZD8oZW50aXR5OiBUcnVFbnRpdHlCYXNlKTogc3RyaW5nIHwgbnVsbCB8IHVuZGVmaW5lZDtcclxuICBwcm90ZWN0ZWQgY2hvaWNlcz86ICgpID0+IE9ic2VydmFibGU8VHJ1Q2hvaWNlW10+O1xyXG4gIHByb3RlY3RlZCBjaG9pY2VzRW50aXR5VHlwZT86IGFueTtcclxufVxyXG4iXX0=
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.propertyConfig.propertyPath?.includes('/')) {
25
- let propertyNameParts = this.config.propertyConfig.propertyPath.split('/');
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.config.entity[targetPropertyName];
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.config.entity.Merge_Data_Set?.get(this.config.propertyName) ? this.config.entity.Merge_Data_Set : undefined;
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.propertyConfig.propertyName;
76
+ return v.propertyName === this.config.propertyName;
74
77
  });
75
78
  let removedPropertyValdations = validationObject.removed.filter((v) => {
76
- return v.propertyName === this.config.propertyConfig.propertyName;
79
+ return v.propertyName === this.config.propertyName;
77
80
  });
78
81
  this.mergeData = this.getMergeData();
79
- if (this.config.propertyConfig.rootTable === validationTableName &&
80
- this.config.entity[entityPkeyName] === validationObjectEntity[validationObjectEntitypkeyName] &&
82
+ if (this.config.rootTable === validationTableName &&
83
+ this.entity[entityPkeyName] === validationObjectEntity[validationObjectEntitypkeyName] &&
81
84
  (addedPropertyValdations.length || this.mergeData)) {
82
85
  this.removeValidationDialog();
83
- this.config.propertyName = this.config.propertyConfig.propertyName;
84
- this.config.mergeData = this.mergeData;
85
- this.config.errorMsg = this.parseErrorMessages(addedPropertyValdations);
86
- this.addValidationDialog(this.config);
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.propertyConfig.rootTable === validationTableName &&
89
- this.config.entity[entityPkeyName] === validationObjectEntity[validationObjectEntitypkeyName] &&
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.config.context !== TruValidationDialogContext.Grid && !this.config.isSubProperty) {
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.config.firstChange) {
107
+ if (!changes.entity.firstChange) {
104
108
  this.removeValidationDialog();
105
- this.config.entity.entityAspect.validateEntity();
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: { config: ["truBreezeValidator", "config"] }, usesOnChanges: true, ngImport: i0 });
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: { config: [{
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"]}
@@ -3,10 +3,10 @@ import * as i0 from "@angular/core";
3
3
  export class TruUtil {
4
4
  constructor() { }
5
5
  numberToString = (value) => {
6
- return this === undefined ? '' : (this).toString();
6
+ return value === undefined ? '' : (value).toString();
7
7
  };
8
8
  nullableNumberToString = (value) => {
9
- return this === null || this === undefined ? '' : (this).toString();
9
+ return value === null || value === undefined ? '' : (value).toString();
10
10
  };
11
11
  tryParseInt = (str, defaultValue) => {
12
12
  var retValue = defaultValue;
@@ -101,4 +101,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
101
101
  providedIn: 'root',
102
102
  }]
103
103
  }], ctorParameters: () => [] });
104
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tru-util.js","sourceRoot":"","sources":["../../../../../projects/tru-common-lib/src/lib/services/tru-util.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,UAAU,EAAE,MAAM,eAAe,CAAC;;AAMvD,MAAM,OAAO,OAAO;IAElB,gBAAgB,CAAC;IAEjB,cAAc,GAAG,CAAC,KAAyB,EAAU,EAAE;QACrD,OAAO,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,CAAC;IACrD,CAAC,CAAA;IAED,sBAAsB,GAAG,CAAC,KAAgC,EAAU,EAAE;QACpE,OAAO,IAAI,KAAK,IAAI,IAAI,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,CAAC;IACtE,CAAC,CAAA;IAED,WAAW,GAAG,CAAC,GAAQ,EAAE,YAAiB,EAAE,EAAE;QAC5C,IAAI,QAAQ,GAAG,YAAY,CAAC;QAC5B,IAAI,GAAG,KAAK,IAAI,EAAE,CAAC;YACjB,IAAI,GAAG,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACnB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC;oBAChB,QAAQ,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC;gBAC3B,CAAC;YACH,CAAC;QACH,CAAC;QACD,OAAO,QAAQ,CAAC;IAClB,CAAC,CAAC;IAEF,YAAY,CAAC,KAAU,EAAE,YAAiB;QACxC,OAAO,CAAC,KAAK,IAAI,MAAM,IAAI,KAAK,IAAI,OAAO,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,KAAK,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,YAAY,CAAC;IACzH,CAAC;IAED,0BAA0B,GAAG,CAAC,OAAY,EAAE,WAAmB,EAAE,EAAE;QACjE,IAAI,SAAS,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACtC,OAAO,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;YAC7C,IAAI,SAAS,KAAK,GAAG,EAAE,CAAC;gBACtB,IAAI,OAAO,CAAC,SAAS,IAAI,OAAO,CAAC,SAAS,CAAC,QAAQ,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;oBAC3E,OAAO,OAAO,CAAC;gBACjB,CAAC;YACH,CAAC;QACH,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC,CAAC;IAEF,SAAS,GAAG,CAAC,CAAM,EAAE,EAAE;QACrB,OAAO,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,IAAI,QAAQ,CAAC,CAAC,CAAC,CAAC;IAC9C,CAAC,CAAA;IAED,iCAAiC,GAAG,CAAC,KAAa,EAAE,EAAE;QACpD,OAAO,KAAK,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;IACtC,CAAC,CAAA;IAED,MAAM,GAAG,CAAC,IAAU,EAAE,EAAE;QACtB,IAAI,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,eAAe,EAAE,CAAC;YAC7D,IAAI,KAAK,CAAE,IAAa,CAAC,OAAO,EAAE,CAAC,EAAE,CAAC;gBACpC,OAAO,KAAK,CAAC;YACf,CAAC;iBACI,CAAC;gBACJ,OAAO,IAAI,CAAC;YACd,CAAC;QACH,CAAC;aACI,CAAC;YACJ,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC,CAAC;IAEF,WAAW,GAAG,CAAC,KAAa,EAAE,EAAE;QAC9B,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;IACnC,CAAC,CAAA;IAED,SAAS,GAAG,CAAC,MAAqB,EAAU,EAAE;QAC5C,IAAI,aAAa,GAAG;YAClB,iBAAiB,EAAE,SAAS;YAC5B,OAAO,EAAE,SAAS;YAClB,YAAY,EAAE,QAAQ;YACtB,iBAAiB,EAAE,OAAO;SAC3B,CAAA;QACD,IAAI,MAAM,KAAK,IAAI;YACjB,OAAO,aAAa,CAAC;QACvB,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACxC,MAAM,CAAC,MAAM,CAAC,aAAa,EAAE,MAAM,CAAC,CAAC;YACrC,OAAO,aAAa,CAAC;QACvB,CAAC;QACD,OAAO,aAAa,CAAC;IACvB,CAAC,CAAA;IAED;;;;;QAKI;IACJ,qBAAqB,GAAG,CAAC,IAAS,EAAS,EAAE;QAC3C,IAAI,OAAO,IAAI,KAAK,QAAQ,IAAI,IAAI,KAAK,IAAI;YAC3C,OAAO,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC/C,IAAI,MAAM,GAAG,EAAE,CAAC;QAChB,KAAK,IAAI,IAAI,IAAI,IAAI,EAAE,CAAC;YACtB,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,CAAC;gBAC/B,SAAS;YACX,CAAC;YACD,IAAI,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC;YACvB,MAAM,CAAC,IAAI,CACT,kBAAkB,CAAC,IAAI,CAAC;gBACxB,GAAG,GAAG,kBAAkB,CAAC,KAAK,IAAI,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;QAC1D,CAAC;QACD,IAAI,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC;aAC1B,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;QACxB,OAAO,CAAC,MAAM,CAAC,CAAC;IAClB,CAAC,CAAA;uGAxGU,OAAO;2GAAP,OAAO,cAFN,MAAM;;2FAEP,OAAO;kBAHnB,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","sourcesContent":["import { ElementRef, Injectable } from '@angular/core';\r\nimport moment from 'moment';\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class TruUtil {\r\n\r\n  constructor() { }\r\n\r\n  numberToString = (value: number | undefined): string => {\r\n    return this === undefined ? '' : (this).toString();\r\n  }\r\n\r\n  nullableNumberToString = (value: number | null | undefined): string => {\r\n    return this === null || this === undefined ? '' : (this).toString();\r\n  }\r\n\r\n  tryParseInt = (str: any, defaultValue: any) => {\r\n    var retValue = defaultValue;\r\n    if (str !== null) {\r\n      if (str.length > 0) {\r\n        if (!isNaN(str)) {\r\n          retValue = parseInt(str);\r\n        }\r\n      }\r\n    }\r\n    return retValue;\r\n  };\r\n\r\n  tryParseBool(value: any, defaultValue: any) {\r\n    return (value == 'true' || value == 'false' || value === true || value === false) && JSON.parse(value) || defaultValue;\r\n  }\r\n\r\n  findClosestAncestorByClass = (element: any, cssSelector: string) => {\r\n    let firstChar = cssSelector.charAt(0);\r\n    for (; element; element = element.parentNode) {\r\n      if (firstChar === '.') {\r\n        if (element.classList && element.classList.contains(cssSelector.substr(1))) {\r\n          return element;\r\n        }\r\n      }\r\n    }\r\n    return null;\r\n  };\r\n\r\n  isNumeric = (n: any) => {\r\n    return !isNaN(parseFloat(n)) && isFinite(n);\r\n  }\r\n\r\n  removeNonNumericCharactersFromStr = (value: string) => {\r\n    return value.replace(/[^0-9]/g, '');\r\n  }\r\n\r\n  isDate = (date: Date) => {\r\n    if (Object.prototype.toString.call(date) === '[object Date]') {\r\n      if (isNaN((date as Date).getTime())) {\r\n        return false;\r\n      }\r\n      else {\r\n        return true;\r\n      }\r\n    }\r\n    else {\r\n      return false;\r\n    }\r\n  };\r\n\r\n  isValidDate = (value: string) => {\r\n    return !isNaN(Date.parse(value));\r\n  }\r\n\r\n  rulesEval = (styles: object | null): object => {\r\n    let defaultStyles = {\r\n      'backgroundColor': '#ffffff',\r\n      'color': '#000000',\r\n      'font-style': 'normal',\r\n      'text-decoration': 'unset'\r\n    }\r\n    if (styles === null)\r\n      return defaultStyles;\r\n    if (Object.entries(styles).length !== 0) {\r\n      Object.assign(defaultStyles, styles);\r\n      return defaultStyles;\r\n    }\r\n    return defaultStyles;\r\n  }\r\n\r\n  /**\r\n    * Serializes an object as URL parameters.  The object should be a base type or have \r\n    * properties that are each base types.  Does not support a property with structure.\r\n    * @param {Object} data \r\n    * @returns {String} \r\n    */\r\n  formatAsUrlParameters = (data: any):string => {\r\n    if (typeof data !== 'object' || data === null)\r\n      return (data == null ? '' : data.toString());\r\n    var buffer = [];\r\n    for (var name in data) {\r\n      if (!data.hasOwnProperty(name)) {\r\n        continue;\r\n      }\r\n      var value = data[name];\r\n      buffer.push(\r\n        encodeURIComponent(name) +\r\n        '=' + encodeURIComponent(value == null ? '' : value));\r\n    }\r\n    var source = buffer.join('&')\r\n      .replace(/%20/g, '+');\r\n    return (source);\r\n  }\r\n}\r\n"]}
104
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tru-util.js","sourceRoot":"","sources":["../../../../../projects/tru-common-lib/src/lib/services/tru-util.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef, Injectable } from '@angular/core';\r\nimport moment from 'moment';\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class TruUtil {\r\n\r\n  constructor() { }\r\n\r\n  numberToString = (value: number | undefined): string => {\r\n    return value === undefined ? '' : (value).toString();\r\n  }\r\n\r\n  nullableNumberToString = (value: number | null | undefined): string => {\r\n    return value === null || value === undefined ? '' : (value).toString();\r\n  }\r\n\r\n  tryParseInt = (str: any, defaultValue: any) => {\r\n    var retValue = defaultValue;\r\n    if (str !== null) {\r\n      if (str.length > 0) {\r\n        if (!isNaN(str)) {\r\n          retValue = parseInt(str);\r\n        }\r\n      }\r\n    }\r\n    return retValue;\r\n  };\r\n\r\n  tryParseBool(value: any, defaultValue: any) {\r\n    return (value == 'true' || value == 'false' || value === true || value === false) && JSON.parse(value) || defaultValue;\r\n  }\r\n\r\n  findClosestAncestorByClass = (element: any, cssSelector: string) => {\r\n    let firstChar = cssSelector.charAt(0);\r\n    for (; element; element = element.parentNode) {\r\n      if (firstChar === '.') {\r\n        if (element.classList && element.classList.contains(cssSelector.substr(1))) {\r\n          return element;\r\n        }\r\n      }\r\n    }\r\n    return null;\r\n  };\r\n\r\n  isNumeric = (n: any) => {\r\n    return !isNaN(parseFloat(n)) && isFinite(n);\r\n  }\r\n\r\n  removeNonNumericCharactersFromStr = (value: string) => {\r\n    return value.replace(/[^0-9]/g, '');\r\n  }\r\n\r\n  isDate = (date: Date) => {\r\n    if (Object.prototype.toString.call(date) === '[object Date]') {\r\n      if (isNaN((date as Date).getTime())) {\r\n        return false;\r\n      }\r\n      else {\r\n        return true;\r\n      }\r\n    }\r\n    else {\r\n      return false;\r\n    }\r\n  };\r\n\r\n  isValidDate = (value: string) => {\r\n    return !isNaN(Date.parse(value));\r\n  }\r\n\r\n  rulesEval = (styles: object | null): object => {\r\n    let defaultStyles = {\r\n      'backgroundColor': '#ffffff',\r\n      'color': '#000000',\r\n      'font-style': 'normal',\r\n      'text-decoration': 'unset'\r\n    }\r\n    if (styles === null)\r\n      return defaultStyles;\r\n    if (Object.entries(styles).length !== 0) {\r\n      Object.assign(defaultStyles, styles);\r\n      return defaultStyles;\r\n    }\r\n    return defaultStyles;\r\n  }\r\n\r\n  /**\r\n    * Serializes an object as URL parameters.  The object should be a base type or have \r\n    * properties that are each base types.  Does not support a property with structure.\r\n    * @param {Object} data \r\n    * @returns {String} \r\n    */\r\n  formatAsUrlParameters = (data: any):string => {\r\n    if (typeof data !== 'object' || data === null)\r\n      return (data == null ? '' : data.toString());\r\n    var buffer = [];\r\n    for (var name in data) {\r\n      if (!data.hasOwnProperty(name)) {\r\n        continue;\r\n      }\r\n      var value = data[name];\r\n      buffer.push(\r\n        encodeURIComponent(name) +\r\n        '=' + encodeURIComponent(value == null ? '' : value));\r\n    }\r\n    var source = buffer.join('&')\r\n      .replace(/%20/g, '+');\r\n    return (source);\r\n  }\r\n}\r\n"]}
@@ -3067,10 +3067,10 @@ class TruValidationDialogConfig {
3067
3067
  class TruUtil {
3068
3068
  constructor() { }
3069
3069
  numberToString = (value) => {
3070
- return this === undefined ? '' : (this).toString();
3070
+ return value === undefined ? '' : (value).toString();
3071
3071
  };
3072
3072
  nullableNumberToString = (value) => {
3073
- return this === null || this === undefined ? '' : (this).toString();
3073
+ return value === null || value === undefined ? '' : (value).toString();
3074
3074
  };
3075
3075
  tryParseInt = (str, defaultValue) => {
3076
3076
  var retValue = defaultValue;
@@ -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.propertyConfig.propertyPath?.includes('/')) {
7135
- let propertyNameParts = this.config.propertyConfig.propertyPath.split('/');
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.config.entity[targetPropertyName];
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.config.entity.Merge_Data_Set?.get(this.config.propertyName) ? this.config.entity.Merge_Data_Set : undefined;
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.propertyConfig.propertyName;
7185
+ return v.propertyName === this.config.propertyName;
7184
7186
  });
7185
7187
  let removedPropertyValdations = validationObject.removed.filter((v) => {
7186
- return v.propertyName === this.config.propertyConfig.propertyName;
7188
+ return v.propertyName === this.config.propertyName;
7187
7189
  });
7188
7190
  this.mergeData = this.getMergeData();
7189
- if (this.config.propertyConfig.rootTable === validationTableName &&
7190
- this.config.entity[entityPkeyName] === validationObjectEntity[validationObjectEntitypkeyName] &&
7191
+ if (this.config.rootTable === validationTableName &&
7192
+ this.entity[entityPkeyName] === validationObjectEntity[validationObjectEntitypkeyName] &&
7191
7193
  (addedPropertyValdations.length || this.mergeData)) {
7192
7194
  this.removeValidationDialog();
7193
- this.config.propertyName = this.config.propertyConfig.propertyName;
7194
- this.config.mergeData = this.mergeData;
7195
- this.config.errorMsg = this.parseErrorMessages(addedPropertyValdations);
7196
- this.addValidationDialog(this.config);
7197
- }
7198
- if (this.config.propertyConfig.rootTable === validationTableName &&
7199
- this.config.entity[entityPkeyName] === validationObjectEntity[validationObjectEntitypkeyName] &&
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.config.context !== TruValidationDialogContext.Grid && !this.config.isSubProperty) {
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.config.firstChange) {
7216
+ if (!changes.entity.firstChange) {
7214
7217
  this.removeValidationDialog();
7215
- this.config.entity.entityAspect.validateEntity();
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: { config: ["truBreezeValidator", "config"] }, usesOnChanges: true, ngImport: i0 });
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: { config: [{
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 {