@trudb/tru-common-lib 0.0.822 → 0.0.824

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.
@@ -12,6 +12,9 @@ export class TruMergeDataSet {
12
12
  clearAll = () => {
13
13
  this._data = {};
14
14
  };
15
+ isEmpty = () => {
16
+ return Object.keys(this._data).length === 0;
17
+ };
15
18
  constructor() { }
16
19
  }
17
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LW1lcmdlLWRhdGEtc2V0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHJ1LWNvbW1vbi1saWIvc3JjL2xpYi9jbGFzc2VzL3RydS1tZXJnZS1kYXRhLXNldC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLE9BQU8sZUFBZTtJQUNsQixLQUFLLEdBQWlDLEVBQUUsQ0FBQztJQUVqRCxHQUFHLEdBQUcsQ0FBQyxZQUFvQixFQUE0QixFQUFFO1FBQ3ZELE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUNsQyxDQUFDLENBQUE7SUFFRCxHQUFHLEdBQUcsQ0FBQyxZQUFvQixFQUFFLElBQWtCLEVBQUUsRUFBRTtRQUNqRCxJQUFJLENBQUMsS0FBSyxDQUFDLFlBQVksQ0FBQyxHQUFHLElBQUksQ0FBQztJQUNsQyxDQUFDLENBQUE7SUFFRCxLQUFLLEdBQUcsQ0FBQyxZQUFvQixFQUFFLEVBQUU7UUFDL0IsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLFlBQVksQ0FBQyxDQUFDO0lBQ2xDLENBQUMsQ0FBQTtJQUVELFFBQVEsR0FBRyxHQUFHLEVBQUU7UUFDZCxJQUFJLENBQUMsS0FBSyxHQUFHLEVBQUUsQ0FBQztJQUNsQixDQUFDLENBQUE7SUFFRCxnQkFBZSxDQUFDO0NBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVHJ1TWVyZ2VEYXRhIH0gZnJvbSBcIi4vdHJ1LW1lcmdlLWRhdGFcIjtcclxuXHJcbmV4cG9ydCBjbGFzcyBUcnVNZXJnZURhdGFTZXQge1xyXG4gIHByaXZhdGUgX2RhdGE6IFJlY29yZDxzdHJpbmcsIFRydU1lcmdlRGF0YT4gPSB7fTtcclxuXHJcbiAgZ2V0ID0gKHByb3BlcnR5TmFtZTogc3RyaW5nKTogVHJ1TWVyZ2VEYXRhIHwgdW5kZWZpbmVkID0+IHtcclxuICAgIHJldHVybiB0aGlzLl9kYXRhW3Byb3BlcnR5TmFtZV07XHJcbiAgfVxyXG5cclxuICBzZXQgPSAocHJvcGVydHlOYW1lOiBzdHJpbmcsIGRhdGE6IFRydU1lcmdlRGF0YSkgPT4ge1xyXG4gICAgdGhpcy5fZGF0YVtwcm9wZXJ0eU5hbWVdID0gZGF0YTtcclxuICB9XHJcblxyXG4gIGNsZWFyID0gKHByb3BlcnR5TmFtZTogc3RyaW5nKSA9PiB7XHJcbiAgICBkZWxldGUgdGhpcy5fZGF0YVtwcm9wZXJ0eU5hbWVdO1xyXG4gIH1cclxuXHJcbiAgY2xlYXJBbGwgPSAoKSA9PiB7XHJcbiAgICB0aGlzLl9kYXRhID0ge307XHJcbiAgfVxyXG5cclxuICBjb25zdHJ1Y3RvcigpIHt9XHJcbn1cclxuIl19
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LW1lcmdlLWRhdGEtc2V0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHJ1LWNvbW1vbi1saWIvc3JjL2xpYi9jbGFzc2VzL3RydS1tZXJnZS1kYXRhLXNldC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLE9BQU8sZUFBZTtJQUNsQixLQUFLLEdBQWlDLEVBQUUsQ0FBQztJQUVqRCxHQUFHLEdBQUcsQ0FBQyxZQUFvQixFQUE0QixFQUFFO1FBQ3ZELE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUNsQyxDQUFDLENBQUE7SUFFRCxHQUFHLEdBQUcsQ0FBQyxZQUFvQixFQUFFLElBQWtCLEVBQUUsRUFBRTtRQUNqRCxJQUFJLENBQUMsS0FBSyxDQUFDLFlBQVksQ0FBQyxHQUFHLElBQUksQ0FBQztJQUNsQyxDQUFDLENBQUE7SUFFRCxLQUFLLEdBQUcsQ0FBQyxZQUFvQixFQUFFLEVBQUU7UUFDL0IsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLFlBQVksQ0FBQyxDQUFDO0lBQ2xDLENBQUMsQ0FBQTtJQUVELFFBQVEsR0FBRyxHQUFHLEVBQUU7UUFDZCxJQUFJLENBQUMsS0FBSyxHQUFHLEVBQUUsQ0FBQztJQUNsQixDQUFDLENBQUE7SUFFRCxPQUFPLEdBQUcsR0FBWSxFQUFFO1FBQ3RCLE9BQU8sTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsTUFBTSxLQUFLLENBQUMsQ0FBQztJQUM5QyxDQUFDLENBQUE7SUFFRCxnQkFBZSxDQUFDO0NBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVHJ1TWVyZ2VEYXRhIH0gZnJvbSBcIi4vdHJ1LW1lcmdlLWRhdGFcIjtcclxuXHJcbmV4cG9ydCBjbGFzcyBUcnVNZXJnZURhdGFTZXQge1xyXG4gIHByaXZhdGUgX2RhdGE6IFJlY29yZDxzdHJpbmcsIFRydU1lcmdlRGF0YT4gPSB7fTtcclxuXHJcbiAgZ2V0ID0gKHByb3BlcnR5TmFtZTogc3RyaW5nKTogVHJ1TWVyZ2VEYXRhIHwgdW5kZWZpbmVkID0+IHtcclxuICAgIHJldHVybiB0aGlzLl9kYXRhW3Byb3BlcnR5TmFtZV07XHJcbiAgfVxyXG5cclxuICBzZXQgPSAocHJvcGVydHlOYW1lOiBzdHJpbmcsIGRhdGE6IFRydU1lcmdlRGF0YSkgPT4ge1xyXG4gICAgdGhpcy5fZGF0YVtwcm9wZXJ0eU5hbWVdID0gZGF0YTtcclxuICB9XHJcblxyXG4gIGNsZWFyID0gKHByb3BlcnR5TmFtZTogc3RyaW5nKSA9PiB7XHJcbiAgICBkZWxldGUgdGhpcy5fZGF0YVtwcm9wZXJ0eU5hbWVdO1xyXG4gIH1cclxuXHJcbiAgY2xlYXJBbGwgPSAoKSA9PiB7XHJcbiAgICB0aGlzLl9kYXRhID0ge307XHJcbiAgfVxyXG5cclxuICBpc0VtcHR5ID0gKCk6IGJvb2xlYW4gPT4ge1xyXG4gICAgcmV0dXJuIE9iamVjdC5rZXlzKHRoaXMuX2RhdGEpLmxlbmd0aCA9PT0gMDtcclxuICB9XHJcblxyXG4gIGNvbnN0cnVjdG9yKCkge31cclxufVxyXG4iXX0=
@@ -42,12 +42,13 @@ export class TruValidatorFactory {
42
42
  return true;
43
43
  }
