@trudb/tru-common-lib 0.0.339 → 0.0.341

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.
@@ -6,6 +6,7 @@ export class TruEntityBase {
6
6
  this.CreatedRef = -1;
7
7
  this.Updated = undefined;
8
8
  this.UpdatedRef = undefined;
9
+ this.Merge_Data_Set = undefined;
9
10
  }
10
11
  }
11
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LWVudGl0eS1iYXNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHJ1LWNvbW1vbi1saWIvc3JjL2xpYi9iYXNlLWNsYXNzZXMvdHJ1LWVudGl0eS1iYXNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBVSxZQUFZLEVBQWMsTUFBTSxlQUFlLENBQUM7QUFFakUsTUFBTSxPQUFPLGFBQWE7SUFDeEIsWUFBWSxHQUFHLElBQVc7UUFFMUIsaUJBQVksR0FBaUIsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUdoRCxZQUFPLEdBQVMsSUFBSSxJQUFJLEVBQUUsQ0FBQztRQUMzQixlQUFVLEdBQVcsQ0FBQyxDQUFDLENBQUM7UUFDeEIsWUFBTyxHQUFxQixTQUFTLENBQUM7UUFDdEMsZUFBVSxHQUF1QixTQUFTLENBQUM7SUFSYixDQUFDO0NBVWhDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRW50aXR5LCBFbnRpdHlBc3BlY3QsIEVudGl0eVR5cGUgfSBmcm9tICdicmVlemUtY2xpZW50JztcclxuXHJcbmV4cG9ydCBjbGFzcyBUcnVFbnRpdHlCYXNlIGltcGxlbWVudHMgRW50aXR5IHtcclxuICBjb25zdHJ1Y3RvciguLi5hcmdzOiBhbnlbXSkgeyB9XHJcblxyXG4gIGVudGl0eUFzcGVjdDogRW50aXR5QXNwZWN0ID0gbmV3IEVudGl0eUFzcGVjdCgpO1xyXG4gIGVudGl0eVR5cGUhOiBFbnRpdHlUeXBlO1xyXG5cclxuICBDcmVhdGVkOiBEYXRlID0gbmV3IERhdGUoKTtcclxuICBDcmVhdGVkUmVmOiBudW1iZXIgPSAtMTtcclxuICBVcGRhdGVkOiBEYXRlIHwgdW5kZWZpbmVkID0gdW5kZWZpbmVkO1xyXG4gIFVwZGF0ZWRSZWY6IG51bWJlciB8IHVuZGVmaW5lZCA9IHVuZGVmaW5lZDtcclxuICByb3d2ZXI6IGFueTtcclxufVxyXG4iXX0=
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LWVudGl0eS1iYXNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHJ1LWNvbW1vbi1saWIvc3JjL2xpYi9iYXNlLWNsYXNzZXMvdHJ1LWVudGl0eS1iYXNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBVSxZQUFZLEVBQWMsTUFBTSxlQUFlLENBQUM7QUFHakUsTUFBTSxPQUFPLGFBQWE7SUFDeEIsWUFBWSxHQUFHLElBQVc7UUFFMUIsaUJBQVksR0FBaUIsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUdoRCxZQUFPLEdBQVMsSUFBSSxJQUFJLEVBQUUsQ0FBQztRQUMzQixlQUFVLEdBQVcsQ0FBQyxDQUFDLENBQUM7UUFDeEIsWUFBTyxHQUFxQixTQUFTLENBQUM7UUFDdEMsZUFBVSxHQUF1QixTQUFTLENBQUM7UUFHM0MsbUJBQWMsR0FBZ0MsU0FBUyxDQUFDO0lBWDFCLENBQUM7Q0FZaEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFbnRpdHksIEVudGl0eUFzcGVjdCwgRW50aXR5VHlwZSB9IGZyb20gJ2JyZWV6ZS1jbGllbnQnO1xyXG5pbXBvcnQgeyBUcnVNZXJnZURhdGFTZXQgfSBmcm9tICcuLi9jbGFzc2VzL3RydS1tZXJnZS1kYXRhLXNldCc7XHJcblxyXG5leHBvcnQgY2xhc3MgVHJ1RW50aXR5QmFzZSBpbXBsZW1lbnRzIEVudGl0eSB7XHJcbiAgY29uc3RydWN0b3IoLi4uYXJnczogYW55W10pIHsgfVxyXG5cclxuICBlbnRpdHlBc3BlY3Q6IEVudGl0eUFzcGVjdCA9IG5ldyBFbnRpdHlBc3BlY3QoKTtcclxuICBlbnRpdHlUeXBlITogRW50aXR5VHlwZTtcclxuXHJcbiAgQ3JlYXRlZDogRGF0ZSA9IG5ldyBEYXRlKCk7XHJcbiAgQ3JlYXRlZFJlZjogbnVtYmVyID0gLTE7XHJcbiAgVXBkYXRlZDogRGF0ZSB8IHVuZGVmaW5lZCA9IHVuZGVmaW5lZDtcclxuICBVcGRhdGVkUmVmOiBudW1iZXIgfCB1bmRlZmluZWQgPSB1bmRlZmluZWQ7XHJcbiAgcm93dmVyOiBhbnk7XHJcblxyXG4gIE1lcmdlX0RhdGFfU2V0OiBUcnVNZXJnZURhdGFTZXQgfCB1bmRlZmluZWQgPSB1bmRlZmluZWQ7XHJcbn1cclxuIl19
@@ -0,0 +1,12 @@
1
+ export class TruMergeDataSet {
2
+ constructor() {
3
+ this._data = {};
4
+ this.getData = (propertyName) => {
5
+ return this._data[propertyName];
6
+ };
7
+ this.setData = (propertyName, data) => {
8
+ this._data[propertyName] = data;
9
+ };
10
+ }
11
+ }
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LW1lcmdlLWRhdGEtc2V0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHJ1LWNvbW1vbi1saWIvc3JjL2xpYi9jbGFzc2VzL3RydS1tZXJnZS1kYXRhLXNldC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLE9BQU8sZUFBZTtJQVcxQjtRQVZRLFVBQUssR0FBaUMsRUFBRSxDQUFDO1FBRWpELFlBQU8sR0FBRyxDQUFDLFlBQW9CLEVBQTRCLEVBQUU7WUFDM0QsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQ2xDLENBQUMsQ0FBQTtRQUVELFlBQU8sR0FBRyxDQUFDLFlBQW9CLEVBQUUsSUFBa0IsRUFBRSxFQUFFO1lBQ3JELElBQUksQ0FBQyxLQUFLLENBQUMsWUFBWSxDQUFDLEdBQUcsSUFBSSxDQUFDO1FBQ2xDLENBQUMsQ0FBQTtJQUVjLENBQUM7Q0FDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUcnVNZXJnZURhdGEgfSBmcm9tIFwiLi90cnUtbWVyZ2UtZGF0YVwiO1xyXG5cclxuZXhwb3J0IGNsYXNzIFRydU1lcmdlRGF0YVNldCB7XHJcbiAgcHJpdmF0ZSBfZGF0YTogUmVjb3JkPHN0cmluZywgVHJ1TWVyZ2VEYXRhPiA9IHt9O1xyXG5cclxuICBnZXREYXRhID0gKHByb3BlcnR5TmFtZTogc3RyaW5nKTogVHJ1TWVyZ2VEYXRhIHwgdW5kZWZpbmVkID0+IHtcclxuICAgIHJldHVybiB0aGlzLl9kYXRhW3Byb3BlcnR5TmFtZV07XHJcbiAgfVxyXG5cclxuICBzZXREYXRhID0gKHByb3BlcnR5TmFtZTogc3RyaW5nLCBkYXRhOiBUcnVNZXJnZURhdGEpID0+IHtcclxuICAgIHRoaXMuX2RhdGFbcHJvcGVydHlOYW1lXSA9IGRhdGE7XHJcbiAgfVxyXG5cclxuICBjb25zdHJ1Y3RvcigpIHt9XHJcbn1cclxuIl19
@@ -0,0 +1,17 @@
1
+ export class TruMergeData {
2
+ get value() {
3
+ return this._value;
4
+ }
5
+ get modifiedBy() {
6
+ return this._modifiedBy;
7
+ }
8
+ get hid() {
9
+ return this._hid;
10
+ }
11
+ constructor(value, modifiedBy, hid) {
12
+ this._value = value;
13
+ this._modifiedBy = modifiedBy;
14
+ this._hid = hid;
15
+ }
16
+ }
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LW1lcmdlLWRhdGEuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90cnUtY29tbW9uLWxpYi9zcmMvbGliL2NsYXNzZXMvdHJ1LW1lcmdlLWRhdGEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxPQUFPLFlBQVk7SUFNdkIsSUFBVyxLQUFLO1FBQ2QsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDO0lBQ3JCLENBQUM7SUFFRCxJQUFXLFVBQVU7UUFDbkIsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDO0lBQzFCLENBQUM7SUFFRCxJQUFXLEdBQUc7UUFDWixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUM7SUFDbkIsQ0FBQztJQUVELFlBQVksS0FBVSxFQUFFLFVBQWtCLEVBQUUsR0FBVztRQUNyRCxJQUFJLENBQUMsTUFBTSxHQUFHLEtBQUssQ0FBQztRQUNwQixJQUFJLENBQUMsV0FBVyxHQUFHLFVBQVUsQ0FBQztRQUM5QixJQUFJLENBQUMsSUFBSSxHQUFHLEdBQUcsQ0FBQztJQUNsQixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY2xhc3MgVHJ1TWVyZ2VEYXRhIHtcclxuICBwcml2YXRlIF92YWx1ZTogYW55O1xyXG4gIHByaXZhdGUgX21vZGlmaWVkQnk6IHN0cmluZztcclxuICBwcml2YXRlIF9oaWQ6IHN0cmluZztcclxuXHJcblxyXG4gIHB1YmxpYyBnZXQgdmFsdWUoKTogc3RyaW5nIHtcclxuICAgIHJldHVybiB0aGlzLl92YWx1ZTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBnZXQgbW9kaWZpZWRCeSgpOiBzdHJpbmcge1xyXG4gICAgcmV0dXJuIHRoaXMuX21vZGlmaWVkQnk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0IGhpZCgpOiBzdHJpbmcge1xyXG4gICAgcmV0dXJuIHRoaXMuX2hpZDtcclxuICB9XHJcblxyXG4gIGNvbnN0cnVjdG9yKHZhbHVlOiBhbnksIG1vZGlmaWVkQnk6IHN0cmluZywgaGlkOiBzdHJpbmcpIHtcclxuICAgIHRoaXMuX3ZhbHVlID0gdmFsdWU7XHJcbiAgICB0aGlzLl9tb2RpZmllZEJ5ID0gbW9kaWZpZWRCeTtcclxuICAgIHRoaXMuX2hpZCA9IGhpZDtcclxuICB9XHJcbn1cclxuIl19
@@ -0,0 +1,21 @@
1
+ export class TruValidationDialogConfig {
2
+ get entity() {
3
+ return this._entity;
4
+ }
5
+ get propertyName() {
6
+ return this._propertyName;
7
+ }
8
+ get errorMsg() {
9
+ return this._errorMsg;
10
+ }
11
+ get mergeData() {
12
+ return this._mergeData;
13
+ }
14
+ constructor(entity, propertyName, errorMsg, mergeData = null) {
15
+ this._entity = entity;
16
+ this._propertyName = propertyName;
17
+ this._errorMsg = errorMsg;
18
+ this._mergeData = mergeData;
19
+ }
20
+ }
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LXZhbGlkYXRpb24tZGlhbG9nLWNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RydS1jb21tb24tbGliL3NyYy9saWIvY29tcG9uZW50cy92YWxpZGF0aW9uLWRpYWxvZy90cnUtdmFsaWRhdGlvbi1kaWFsb2ctY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlBLE1BQU0sT0FBTyx5QkFBeUI7SUFNcEMsSUFBVyxNQUFNO1FBQ2YsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ3RCLENBQUM7SUFFRCxJQUFXLFlBQVk7UUFDckIsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDO0lBQzVCLENBQUM7SUFFRCxJQUFXLFFBQVE7UUFDakIsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDO0lBQ3hCLENBQUM7SUFFRCxJQUFXLFNBQVM7UUFDbEIsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDO0lBQ3pCLENBQUM7SUFFRCxZQUNFLE1BQXFCLEVBQ3JCLFlBQW9CLEVBQ3BCLFFBQWdCLEVBQ2hCLFlBQW9DLElBQUk7UUFDeEMsSUFBSSxDQUFDLE9BQU8sR0FBRyxNQUFNLENBQUM7UUFDdEIsSUFBSSxDQUFDLGFBQWEsR0FBRyxZQUFZLENBQUE7UUFDakMsSUFBSSxDQUFDLFNBQVMsR0FBRyxRQUFRLENBQUM7UUFDMUIsSUFBSSxDQUFDLFVBQVUsR0FBRyxTQUFTLENBQUM7SUFDOUIsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVHJ1RW50aXR5QmFzZSB9IGZyb20gXCIuLi8uLi9iYXNlLWNsYXNzZXMvdHJ1LWVudGl0eS1iYXNlXCI7XHJcbmltcG9ydCB7IFRydU1lcmdlRGF0YVNldCB9IGZyb20gXCIuLi8uLi9jbGFzc2VzL3RydS1tZXJnZS1kYXRhLXNldFwiO1xyXG5cclxuXHJcbmV4cG9ydCBjbGFzcyBUcnVWYWxpZGF0aW9uRGlhbG9nQ29uZmlnIHtcclxuICBwcml2YXRlIF9lbnRpdHk6IFRydUVudGl0eUJhc2U7XHJcbiAgcHJpdmF0ZSBfcHJvcGVydHlOYW1lOiBzdHJpbmc7XHJcbiAgcHJpdmF0ZSBfZXJyb3JNc2c6IHN0cmluZztcclxuICBwcml2YXRlIF9tZXJnZURhdGE6IFRydU1lcmdlRGF0YVNldCB8IG51bGw7XHJcbiAgXHJcbiAgcHVibGljIGdldCBlbnRpdHkoKTogVHJ1RW50aXR5QmFzZSB7XHJcbiAgICByZXR1cm4gdGhpcy5fZW50aXR5O1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGdldCBwcm9wZXJ0eU5hbWUoKTogc3RyaW5nIHtcclxuICAgIHJldHVybiB0aGlzLl9wcm9wZXJ0eU5hbWU7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0IGVycm9yTXNnKCk6IHN0cmluZyB7XHJcbiAgICByZXR1cm4gdGhpcy5fZXJyb3JNc2c7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0IG1lcmdlRGF0YSgpOiBUcnVNZXJnZURhdGFTZXQgfCBudWxsIHtcclxuICAgIHJldHVybiB0aGlzLl9tZXJnZURhdGE7XHJcbiAgfVxyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIGVudGl0eTogVHJ1RW50aXR5QmFzZSxcclxuICAgIHByb3BlcnR5TmFtZTogc3RyaW5nLFxyXG4gICAgZXJyb3JNc2c6IHN0cmluZyxcclxuICAgIG1lcmdlRGF0YTogVHJ1TWVyZ2VEYXRhU2V0IHwgbnVsbCA9IG51bGwpIHtcclxuICAgIHRoaXMuX2VudGl0eSA9IGVudGl0eTtcclxuICAgIHRoaXMuX3Byb3BlcnR5TmFtZSA9IHByb3BlcnR5TmFtZVxyXG4gICAgdGhpcy5fZXJyb3JNc2cgPSBlcnJvck1zZztcclxuICAgIHRoaXMuX21lcmdlRGF0YSA9IG1lcmdlRGF0YTtcclxuICB9XHJcbn1cclxuIl19
@@ -2,59 +2,59 @@ import { Component, Input } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
3
  export class TruValidationDialog {
4
4
  constructor() {
5
+ this.errorMsg = '';
5
6
  this.onAcceptAll = () => {
6
- let entity = this.entity;
7
+ let entity = this.config.entity;
7
8
  let originalValues = entity.entityAspect.originalValues;
8
- Object.keys(this.mergeData).forEach((key) => {
9
- let propertyNameKey = key;
10
- entity[key] = this.mergeData[propertyNameKey].value;
9
+ for (const key in this.config.mergeData) {
10
+ entity[key] = this.config.mergeData.getData(key).value;
11
11
  if (originalValues.hasOwnProperty(key))
12
12
  delete originalValues[key];
13
- });
13
+ }
14
+ ;
14
15
  if (Object.keys(originalValues).length === 0 && originalValues.constructor === Object)
15
16
  entity.entityAspect.setUnchanged();
16
- let propertiesToValidate = Object.getOwnPropertyNames(this.mergeData);
17
- entity.Merge_Data = JSON.stringify({});
18
- propertiesToValidate.forEach(function (key) {
17
+ entity.Merge_Data_Set = JSON.stringify({});
18
+ for (const key in this.config.mergeData) {
19
19
  entity.entityAspect.validateProperty(key);
20
- });
20
+ }
21
+ ;
21
22
  };
22
23
  this.onAccept = () => {
23
- let entity = this.entity;
24
- let originalValues = entity.entityAspect.originalValues;
25
- let propertyName = '';
26
- this.mergeData = JSON.parse(entity.Merge_Data);
27
- let propertyNameKey = propertyName;
28
- entity[propertyName] = this.mergeData[propertyNameKey].value;
29
- delete this.mergeData[propertyNameKey];
30
- if (originalValues.hasOwnProperty(propertyName) && (Object.keys(originalValues).length === 0 && originalValues.constructor === Object))
31
- delete originalValues[propertyName];
32
- if (!Object.keys(this.mergeData).length)
33
- entity.entityAspect.setUnchanged();
34
- entity.Merge_Data = JSON.stringify(this.mergeData);
35
- entity.entityAspect.validateProperty(propertyName);
24
+ //let entity = this.config.entity as any;
25
+ //let originalValues = entity.entityAspect.originalValues;
26
+ //let propertyName = '';
27
+ //let mergeData = JSON.parse(entity.Merge_Data_Set);
28
+ //let propertyNameKey = propertyName as keyof typeof this.mergeData;
29
+ //entity[propertyName] = this.config.mergeData?.getData(propertyNameKey)!.value;
30
+ //delete this.mergeData[propertyNameKey];
31
+ //if (originalValues.hasOwnProperty(propertyName) && (Object.keys(originalValues).length === 0 && originalValues.constructor === Object))
32
+ // delete originalValues[propertyName];
33
+ //if (!Object.keys(this.mergeData).length)
34
+ // entity.entityAspect.setUnchanged();
35
+ //entity.Merge_Data = JSON.stringify(this.mergeData);
36
+ //entity.entityAspect.validateProperty(propertyName);
36
37
  };
37
38
  this.onDecline = () => {
38
- let entity = this.entity;
39
- let propertyName = '';
40
- this.mergeData = JSON.parse(entity.Merge_Data);
41
- let propertyNameKey = propertyName;
42
- delete this.mergeData[propertyNameKey];
43
- entity.Merge_Data = JSON.stringify(this.mergeData);
44
- entity.entityAspect.validateProperty(propertyName);
39
+ //let entity = this.entity as any;
40
+ //let propertyName = '';
41
+ //this.mergeData = JSON.parse(entity.Merge_Data);
42
+ //let propertyNameKey = propertyName as keyof typeof this.mergeData;
43
+ //delete this.mergeData[propertyNameKey];
44
+ //entity.Merge_Data = JSON.stringify(this.mergeData);
45
+ //entity.entityAspect.validateProperty(propertyName);
45
46
  };
46
47
  }
47
48
  ngOnInit() {
49
+ this.errorMsg = this.config.errorMsg;
48
50
  }
49
51
  }
