@trudb/tru-common-lib 0.1.158 → 0.1.159

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.
@@ -49,4 +49,4 @@ export class TruValidationDialogConfig {
49
49
  this._ignore = ignore;
50
50
  }
51
51
  }
52
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LXZhbGlkYXRpb24tZGlhbG9nLWNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RydS1jb21tb24tbGliL3NyYy9saWIvY29tcG9uZW50cy92YWxpZGF0aW9uLWRpYWxvZy90cnUtdmFsaWRhdGlvbi1kaWFsb2ctY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlBLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBRzdFLE1BQU0sT0FBTyx5QkFBeUI7SUFDNUIsT0FBTyxDQUFnQjtJQUN2QixlQUFlLENBQXVFO0lBQ3RGLFFBQVEsQ0FBNkI7SUFDckMsY0FBYyxDQUFVO0lBQ3hCLE9BQU8sQ0FBVTtJQUNqQixhQUFhLEdBQVcsRUFBRSxDQUFDO0lBQzNCLFNBQVMsR0FBVyxFQUFFLENBQUM7SUFDdkIsVUFBVSxHQUEyQixJQUFJLENBQUM7SUFFbEQsSUFBVyxNQUFNO1FBQ2YsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ3RCLENBQUM7SUFFRCxJQUFXLGNBQWM7UUFDdkIsT0FBTyxJQUFJLENBQUMsZUFBZSxDQUFDO0lBQzlCLENBQUM7SUFFRCxJQUFXLE9BQU87UUFDaEIsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDO0lBQ3ZCLENBQUM7SUFFRCxJQUFXLGFBQWE7UUFDdEIsT0FBTyxJQUFJLENBQUMsY0FBYyxDQUFDO0lBQzdCLENBQUM7SUFFRCxJQUFXLE1BQU07UUFDZixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUM7SUFDdEIsQ0FBQztJQUVELElBQVcsWUFBWTtRQUNyQixPQUFPLElBQUksQ0FBQyxhQUFhLENBQUM7SUFDNUIsQ0FBQztJQUVELElBQVcsWUFBWSxDQUFDLEtBQWE7UUFDbkMsSUFBSSxDQUFDLGFBQWEsR0FBRyxLQUFLLENBQUM7SUFDN0IsQ0FBQztJQUVELElBQVcsUUFBUTtRQUNqQixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDeEIsQ0FBQztJQUVELElBQVcsUUFBUSxDQUFDLEtBQWE7UUFDL0IsSUFBSSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUM7SUFDekIsQ0FBQztJQUVELElBQVcsU0FBUztRQUNsQixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUM7SUFDekIsQ0FBQztJQUVELElBQVcsU0FBUyxDQUFDLEtBQTZCO1FBQ2hELElBQUksQ0FBQyxVQUFVLEdBQUcsS0FBSyxDQUFDO0lBQzFCLENBQUM7SUFFRCxZQUNFLE1BQXFCLEVBQ3JCLGNBQW9GLEVBQ3BGLFVBQXNDLDBCQUEwQixDQUFDLE9BQU8sRUFDeEUsZ0JBQXlCLEtBQUssRUFDOUIsU0FBa0IsS0FBSztRQUN2QixJQUFJLENBQUMsT0FBTyxHQUFHLE1BQU0sQ0FBQztRQUN0QixJQUFJLENBQUMsZUFBZSxHQUFHLGNBQWMsQ0FBQztRQUN0QyxJQUFJLENBQUMsUUFBUSxHQUFHLE9BQU8sQ0FBQztRQUN4QixJQUFJLENBQUMsY0FBYyxHQUFHLGFBQWEsQ0FBQztRQUNwQyxJQUFJLENBQUMsT0FBTyxHQUFHLE1BQU0sQ0FBQztJQUN4QixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUcnVFZGl0Q29udHJvbENvbmZpZ0Jhc2UgfSBmcm9tIFwiLi4vLi4vYmFzZS1jbGFzc2VzL3RydS1lZGl0LWNvbnRyb2wtY29uZmlnLWJhc2VcIjtcclxuaW1wb3J0IHsgVHJ1RW50aXR5QmFzZSB9IGZyb20gXCIuLi8uLi9iYXNlLWNsYXNzZXMvdHJ1LWVudGl0eS1iYXNlXCI7XHJcbmltcG9ydCB7IFRydUxpc3RDb250cm9sQ29uZmlnQmFzZSB9IGZyb20gXCIuLi8uLi9iYXNlLWNsYXNzZXMvdHJ1LWxpc3QtY29udHJvbC1jb25maWctYmFzZVwiO1xyXG5pbXBvcnQgeyBUcnVNZXJnZURhdGFTZXQgfSBmcm9tIFwiLi4vLi4vY2xhc3Nlcy90cnUtbWVyZ2UtZGF0YS1zZXRcIjtcclxuaW1wb3J0IHsgVHJ1VmFsaWRhdGlvbkRpYWxvZ0NvbnRleHQgfSBmcm9tIFwiLi90cnUtdmFsaWRhdGlvbi1kaWFsb2ctY29udGV4dFwiO1xyXG5cclxuXHJcbmV4cG9ydCBjbGFzcyBUcnVWYWxpZGF0aW9uRGlhbG9nQ29uZmlnIHtcclxuICBwcml2YXRlIF9lbnRpdHk6IFRydUVudGl0eUJhc2U7XHJcbiAgcHJpdmF0ZSBfcHJvcGVydHlDb25maWc6IEFycmF5PFRydUVkaXRDb250cm9sQ29uZmlnQmFzZTxhbnk+IHwgVHJ1TGlzdENvbnRyb2xDb25maWdCYXNlPGFueT4+O1xyXG4gIHByaXZhdGUgX2NvbnRleHQ6IFRydVZhbGlkYXRpb25EaWFsb2dDb250ZXh0O1xyXG4gIHByaXZhdGUgX2lzU3ViUHJvcGVydHk6IGJvb2xlYW47XHJcbiAgcHJpdmF0ZSBfaWdub3JlOiBib29sZWFuO1xyXG4gIHByaXZhdGUgX3Byb3BlcnR5TmFtZTogc3RyaW5nID0gJyc7XHJcbiAgcHJpdmF0ZSBfZXJyb3JNc2c6IHN0cmluZyA9ICcnO1xyXG4gIHByaXZhdGUgX21lcmdlRGF0YTogVHJ1TWVyZ2VEYXRhU2V0IHwgbnVsbCA9IG51bGw7XHJcbiAgXHJcbiAgcHVibGljIGdldCBlbnRpdHkoKTogVHJ1RW50aXR5QmFzZSB7XHJcbiAgICByZXR1cm4gdGhpcy5fZW50aXR5O1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGdldCBwcm9wZXJ0eUNvbmZpZygpOiBBcnJheTxUcnVFZGl0Q29udHJvbENvbmZpZ0Jhc2U8YW55PiB8IFRydUxpc3RDb250cm9sQ29uZmlnQmFzZTxhbnk+PiB7XHJcbiAgICByZXR1cm4gdGhpcy5fcHJvcGVydHlDb25maWc7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0IGNvbnRleHQoKTogVHJ1VmFsaWRhdGlvbkRpYWxvZ0NvbnRleHQge1xyXG4gICAgcmV0dXJuIHRoaXMuX2NvbnRleHQ7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0IGlzU3ViUHJvcGVydHkoKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gdGhpcy5faXNTdWJQcm9wZXJ0eTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBnZXQgaWdub3JlKCk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuIHRoaXMuX2lnbm9yZTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBnZXQgcHJvcGVydHlOYW1lKCk6IHN0cmluZyB8IG51bGwge1xyXG4gICAgcmV0dXJuIHRoaXMuX3Byb3BlcnR5TmFtZTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBzZXQgcHJvcGVydHlOYW1lKHZhbHVlOiBzdHJpbmcpIHtcclxuICAgIHRoaXMuX3Byb3BlcnR5TmFtZSA9IHZhbHVlO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGdldCBlcnJvck1zZygpOiBzdHJpbmcgfCBudWxsIHtcclxuICAgIHJldHVybiB0aGlzLl9lcnJvck1zZztcclxuICB9XHJcblxyXG4gIHB1YmxpYyBzZXQgZXJyb3JNc2codmFsdWU6IHN0cmluZykge1xyXG4gICAgdGhpcy5fZXJyb3JNc2cgPSB2YWx1ZTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBnZXQgbWVyZ2VEYXRhKCk6IFRydU1lcmdlRGF0YVNldCB8IG51bGwge1xyXG4gICAgcmV0dXJuIHRoaXMuX21lcmdlRGF0YTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBzZXQgbWVyZ2VEYXRhKHZhbHVlOiBUcnVNZXJnZURhdGFTZXQgfCBudWxsKSB7XHJcbiAgICB0aGlzLl9tZXJnZURhdGEgPSB2YWx1ZTtcclxuICB9XHJcblxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgZW50aXR5OiBUcnVFbnRpdHlCYXNlLFxyXG4gICAgcHJvcGVydHlDb25maWc6IEFycmF5PFRydUVkaXRDb250cm9sQ29uZmlnQmFzZTxhbnk+IHwgVHJ1TGlzdENvbnRyb2xDb25maWdCYXNlPGFueT4+LFxyXG4gICAgY29udGV4dDogVHJ1VmFsaWRhdGlvbkRpYWxvZ0NvbnRleHQgPSBUcnVWYWxpZGF0aW9uRGlhbG9nQ29udGV4dC5Db250cm9sLFxyXG4gICAgaXNTdWJQcm9wZXJ0eTogYm9vbGVhbiA9IGZhbHNlLFxyXG4gICAgaWdub3JlOiBib29sZWFuID0gZmFsc2UpIHtcclxuICAgIHRoaXMuX2VudGl0eSA9IGVudGl0eTtcclxuICAgIHRoaXMuX3Byb3BlcnR5Q29uZmlnID0gcHJvcGVydHlDb25maWc7XHJcbiAgICB0aGlzLl9jb250ZXh0ID0gY29udGV4dDtcclxuICAgIHRoaXMuX2lzU3ViUHJvcGVydHkgPSBpc1N1YlByb3BlcnR5O1xyXG4gICAgdGhpcy5faWdub3JlID0gaWdub3JlO1xyXG4gIH1cclxufVxyXG4iXX0=
52
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LXZhbGlkYXRpb24tZGlhbG9nLWNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RydS1jb21tb24tbGliL3NyYy9saWIvY29tcG9uZW50cy92YWxpZGF0aW9uLWRpYWxvZy90cnUtdmFsaWRhdGlvbi1kaWFsb2ctY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlBLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBRzdFLE1BQU0sT0FBTyx5QkFBeUI7SUFDNUIsT0FBTyxDQUFnQjtJQUN2QixlQUFlLENBQWdFO0lBQy9FLFFBQVEsQ0FBNkI7SUFDckMsY0FBYyxDQUFVO0lBQ3hCLE9BQU8sQ0FBVTtJQUNqQixhQUFhLEdBQVcsRUFBRSxDQUFDO0lBQzNCLFNBQVMsR0FBVyxFQUFFLENBQUM7SUFDdkIsVUFBVSxHQUEyQixJQUFJLENBQUM7SUFFbEQsSUFBVyxNQUFNO1FBQ2YsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ3RCLENBQUM7SUFFRCxJQUFXLGNBQWM7UUFDdkIsT0FBTyxJQUFJLENBQUMsZUFBZSxDQUFDO0lBQzlCLENBQUM7SUFFRCxJQUFXLE9BQU87UUFDaEIsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDO0lBQ3ZCLENBQUM7SUFFRCxJQUFXLGFBQWE7UUFDdEIsT0FBTyxJQUFJLENBQUMsY0FBYyxDQUFDO0lBQzdCLENBQUM7SUFFRCxJQUFXLE1BQU07UUFDZixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUM7SUFDdEIsQ0FBQztJQUVELElBQVcsWUFBWTtRQUNyQixPQUFPLElBQUksQ0FBQyxhQUFhLENBQUM7SUFDNUIsQ0FBQztJQUVELElBQVcsWUFBWSxDQUFDLEtBQWE7UUFDbkMsSUFBSSxDQUFDLGFBQWEsR0FBRyxLQUFLLENBQUM7SUFDN0IsQ0FBQztJQUVELElBQVcsUUFBUTtRQUNqQixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDeEIsQ0FBQztJQUVELElBQVcsUUFBUSxDQUFDLEtBQWE7UUFDL0IsSUFBSSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUM7SUFDekIsQ0FBQztJQUVELElBQVcsU0FBUztRQUNsQixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUM7SUFDekIsQ0FBQztJQUVELElBQVcsU0FBUyxDQUFDLEtBQTZCO1FBQ2hELElBQUksQ0FBQyxVQUFVLEdBQUcsS0FBSyxDQUFDO0lBQzFCLENBQUM7SUFFRCxZQUNFLE1BQXFCLEVBQ3JCLGNBQTZFLEVBQzdFLFVBQXNDLDBCQUEwQixDQUFDLE9BQU8sRUFDeEUsZ0JBQXlCLEtBQUssRUFDOUIsU0FBa0IsS0FBSztRQUN2QixJQUFJLENBQUMsT0FBTyxHQUFHLE1BQU0sQ0FBQztRQUN0QixJQUFJLENBQUMsZUFBZSxHQUFHLGNBQWMsQ0FBQztRQUN0QyxJQUFJLENBQUMsUUFBUSxHQUFHLE9BQU8sQ0FBQztRQUN4QixJQUFJLENBQUMsY0FBYyxHQUFHLGFBQWEsQ0FBQztRQUNwQyxJQUFJLENBQUMsT0FBTyxHQUFHLE1BQU0sQ0FBQztJQUN4QixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUcnVFZGl0Q29udHJvbENvbmZpZ0Jhc2UgfSBmcm9tIFwiLi4vLi4vYmFzZS1jbGFzc2VzL3RydS1lZGl0LWNvbnRyb2wtY29uZmlnLWJhc2VcIjtcclxuaW1wb3J0IHsgVHJ1RW50aXR5QmFzZSB9IGZyb20gXCIuLi8uLi9iYXNlLWNsYXNzZXMvdHJ1LWVudGl0eS1iYXNlXCI7XHJcbmltcG9ydCB7IFRydUxpc3RDb250cm9sQ29uZmlnQmFzZSB9IGZyb20gXCIuLi8uLi9iYXNlLWNsYXNzZXMvdHJ1LWxpc3QtY29udHJvbC1jb25maWctYmFzZVwiO1xyXG5pbXBvcnQgeyBUcnVNZXJnZURhdGFTZXQgfSBmcm9tIFwiLi4vLi4vY2xhc3Nlcy90cnUtbWVyZ2UtZGF0YS1zZXRcIjtcclxuaW1wb3J0IHsgVHJ1VmFsaWRhdGlvbkRpYWxvZ0NvbnRleHQgfSBmcm9tIFwiLi90cnUtdmFsaWRhdGlvbi1kaWFsb2ctY29udGV4dFwiO1xyXG5cclxuXHJcbmV4cG9ydCBjbGFzcyBUcnVWYWxpZGF0aW9uRGlhbG9nQ29uZmlnIHtcclxuICBwcml2YXRlIF9lbnRpdHk6IFRydUVudGl0eUJhc2U7XHJcbiAgcHJpdmF0ZSBfcHJvcGVydHlDb25maWc6IFRydUVkaXRDb250cm9sQ29uZmlnQmFzZTxhbnk+IHwgVHJ1TGlzdENvbnRyb2xDb25maWdCYXNlPGFueT47XHJcbiAgcHJpdmF0ZSBfY29udGV4dDogVHJ1VmFsaWRhdGlvbkRpYWxvZ0NvbnRleHQ7XHJcbiAgcHJpdmF0ZSBfaXNTdWJQcm9wZXJ0eTogYm9vbGVhbjtcclxuICBwcml2YXRlIF9pZ25vcmU6IGJvb2xlYW47XHJcbiAgcHJpdmF0ZSBfcHJvcGVydHlOYW1lOiBzdHJpbmcgPSAnJztcclxuICBwcml2YXRlIF9lcnJvck1zZzogc3RyaW5nID0gJyc7XHJcbiAgcHJpdmF0ZSBfbWVyZ2VEYXRhOiBUcnVNZXJnZURhdGFTZXQgfCBudWxsID0gbnVsbDtcclxuICBcclxuICBwdWJsaWMgZ2V0IGVudGl0eSgpOiBUcnVFbnRpdHlCYXNlIHtcclxuICAgIHJldHVybiB0aGlzLl9lbnRpdHk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0IHByb3BlcnR5Q29uZmlnKCk6IFRydUVkaXRDb250cm9sQ29uZmlnQmFzZTxhbnk+IHwgVHJ1TGlzdENvbnRyb2xDb25maWdCYXNlPGFueT4ge1xyXG4gICAgcmV0dXJuIHRoaXMuX3Byb3BlcnR5Q29uZmlnO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGdldCBjb250ZXh0KCk6IFRydVZhbGlkYXRpb25EaWFsb2dDb250ZXh0IHtcclxuICAgIHJldHVybiB0aGlzLl9jb250ZXh0O1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGdldCBpc1N1YlByb3BlcnR5KCk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuIHRoaXMuX2lzU3ViUHJvcGVydHk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0IGlnbm9yZSgpOiBib29sZWFuIHtcclxuICAgIHJldHVybiB0aGlzLl9pZ25vcmU7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0IHByb3BlcnR5TmFtZSgpOiBzdHJpbmcgfCBudWxsIHtcclxuICAgIHJldHVybiB0aGlzLl9wcm9wZXJ0eU5hbWU7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgc2V0IHByb3BlcnR5TmFtZSh2YWx1ZTogc3RyaW5nKSB7XHJcbiAgICB0aGlzLl9wcm9wZXJ0eU5hbWUgPSB2YWx1ZTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBnZXQgZXJyb3JNc2coKTogc3RyaW5nIHwgbnVsbCB7XHJcbiAgICByZXR1cm4gdGhpcy5fZXJyb3JNc2c7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgc2V0IGVycm9yTXNnKHZhbHVlOiBzdHJpbmcpIHtcclxuICAgIHRoaXMuX2Vycm9yTXNnID0gdmFsdWU7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0IG1lcmdlRGF0YSgpOiBUcnVNZXJnZURhdGFTZXQgfCBudWxsIHtcclxuICAgIHJldHVybiB0aGlzLl9tZXJnZURhdGE7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgc2V0IG1lcmdlRGF0YSh2YWx1ZTogVHJ1TWVyZ2VEYXRhU2V0IHwgbnVsbCkge1xyXG4gICAgdGhpcy5fbWVyZ2VEYXRhID0gdmFsdWU7XHJcbiAgfVxyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIGVudGl0eTogVHJ1RW50aXR5QmFzZSxcclxuICAgIHByb3BlcnR5Q29uZmlnOiBUcnVFZGl0Q29udHJvbENvbmZpZ0Jhc2U8YW55PiB8IFRydUxpc3RDb250cm9sQ29uZmlnQmFzZTxhbnk+LFxyXG4gICAgY29udGV4dDogVHJ1VmFsaWRhdGlvbkRpYWxvZ0NvbnRleHQgPSBUcnVWYWxpZGF0aW9uRGlhbG9nQ29udGV4dC5Db250cm9sLFxyXG4gICAgaXNTdWJQcm9wZXJ0eTogYm9vbGVhbiA9IGZhbHNlLFxyXG4gICAgaWdub3JlOiBib29sZWFuID0gZmFsc2UpIHtcclxuICAgIHRoaXMuX2VudGl0eSA9IGVudGl0eTtcclxuICAgIHRoaXMuX3Byb3BlcnR5Q29uZmlnID0gcHJvcGVydHlDb25maWc7XHJcbiAgICB0aGlzLl9jb250ZXh0ID0gY29udGV4dDtcclxuICAgIHRoaXMuX2lzU3ViUHJvcGVydHkgPSBpc1N1YlByb3BlcnR5O1xyXG4gICAgdGhpcy5faWdub3JlID0gaWdub3JlO1xyXG4gIH1cclxufVxyXG4iXX0=
@@ -2,7 +2,6 @@ import { Directive, Input } from '@angular/core';
2
2
  import { TruValidationDialogContext } from '../../../public-api';