44
44
  satisfiesMergeValidation = (value, context) => {
45
- var mergeData = JSON.parse(context.entity.Merge_Data);
46
- if (!mergeData)
45
+ var mergeData = context.entity.Merge_Data_Set;
46
+ if (mergeData.isEmpty())
47
47
  return true;
48
- if (mergeData.hasOwnProperty(context.propertyName)) {
49
- var mergeValue = mergeData[context.propertyName].hid ? mergeData[context.propertyName].hid : mergeData[context.propertyName].value;
50
- context.error = mergeData[context.propertyName].modifiedBy + ' changed ' + context.propertyName + ' to ' + mergeValue + '.';
48
+ let targetProperty = mergeData.get(context.propertyName);
49
+ if (targetProperty) {
50
+ var mergeValue = targetProperty.hid ? targetProperty.hid : targetProperty.value;
51
+ context.error = targetProperty.modifiedBy + ' changed ' + context.propertyName + ' to ' + mergeValue + '.';
51
52
  return false;
52
53
  }
53
54
  return true;
@@ -93,4 +94,4 @@ export class TruValidatorFactory {
93
94
  });
94
95
  };
95
96
  }
96
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tru-validator-factory.js","sourceRoot":"","sources":["../../../../../projects/tru-common-lib/src/lib/classes/tru-validator-factory.ts"],"names":[],"mappings":"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","sourcesContent":["import { breeze, Validator } from \"breeze-client\";\r\nimport _ from \"underscore\";\r\n\r\nexport class TruValidatorFactory {\r\n  private satisfiesEntityMessageValidation = (entity: any, context: any) => {\r\n    var messages = _.values(entity._customValidationErrors);\r\n    if (!messages.length)\r\n      return true;\r\n    context.messageTemplate = messages.join('...');\r\n    return false;\r\n  }\r\n\r\n  private satisfiesRequiredValidation(value: any) {\r\n    if (value === null || value === '') return false;\r\n    return true;\r\n  }\r\n\r\n  private satisfiesMaxLengthValidation = (value: any, context: any) => {\r\n    if (!value)\r\n      return true;\r\n    return typeof value === 'string' && value.length <= context.maxLength;\r\n  }\r\n\r\n  private satisfiesFloatValidation = (value: any) => {\r\n    if (value === null)\r\n      return true;\r\n    return typeof value === 'number' && isFinite(value);\r\n  }\r\n\r\n  private satisfiesIntegerValidation = (value: any) => {\r\n    if (value === null)\r\n      return true;\r\n    //NOTE: Number.isInteger() would work, but is not implemented in all supported browsers\r\n    return typeof value === 'number' && isFinite(value) && Math.floor(value) === value;\r\n  }\r\n\r\n  private satisfiesDateValidation(value: any) {\r\n    if (Object.prototype.toString.call(value) !== '[object Date]')\r\n      return false;\r\n    return isFinite(value.getTime());\r\n  }\r\n\r\n  private satisfiesInvalidChoiceValidation(value: any, context: any) {\r\n    if (context.entity.Is_Invalid === 'true') {\r\n      context.error = context.propertyName + '\\' invalid choice'\r\n      return false;\r\n    }\r\n    return true;\r\n  }\r\n\r\n  private satisfiesMergeValidation = (value: any, context: any) => {\r\n    var mergeData = JSON.parse(context.entity.Merge_Data);\r\n    if (!mergeData)\r\n      return true;\r\n    if (mergeData.hasOwnProperty(context.propertyName)) {\r\n      var mergeValue = mergeData[context.propertyName].hid ? mergeData[context.propertyName].hid : mergeData[context.propertyName].value;\r\n      context.error = mergeData[context.propertyName].modifiedBy + ' changed ' + context.propertyName + ' to ' + mergeValue + '.';\r\n      return false;\r\n    }\r\n    return true;\r\n  }\r\n\r\n  createEntityMessageValidator = (): Validator => {\r\n    return new breeze.Validator('entityMessage', this.satisfiesEntityMessageValidation);\r\n  }\r\n\r\n  createRequiredValidator = (): Validator => {\r\n    return new breeze.Validator('required', this.satisfiesRequiredValidation, {\r\n      messageTemplate: '\\'%displayName%\\' is required'\r\n    });\r\n  }\r\n\r\n  createMaxLengthValidator = (maxLength: any): Validator => {\r\n    var context = {\r\n      messageTemplate: '\\'%displayName%\\' exceeds maximum character length of %maxLength%',\r\n      maxLength: maxLength\r\n    };\r\n    return new breeze.Validator('maxLength', this.satisfiesMaxLengthValidation, context);\r\n  };\r\n\r\n  createIntegerValidator = (): Validator => {\r\n    return new breeze.Validator('integer', this.satisfiesIntegerValidation, {\r\n      messageTemplate: '\\'%displayName%\\' must be an integer'\r\n    });\r\n  }\r\n\r\n  createFloatValidator = (): Validator => {\r\n    return new breeze.Validator('float', this.satisfiesFloatValidation, {\r\n      messageTemplate: '\\'%displayName%\\' must be a number'\r\n    });\r\n  }\r\n\r\n  createDateValidator = (): Validator => {\r\n    return new breeze.Validator('date', this.satisfiesDateValidation, {\r\n      messageTemplate: '\\'%displayName%\\' must be a date'\r\n    });\r\n  }\r\n\r\n  createInvalidChoiceValidator = (): Validator => {\r\n    return new breeze.Validator('invalid', this.satisfiesInvalidChoiceValidation, {\r\n      messageTemplate: '\\'%error%'\r\n    });\r\n  }\r\n\r\n  createMergeValidator = (): Validator => {\r\n    return new breeze.Validator('merge', this.satisfiesMergeValidation, {\r\n      messageTemplate: '\\'%error%\\''\r\n    });\r\n  }\r\n}\r\n"]}
97
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tru-validator-factory.js","sourceRoot":"","sources":["../../../../../projects/tru-common-lib/src/lib/classes/tru-validator-factory.ts"],"names":[],"mappings":"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","sourcesContent":["import { breeze, Validator } from \"breeze-client\";\r\nimport _ from \"underscore\";\r\nimport { TruMergeDataSet } from \"./tru-merge-data-set\";\r\n\r\nexport class TruValidatorFactory {\r\n  private satisfiesEntityMessageValidation = (entity: any, context: any) => {\r\n    var messages = _.values(entity._customValidationErrors);\r\n    if (!messages.length)\r\n      return true;\r\n    context.messageTemplate = messages.join('...');\r\n    return false;\r\n  }\r\n\r\n  private satisfiesRequiredValidation(value: any) {\r\n    if (value === null || value === '') return false;\r\n    return true;\r\n  }\r\n\r\n  private satisfiesMaxLengthValidation = (value: any, context: any) => {\r\n    if (!value)\r\n      return true;\r\n    return typeof value === 'string' && value.length <= context.maxLength;\r\n  }\r\n\r\n  private satisfiesFloatValidation = (value: any) => {\r\n    if (value === null)\r\n      return true;\r\n    return typeof value === 'number' && isFinite(value);\r\n  }\r\n\r\n  private satisfiesIntegerValidation = (value: any) => {\r\n    if (value === null)\r\n      return true;\r\n    //NOTE: Number.isInteger() would work, but is not implemented in all supported browsers\r\n    return typeof value === 'number' && isFinite(value) && Math.floor(value) === value;\r\n  }\r\n\r\n  private satisfiesDateValidation(value: any) {\r\n    if (Object.prototype.toString.call(value) !== '[object Date]')\r\n      return false;\r\n    return isFinite(value.getTime());\r\n  }\r\n\r\n  private satisfiesInvalidChoiceValidation(value: any, context: any) {\r\n    if (context.entity.Is_Invalid === 'true') {\r\n      context.error = context.propertyName + '\\' invalid choice'\r\n      return false;\r\n    }\r\n    return true;\r\n  }\r\n\r\n  private satisfiesMergeValidation = (value: any, context: any) => {\r\n    var mergeData = context.entity.Merge_Data_Set as TruMergeDataSet;\r\n    if (mergeData.isEmpty())\r\n      return true;\r\n    let targetProperty = mergeData.get(context.propertyName);\r\n    if (targetProperty) {\r\n      var mergeValue = targetProperty.hid ? targetProperty.hid : targetProperty.value;\r\n      context.error = targetProperty.modifiedBy + ' changed ' + context.propertyName + ' to ' + mergeValue + '.';\r\n      return false;\r\n    }\r\n    return true;\r\n  }\r\n\r\n  createEntityMessageValidator = (): Validator => {\r\n    return new breeze.Validator('entityMessage', this.satisfiesEntityMessageValidation);\r\n  }\r\n\r\n  createRequiredValidator = (): Validator => {\r\n    return new breeze.Validator('required', this.satisfiesRequiredValidation, {\r\n      messageTemplate: '\\'%displayName%\\' is required'\r\n    });\r\n  }\r\n\r\n  createMaxLengthValidator = (maxLength: any): Validator => {\r\n    var context = {\r\n      messageTemplate: '\\'%displayName%\\' exceeds maximum character length of %maxLength%',\r\n      maxLength: maxLength\r\n    };\r\n    return new breeze.Validator('maxLength', this.satisfiesMaxLengthValidation, context);\r\n  };\r\n\r\n  createIntegerValidator = (): Validator => {\r\n    return new breeze.Validator('integer', this.satisfiesIntegerValidation, {\r\n      messageTemplate: '\\'%displayName%\\' must be an integer'\r\n    });\r\n  }\r\n\r\n  createFloatValidator = (): Validator => {\r\n    return new breeze.Validator('float', this.satisfiesFloatValidation, {\r\n      messageTemplate: '\\'%displayName%\\' must be a number'\r\n    });\r\n  }\r\n\r\n  createDateValidator = (): Validator => {\r\n    return new breeze.Validator('date', this.satisfiesDateValidation, {\r\n      messageTemplate: '\\'%displayName%\\' must be a date'\r\n    });\r\n  }\r\n\r\n  createInvalidChoiceValidator = (): Validator => {\r\n    return new breeze.Validator('invalid', this.satisfiesInvalidChoiceValidation, {\r\n      messageTemplate: '\\'%error%'\r\n    });\r\n  }\r\n\r\n  createMergeValidator = (): Validator => {\r\n    return new breeze.Validator('merge', this.satisfiesMergeValidation, {\r\n      messageTemplate: '\\'%error%\\''\r\n    });\r\n  }\r\n}\r\n"]}
@@ -28,10 +28,9 @@ export class TruGridValidationDialog {
28
28
  if (Object.keys(originalValues).length === 0 && originalValues.constructor === Object)
29
29
  entity.entityAspect.setUnchanged();
30
30
  entity.Merge_Data_Set.clearAll();
31
- for (const key in this.config.mergeData) {
32
- entity.entityAspect.validateProperty(key);
33
- }
34
- ;
31
+ //for (const key in this.config.mergeData) {
32
+ // entity.entityAspect.validateProperty(key);
33
+ //};
35
34
  };