50
52
  TruValidationDialog.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.1", ngImport: i0, type: TruValidationDialog, deps: [], target: i0.ɵɵFactoryTarget.Component });
51
- TruValidationDialog.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.1", type: TruValidationDialog, selector: "tru-validation-dialog", inputs: { entity: "entity", mergeData: "mergeData" }, ngImport: i0, template: "<span class=\"invalid\">\r\n <i class=\"icon-warning-sign icon-white\"></i>%error%\r\n <div>\r\n <button style=\"margin: 5px;background-color:#fff;\" class=\"md-primary md-button ng-scope md-ink-ripple\" (click)=\"onAcceptAll()\">Accept All</button>\r\n <button style=\"margin: 5px;background-color:#fff;\" class=\"md-primary md-button ng-scope md-ink-ripple\" (click)=\"onAccept()\">Accept</button>\r\n <button style=\"margin: 5px;background-color:#fff;\" class=\"md-primary md-button ng-scope md-ink-ripple\" (click)=\"onDecline()\">Decline</button>\r\n </div>\r\n</span>\r\n<span class=\"invalid-flag\"></span>\r\n", styles: [".invalid{position:absolute;left:0;top:20px;display:none;-moz-min-width:200px;-ms-min-width:200px;-o-min-width:200px;-webkit-min-width:200px;min-width:200px;min-height:20px;max-width:500px;max-height:500px}.invalid-flag{box-sizing:border-box;position:absolute;left:0;top:0;width:8px;height:8px;border-bottom:solid 4px transparent;border-right:solid 4px transparent;border-left:solid 4px red;border-top:solid 4px red}.invalid-triangle:after{box-sizing:border-box}\n"] });
53
+ TruValidationDialog.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.1", type: TruValidationDialog, selector: "tru-validation-dialog", inputs: { config: "config" }, ngImport: i0, template: "<div class=\"invalid\">\r\n <i class=\"icon-warning-sign icon-white\"></i>{{config.errorMsg}}\r\n <div>\r\n <button *ngif=\"config.mergeData\" class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onAcceptAll()\">Accept All</button>\r\n <button *ngif=\"config.mergeData\" class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onAccept()\">Accept</button>\r\n <button *ngif=\"config.mergeData\" 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", styles: [".invalid{position:absolute;left:0;top:20px;display:none;-moz-min-width:200px;-ms-min-width:200px;-o-min-width:200px;-webkit-min-width:200px;min-width:200px;min-height:20px;max-width:500px;max-height:500px}.invalid-flag{box-sizing:border-box;position:absolute;left:0;top:0;width:8px;height:8px;border-bottom:solid 4px transparent;border-right:solid 4px transparent;border-left:solid 4px red;border-top:solid 4px red}.invalid-triangle:after{box-sizing:border-box}.invalid{background-color:#bd362f;margin:2px 0 0;padding:4px 10px;border-radius:3px!important;background-position:15px center;background-repeat:no-repeat;-ms-box-shadow:0 0 12px #999999;box-shadow:0 0 12px #999;color:#fff;-ms-opacity:.9;opacity:.9;z-index:1000}.merge-button{margin:5px;background-color:#fff}\n"] });
52
54
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.1", ngImport: i0, type: TruValidationDialog, decorators: [{
53
55
  type: Component,