3
3
  import { TruValidationDialog } from '../../components/validation-dialog/tru-validation-dialog';
4
4
  import { TruValidationDialogConfig } from '../../components/validation-dialog/tru-validation-dialog-config';
5
- import { forEach } from 'underscore';
6
5
  import * as i0 from "@angular/core";
7
6
  import * as i1 from "../../services/tru-data-context";
8
7
  export class TruBreezeValidator {
@@ -73,44 +72,18 @@ export class TruBreezeValidator {
73
72
  let validationTableName = validationObjectEntity.constructor.name;
74
73
  const entityPkeyName = validationTableName + 'Ref';
75
74
  const validationObjectEntitypkeyName = validationTableName + 'Ref';
76
- let addedPropertyValdations;
77
- let removedPropertyValdations;
78
- let configs = [];
79
- if (this.config.subProperties.length) {
80
- forEach(this.config.subPropertyNames, (subPropertyName) => {
81
- const subPropertyNameKey = validationTableName + 'Ref';
82
- addedPropertyValdations = validationObject.added.filter((v) => {
83
- let propertyName = this.config[subPropertyNameKey].propertyName;
84
- if (v.propertyName === propertyName) {
85
- configs.push(this.config[subPropertyNameKey]);
86
- return v.propertyName === propertyName;
87
- }
88
- return v.propertyName === propertyName;
89
- });
90
- removedPropertyValdations = validationObject.removed.filter((v) => {
91
- let propertyName = this.config[subPropertyNameKey].propertyName;
92
- if (v.propertyName === propertyName) {
93
- return v.propertyName === propertyName;
94
- }
95
- return v.propertyName === propertyName;
96
- });
97
- });
98
- }
99
- else {
100
- configs.push(this.config);
101
- addedPropertyValdations = validationObject.added.filter((v) => {
102
- return v.propertyName === this.config.propertyName;
103
- });
104
- removedPropertyValdations = validationObject.removed.filter((v) => {
105
- return v.propertyName === this.config.propertyName;
106
- });
107
- }
75
+ let addedPropertyValdations = validationObject.added.filter((v) => {
76
+ return v.propertyName === this.config.propertyName;
77
+ });
78
+ let removedPropertyValdations = validationObject.removed.filter((v) => {
79
+ return v.propertyName === this.config.propertyName;
80
+ });
108
81
  this.mergeData = this.getMergeData();
109
82
  if (this.config.rootTable === validationTableName &&
110
83
  this.entity[entityPkeyName] === validationObjectEntity[validationObjectEntitypkeyName] &&
111
84
  (addedPropertyValdations.length || this.mergeData)) {
112
85
  this.removeValidationDialog();
113
- let config = new TruValidationDialogConfig(this.entity, configs);
86
+ let config = new TruValidationDialogConfig(this.entity, this.config);
114
87
  config.propertyName = this.config.propertyName;
115
88
  config.mergeData = this.mergeData;
116
89
  config.errorMsg = this.parseErrorMessages(addedPropertyValdations);
@@ -124,7 +97,7 @@ export class TruBreezeValidator {
124
97
  };
125
98
  ngOnInit() { }
126
99
  ngAfterViewInit() {
127
- if (this.context !== TruValidationDialogContext.Grid && !this.config.isSubProperty) {
100
+ if (this.context !== TruValidationDialogContext.Grid) {
128
101
  this.subs.push(this.dataContext.validationChangeDetection.subscribe(entities => {
129
102
  this.valErrsChanged(entities);
130
103
  }));
@@ -151,4 +124,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
151
124
  }], config: [{
152
125
  type: Input
153
126
  }] } });
154
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tru-breeze-validator.js","sourceRoot":"","sources":["../../../../../../projects/tru-common-lib/src/lib/directives/breeze-validator/tru-breeze-validator.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentFactoryResolver, ComponentRef, Directive, ElementRef, Input, OnDestroy, OnInit, SimpleChanges, ViewContainerRef } from '@angular/core';\r\nimport { ValidationError } from 'breeze-client';\r\nimport { Subscription } from 'rxjs';\r\nimport { TruValidationDialogContext } from '../../../public-api';\r\nimport { TruEditControlConfigBase } from '../../base-classes/tru-edit-control-config-base';\r\nimport { TruListControlConfigBase } from '../../base-classes/tru-list-control-config-base';\r\nimport { TruMergeDataSet } from '../../classes/tru-merge-data-set';\r\nimport { TruValidationDialog } from '../../components/validation-dialog/tru-validation-dialog';\r\nimport { TruValidationDialogConfig } from '../../components/validation-dialog/tru-validation-dialog-config';\r\nimport { TruDataContext } from '../../services/tru-data-context';\r\nimport { forEach } from 'underscore';\r\n\r\n@Directive({\r\n  selector: '[truBreezeValidator]'\r\n})\r\nexport class TruBreezeValidator implements OnInit, OnDestroy {\r\n  @Input('truBreezeValidator') entity!: any;\r\n  @Input() config!: TruEditControlConfigBase<any> | TruListControlConfigBase<any>;\r\n\r\n  constructor(\r\n    private el: ElementRef,\r\n    private dataContext: TruDataContext,\r\n    private viewContainerRef: ViewContainerRef,\r\n    private componentFactoryResolver: ComponentFactoryResolver) {\r\n  }\r\n\r\n  configModel: any = {};\r\n  mergeData: any;\r\n\r\n  private dialogRef: ComponentRef<any> | null = null;\r\n  private subs: Array<Subscription> = [];\r\n  private currentDialog: ComponentRef<TruValidationDialog> | null = null;\r\n  private context: TruValidationDialogContext = TruValidationDialogContext.Control;\r\n\r\n  private getMergeData = (): TruMergeDataSet | undefined => {\r\n    if (this.config.propertyPath?.includes('/')) {\r\n      let propertyNameParts = this.config.propertyPath.split('/');\r\n      propertyNameParts.pop();\r\n      let targetProperty: any;\r\n      propertyNameParts.forEach((name) => {\r\n        if (!targetProperty) {\r\n          let targetPropertyName = 'o' + name as keyof typeof this.entity;\r\n          targetProperty = this.entity[targetPropertyName];\r\n        } else {\r\n          let targetPropertyName = 'o' + name as keyof typeof this.entity;\r\n          targetProperty = targetProperty[targetPropertyName];\r\n        }\r\n      });\r\n      if (targetProperty && targetProperty.Merge_Data) {\r\n        return targetProperty.Merge_Data_Set;\r\n      }\r\n      return undefined;\r\n    } else {\r\n      return this.entity.Merge_Data_Set?.get(this.config.propertyName as string) ? this.entity.Merge_Data_Set : undefined;\r\n    }\r\n  }\r\n\r\n  private parseErrorMessages = (validationErrors: Array<ValidationError>): string => {\r\n    let errorMsg: string = '';\r\n    validationErrors.forEach((error) => {\r\n      errorMsg += error.errorMessage + '; ';\r\n    });\r\n    return errorMsg;\r\n  }\r\n\r\n  private addValidationDialog = (config: TruValidationDialogConfig) => {\r\n    let componentFactory = this.componentFactoryResolver.resolveComponentFactory(TruValidationDialog);\r\n    let component = this.viewContainerRef.createComponent<TruValidationDialog>(componentFactory, 0, this.viewContainerRef.injector);\r\n    component.instance.config = config;\r\n    this.currentDialog = component;\r\n    this.dialogRef = component;\r\n  }\r\n\r\n  private removeValidationDialog = () => {\r\n    if (this.currentDialog) {\r\n      this.currentDialog.destroy();\r\n      this.currentDialog = null;\r\n    }\r\n  }\r\n\r\n  valErrsChanged = (validationObject: any) => {\r\n    let validationObjectEntity = validationObject.entity\r\n    let validationTableName = validationObjectEntity.constructor.name;\r\n\r\n    type EntityObjectKey = keyof typeof this.entity;\r\n    const entityPkeyName = validationTableName + 'Ref' as EntityObjectKey;\r\n\r\n    type ValidationObjectEntityObjectKey = keyof typeof validationObjectEntity;\r\n    const validationObjectEntitypkeyName = validationTableName + 'Ref' as ValidationObjectEntityObjectKey;\r\n\r\n    let addedPropertyValdations\r\n    let removedPropertyValdations\r\n    let configs: any[] = [];\r\n    if (this.config.subProperties.length) {\r\n      forEach(this.config.subPropertyNames, (subPropertyName) => {\r\n        type ConfigObjectKey = keyof typeof this.config;\r\n        const subPropertyNameKey = validationTableName + 'Ref' as ConfigObjectKey;\r\n        addedPropertyValdations = validationObject.added.filter((v: any) => {\r\n          let propertyName = this.config[subPropertyNameKey].propertyName as string;\r\n          if (v.propertyName === propertyName) {\r\n            configs.push(this.config[subPropertyNameKey]);\r\n            return v.propertyName === propertyName\r\n          }\r\n          return v.propertyName === propertyName\r\n        });\r\n\r\n        removedPropertyValdations = validationObject.removed.filter((v: any) => {\r\n          let propertyName = this.config[subPropertyNameKey].propertyName as string;\r\n          if (v.propertyName === propertyName) {\r\n            return v.propertyName === propertyName\r\n          }\r\n          return v.propertyName === propertyName\r\n        });\r\n      });\r\n    } else {\r\n      configs.push(this.config);\r\n      addedPropertyValdations = validationObject.added.filter((v: any) => {\r\n        return v.propertyName === this.config.propertyName\r\n      });\r\n\r\n      removedPropertyValdations = validationObject.removed.filter((v: any) => {\r\n        return v.propertyName === this.config.propertyName\r\n      });\r\n    }\r\n\r\n\r\n\r\n    this.mergeData = this.getMergeData();\r\n\r\n    if (\r\n      this.config.rootTable === validationTableName &&\r\n      this.entity[entityPkeyName] === validationObjectEntity[validationObjectEntitypkeyName] &&\r\n      (addedPropertyValdations.length || this.mergeData)) {\r\n      this.removeValidationDialog();\r\n      let config = new TruValidationDialogConfig(this.entity, configs);\r\n      config.propertyName = this.config.propertyName as string;\r\n      config.mergeData = this.mergeData;\r\n      config.errorMsg = this.parseErrorMessages(addedPropertyValdations);\r\n      this.addValidationDialog(config);\r\n    }\r\n\r\n    if (\r\n      this.config.rootTable === validationTableName &&\r\n      this.entity[entityPkeyName] === validationObjectEntity[validationObjectEntitypkeyName] &&\r\n      (removedPropertyValdations.length)) {\r\n      this.removeValidationDialog();\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void { }\r\n\r\n  ngAfterViewInit(): void {\r\n    if (this.context !== TruValidationDialogContext.Grid && !this.config.isSubProperty) {\r\n      this.subs.push(this.dataContext.validationChangeDetection.subscribe(entities => {\r\n        this.valErrsChanged(entities);\r\n      }));\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    this.removeValidationDialog();\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"]}
127
+ //# 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;AAGzJ,OAAO,EAAE,0BAA0B,EAAE,MAAM,qBAAqB,CAAC;AAIjE,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,CAAO;IACjC,MAAM,CAAiE;IAEhF,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,CAAC;IAC/D,OAAO,GAA+B,0BAA0B,CAAC,OAAO,CAAC;IAEzE,YAAY,GAAG,GAAgC,EAAE;QACvD,IAAI,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;YAC5C,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,CAAC;oBACpB,IAAI,kBAAkB,GAAG,GAAG,GAAG,IAAgC,CAAC;oBAChE,cAAc,GAAG,IAAI,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAAC;gBACnD,CAAC;qBAAM,CAAC;oBACN,IAAI,kBAAkB,GAAG,GAAG,GAAG,IAAgC,CAAC;oBAChE,cAAc,GAAG,cAAc,CAAC,kBAAkB,CAAC,CAAC;gBACtD,CAAC;YACH,CAAC,CAAC,CAAC;YACH,IAAI,cAAc,IAAI,cAAc,CAAC,UAAU,EAAE,CAAC;gBAChD,OAAO,cAAc,CAAC,cAAc,CAAC;YACvC,CAAC;YACD,OAAO,SAAS,CAAC;QACnB,CAAC;aAAM,CAAC;YACN,OAAO,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,YAAsB,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC,SAAS,CAAC;QACtH,CAAC;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,CAAC;YACvB,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC;YAC7B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAC5B,CAAC;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,CAAC;YACrD,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAC9B,IAAI,MAAM,GAAG,IAAI,yBAAyB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;YACrE,MAAM,CAAC,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,YAAsB,CAAC;YACzD,MAAM,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;YAClC,MAAM,CAAC,QAAQ,GAAG,IAAI,CAAC,kBAAkB,CAAC,uBAAuB,CAAC,CAAC;YACnE,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC;QACnC,CAAC;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,CAAC;YACrC,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAChC,CAAC;IACH,CAAC,CAAA;IAED,QAAQ,KAAW,CAAC;IAEpB,eAAe;QACb,IAAI,IAAI,CAAC,OAAO,KAAK,0BAA0B,CAAC,IAAI,EAAE,CAAC;YACrD,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,yBAAyB,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE;gBAC7E,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;YAChC,CAAC,CAAC,CAAC,CAAC;QACN,CAAC;IACH,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAC9B,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,cAAc,EAAE,CAAC;IAC5C,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 { TruValidationDialogContext } from '../../../public-api';\r\nimport { TruEditControlConfigBase } from '../../base-classes/tru-edit-control-config-base';\r\nimport { TruListControlConfigBase } from '../../base-classes/tru-list-control-config-base';\r\nimport { TruMergeDataSet } from '../../classes/tru-merge-data-set';\r\nimport { TruValidationDialog } from '../../components/validation-dialog/tru-validation-dialog';\r\nimport { TruValidationDialogConfig } from '../../components/validation-dialog/tru-validation-dialog-config';\r\nimport { TruDataContext } from '../../services/tru-data-context';\r\n\r\n@Directive({\r\n  selector: '[truBreezeValidator]'\r\n})\r\nexport class TruBreezeValidator implements OnInit, OnDestroy {\r\n  @Input('truBreezeValidator') entity!: any;\r\n  @Input() config!: TruEditControlConfigBase<any> | TruListControlConfigBase<any>;\r\n\r\n  constructor(\r\n    private el: ElementRef,\r\n    private dataContext: TruDataContext,\r\n    private viewContainerRef: ViewContainerRef,\r\n    private componentFactoryResolver: ComponentFactoryResolver) {\r\n  }\r\n\r\n  configModel: any = {};\r\n  mergeData: any;\r\n\r\n  private dialogRef: ComponentRef<any> | null = null;\r\n  private subs: Array<Subscription> = [];\r\n  private currentDialog: ComponentRef<TruValidationDialog> | null = null;\r\n  private context: TruValidationDialogContext = TruValidationDialogContext.Control;\r\n\r\n  private getMergeData = (): TruMergeDataSet | undefined => {\r\n    if (this.config.propertyPath?.includes('/')) {\r\n      let propertyNameParts = this.config.propertyPath.split('/');\r\n      propertyNameParts.pop();\r\n      let targetProperty: any;\r\n      propertyNameParts.forEach((name) => {\r\n        if (!targetProperty) {\r\n          let targetPropertyName = 'o' + name as keyof typeof this.entity;\r\n          targetProperty = this.entity[targetPropertyName];\r\n        } else {\r\n          let targetPropertyName = 'o' + name as keyof typeof this.entity;\r\n          targetProperty = targetProperty[targetPropertyName];\r\n        }\r\n      });\r\n      if (targetProperty && targetProperty.Merge_Data) {\r\n        return targetProperty.Merge_Data_Set;\r\n      }\r\n      return undefined;\r\n    } else {\r\n      return this.entity.Merge_Data_Set?.get(this.config.propertyName as string) ? this.entity.Merge_Data_Set : undefined;\r\n    }\r\n  }\r\n\r\n  private parseErrorMessages = (validationErrors: Array<ValidationError>): string => {\r\n    let errorMsg: string = '';\r\n    validationErrors.forEach((error) => {\r\n      errorMsg += error.errorMessage + '; ';\r\n    });\r\n    return errorMsg;\r\n  }\r\n\r\n  private addValidationDialog = (config: TruValidationDialogConfig) => {\r\n    let componentFactory = this.componentFactoryResolver.resolveComponentFactory(TruValidationDialog);\r\n    let component = this.viewContainerRef.createComponent<TruValidationDialog>(componentFactory, 0, this.viewContainerRef.injector);\r\n    component.instance.config = config;\r\n    this.currentDialog = component;\r\n    this.dialogRef = component;\r\n  }\r\n\r\n  private removeValidationDialog = () => {\r\n    if (this.currentDialog) {\r\n      this.currentDialog.destroy();\r\n      this.currentDialog = null;\r\n    }\r\n  }\r\n\r\n  valErrsChanged = (validationObject: any) => {\r\n    let validationObjectEntity = validationObject.entity\r\n    let validationTableName = validationObjectEntity.constructor.name;\r\n\r\n    type EntityObjectKey = keyof typeof this.entity;\r\n    const entityPkeyName = validationTableName + 'Ref' as EntityObjectKey;\r\n\r\n    type ValidationObjectEntityObjectKey = keyof typeof validationObjectEntity;\r\n    const validationObjectEntitypkeyName = validationTableName + 'Ref' as ValidationObjectEntityObjectKey;\r\n\r\n    let addedPropertyValdations = validationObject.added.filter((v: any) => {\r\n      return v.propertyName === this.config.propertyName\r\n    });\r\n\r\n    let removedPropertyValdations = validationObject.removed.filter((v: any) => {\r\n      return v.propertyName === this.config.propertyName\r\n    });\r\n\r\n    this.mergeData = this.getMergeData();\r\n\r\n    if (\r\n      this.config.rootTable === validationTableName &&\r\n      this.entity[entityPkeyName] === validationObjectEntity[validationObjectEntitypkeyName] &&\r\n      (addedPropertyValdations.length || this.mergeData)) {\r\n      this.removeValidationDialog();\r\n      let config = new TruValidationDialogConfig(this.entity, this.config);\r\n      config.propertyName = this.config.propertyName as string;\r\n      config.mergeData = this.mergeData;\r\n      config.errorMsg = this.parseErrorMessages(addedPropertyValdations);\r\n      this.addValidationDialog(config);\r\n    }\r\n\r\n    if (\r\n      this.config.rootTable === validationTableName &&\r\n      this.entity[entityPkeyName] === validationObjectEntity[validationObjectEntitypkeyName] &&\r\n      (removedPropertyValdations.length)) {\r\n      this.removeValidationDialog();\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void { }\r\n\r\n  ngAfterViewInit(): void {\r\n    if (this.context !== TruValidationDialogContext.Grid) {\r\n      this.subs.push(this.dataContext.validationChangeDetection.subscribe(entities => {\r\n        this.valErrsChanged(entities);\r\n      }));\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    this.removeValidationDialog();\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"]}
@@ -3,7 +3,7 @@ import { Directive, Input, Injectable, Component, Inject, HostListener, Injectio
3
3
  import { EntityAspect, MetadataStore, DataService, EntityManager, EntityQuery, Predicate, FetchStrategy, EntityState, breeze, BinaryPredicate, AndOrPredicate } from 'breeze-client';
4
4
  import { BehaviorSubject, defer, from, of, Subject, Observable, skip, forkJoin, finalize, throwError } from 'rxjs';
5
5
  import * as _ from 'underscore';
6
- import ___default, { forEach } from 'underscore';
6
+ import ___default from 'underscore';
7
7
  import * as i2 from '@angular/common/http';
8
8
  import { HttpClientModule, HttpClient, HTTP_INTERCEPTORS } from '@angular/common/http';
9
9
  import * as i1 from '@angular/material/dialog';
@@ -7407,44 +7407,18 @@ class TruBreezeValidator {
7407
7407
  let validationTableName = validationObjectEntity.constructor.name;
7408
7408
  const entityPkeyName = validationTableName + 'Ref';
7409
7409
  const validationObjectEntitypkeyName = validationTableName + 'Ref';
7410
- let addedPropertyValdations;
7411
- let removedPropertyValdations;
7412
- let configs = [];
7413
- if (this.config.subProperties.length) {
7414
- forEach(this.config.subPropertyNames, (subPropertyName) => {
7415
- const subPropertyNameKey = validationTableName + 'Ref';
7416
- addedPropertyValdations = validationObject.added.filter((v) => {
7417
- let propertyName = this.config[subPropertyNameKey].propertyName;
7418
- if (v.propertyName === propertyName) {
7419
- configs.push(this.config[subPropertyNameKey]);
7420
- return v.propertyName === propertyName;
7421
- }
7422
- return v.propertyName === propertyName;
7423
- });
7424
- removedPropertyValdations = validationObject.removed.filter((v) => {
7425
- let propertyName = this.config[subPropertyNameKey].propertyName;
7426
- if (v.propertyName === propertyName) {
7427
- return v.propertyName === propertyName;
7428
- }
7429
- return v.propertyName === propertyName;
7430
- });
7431
- });
7432
- }
7433
- else {
7434
- configs.push(this.config);
7435
- addedPropertyValdations = validationObject.added.filter((v) => {
7436
- return v.propertyName === this.config.propertyName;
7437
- });
7438
- removedPropertyValdations = validationObject.removed.filter((v) => {
7439
- return v.propertyName === this.config.propertyName;
7440
- });
7441
- }
7410
+ let addedPropertyValdations = validationObject.added.filter((v) => {
7411
+ return v.propertyName === this.config.propertyName;
7412
+ });
7413
+ let removedPropertyValdations = validationObject.removed.filter((v) => {
7414
+ return v.propertyName === this.config.propertyName;
7415
+ });
7442
7416
  this.mergeData = this.getMergeData();
7443
7417
  if (this.config.rootTable === validationTableName &&
7444
7418
  this.entity[entityPkeyName] === validationObjectEntity[validationObjectEntitypkeyName] &&
7445
7419
  (addedPropertyValdations.length || this.mergeData)) {
7446
7420
  this.removeValidationDialog();
7447
- let config = new TruValidationDialogConfig(this.entity, configs);
7421
+ let config = new TruValidationDialogConfig(this.entity, this.config);
7448
7422
  config.propertyName = this.config.propertyName;
7449
7423
  config.mergeData = this.mergeData;
7450
7424
  config.errorMsg = this.parseErrorMessages(addedPropertyValdations);
@@ -7458,7 +7432,7 @@ class TruBreezeValidator {
7458
7432
  };
7459
7433
  ngOnInit() { }
7460
7434
  ngAfterViewInit() {
7461
- if (this.context !== TruValidationDialogContext.Grid && !this.config.isSubProperty) {
7435
+ if (this.context !== TruValidationDialogContext.Grid) {
7462
7436
  this.subs.push(this.dataContext.validationChangeDetection.subscribe(entities => {
7463
7437
  this.valErrsChanged(entities);
7464
7438
  }));