36
35
  onAccept = () => {
37
36
  //let entity = this.config.entity as any;
@@ -87,4 +86,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImpor
87
86
  }], ctorParameters: () => [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i1.TruUtil }], propDecorators: { config: [{
88
87
  type: Input
89
88
  }] } });
90
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tru-grid-validation-dialog.js","sourceRoot":"","sources":["../../../../../../projects/tru-common-lib/src/lib/components/grid-validation-dialog/tru-grid-validation-dialog.ts","../../../../../../projects/tru-common-lib/src/lib/components/grid-validation-dialog/tru-grid-validation-dialog.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAc,KAAK,EAAgC,MAAM,eAAe,CAAC;;;;AAS3F,MAAM,OAAO,uBAAuB;IAUxB;IACA;IACA;IAXD,MAAM,CAAiC;IAEhD,QAAQ,GAAW,EAAE,CAAC;IAEd,UAAU,CAAe;IACzB,WAAW,CAAe;IAC1B,SAAS,GAAsB,EAAE,CAAC;IAE1C,YACU,QAAmB,EACnB,UAAsB,EACtB,IAAa;QAFb,aAAQ,GAAR,QAAQ,CAAW;QACnB,eAAU,GAAV,UAAU,CAAY;QACtB,SAAI,GAAJ,IAAI,CAAS;IAAI,CAAC;IAE5B,WAAW,GAAG,GAAG,EAAE;QACjB,IAAI,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,MAAa,CAAC;QACvC,IAAI,cAAc,GAAG,MAAM,CAAC,YAAY,CAAC,cAAc,CAAC;QAExD,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE;YACvC,MAAM,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,CAAE,CAAC,KAAK,CAAC;YACpD,IAAI,cAAc,CAAC,cAAc,CAAC,GAAG,CAAC;gBACpC,OAAO,cAAc,CAAC,GAAG,CAAC,CAAC;SAC9B;QAAA,CAAC;QAEF,IAAI,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,MAAM,KAAK,CAAC,IAAI,cAAc,CAAC,WAAW,KAAK,MAAM;YACnF,MAAM,CAAC,YAAY,CAAC,YAAY,EAAE,CAAC;QAErC,MAAM,CAAC,cAAc,CAAC,QAAQ,EAAE,CAAC;QAEjC,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE;YACvC,MAAM,CAAC,YAAY,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC;SAC3C;QAAA,CAAC;IACJ,CAAC,CAAA;IAED,QAAQ,GAAG,GAAG,EAAE;QACd,yCAAyC;QACzC,0DAA0D;QAC1D,wBAAwB;QAExB,oDAAoD;QACpD,oEAAoE;QACpE,gFAAgF;QAChF,yCAAyC;QAEzC,yIAAyI;QACzI,wCAAwC;QAExC,0CAA0C;QAC1C,uCAAuC;QAEvC,qDAAqD;QACrD,qDAAqD;IACvD,CAAC,CAAA;IAED,SAAS,GAAG,GAAG,EAAE;QACf,kCAAkC;QAClC,wBAAwB;QAExB,iDAAiD;QACjD,oEAAoE;QACpE,yCAAyC;QACzC,qDAAqD;QACrD,qDAAqD;IACvD,CAAC,CAAA;IAED,QAAQ,KAAI,CAAC;IAEb,eAAe;QACb,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,0BAA0B,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,SAAS,CAAC,CAAC;QACjG,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,0BAA0B,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,gBAAgB,CAAC,CAAC;QACzG,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAE1C,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC;QAErC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,YAAY,EAAE,CAAC,KAAiB,EAAE,EAAE;YAC7F,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,MAAM,GAAG,aAAa,CAAC;YAC7C,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;YAC1C,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QACzC,CAAC,CAAC,CAAC,CAAC;QAEJ,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,YAAY,EAAE,CAAC,KAAiB,EAAE,EAAE;YAC7F,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;YACtC,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;YAC1C,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QACzC,CAAC,CAAC,CAAC,CAAC;IACN,CAAC;IAED,WAAW;QACT,IAAI,CAAC,IAAI,CAAC,0BAA0B,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,gBAAgB,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QAClH,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;IACnC,CAAC;uGA1FU,uBAAuB;2FAAvB,uBAAuB,gGCTpC,4jBASA;;2FDAa,uBAAuB;kBALnC,SAAS;+BACE,4BAA4B;6HAK7B,MAAM;sBAAd,KAAK","sourcesContent":["import { Component, ElementRef, Input, OnDestroy, OnInit, Renderer2 } from '@angular/core';\r\nimport { TruUtil } from '../../services/tru-util';\r\nimport { TruGridValidationDialogConfig } from './tru-grid-validation-dialog-config';\r\n\r\n@Component({\r\n  selector: 'tru-grid-validation-dialog',\r\n  templateUrl: './tru-grid-validation-dialog.html',\r\n  styleUrls: ['./tru-grid-validation-dialog.css']\r\n})\r\nexport class TruGridValidationDialog implements OnInit, OnDestroy {\r\n  @Input() config!: TruGridValidationDialogConfig;\r\n\r\n  errorMsg: string = '';\r\n\r\n  private rowElement!: HTMLElement;\r\n  private cellElement!: HTMLElement;\r\n  private listeners: Array<() => void> = [];\r\n\r\n  constructor(\r\n    private renderer: Renderer2,\r\n    private elementRef: ElementRef, \r\n    private util: TruUtil) { }\r\n\r\n  onAcceptAll = () => {\r\n    let entity = this.config.entity as any;\r\n    let originalValues = entity.entityAspect.originalValues;\r\n\r\n    for (const key in this.config.mergeData) {\r\n      entity[key] = this.config.mergeData.get(key)!.value;\r\n      if (originalValues.hasOwnProperty(key))\r\n        delete originalValues[key];\r\n    };\r\n\r\n    if (Object.keys(originalValues).length === 0 && originalValues.constructor === Object)\r\n      entity.entityAspect.setUnchanged();\r\n\r\n    entity.Merge_Data_Set.clearAll();\r\n\r\n    for (const key in this.config.mergeData) {\r\n      entity.entityAspect.validateProperty(key);\r\n    };\r\n  }\r\n\r\n  onAccept = () => {\r\n    //let entity = this.config.entity as any;\r\n    //let originalValues = entity.entityAspect.originalValues;\r\n    //let propertyName = '';\r\n\r\n    //let mergeData = JSON.parse(entity.Merge_Data_Set);\r\n    //let propertyNameKey = propertyName as keyof typeof this.mergeData;\r\n    //entity[propertyName] = this.config.mergeData?.getData(propertyNameKey)!.value;\r\n    //delete this.mergeData[propertyNameKey];\r\n\r\n    //if (originalValues.hasOwnProperty(propertyName) && (Object.keys(originalValues).length === 0 && originalValues.constructor === Object))\r\n    //  delete originalValues[propertyName];\r\n\r\n    //if (!Object.keys(this.mergeData).length)\r\n    //  entity.entityAspect.setUnchanged();\r\n\r\n    //entity.Merge_Data = JSON.stringify(this.mergeData);\r\n    //entity.entityAspect.validateProperty(propertyName);\r\n  }\r\n\r\n  onDecline = () => {\r\n    //let entity = this.entity as any;\r\n    //let propertyName = '';\r\n\r\n    //this.mergeData = JSON.parse(entity.Merge_Data);\r\n    //let propertyNameKey = propertyName as keyof typeof this.mergeData;\r\n    //delete this.mergeData[propertyNameKey];\r\n    //entity.Merge_Data = JSON.stringify(this.mergeData);\r\n    //entity.entityAspect.validateProperty(propertyName);\r\n  }\r\n\r\n  ngOnInit() {}\r\n\r\n  ngAfterViewInit(): void {\r\n    this.rowElement = this.util.findClosestAncestorByClass(this.elementRef.nativeElement, '.ag-row');\r\n    this.cellElement = this.util.findClosestAncestorByClass(this.elementRef.nativeElement, '.ag-cell-value');\r\n    this.cellElement.classList.add('invalid');\r\n\r\n    this.errorMsg = this.config.errorMsg;\r\n\r\n    this.listeners.push(this.renderer.listen(this.cellElement, 'mouseenter', (event: MouseEvent) => {\r\n      this.rowElement.style.zIndex = '10000000000';\r\n      this.cellElement.classList.remove('hide');\r\n      this.cellElement.classList.add('show');\r\n    }));\r\n\r\n    this.listeners.push(this.renderer.listen(this.cellElement, 'mouseleave', (event: MouseEvent) => {\r\n      this.rowElement.style.zIndex = 'auto';\r\n      this.cellElement.classList.remove('show');\r\n      this.cellElement.classList.add('hide');\r\n    }));\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.util.findClosestAncestorByClass(this.elementRef.nativeElement, '.ag-cell-value').classList.remove('invalid');\r\n    this.listeners.forEach(l => l());\r\n  }\r\n}\r\n\r\n","<div class=\"invalid\">\r\n  <i class=\"icon-warning-sign icon-white\"></i>{{config.errorMsg}}\r\n  <div *ngIf=\"config.mergeData\">\r\n    <button class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onAcceptAll()\">Accept All</button>\r\n    <button class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onAccept()\">Accept</button>\r\n    <button class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onDecline()\">Decline</button>\r\n  </div>\r\n</div>\r\n<span class=\"invalid-flag\"></span>\r\n"]}
89
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tru-grid-validation-dialog.js","sourceRoot":"","sources":["../../../../../../projects/tru-common-lib/src/lib/components/grid-validation-dialog/tru-grid-validation-dialog.ts","../../../../../../projects/tru-common-lib/src/lib/components/grid-validation-dialog/tru-grid-validation-dialog.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, OnDestroy, OnInit, Renderer2 } from '@angular/core';\r\nimport { TruUtil } from '../../services/tru-util';\r\nimport { TruGridValidationDialogConfig } from './tru-grid-validation-dialog-config';\r\n\r\n@Component({\r\n  selector: 'tru-grid-validation-dialog',\r\n  templateUrl: './tru-grid-validation-dialog.html',\r\n  styleUrls: ['./tru-grid-validation-dialog.css']\r\n})\r\nexport class TruGridValidationDialog implements OnInit, OnDestroy {\r\n  @Input() config!: TruGridValidationDialogConfig;\r\n\r\n  errorMsg: string = '';\r\n\r\n  private rowElement!: HTMLElement;\r\n  private cellElement!: HTMLElement;\r\n  private listeners: Array<() => void> = [];\r\n\r\n  constructor(\r\n    private renderer: Renderer2,\r\n    private elementRef: ElementRef, \r\n    private util: TruUtil) { }\r\n\r\n  onAcceptAll = () => {\r\n    let entity = this.config.entity as any;\r\n    let originalValues = entity.entityAspect.originalValues;\r\n\r\n    for (const key in this.config.mergeData) {\r\n      entity[key] = this.config.mergeData.get(key)!.value;\r\n      if (originalValues.hasOwnProperty(key))\r\n        delete originalValues[key];\r\n    };\r\n\r\n    if (Object.keys(originalValues).length === 0 && originalValues.constructor === Object)\r\n      entity.entityAspect.setUnchanged();\r\n\r\n    entity.Merge_Data_Set.clearAll();\r\n\r\n    //for (const key in this.config.mergeData) {\r\n    //  entity.entityAspect.validateProperty(key);\r\n    //};\r\n  }\r\n\r\n  onAccept = () => {\r\n    //let entity = this.config.entity as any;\r\n    //let originalValues = entity.entityAspect.originalValues;\r\n    //let propertyName = '';\r\n\r\n    //let mergeData = JSON.parse(entity.Merge_Data_Set);\r\n    //let propertyNameKey = propertyName as keyof typeof this.mergeData;\r\n    //entity[propertyName] = this.config.mergeData?.getData(propertyNameKey)!.value;\r\n    //delete this.mergeData[propertyNameKey];\r\n\r\n    //if (originalValues.hasOwnProperty(propertyName) && (Object.keys(originalValues).length === 0 && originalValues.constructor === Object))\r\n    //  delete originalValues[propertyName];\r\n\r\n    //if (!Object.keys(this.mergeData).length)\r\n    //  entity.entityAspect.setUnchanged();\r\n\r\n    //entity.Merge_Data = JSON.stringify(this.mergeData);\r\n    //entity.entityAspect.validateProperty(propertyName);\r\n  }\r\n\r\n  onDecline = () => {\r\n    //let entity = this.entity as any;\r\n    //let propertyName = '';\r\n\r\n    //this.mergeData = JSON.parse(entity.Merge_Data);\r\n    //let propertyNameKey = propertyName as keyof typeof this.mergeData;\r\n    //delete this.mergeData[propertyNameKey];\r\n    //entity.Merge_Data = JSON.stringify(this.mergeData);\r\n    //entity.entityAspect.validateProperty(propertyName);\r\n  }\r\n\r\n  ngOnInit() {}\r\n\r\n  ngAfterViewInit(): void {\r\n    this.rowElement = this.util.findClosestAncestorByClass(this.elementRef.nativeElement, '.ag-row');\r\n    this.cellElement = this.util.findClosestAncestorByClass(this.elementRef.nativeElement, '.ag-cell-value');\r\n    this.cellElement.classList.add('invalid');\r\n\r\n    this.errorMsg = this.config.errorMsg;\r\n\r\n    this.listeners.push(this.renderer.listen(this.cellElement, 'mouseenter', (event: MouseEvent) => {\r\n      this.rowElement.style.zIndex = '10000000000';\r\n      this.cellElement.classList.remove('hide');\r\n      this.cellElement.classList.add('show');\r\n    }));\r\n\r\n    this.listeners.push(this.renderer.listen(this.cellElement, 'mouseleave', (event: MouseEvent) => {\r\n      this.rowElement.style.zIndex = 'auto';\r\n      this.cellElement.classList.remove('show');\r\n      this.cellElement.classList.add('hide');\r\n    }));\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.util.findClosestAncestorByClass(this.elementRef.nativeElement, '.ag-cell-value').classList.remove('invalid');\r\n    this.listeners.forEach(l => l());\r\n  }\r\n}\r\n\r\n","<div class=\"invalid\">\r\n  <i class=\"icon-warning-sign icon-white\"></i>{{config.errorMsg}}\r\n  <div *ngIf=\"config.mergeData\">\r\n    <button class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onAcceptAll()\">Accept All</button>\r\n    <button class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onAccept()\">Accept</button>\r\n    <button class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onDecline()\">Decline</button>\r\n  </div>\r\n</div>\r\n<span class=\"invalid-flag\"></span>\r\n"]}
@@ -42,7 +42,7 @@ export class TruBreezeGridValidator {
42
42
  return undefined;
43
43
  }
44
44
  else {
45
- return this.entity.Merge_Data_Set?.get(this.config.propertyName);
45
+ return this.entity.Merge_Data_Set?.get(this.config.propertyName) ? this.entity.Merge_Data_Set : undefined;
46
46
  }
47
47
  };
48
48
  parseErrorMessages = (validationErrors) => {
@@ -116,4 +116,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImpor
116
116
  }], config: [{
117
117
  type: Input
118
118
  }] } });