54
- args: [{ selector: 'tru-validation-dialog', template: "<span class=\"invalid\">\r\n <i class=\"icon-warning-sign icon-white\"></i>%error%\r\n <div>\r\n <button style=\"margin: 5px;background-color:#fff;\" class=\"md-primary md-button ng-scope md-ink-ripple\" (click)=\"onAcceptAll()\">Accept All</button>\r\n <button style=\"margin: 5px;background-color:#fff;\" class=\"md-primary md-button ng-scope md-ink-ripple\" (click)=\"onAccept()\">Accept</button>\r\n <button style=\"margin: 5px;background-color:#fff;\" class=\"md-primary md-button ng-scope md-ink-ripple\" (click)=\"onDecline()\">Decline</button>\r\n </div>\r\n</span>\r\n<span class=\"invalid-flag\"></span>\r\n", styles: [".invalid{position:absolute;left:0;top:20px;display:none;-moz-min-width:200px;-ms-min-width:200px;-o-min-width:200px;-webkit-min-width:200px;min-width:200px;min-height:20px;max-width:500px;max-height:500px}.invalid-flag{box-sizing:border-box;position:absolute;left:0;top:0;width:8px;height:8px;border-bottom:solid 4px transparent;border-right:solid 4px transparent;border-left:solid 4px red;border-top:solid 4px red}.invalid-triangle:after{box-sizing:border-box}\n"] }]
55
- }], ctorParameters: function () { return []; }, propDecorators: { entity: [{
56
- type: Input
57
- }], mergeData: [{
56
+ args: [{ selector: 'tru-validation-dialog', template: "<div class=\"invalid\">\r\n <i class=\"icon-warning-sign icon-white\"></i>{{config.errorMsg}}\r\n <div>\r\n <button *ngif=\"config.mergeData\" class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onAcceptAll()\">Accept All</button>\r\n <button *ngif=\"config.mergeData\" class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onAccept()\">Accept</button>\r\n <button *ngif=\"config.mergeData\" 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", styles: [".invalid{position:absolute;left:0;top:20px;display:none;-moz-min-width:200px;-ms-min-width:200px;-o-min-width:200px;-webkit-min-width:200px;min-width:200px;min-height:20px;max-width:500px;max-height:500px}.invalid-flag{box-sizing:border-box;position:absolute;left:0;top:0;width:8px;height:8px;border-bottom:solid 4px transparent;border-right:solid 4px transparent;border-left:solid 4px red;border-top:solid 4px red}.invalid-triangle:after{box-sizing:border-box}.invalid{background-color:#bd362f;margin:2px 0 0;padding:4px 10px;border-radius:3px!important;background-position:15px center;background-repeat:no-repeat;-ms-box-shadow:0 0 12px #999999;box-shadow:0 0 12px #999;color:#fff;-ms-opacity:.9;opacity:.9;z-index:1000}.merge-button{margin:5px;background-color:#fff}\n"] }]
57
+ }], ctorParameters: function () { return []; }, propDecorators: { config: [{
58
58
  type: Input
59
59
  }] } });
60
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LXZhbGlkYXRpb24tZGlhbG9nLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHJ1LWNvbW1vbi1saWIvc3JjL2xpYi9jb21wb25lbnRzL3ZhbGlkYXRpb24tZGlhbG9nL3RydS12YWxpZGF0aW9uLWRpYWxvZy50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RydS1jb21tb24tbGliL3NyYy9saWIvY29tcG9uZW50cy92YWxpZGF0aW9uLWRpYWxvZy90cnUtdmFsaWRhdGlvbi1kaWFsb2cuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQzs7QUFTekQsTUFBTSxPQUFPLG1CQUFtQjtJQUk5QjtRQUlBLGdCQUFXLEdBQUcsR0FBRyxFQUFFO1lBQ2pCLElBQUksTUFBTSxHQUFHLElBQUksQ0FBQyxNQUFhLENBQUM7WUFDaEMsSUFBSSxjQUFjLEdBQUcsTUFBTSxDQUFDLFlBQVksQ0FBQyxjQUFjLENBQUM7WUFFeEQsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUU7Z0JBQzFDLElBQUksZUFBZSxHQUFHLEdBQWtDLENBQUM7Z0JBQ3pELE1BQU0sQ0FBQyxHQUFHLENBQUMsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLGVBQWUsQ0FBQyxDQUFDLEtBQUssQ0FBQztnQkFDcEQsSUFBSSxjQUFjLENBQUMsY0FBYyxDQUFDLEdBQUcsQ0FBQztvQkFDcEMsT0FBTyxjQUFjLENBQUMsR0FBRyxDQUFDLENBQUM7WUFDL0IsQ0FBQyxDQUFDLENBQUM7WUFFSCxJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLENBQUMsTUFBTSxLQUFLLENBQUMsSUFBSSxjQUFjLENBQUMsV0FBVyxLQUFLLE1BQU07Z0JBQ25GLE1BQU0sQ0FBQyxZQUFZLENBQUMsWUFBWSxFQUFFLENBQUM7WUFFckMsSUFBSSxvQkFBb0IsR0FBRyxNQUFNLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBRXRFLE1BQU0sQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUMsQ0FBQztZQUV2QyxvQkFBb0IsQ0FBQyxPQUFPLENBQUMsVUFBVSxHQUFHO2dCQUN4QyxNQUFNLENBQUMsWUFBWSxDQUFDLGdCQUFnQixDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQzVDLENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQyxDQUFBO1FBRUQsYUFBUSxHQUFHLEdBQUcsRUFBRTtZQUNkLElBQUksTUFBTSxHQUFHLElBQUksQ0FBQyxNQUFhLENBQUM7WUFDaEMsSUFBSSxjQUFjLEdBQUcsTUFBTSxDQUFDLFlBQVksQ0FBQyxjQUFjLENBQUM7WUFDeEQsSUFBSSxZQUFZLEdBQUcsRUFBRSxDQUFDO1lBRXRCLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7WUFDL0MsSUFBSSxlQUFlLEdBQUcsWUFBMkMsQ0FBQztZQUNsRSxNQUFNLENBQUMsWUFBWSxDQUFDLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxlQUFlLENBQUMsQ0FBQyxLQUFLLENBQUM7WUFDN0QsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLGVBQWUsQ0FBQyxDQUFDO1lBRXZDLElBQUksY0FBYyxDQUFDLGNBQWMsQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLENBQUMsTUFBTSxLQUFLLENBQUMsSUFBSSxjQUFjLENBQUMsV0FBVyxLQUFLLE1BQU0sQ0FBQztnQkFDcEksT0FBTyxjQUFjLENBQUMsWUFBWSxDQUFDLENBQUM7WUFFdEMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLE1BQU07Z0JBQ3JDLE1BQU0sQ0FBQyxZQUFZLENBQUMsWUFBWSxFQUFFLENBQUM7WUFFckMsTUFBTSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztZQUNuRCxNQUFNLENBQUMsWUFBWSxDQUFDLGdCQUFnQixDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQ3JELENBQUMsQ0FBQTtRQUVELGNBQVMsR0FBRyxHQUFHLEVBQUU7WUFDZixJQUFJLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBYSxDQUFDO1lBQ2hDLElBQUksWUFBWSxHQUFHLEVBQUUsQ0FBQztZQUV0QixJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1lBQy9DLElBQUksZUFBZSxHQUFHLFlBQTJDLENBQUM7WUFDbEUsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLGVBQWUsQ0FBQyxDQUFDO1lBQ3ZDLE1BQU0sQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7WUFDbkQsTUFBTSxDQUFDLFlBQVksQ0FBQyxnQkFBZ0IsQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUNyRCxDQUFDLENBQUE7SUF0REQsQ0FBQztJQXdERCxRQUFRO0lBQ1IsQ0FBQzs7Z0hBL0RVLG1CQUFtQjtvR0FBbkIsbUJBQW1CLG1IQ1RoQyx1bkJBU0E7MkZEQWEsbUJBQW1CO2tCQUwvQixTQUFTOytCQUNFLHVCQUF1QjswRUFLeEIsTUFBTTtzQkFBZCxLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgVHJ1RWRpdENvbnRyb2xCYXNlIH0gZnJvbSAnLi4vLi4vYmFzZS1jbGFzc2VzL3RydS1lZGl0LWNvbnRyb2wtYmFzZSc7XHJcbmltcG9ydCB7IFRydUVudGl0eUJhc2UgfSBmcm9tICcuLi8uLi9iYXNlLWNsYXNzZXMvdHJ1LWVudGl0eS1iYXNlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAndHJ1LXZhbGlkYXRpb24tZGlhbG9nJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vdHJ1LXZhbGlkYXRpb24tZGlhbG9nLmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL3RydS12YWxpZGF0aW9uLWRpYWxvZy5jc3MnXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgVHJ1VmFsaWRhdGlvbkRpYWxvZyBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgQElucHV0KCkgZW50aXR5ITogYW55O1xyXG4gIEBJbnB1dCgpIG1lcmdlRGF0YSE6IGFueTtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7XHJcblxyXG4gIH1cclxuXHJcbiAgb25BY2NlcHRBbGwgPSAoKSA9PiB7XHJcbiAgICBsZXQgZW50aXR5ID0gdGhpcy5lbnRpdHkgYXMgYW55O1xyXG4gICAgbGV0IG9yaWdpbmFsVmFsdWVzID0gZW50aXR5LmVudGl0eUFzcGVjdC5vcmlnaW5hbFZhbHVlcztcclxuXHJcbiAgICBPYmplY3Qua2V5cyh0aGlzLm1lcmdlRGF0YSkuZm9yRWFjaCgoa2V5KSA9PiB7XHJcbiAgICAgIGxldCBwcm9wZXJ0eU5hbWVLZXkgPSBrZXkgYXMga2V5b2YgdHlwZW9mIHRoaXMubWVyZ2VEYXRhO1xyXG4gICAgICBlbnRpdHlba2V5XSA9IHRoaXMubWVyZ2VEYXRhW3Byb3BlcnR5TmFtZUtleV0udmFsdWU7XHJcbiAgICAgIGlmIChvcmlnaW5hbFZhbHVlcy5oYXNPd25Qcm9wZXJ0eShrZXkpKVxyXG4gICAgICAgIGRlbGV0ZSBvcmlnaW5hbFZhbHVlc1trZXldO1xyXG4gICAgfSk7XHJcblxyXG4gICAgaWYgKE9iamVjdC5rZXlzKG9yaWdpbmFsVmFsdWVzKS5sZW5ndGggPT09IDAgJiYgb3JpZ2luYWxWYWx1ZXMuY29uc3RydWN0b3IgPT09IE9iamVjdClcclxuICAgICAgZW50aXR5LmVudGl0eUFzcGVjdC5zZXRVbmNoYW5nZWQoKTtcclxuXHJcbiAgICBsZXQgcHJvcGVydGllc1RvVmFsaWRhdGUgPSBPYmplY3QuZ2V0T3duUHJvcGVydHlOYW1lcyh0aGlzLm1lcmdlRGF0YSk7XHJcblxyXG4gICAgZW50aXR5Lk1lcmdlX0RhdGEgPSBKU09OLnN0cmluZ2lmeSh7fSk7XHJcblxyXG4gICAgcHJvcGVydGllc1RvVmFsaWRhdGUuZm9yRWFjaChmdW5jdGlvbiAoa2V5KSB7XHJcbiAgICAgIGVudGl0eS5lbnRpdHlBc3BlY3QudmFsaWRhdGVQcm9wZXJ0eShrZXkpO1xyXG4gICAgfSk7XHJcbiAgfVxyXG5cclxuICBvbkFjY2VwdCA9ICgpID0+IHtcclxuICAgIGxldCBlbnRpdHkgPSB0aGlzLmVudGl0eSBhcyBhbnk7XHJcbiAgICBsZXQgb3JpZ2luYWxWYWx1ZXMgPSBlbnRpdHkuZW50aXR5QXNwZWN0Lm9yaWdpbmFsVmFsdWVzO1xyXG4gICAgbGV0IHByb3BlcnR5TmFtZSA9ICcnO1xyXG5cclxuICAgIHRoaXMubWVyZ2VEYXRhID0gSlNPTi5wYXJzZShlbnRpdHkuTWVyZ2VfRGF0YSk7XHJcbiAgICBsZXQgcHJvcGVydHlOYW1lS2V5ID0gcHJvcGVydHlOYW1lIGFzIGtleW9mIHR5cGVvZiB0aGlzLm1lcmdlRGF0YTtcclxuICAgIGVudGl0eVtwcm9wZXJ0eU5hbWVdID0gdGhpcy5tZXJnZURhdGFbcHJvcGVydHlOYW1lS2V5XS52YWx1ZTtcclxuICAgIGRlbGV0ZSB0aGlzLm1lcmdlRGF0YVtwcm9wZXJ0eU5hbWVLZXldO1xyXG5cclxuICAgIGlmIChvcmlnaW5hbFZhbHVlcy5oYXNPd25Qcm9wZXJ0eShwcm9wZXJ0eU5hbWUpICYmIChPYmplY3Qua2V5cyhvcmlnaW5hbFZhbHVlcykubGVuZ3RoID09PSAwICYmIG9yaWdpbmFsVmFsdWVzLmNvbnN0cnVjdG9yID09PSBPYmplY3QpKVxyXG4gICAgICBkZWxldGUgb3JpZ2luYWxWYWx1ZXNbcHJvcGVydHlOYW1lXTtcclxuXHJcbiAgICBpZiAoIU9iamVjdC5rZXlzKHRoaXMubWVyZ2VEYXRhKS5sZW5ndGgpXHJcbiAgICAgIGVudGl0eS5lbnRpdHlBc3BlY3Quc2V0VW5jaGFuZ2VkKCk7XHJcblxyXG4gICAgZW50aXR5Lk1lcmdlX0RhdGEgPSBKU09OLnN0cmluZ2lmeSh0aGlzLm1lcmdlRGF0YSk7XHJcbiAgICBlbnRpdHkuZW50aXR5QXNwZWN0LnZhbGlkYXRlUHJvcGVydHkocHJvcGVydHlOYW1lKTtcclxuICB9XHJcblxyXG4gIG9uRGVjbGluZSA9ICgpID0+IHtcclxuICAgIGxldCBlbnRpdHkgPSB0aGlzLmVudGl0eSBhcyBhbnk7XHJcbiAgICBsZXQgcHJvcGVydHlOYW1lID0gJyc7XHJcblxyXG4gICAgdGhpcy5tZXJnZURhdGEgPSBKU09OLnBhcnNlKGVudGl0eS5NZXJnZV9EYXRhKTtcclxuICAgIGxldCBwcm9wZXJ0eU5hbWVLZXkgPSBwcm9wZXJ0eU5hbWUgYXMga2V5b2YgdHlwZW9mIHRoaXMubWVyZ2VEYXRhO1xyXG4gICAgZGVsZXRlIHRoaXMubWVyZ2VEYXRhW3Byb3BlcnR5TmFtZUtleV07XHJcbiAgICBlbnRpdHkuTWVyZ2VfRGF0YSA9IEpTT04uc3RyaW5naWZ5KHRoaXMubWVyZ2VEYXRhKTtcclxuICAgIGVudGl0eS5lbnRpdHlBc3BlY3QudmFsaWRhdGVQcm9wZXJ0eShwcm9wZXJ0eU5hbWUpO1xyXG4gIH1cclxuXHJcbiAgbmdPbkluaXQoKSB7XHJcbiAgfVxyXG59XHJcblxyXG4iLCI8c3BhbiBjbGFzcz1cImludmFsaWRcIj5cclxuICA8aSBjbGFzcz1cImljb24td2FybmluZy1zaWduIGljb24td2hpdGVcIj48L2k+JWVycm9yJVxyXG4gIDxkaXY+XHJcbiAgICA8YnV0dG9uIHN0eWxlPVwibWFyZ2luOiA1cHg7YmFja2dyb3VuZC1jb2xvcjojZmZmO1wiIGNsYXNzPVwibWQtcHJpbWFyeSBtZC1idXR0b24gbmctc2NvcGUgbWQtaW5rLXJpcHBsZVwiIChjbGljayk9XCJvbkFjY2VwdEFsbCgpXCI+QWNjZXB0IEFsbDwvYnV0dG9uPlxyXG4gICAgPGJ1dHRvbiBzdHlsZT1cIm1hcmdpbjogNXB4O2JhY2tncm91bmQtY29sb3I6I2ZmZjtcIiBjbGFzcz1cIm1kLXByaW1hcnkgbWQtYnV0dG9uIG5nLXNjb3BlIG1kLWluay1yaXBwbGVcIiAoY2xpY2spPVwib25BY2NlcHQoKVwiPkFjY2VwdDwvYnV0dG9uPlxyXG4gICAgPGJ1dHRvbiBzdHlsZT1cIm1hcmdpbjogNXB4O2JhY2tncm91bmQtY29sb3I6I2ZmZjtcIiBjbGFzcz1cIm1kLXByaW1hcnkgbWQtYnV0dG9uIG5nLXNjb3BlIG1kLWluay1yaXBwbGVcIiAoY2xpY2spPVwib25EZWNsaW5lKClcIj5EZWNsaW5lPC9idXR0b24+XHJcbiAgPC9kaXY+XHJcbjwvc3Bhbj5cclxuPHNwYW4gY2xhc3M9XCJpbnZhbGlkLWZsYWdcIj48L3NwYW4+XHJcbiJdfQ==
60
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LXZhbGlkYXRpb24tZGlhbG9nLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHJ1LWNvbW1vbi1saWIvc3JjL2xpYi9jb21wb25lbnRzL3ZhbGlkYXRpb24tZGlhbG9nL3RydS12YWxpZGF0aW9uLWRpYWxvZy50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RydS1jb21tb24tbGliL3NyYy9saWIvY29tcG9uZW50cy92YWxpZGF0aW9uLWRpYWxvZy90cnUtdmFsaWRhdGlvbi1kaWFsb2cuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQzs7QUFRekQsTUFBTSxPQUFPLG1CQUFtQjtJQUs5QjtRQUZBLGFBQVEsR0FBVyxFQUFFLENBQUM7UUFJdEIsZ0JBQVcsR0FBRyxHQUFHLEVBQUU7WUFDakIsSUFBSSxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFhLENBQUM7WUFDdkMsSUFBSSxjQUFjLEdBQUcsTUFBTSxDQUFDLFlBQVksQ0FBQyxjQUFjLENBQUM7WUFFeEQsS0FBSyxNQUFNLEdBQUcsSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLFNBQVMsRUFBRTtnQkFDdkMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUUsQ0FBQyxLQUFLLENBQUM7Z0JBQ3hELElBQUksY0FBYyxDQUFDLGNBQWMsQ0FBQyxHQUFHLENBQUM7b0JBQ3BDLE9BQU8sY0FBYyxDQUFDLEdBQUcsQ0FBQyxDQUFDO2FBQzlCO1lBQUEsQ0FBQztZQUVGLElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQyxNQUFNLEtBQUssQ0FBQyxJQUFJLGNBQWMsQ0FBQyxXQUFXLEtBQUssTUFBTTtnQkFDbkYsTUFBTSxDQUFDLFlBQVksQ0FBQyxZQUFZLEVBQUUsQ0FBQztZQUVyQyxNQUFNLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsRUFBRSxDQUFDLENBQUM7WUFFM0MsS0FBSyxNQUFNLEdBQUcsSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLFNBQVMsRUFBRTtnQkFDdkMsTUFBTSxDQUFDLFlBQVksQ0FBQyxnQkFBZ0IsQ0FBQyxHQUFHLENBQUMsQ0FBQzthQUMzQztZQUFBLENBQUM7UUFDSixDQUFDLENBQUE7UUFFRCxhQUFRLEdBQUcsR0FBRyxFQUFFO1lBQ2QseUNBQXlDO1lBQ3pDLDBEQUEwRDtZQUMxRCx3QkFBd0I7WUFFeEIsb0RBQW9EO1lBQ3BELG9FQUFvRTtZQUNwRSxnRkFBZ0Y7WUFDaEYseUNBQXlDO1lBRXpDLHlJQUF5STtZQUN6SSx3Q0FBd0M7WUFFeEMsMENBQTBDO1lBQzFDLHVDQUF1QztZQUV2QyxxREFBcUQ7WUFDckQscURBQXFEO1FBQ3ZELENBQUMsQ0FBQTtRQUVELGNBQVMsR0FBRyxHQUFHLEVBQUU7WUFDZixrQ0FBa0M7WUFDbEMsd0JBQXdCO1lBRXhCLGlEQUFpRDtZQUNqRCxvRUFBb0U7WUFDcEUseUNBQXlDO1lBQ3pDLHFEQUFxRDtZQUNyRCxxREFBcUQ7UUFDdkQsQ0FBQyxDQUFBO0lBbkRjLENBQUM7SUFxRGhCLFFBQVE7UUFDTixJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDO0lBQ3ZDLENBQUM7O2dIQTVEVSxtQkFBbUI7b0dBQW5CLG1CQUFtQiwyRkNSaEMsa25CQVNBOzJGRERhLG1CQUFtQjtrQkFML0IsU0FBUzsrQkFDRSx1QkFBdUI7MEVBS3hCLE1BQU07c0JBQWQsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBUcnVWYWxpZGF0aW9uRGlhbG9nQ29uZmlnIH0gZnJvbSAnLi90cnUtdmFsaWRhdGlvbi1kaWFsb2ctY29uZmlnJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAndHJ1LXZhbGlkYXRpb24tZGlhbG9nJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vdHJ1LXZhbGlkYXRpb24tZGlhbG9nLmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL3RydS12YWxpZGF0aW9uLWRpYWxvZy5jc3MnXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgVHJ1VmFsaWRhdGlvbkRpYWxvZyBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgQElucHV0KCkgY29uZmlnITogVHJ1VmFsaWRhdGlvbkRpYWxvZ0NvbmZpZztcclxuXHJcbiAgZXJyb3JNc2c6IHN0cmluZyA9ICcnO1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHt9XHJcblxyXG4gIG9uQWNjZXB0QWxsID0gKCkgPT4ge1xyXG4gICAgbGV0IGVudGl0eSA9IHRoaXMuY29uZmlnLmVudGl0eSBhcyBhbnk7XHJcbiAgICBsZXQgb3JpZ2luYWxWYWx1ZXMgPSBlbnRpdHkuZW50aXR5QXNwZWN0Lm9yaWdpbmFsVmFsdWVzO1xyXG5cclxuICAgIGZvciAoY29uc3Qga2V5IGluIHRoaXMuY29uZmlnLm1lcmdlRGF0YSkge1xyXG4gICAgICBlbnRpdHlba2V5XSA9IHRoaXMuY29uZmlnLm1lcmdlRGF0YS5nZXREYXRhKGtleSkhLnZhbHVlO1xyXG4gICAgICBpZiAob3JpZ2luYWxWYWx1ZXMuaGFzT3duUHJvcGVydHkoa2V5KSlcclxuICAgICAgICBkZWxldGUgb3JpZ2luYWxWYWx1ZXNba2V5XTtcclxuICAgIH07XHJcblxyXG4gICAgaWYgKE9iamVjdC5rZXlzKG9yaWdpbmFsVmFsdWVzKS5sZW5ndGggPT09IDAgJiYgb3JpZ2luYWxWYWx1ZXMuY29uc3RydWN0b3IgPT09IE9iamVjdClcclxuICAgICAgZW50aXR5LmVudGl0eUFzcGVjdC5zZXRVbmNoYW5nZWQoKTtcclxuXHJcbiAgICBlbnRpdHkuTWVyZ2VfRGF0YV9TZXQgPSBKU09OLnN0cmluZ2lmeSh7fSk7XHJcblxyXG4gICAgZm9yIChjb25zdCBrZXkgaW4gdGhpcy5jb25maWcubWVyZ2VEYXRhKSB7XHJcbiAgICAgIGVudGl0eS5lbnRpdHlBc3BlY3QudmFsaWRhdGVQcm9wZXJ0eShrZXkpO1xyXG4gICAgfTtcclxuICB9XHJcblxyXG4gIG9uQWNjZXB0ID0gKCkgPT4ge1xyXG4gICAgLy9sZXQgZW50aXR5ID0gdGhpcy5jb25maWcuZW50aXR5IGFzIGFueTtcclxuICAgIC8vbGV0IG9yaWdpbmFsVmFsdWVzID0gZW50aXR5LmVudGl0eUFzcGVjdC5vcmlnaW5hbFZhbHVlcztcclxuICAgIC8vbGV0IHByb3BlcnR5TmFtZSA9ICcnO1xyXG5cclxuICAgIC8vbGV0IG1lcmdlRGF0YSA9IEpTT04ucGFyc2UoZW50aXR5Lk1lcmdlX0RhdGFfU2V0KTtcclxuICAgIC8vbGV0IHByb3BlcnR5TmFtZUtleSA9IHByb3BlcnR5TmFtZSBhcyBrZXlvZiB0eXBlb2YgdGhpcy5tZXJnZURhdGE7XHJcbiAgICAvL2VudGl0eVtwcm9wZXJ0eU5hbWVdID0gdGhpcy5jb25maWcubWVyZ2VEYXRhPy5nZXREYXRhKHByb3BlcnR5TmFtZUtleSkhLnZhbHVlO1xyXG4gICAgLy9kZWxldGUgdGhpcy5tZXJnZURhdGFbcHJvcGVydHlOYW1lS2V5XTtcclxuXHJcbiAgICAvL2lmIChvcmlnaW5hbFZhbHVlcy5oYXNPd25Qcm9wZXJ0eShwcm9wZXJ0eU5hbWUpICYmIChPYmplY3Qua2V5cyhvcmlnaW5hbFZhbHVlcykubGVuZ3RoID09PSAwICYmIG9yaWdpbmFsVmFsdWVzLmNvbnN0cnVjdG9yID09PSBPYmplY3QpKVxyXG4gICAgLy8gIGRlbGV0ZSBvcmlnaW5hbFZhbHVlc1twcm9wZXJ0eU5hbWVdO1xyXG5cclxuICAgIC8vaWYgKCFPYmplY3Qua2V5cyh0aGlzLm1lcmdlRGF0YSkubGVuZ3RoKVxyXG4gICAgLy8gIGVudGl0eS5lbnRpdHlBc3BlY3Quc2V0VW5jaGFuZ2VkKCk7XHJcblxyXG4gICAgLy9lbnRpdHkuTWVyZ2VfRGF0YSA9IEpTT04uc3RyaW5naWZ5KHRoaXMubWVyZ2VEYXRhKTtcclxuICAgIC8vZW50aXR5LmVudGl0eUFzcGVjdC52YWxpZGF0ZVByb3BlcnR5KHByb3BlcnR5TmFtZSk7XHJcbiAgfVxyXG5cclxuICBvbkRlY2xpbmUgPSAoKSA9PiB7XHJcbiAgICAvL2xldCBlbnRpdHkgPSB0aGlzLmVudGl0eSBhcyBhbnk7XHJcbiAgICAvL2xldCBwcm9wZXJ0eU5hbWUgPSAnJztcclxuXHJcbiAgICAvL3RoaXMubWVyZ2VEYXRhID0gSlNPTi5wYXJzZShlbnRpdHkuTWVyZ2VfRGF0YSk7XHJcbiAgICAvL2xldCBwcm9wZXJ0eU5hbWVLZXkgPSBwcm9wZXJ0eU5hbWUgYXMga2V5b2YgdHlwZW9mIHRoaXMubWVyZ2VEYXRhO1xyXG4gICAgLy9kZWxldGUgdGhpcy5tZXJnZURhdGFbcHJvcGVydHlOYW1lS2V5XTtcclxuICAgIC8vZW50aXR5Lk1lcmdlX0RhdGEgPSBKU09OLnN0cmluZ2lmeSh0aGlzLm1lcmdlRGF0YSk7XHJcbiAgICAvL2VudGl0eS5lbnRpdHlBc3BlY3QudmFsaWRhdGVQcm9wZXJ0eShwcm9wZXJ0eU5hbWUpO1xyXG4gIH1cclxuXHJcbiAgbmdPbkluaXQoKSB7XHJcbiAgICB0aGlzLmVycm9yTXNnID0gdGhpcy5jb25maWcuZXJyb3JNc2c7XHJcbiAgfVxyXG59XHJcblxyXG4iLCI8ZGl2IGNsYXNzPVwiaW52YWxpZFwiPlxyXG4gIDxpIGNsYXNzPVwiaWNvbi13YXJuaW5nLXNpZ24gaWNvbi13aGl0ZVwiPjwvaT57e2NvbmZpZy5lcnJvck1zZ319XHJcbiAgPGRpdj5cclxuICAgIDxidXR0b24gKm5naWY9XCJjb25maWcubWVyZ2VEYXRhXCIgY2xhc3M9XCJtZC1wcmltYXJ5IG1kLWJ1dHRvbiBuZy1zY29wZSBtZC1pbmstcmlwcGxlIG1lcmdlLWJ1dHRvblwiIChjbGljayk9XCJvbkFjY2VwdEFsbCgpXCI+QWNjZXB0IEFsbDwvYnV0dG9uPlxyXG4gICAgPGJ1dHRvbiAqbmdpZj1cImNvbmZpZy5tZXJnZURhdGFcIiBjbGFzcz1cIm1kLXByaW1hcnkgbWQtYnV0dG9uIG5nLXNjb3BlIG1kLWluay1yaXBwbGUgbWVyZ2UtYnV0dG9uXCIgKGNsaWNrKT1cIm9uQWNjZXB0KClcIj5BY2NlcHQ8L2J1dHRvbj5cclxuICAgIDxidXR0b24gKm5naWY9XCJjb25maWcubWVyZ2VEYXRhXCIgY2xhc3M9XCJtZC1wcmltYXJ5IG1kLWJ1dHRvbiBuZy1zY29wZSBtZC1pbmstcmlwcGxlIG1lcmdlLWJ1dHRvblwiIChjbGljayk9XCJvbkRlY2xpbmUoKVwiPkRlY2xpbmU8L2J1dHRvbj5cclxuICA8L2Rpdj5cclxuPC9kaXY+XHJcbjxzcGFuIGNsYXNzPVwiaW52YWxpZC1mbGFnXCI+PC9zcGFuPlxyXG4iXX0=
@@ -1,5 +1,6 @@
1
1
  import { Directive, Input } from '@angular/core';