119
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tru-breeze-grid-validator.js","sourceRoot":"","sources":["../../../../../../projects/tru-common-lib/src/lib/directives/breeze-grid-validator/tru-breeze-grid-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 { TruGridValidationDialog } from '../../components/grid-validation-dialog/tru-grid-validation-dialog';\r\nimport { TruGridValidationDialogConfig } from '../../components/grid-validation-dialog/tru-grid-validation-dialog-config';\r\nimport { TruDataContext } from '../../services/tru-data-context';\r\n\r\n@Directive({\r\n  selector: '[truBreezeGridValidator]'\r\n})\r\nexport class TruBreezeGridValidator implements OnInit, OnDestroy {\r\n  @Input('truBreezeGridValidator') entity!: TruEntityBase;\r\n  @Input() config!: TruEditControlConfigBase<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<TruGridValidationDialog> | null = null\r\n\r\n  private getMergeData = (): TruMergeData | 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);\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: TruGridValidationDialogConfig) => {\r\n    let componentFactory = this.componentFactoryResolver.resolveComponentFactory(TruGridValidationDialog);\r\n    let component = this.viewContainerRef.createComponent<TruGridValidationDialog>(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      this.addValidationDialog(new TruGridValidationDialogConfig(\r\n        this.entity,\r\n        this.config.propertyName as string,\r\n        this.parseErrorMessages(addedPropertyValdations),\r\n        this.mergeData\r\n      ));\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    this.subs.push(this.dataContext.validationChangeDetection.subscribe(entities => {\r\n      this.valErrsChanged(entities);\r\n    }));\r\n    this.entity.entityAspect.validateEntity();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    this.entity.entityAspect.validateEntity();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subs.forEach(s => s.unsubscribe());\r\n  }\r\n}\r\n"]}
119
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tru-breeze-grid-validator.js","sourceRoot":"","sources":["../../../../../../projects/tru-common-lib/src/lib/directives/breeze-grid-validator/tru-breeze-grid-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 { TruGridValidationDialog } from '../../components/grid-validation-dialog/tru-grid-validation-dialog';\r\nimport { TruGridValidationDialogConfig } from '../../components/grid-validation-dialog/tru-grid-validation-dialog-config';\r\nimport { TruDataContext } from '../../services/tru-data-context';\r\n\r\n@Directive({\r\n  selector: '[truBreezeGridValidator]'\r\n})\r\nexport class TruBreezeGridValidator implements OnInit, OnDestroy {\r\n  @Input('truBreezeGridValidator') entity!: TruEntityBase;\r\n  @Input() config!: TruEditControlConfigBase<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<TruGridValidationDialog> | null = null\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: TruGridValidationDialogConfig) => {\r\n    let componentFactory = this.componentFactoryResolver.resolveComponentFactory(TruGridValidationDialog);\r\n    let component = this.viewContainerRef.createComponent<TruGridValidationDialog>(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      this.addValidationDialog(new TruGridValidationDialogConfig(\r\n        this.entity,\r\n        this.config.propertyName as string,\r\n        this.parseErrorMessages(addedPropertyValdations),\r\n        this.mergeData\r\n      ));\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    this.subs.push(this.dataContext.validationChangeDetection.subscribe(entities => {\r\n      this.valErrsChanged(entities);\r\n    }));\r\n    this.entity.entityAspect.validateEntity();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    this.entity.entityAspect.validateEntity();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subs.forEach(s => s.unsubscribe());\r\n  }\r\n}\r\n"]}
@@ -42,7 +42,7 @@ export class TruBreezeValidator {
42
42
  return undefined;
43
43
  }