2
2
  import { TruValidationDialog } from '../../components/validation-dialog/tru-validation-dialog';
3
+ import { TruValidationDialogConfig } from '../../components/validation-dialog/tru-validation-dialog-config';
3
4
  import * as i0 from "@angular/core";
4
5
  import * as i1 from "../../services/tru-data-context";
5
6
  export class TruBreezeValidator {
@@ -27,21 +28,30 @@ export class TruBreezeValidator {
27
28
  }
28
29
  });
29
30
  if (targetProperty && targetProperty.Merge_Data) {
30
- return JSON.parse(targetProperty.Merge_Data);
31
+ return targetProperty.Merge_Data_Set;
31
32
  }
33
+ return undefined;
32
34
  }
33
35
  else {
34
- return JSON.parse(this.entity.Merge_Data);
36
+ return this.entity.Merge_Data_Set;
35
37
  }
36
38
  };
37
- this.addValidation = (propertyValidations) => {
39
+ this.parseErrorMessages = (validationErrors) => {
40
+ let errorMsg = '';
41
+ validationErrors.forEach((error) => {
42
+ errorMsg += error.errorMessage + '; ';
43
+ });
44
+ return errorMsg;
45
+ };
46
+ this.addValidationDialog = (config) => {
38
47
  const componentFactory = this.componentFactoryResolver.resolveComponentFactory(TruValidationDialog);
39
48
  const component = this.viewContainerRef.createComponent(componentFactory, 0, this.viewContainerRef.injector);
49
+ component.instance.config = config;
40
50
  this.dialogRef = component;
41
51
  };
42
- this.removeValidation = () => {
52
+ this.removeValidationDialog = () => {
43
53
  if (this.dialogRef) {
44
- this.viewContainerRef.remove(this.viewContainerRef.indexOf(this.dialogRef.instance));
54
+ this.dialogRef.destroy();
45
55
  this.dialogRef = null;
46
56
  }
47
57
  };
@@ -55,11 +65,11 @@ export class TruBreezeValidator {
55
65
  let removedPropertyValdations = validationObject.removed.filter((v) => {
56
66
  return v.propertyName === this.config.propertyName;
57
67
  });
58
- if (addedPropertyValdations.length) {
59
- this.addValidation(addedPropertyValdations);
68
+ if (addedPropertyValdations.length || this.mergeData) {
69
+ this.addValidationDialog(new TruValidationDialogConfig(this.entity, this.config.propertyName, this.parseErrorMessages(addedPropertyValdations), this.mergeData));
60
70
  }
61
71
  else if (!addedPropertyValdations.length && removedPropertyValdations.length) {
62
- this.removeValidation();
72
+ this.removeValidationDialog();
63
73
  }
64
74
  }
65
75
  };
@@ -87,4 +97,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.1", ngImpor
87
97
  }], config: [{
88
98
  type: Input
89
99
  }] } });
90
- //# 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 { Component, ComponentFactoryResolver, ComponentRef, Directive, ElementRef, Input, OnDestroy, OnInit, ViewChild, ViewContainerRef } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { TruEditControlBase } from '../../base-classes/tru-edit-control-base';\r\nimport { TruEditControlConfigBase } from '../../base-classes/tru-edit-control-config-base';\r\nimport { TruEntityBase } from '../../base-classes/tru-entity-base';\r\nimport { TruValidationDialog } from '../../components/validation-dialog/tru-validation-dialog';\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;\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\r\n  private getMergeData = (): any => {\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 JSON.parse(targetProperty.Merge_Data);\r\n      }\r\n    } else {\r\n      return JSON.parse(this.entity.Merge_Data);\r\n    }\r\n  }\r\n\r\n  private addValidation = (propertyValidations: any) => {\r\n    const componentFactory = this.componentFactoryResolver.resolveComponentFactory(TruValidationDialog);\r\n    const component = this.viewContainerRef.createComponent<any>(componentFactory, 0, this.viewContainerRef.injector);\r\n    this.dialogRef = component;\r\n  }\r\n\r\n  private removeValidation = () => {\r\n    if (this.dialogRef) {\r\n      this.viewContainerRef.remove(this.viewContainerRef.indexOf(this.dialogRef.instance));\r\n      this.dialogRef = null;\r\n    }\r\n  }\r\n\r\n  valErrsChanged = (validationObject: any) => {\r\n    let validationTableName = validationObject.entity.constructor.name;\r\n    if (this.config.rootTable === validationTableName) {\r\n      this.mergeData = this.getMergeData();\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      if (addedPropertyValdations.length) {\r\n        this.addValidation(addedPropertyValdations);\r\n      } else if (!addedPropertyValdations.length && removedPropertyValdations.length) {\r\n        this.removeValidation();\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.subs.push(this.dataContext.validationChangeDetection.subscribe(entities => {\r\n      console.log(entities);\r\n      this.valErrsChanged(entities);\r\n    }));\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subs.forEach(s => s.unsubscribe());\r\n  }\r\n}\r\n"]}
100
+ //# 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, 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 { 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;\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\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;\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    const componentFactory = this.componentFactoryResolver.resolveComponentFactory(TruValidationDialog);\r\n    const component = this.viewContainerRef.createComponent<TruValidationDialog>(componentFactory, 0, this.viewContainerRef.injector);\r\n    component.instance.config = config;\r\n    this.dialogRef = component;\r\n  }\r\n\r\n  private removeValidationDialog = () => {\r\n    if (this.dialogRef) {\r\n      this.dialogRef.destroy();\r\n      this.dialogRef = null;\r\n    }\r\n  }\r\n\r\n  valErrsChanged = (validationObject: any) => {\r\n    let validationTableName = validationObject.entity.constructor.name;\r\n    if (this.config.rootTable === validationTableName) {\r\n      this.mergeData = this.getMergeData();\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      if (addedPropertyValdations.length || this.mergeData) {\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      } else if (!addedPropertyValdations.length && removedPropertyValdations.length) {\r\n        this.removeValidationDialog();\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.subs.push(this.dataContext.validationChangeDetection.subscribe(entities => {\r\n      console.log(entities);\r\n      this.valErrsChanged(entities);\r\n    }));\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subs.forEach(s => s.unsubscribe());\r\n  }\r\n}\r\n"]}
@@ -106,6 +106,7 @@ class TruEntityBase {
106
106
  this.CreatedRef = -1;
107
107
  this.Updated = undefined;
108
108
  this.UpdatedRef = undefined;
109
+ this.Merge_Data_Set = undefined;
109
110
  }