44
44
  else {
45
- return this.entity.Merge_Data_Set?.get(this.config.propertyName);
45
+ return this.entity.Merge_Data_Set?.get(this.config.propertyName) ? this.entity.Merge_Data_Set : undefined;
46
46
  }
47
47
  };
48
48
  parseErrorMessages = (validationErrors) => {
@@ -118,4 +118,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImpor
118
118
  }], config: [{
119
119
  type: Input
120
120
  }] } });
121
- //# 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":"AAAA,OAAO,EAA0C,SAAS,EAAc,KAAK,EAAsD,MAAM,eAAe,CAAC;AAQzJ,OAAO,EAAE,mBAAmB,EAAE,MAAM,0DAA0D,CAAC;AAC/F,OAAO,EAAE,yBAAyB,EAAE,MAAM,iEAAiE,CAAC;;;AAM5G,MAAM,OAAO,kBAAkB;IAKnB;IACA;IACA;IACA;IAPmB,MAAM,CAAiB;IAC3C,MAAM,CAAiC;IAEhD,YACU,EAAc,EACd,WAA2B,EAC3B,gBAAkC,EAClC,wBAAkD;QAHlD,OAAE,GAAF,EAAE,CAAY;QACd,gBAAW,GAAX,WAAW,CAAgB;QAC3B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,6BAAwB,GAAxB,wBAAwB,CAA0B;IAC5D,CAAC;IAED,WAAW,GAAQ,EAAE,CAAC;IACtB,SAAS,CAAM;IAEP,SAAS,GAA6B,IAAI,CAAC;IAC3C,IAAI,GAAwB,EAAE,CAAC;IAC/B,aAAa,GAA6C,IAAI,CAAA;IAE9D,YAAY,GAAG,GAA6B,EAAE;QACpD,IAAI,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,QAAQ,CAAC,GAAG,CAAC,EAAE;YAC3C,IAAI,iBAAiB,GAAG,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YAC5D,iBAAiB,CAAC,GAAG,EAAE,CAAC;YACxB,IAAI,cAAmB,CAAC;YACxB,iBAAiB,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;gBACjC,IAAI,CAAC,cAAc,EAAE;oBACnB,IAAI,kBAAkB,GAAG,GAAG,GAAG,IAAgC,CAAC;oBAChE,cAAc,GAAG,IAAI,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAAC;iBAClD;qBAAM;oBACL,IAAI,kBAAkB,GAAG,GAAG,GAAG,IAAgC,CAAC;oBAChE,cAAc,GAAG,cAAc,CAAC,kBAAkB,CAAC,CAAC;iBACrD;YACH,CAAC,CAAC,CAAC;YACH,IAAI,cAAc,IAAI,cAAc,CAAC,UAAU,EAAE;gBAC/C,OAAO,cAAc,CAAC,cAAc,CAAC;aACtC;YACD,OAAO,SAAS,CAAC;SAClB;aAAM;YACL,OAAO,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,YAAsB,CAAC,CAAC;SAC5E;IACH,CAAC,CAAA;IAEO,kBAAkB,GAAG,CAAC,gBAAwC,EAAU,EAAE;QAChF,IAAI,QAAQ,GAAW,EAAE,CAAC;QAC1B,gBAAgB,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;YACjC,QAAQ,IAAI,KAAK,CAAC,YAAY,GAAG,IAAI,CAAC;QACxC,CAAC,CAAC,CAAC;QACH,OAAO,QAAQ,CAAC;IAClB,CAAC,CAAA;IAEO,mBAAmB,GAAG,CAAC,MAAiC,EAAE,EAAE;QAClE,IAAI,gBAAgB,GAAG,IAAI,CAAC,wBAAwB,CAAC,uBAAuB,CAAC,mBAAmB,CAAC,CAAC;QAClG,IAAI,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAsB,gBAAgB,EAAE,CAAC,EAAE,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;QAChI,SAAS,CAAC,QAAQ,CAAC,MAAM,GAAG,MAAM,CAAC;QACnC,IAAI,CAAC,aAAa,GAAG,SAAS,CAAC;QAC/B,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;IAC7B,CAAC,CAAA;IAEO,sBAAsB,GAAG,GAAG,EAAE;QACpC,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC;YAC7B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;SAC3B;IACH,CAAC,CAAA;IAED,cAAc,GAAG,CAAC,gBAAqB,EAAE,EAAE;QACzC,IAAI,sBAAsB,GAAG,gBAAgB,CAAC,MAAM,CAAA;QACpD,IAAI,mBAAmB,GAAG,sBAAsB,CAAC,WAAW,CAAC,IAAI,CAAC;QAGlE,MAAM,cAAc,GAAG,mBAAmB,GAAG,KAAwB,CAAC;QAGtE,MAAM,8BAA8B,GAAG,mBAAmB,GAAG,KAAwC,CAAC;QAEtG,IAAI,uBAAuB,GAAG,gBAAgB,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAM,EAAE,EAAE;YACrE,OAAO,CAAC,CAAC,YAAY,KAAK,IAAI,CAAC,MAAM,CAAC,YAAY,CAAA;QACpD,CAAC,CAAC,CAAC;QAEH,IAAI,yBAAyB,GAAG,gBAAgB,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAM,EAAE,EAAE;YACzE,OAAO,CAAC,CAAC,YAAY,KAAK,IAAI,CAAC,MAAM,CAAC,YAAY,CAAA;QACpD,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QAErC,IACE,IAAI,CAAC,MAAM,CAAC,SAAS,KAAK,mBAAmB;YAC7C,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,KAAK,sBAAsB,CAAC,8BAA8B,CAAC;YACtF,CAAC,uBAAuB,CAAC,MAAM,IAAI,IAAI,CAAC,SAAS,CAAC,EAAE;YACpD,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAC9B,IAAI,CAAC,mBAAmB,CAAC,IAAI,yBAAyB,CACpD,IAAI,CAAC,MAAM,EACX,IAAI,CAAC,MAAM,CAAC,YAAsB,EAClC,IAAI,CAAC,kBAAkB,CAAC,uBAAuB,CAAC,EAChD,IAAI,CAAC,SAAS,CACf,CAAC,CAAC;SACJ;QAED,IACE,IAAI,CAAC,MAAM,CAAC,SAAS,KAAK,mBAAmB;YAC7C,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,KAAK,sBAAsB,CAAC,8BAA8B,CAAC;YACtF,CAAC,yBAAyB,CAAC,MAAM,CAAC,EAAE;YACpC,IAAI,CAAC,sBAAsB,EAAE,CAAC;SAC/B;IACH,CAAC,CAAA;IAED,QAAQ,KAAW,CAAC;IAEpB,eAAe;QACb,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,yBAAyB,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE;YAC7E,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QAChC,CAAC,CAAC,CAAC,CAAC;IACN,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,WAAW,EAAE;YAC/B,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAC9B,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,cAAc,EAAE,CAAC;SAC3C;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;IAC1C,CAAC;uGA1HU,kBAAkB;2FAAlB,kBAAkB;;2FAAlB,kBAAkB;kBAH9B,SAAS;mBAAC;oBACT,QAAQ,EAAE,sBAAsB;iBACjC;kLAE8B,MAAM;sBAAlC,KAAK;uBAAC,oBAAoB;gBAClB,MAAM;sBAAd,KAAK","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\n\r\n@Directive({\r\n  selector: '[truBreezeValidator]'\r\n})\r\nexport class TruBreezeValidator implements OnInit, OnDestroy {\r\n  @Input('truBreezeValidator') entity!: TruEntityBase;\r\n  @Input() config!: TruEditControlConfigBase<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\r\n  private getMergeData = (): TruMergeData | 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);\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      this.addValidationDialog(new TruValidationDialogConfig(\r\n        this.entity,\r\n        this.config.propertyName as string,\r\n        this.parseErrorMessages(addedPropertyValdations),\r\n        this.mergeData\r\n      ));\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    this.subs.push(this.dataContext.validationChangeDetection.subscribe(entities => {\r\n      this.valErrsChanged(entities);\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"]}
121
+ //# 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\n\r\n@Directive({\r\n  selector: '[truBreezeValidator]'\r\n})\r\nexport class TruBreezeValidator implements OnInit, OnDestroy {\r\n  @Input('truBreezeValidator') entity!: TruEntityBase;\r\n  @Input() config!: TruEditControlConfigBase<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\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      this.addValidationDialog(new TruValidationDialogConfig(\r\n        this.entity,\r\n        this.config.propertyName as string,\r\n        this.parseErrorMessages(addedPropertyValdations),\r\n        this.mergeData\r\n      ));\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    this.subs.push(this.dataContext.validationChangeDetection.subscribe(entities => {\r\n      this.valErrsChanged(entities);\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"]}
@@ -131,6 +131,9 @@ class TruMergeDataSet {
131
131
  clearAll = () => {
132
132
  this._data = {};
133
133
  };
134
+ isEmpty = () => {
135
+ return Object.keys(this._data).length === 0;
136
+ };
134
137
  constructor() { }
135
138
  }