110
111
  }
111
112
 
@@ -4847,59 +4848,59 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.1", ngImpor
4847
4848
 
4848
4849
  class TruValidationDialog {
4849
4850
  constructor() {
4851
+ this.errorMsg = '';
4850
4852
  this.onAcceptAll = () => {
4851
- let entity = this.entity;
4853
+ let entity = this.config.entity;
4852
4854
  let originalValues = entity.entityAspect.originalValues;
4853
- Object.keys(this.mergeData).forEach((key) => {
4854
- let propertyNameKey = key;
4855
- entity[key] = this.mergeData[propertyNameKey].value;
4855
+ for (const key in this.config.mergeData) {
4856
+ entity[key] = this.config.mergeData.getData(key).value;
4856
4857
  if (originalValues.hasOwnProperty(key))
4857
4858
  delete originalValues[key];
4858
- });
4859
+ }
4860
+ ;
4859
4861
  if (Object.keys(originalValues).length === 0 && originalValues.constructor === Object)
4860
4862
  entity.entityAspect.setUnchanged();
4861
- let propertiesToValidate = Object.getOwnPropertyNames(this.mergeData);
4862
- entity.Merge_Data = JSON.stringify({});
4863
- propertiesToValidate.forEach(function (key) {
4863
+ entity.Merge_Data_Set = JSON.stringify({});
4864
+ for (const key in this.config.mergeData) {
4864
4865
  entity.entityAspect.validateProperty(key);
4865
- });
4866
+ }
4867
+ ;
4866
4868
  };
4867
4869
  this.onAccept = () => {
4868
- let entity = this.entity;
4869
- let originalValues = entity.entityAspect.originalValues;
4870
- let propertyName = '';
4871
- this.mergeData = JSON.parse(entity.Merge_Data);
4872
- let propertyNameKey = propertyName;
4873
- entity[propertyName] = this.mergeData[propertyNameKey].value;
4874
- delete this.mergeData[propertyNameKey];
4875
- if (originalValues.hasOwnProperty(propertyName) && (Object.keys(originalValues).length === 0 && originalValues.constructor === Object))
4876
- delete originalValues[propertyName];
4877
- if (!Object.keys(this.mergeData).length)
4878
- entity.entityAspect.setUnchanged();
4879
- entity.Merge_Data = JSON.stringify(this.mergeData);
4880
- entity.entityAspect.validateProperty(propertyName);
4870
+ //let entity = this.config.entity as any;
4871
+ //let originalValues = entity.entityAspect.originalValues;
4872
+ //let propertyName = '';
4873
+ //let mergeData = JSON.parse(entity.Merge_Data_Set);
4874
+ //let propertyNameKey = propertyName as keyof typeof this.mergeData;
4875
+ //entity[propertyName] = this.config.mergeData?.getData(propertyNameKey)!.value;
4876
+ //delete this.mergeData[propertyNameKey];
4877
+ //if (originalValues.hasOwnProperty(propertyName) && (Object.keys(originalValues).length === 0 && originalValues.constructor === Object))
4878
+ // delete originalValues[propertyName];
4879
+ //if (!Object.keys(this.mergeData).length)
4880
+ // entity.entityAspect.setUnchanged();
4881
+ //entity.Merge_Data = JSON.stringify(this.mergeData);
4882
+ //entity.entityAspect.validateProperty(propertyName);
4881
4883
  };
4882
4884
  this.onDecline = () => {
4883
- let entity = this.entity;
4884
- let propertyName = '';
4885
- this.mergeData = JSON.parse(entity.Merge_Data);
4886
- let propertyNameKey = propertyName;
4887
- delete this.mergeData[propertyNameKey];
4888
- entity.Merge_Data = JSON.stringify(this.mergeData);
4889
- entity.entityAspect.validateProperty(propertyName);
4885
+ //let entity = this.entity as any;
4886
+ //let propertyName = '';
4887
+ //this.mergeData = JSON.parse(entity.Merge_Data);
4888
+ //let propertyNameKey = propertyName as keyof typeof this.mergeData;
4889
+ //delete this.mergeData[propertyNameKey];
4890
+ //entity.Merge_Data = JSON.stringify(this.mergeData);
4891
+ //entity.entityAspect.validateProperty(propertyName);
4890
4892
  };
4891
4893
  }
4892
4894
  ngOnInit() {
4895
+ this.errorMsg = this.config.errorMsg;
4893
4896
  }
4894
4897
  }
4895
4898
  TruValidationDialog.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.1", ngImport: i0, type: TruValidationDialog, deps: [], target: i0.ɵɵFactoryTarget.Component });
4896
- TruValidationDialog.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.1", type: TruValidationDialog, selector: "tru-validation-dialog", inputs: { entity: "entity", mergeData: "mergeData" }, ngImport: i0, template: "<span class=\"invalid\">\r\n <i class=\"icon-warning-sign icon-white\"></i>%error%\r\n <div>\r\n <button style=\"margin: 5px;background-color:#fff;\" class=\"md-primary md-button ng-scope md-ink-ripple\" (click)=\"onAcceptAll()\">Accept All</button>\r\n <button style=\"margin: 5px;background-color:#fff;\" class=\"md-primary md-button ng-scope md-ink-ripple\" (click)=\"onAccept()\">Accept</button>\r\n <button style=\"margin: 5px;background-color:#fff;\" class=\"md-primary md-button ng-scope md-ink-ripple\" (click)=\"onDecline()\">Decline</button>\r\n </div>\r\n</span>\r\n<span class=\"invalid-flag\"></span>\r\n", styles: [".invalid{position:absolute;left:0;top:20px;display:none;-moz-min-width:200px;-ms-min-width:200px;-o-min-width:200px;-webkit-min-width:200px;min-width:200px;min-height:20px;max-width:500px;max-height:500px}.invalid-flag{box-sizing:border-box;position:absolute;left:0;top:0;width:8px;height:8px;border-bottom:solid 4px transparent;border-right:solid 4px transparent;border-left:solid 4px red;border-top:solid 4px red}.invalid-triangle:after{box-sizing:border-box}\n"] });
4899
+ TruValidationDialog.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.1", type: TruValidationDialog, selector: "tru-validation-dialog", inputs: { config: "config" }, ngImport: i0, template: "<div class=\"invalid\">\r\n <i class=\"icon-warning-sign icon-white\"></i>{{config.errorMsg}}\r\n <div>\r\n <button *ngif=\"config.mergeData\" class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onAcceptAll()\">Accept All</button>\r\n <button *ngif=\"config.mergeData\" class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onAccept()\">Accept</button>\r\n <button *ngif=\"config.mergeData\" 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", styles: [".invalid{position:absolute;left:0;top:20px;display:none;-moz-min-width:200px;-ms-min-width:200px;-o-min-width:200px;-webkit-min-width:200px;min-width:200px;min-height:20px;max-width:500px;max-height:500px}.invalid-flag{box-sizing:border-box;position:absolute;left:0;top:0;width:8px;height:8px;border-bottom:solid 4px transparent;border-right:solid 4px transparent;border-left:solid 4px red;border-top:solid 4px red}.invalid-triangle:after{box-sizing:border-box}.invalid{background-color:#bd362f;margin:2px 0 0;padding:4px 10px;border-radius:3px!important;background-position:15px center;background-repeat:no-repeat;-ms-box-shadow:0 0 12px #999999;box-shadow:0 0 12px #999;color:#fff;-ms-opacity:.9;opacity:.9;z-index:1000}.merge-button{margin:5px;background-color:#fff}\n"] });
4897
4900
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.1", ngImport: i0, type: TruValidationDialog, decorators: [{
4898
4901
  type: Component,
4899
- args: [{ selector: 'tru-validation-dialog', template: "<span class=\"invalid\">\r\n <i class=\"icon-warning-sign icon-white\"></i>%error%\r\n <div>\r\n <button style=\"margin: 5px;background-color:#fff;\" class=\"md-primary md-button ng-scope md-ink-ripple\" (click)=\"onAcceptAll()\">Accept All</button>\r\n <button style=\"margin: 5px;background-color:#fff;\" class=\"md-primary md-button ng-scope md-ink-ripple\" (click)=\"onAccept()\">Accept</button>\r\n <button style=\"margin: 5px;background-color:#fff;\" class=\"md-primary md-button ng-scope md-ink-ripple\" (click)=\"onDecline()\">Decline</button>\r\n </div>\r\n</span>\r\n<span class=\"invalid-flag\"></span>\r\n", styles: [".invalid{position:absolute;left:0;top:20px;display:none;-moz-min-width:200px;-ms-min-width:200px;-o-min-width:200px;-webkit-min-width:200px;min-width:200px;min-height:20px;max-width:500px;max-height:500px}.invalid-flag{box-sizing:border-box;position:absolute;left:0;top:0;width:8px;height:8px;border-bottom:solid 4px transparent;border-right:solid 4px transparent;border-left:solid 4px red;border-top:solid 4px red}.invalid-triangle:after{box-sizing:border-box}\n"] }]
4900
- }], ctorParameters: function () { return []; }, propDecorators: { entity: [{
4901
- type: Input
4902
- }], mergeData: [{
4902
+ args: [{ selector: 'tru-validation-dialog', template: "<div class=\"invalid\">\r\n <i class=\"icon-warning-sign icon-white\"></i>{{config.errorMsg}}\r\n <div>\r\n <button *ngif=\"config.mergeData\" class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onAcceptAll()\">Accept All</button>\r\n <button *ngif=\"config.mergeData\" class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onAccept()\">Accept</button>\r\n <button *ngif=\"config.mergeData\" 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", styles: [".invalid{position:absolute;left:0;top:20px;display:none;-moz-min-width:200px;-ms-min-width:200px;-o-min-width:200px;-webkit-min-width:200px;min-width:200px;min-height:20px;max-width:500px;max-height:500px}.invalid-flag{box-sizing:border-box;position:absolute;left:0;top:0;width:8px;height:8px;border-bottom:solid 4px transparent;border-right:solid 4px transparent;border-left:solid 4px red;border-top:solid 4px red}.invalid-triangle:after{box-sizing:border-box}.invalid{background-color:#bd362f;margin:2px 0 0;padding:4px 10px;border-radius:3px!important;background-position:15px center;background-repeat:no-repeat;-ms-box-shadow:0 0 12px #999999;box-shadow:0 0 12px #999;color:#fff;-ms-opacity:.9;opacity:.9;z-index:1000}.merge-button{margin:5px;background-color:#fff}\n"] }]
4903
+ }], ctorParameters: function () { return []; }, propDecorators: { config: [{
4903
4904
  type: Input
4904
4905
  }] } });
4905
4906
 
@@ -4917,6 +4918,27 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.1", ngImpor
4917
4918
  }]
4918
4919
  }] });
4919
4920
 
4921
+ class TruValidationDialogConfig {
4922
+ get entity() {
4923
+ return this._entity;
4924
+ }
4925
+ get propertyName() {
4926
+ return this._propertyName;
4927
+ }
4928
+ get errorMsg() {
4929
+ return this._errorMsg;
4930
+ }
4931
+ get mergeData() {
4932
+ return this._mergeData;
4933
+ }
4934
+ constructor(entity, propertyName, errorMsg, mergeData = null) {
4935
+ this._entity = entity;
4936
+ this._propertyName = propertyName;
4937
+ this._errorMsg = errorMsg;
4938
+ this._mergeData = mergeData;
4939
+ }
4940
+ }
4941
+
4920
4942
  class TruBreezeValidator {
4921
4943
  constructor(el, dataContext, viewContainerRef, componentFactoryResolver) {
4922
4944
  this.el = el;
@@ -4943,21 +4965,30 @@ class TruBreezeValidator {
4943
4965
  }
4944
4966
  });
4945
4967
  if (targetProperty && targetProperty.Merge_Data) {
4946
- return JSON.parse(targetProperty.Merge_Data);
4968
+ return targetProperty.Merge_Data_Set;
4947
4969
  }
4970
+ return undefined;
4948
4971
  }
4949
4972
  else {
4950
- return JSON.parse(this.entity.Merge_Data);
4973
+ return this.entity.Merge_Data_Set;
4951
4974
  }
4952
4975
  };
4953
- this.addValidation = (propertyValidations) => {
4976
+ this.parseErrorMessages = (validationErrors) => {
4977
+ let errorMsg = '';
4978
+ validationErrors.forEach((error) => {
4979
+ errorMsg += error.errorMessage + '; ';
4980
+ });
4981
+ return errorMsg;
4982
+ };
4983
+ this.addValidationDialog = (config) => {
4954
4984
  const componentFactory = this.componentFactoryResolver.resolveComponentFactory(TruValidationDialog);
4955
4985
  const component = this.viewContainerRef.createComponent(componentFactory, 0, this.viewContainerRef.injector);
4986
+ component.instance.config = config;
4956
4987
  this.dialogRef = component;
4957
4988
  };
4958
- this.removeValidation = () => {
4989
+ this.removeValidationDialog = () => {
4959
4990
  if (this.dialogRef) {
4960
- this.viewContainerRef.remove(this.viewContainerRef.indexOf(this.dialogRef.instance));
4991
+ this.dialogRef.destroy();
4961
4992
  this.dialogRef = null;
4962
4993
  }
4963
4994
  };
@@ -4971,11 +5002,11 @@ class TruBreezeValidator {
4971
5002
  let removedPropertyValdations = validationObject.removed.filter((v) => {
4972
5003
  return v.propertyName === this.config.propertyName;
4973
5004
  });
4974
- if (addedPropertyValdations.length) {
4975
- this.addValidation(addedPropertyValdations);
5005
+ if (addedPropertyValdations.length || this.mergeData) {
5006
+ this.addValidationDialog(new TruValidationDialogConfig(this.entity, this.config.propertyName, this.parseErrorMessages(addedPropertyValdations), this.mergeData));
4976
5007
  }
4977
5008
  else if (!addedPropertyValdations.length && removedPropertyValdations.length) {
4978
- this.removeValidation();
5009
+ this.removeValidationDialog();
4979
5010
  }
4980
5011
  }
4981
5012
  };