136
139
 
@@ -2420,12 +2423,13 @@ class TruValidatorFactory {
2420
2423
  return true;
2421
2424
  }
2422
2425
  satisfiesMergeValidation = (value, context) => {
2423
- var mergeData = JSON.parse(context.entity.Merge_Data);
2424
- if (!mergeData)
2426
+ var mergeData = context.entity.Merge_Data_Set;
2427
+ if (mergeData.isEmpty())
2425
2428
  return true;
2426
- if (mergeData.hasOwnProperty(context.propertyName)) {
2427
- var mergeValue = mergeData[context.propertyName].hid ? mergeData[context.propertyName].hid : mergeData[context.propertyName].value;
2428
- context.error = mergeData[context.propertyName].modifiedBy + ' changed ' + context.propertyName + ' to ' + mergeValue + '.';
2429
+ let targetProperty = mergeData.get(context.propertyName);
2430
+ if (targetProperty) {
2431
+ var mergeValue = targetProperty.hid ? targetProperty.hid : targetProperty.value;
2432
+ context.error = targetProperty.modifiedBy + ' changed ' + context.propertyName + ' to ' + mergeValue + '.';
2429
2433
  return false;
2430
2434
  }
2431
2435
  return true;
@@ -6165,10 +6169,9 @@ class TruGridValidationDialog {
6165
6169
  if (Object.keys(originalValues).length === 0 && originalValues.constructor === Object)
6166
6170
  entity.entityAspect.setUnchanged();
6167
6171
  entity.Merge_Data_Set.clearAll();
6168
- for (const key in this.config.mergeData) {
6169
- entity.entityAspect.validateProperty(key);
6170
- }
6171
- ;
6172
+ //for (const key in this.config.mergeData) {
6173
+ // entity.entityAspect.validateProperty(key);
6174
+ //};
6172
6175
  };
6173
6176
  onAccept = () => {
6174
6177
  //let entity = this.config.entity as any;
@@ -6751,7 +6754,7 @@ class TruBreezeGridValidator {
6751
6754
  return undefined;
6752
6755
  }
6753
6756
  else {
6754
- return this.entity.Merge_Data_Set?.get(this.config.propertyName);
6757
+ return this.entity.Merge_Data_Set?.get(this.config.propertyName) ? this.entity.Merge_Data_Set : undefined;
6755
6758
  }
6756
6759
  };
6757
6760
  parseErrorMessages = (validationErrors) => {
@@ -6907,7 +6910,7 @@ class TruBreezeValidator {
6907
6910
  return undefined;
6908
6911
  }
6909
6912
  else {
6910
- return this.entity.Merge_Data_Set?.get(this.config.propertyName);
6913
+ return this.entity.Merge_Data_Set?.get(this.config.propertyName) ? this.entity.Merge_Data_Set : undefined;
6911
6914
  }
6912
6915
  };
6913
6916
  parseErrorMessages = (validationErrors) => {