@trudb/tru-common-lib 0.1.19 → 0.1.21

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@trudb/tru-common-lib",
3
- "version": "0.1.19",
3
+ "version": "0.1.21",
4
4
  "type": "module",
5
5
  "peerDependencies": {},
6
6
  "dependencies": {
package/public-api.d.ts CHANGED
@@ -59,8 +59,6 @@ export * from './lib/components/desktop/services/tru-window-event-args';
59
59
  export * from './lib/components/desktop/services/tru-window-event-handler';
60
60
  export * from './lib/components/export-dialog/tru-export-dialog';
61
61
  export * from './lib/components/export-dialog/tru-export-dialog-module';
62
- export * from './lib/components/grid-validation-dialog/tru-grid-validation-dialog';
63
- export * from './lib/components/grid-validation-dialog/tru-grid-validation-dialog-module';
64
62
  export * from './lib/components/layout/column/tru-column';
65
63
  export * from './lib/components/layout/column/tru-column-module';
66
64
  export * from './lib/components/layout/form/tru-form';
@@ -95,10 +93,6 @@ export * from './lib/components/validation-dialog/tru-validation-dialog';
95
93
  export * from './lib/components/validation-dialog/tru-validation-dialog-config';
96
94
  export * from './lib/components/validation-dialog/tru-validation-dialog-context';
97
95
  export * from './lib/components/validation-dialog/tru-validation-dialog-module';
98
- export * from './lib/components/grid-validation-dialog/tru-grid-validation-dialog';
99
- export * from './lib/components/grid-validation-dialog/tru-grid-validation-dialog-module';
100
- export * from './lib/directives/breeze-grid-validator/tru-breeze-grid-validator';
101
- export * from './lib/directives/breeze-grid-validator/tru-breeze-grid-validator-module';
102
96
  export * from './lib/directives/breeze-validator/tru-breeze-validator';
103
97
  export * from './lib/directives/breeze-validator/tru-breeze-validator-module';
104
98
  export * from './lib/directives/search-panel-position-manager/tru-search-panel-position-manager';
@@ -1,25 +0,0 @@
1
- export class TruGridValidationDialogConfig {
2
- _entity;
3
- _propertyName;
4
- _errorMsg;
5
- _mergeData;
6
- get entity() {
7
- return this._entity;
8
- }
9
- get propertyName() {
10
- return this._propertyName;
11
- }
12
- get errorMsg() {
13
- return this._errorMsg;
14
- }
15
- get mergeData() {
16
- return this._mergeData;
17
- }
18
- constructor(entity, propertyName, errorMsg, mergeData = null) {
19
- this._entity = entity;
20
- this._propertyName = propertyName;
21
- this._errorMsg = errorMsg;
22
- this._mergeData = mergeData;
23
- }
24
- }
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LWdyaWQtdmFsaWRhdGlvbi1kaWFsb2ctY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHJ1LWNvbW1vbi1saWIvc3JjL2xpYi9jb21wb25lbnRzL2dyaWQtdmFsaWRhdGlvbi1kaWFsb2cvdHJ1LWdyaWQtdmFsaWRhdGlvbi1kaWFsb2ctY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlBLE1BQU0sT0FBTyw2QkFBNkI7SUFDaEMsT0FBTyxDQUFnQjtJQUN2QixhQUFhLENBQVM7SUFDdEIsU0FBUyxDQUFTO0lBQ2xCLFVBQVUsQ0FBeUI7SUFFM0MsSUFBVyxNQUFNO1FBQ2YsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ3RCLENBQUM7SUFFRCxJQUFXLFlBQVk7UUFDckIsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDO0lBQzVCLENBQUM7SUFFRCxJQUFXLFFBQVE7UUFDakIsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDO0lBQ3hCLENBQUM7SUFFRCxJQUFXLFNBQVM7UUFDbEIsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDO0lBQ3pCLENBQUM7SUFFRCxZQUNFLE1BQXFCLEVBQ3JCLFlBQW9CLEVBQ3BCLFFBQWdCLEVBQ2hCLFlBQW9DLElBQUk7UUFDeEMsSUFBSSxDQUFDLE9BQU8sR0FBRyxNQUFNLENBQUM7UUFDdEIsSUFBSSxDQUFDLGFBQWEsR0FBRyxZQUFZLENBQUE7UUFDakMsSUFBSSxDQUFDLFNBQVMsR0FBRyxRQUFRLENBQUM7UUFDMUIsSUFBSSxDQUFDLFVBQVUsR0FBRyxTQUFTLENBQUM7SUFDOUIsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVHJ1RW50aXR5QmFzZSB9IGZyb20gXCIuLi8uLi9iYXNlLWNsYXNzZXMvdHJ1LWVudGl0eS1iYXNlXCI7XHJcbmltcG9ydCB7IFRydU1lcmdlRGF0YVNldCB9IGZyb20gXCIuLi8uLi9jbGFzc2VzL3RydS1tZXJnZS1kYXRhLXNldFwiO1xyXG5cclxuXHJcbmV4cG9ydCBjbGFzcyBUcnVHcmlkVmFsaWRhdGlvbkRpYWxvZ0NvbmZpZyB7XHJcbiAgcHJpdmF0ZSBfZW50aXR5OiBUcnVFbnRpdHlCYXNlO1xyXG4gIHByaXZhdGUgX3Byb3BlcnR5TmFtZTogc3RyaW5nO1xyXG4gIHByaXZhdGUgX2Vycm9yTXNnOiBzdHJpbmc7XHJcbiAgcHJpdmF0ZSBfbWVyZ2VEYXRhOiBUcnVNZXJnZURhdGFTZXQgfCBudWxsO1xyXG4gIFxyXG4gIHB1YmxpYyBnZXQgZW50aXR5KCk6IFRydUVudGl0eUJhc2Uge1xyXG4gICAgcmV0dXJuIHRoaXMuX2VudGl0eTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBnZXQgcHJvcGVydHlOYW1lKCk6IHN0cmluZyB7XHJcbiAgICByZXR1cm4gdGhpcy5fcHJvcGVydHlOYW1lO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGdldCBlcnJvck1zZygpOiBzdHJpbmcge1xyXG4gICAgcmV0dXJuIHRoaXMuX2Vycm9yTXNnO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGdldCBtZXJnZURhdGEoKTogVHJ1TWVyZ2VEYXRhU2V0IHwgbnVsbCB7XHJcbiAgICByZXR1cm4gdGhpcy5fbWVyZ2VEYXRhO1xyXG4gIH1cclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBlbnRpdHk6IFRydUVudGl0eUJhc2UsXHJcbiAgICBwcm9wZXJ0eU5hbWU6IHN0cmluZyxcclxuICAgIGVycm9yTXNnOiBzdHJpbmcsXHJcbiAgICBtZXJnZURhdGE6IFRydU1lcmdlRGF0YVNldCB8IG51bGwgPSBudWxsKSB7XHJcbiAgICB0aGlzLl9lbnRpdHkgPSBlbnRpdHk7XHJcbiAgICB0aGlzLl9wcm9wZXJ0eU5hbWUgPSBwcm9wZXJ0eU5hbWVcclxuICAgIHRoaXMuX2Vycm9yTXNnID0gZXJyb3JNc2c7XHJcbiAgICB0aGlzLl9tZXJnZURhdGEgPSBtZXJnZURhdGE7XHJcbiAgfVxyXG59XHJcbiJdfQ==
@@ -1,19 +0,0 @@
1
- import { NgModule } from "@angular/core";
2
- import { CommonModule } from "@angular/common";
3
- import { FormsModule } from "@angular/forms";
4
- import { TruGridValidationDialog } from "./tru-grid-validation-dialog";
5
- import * as i0 from "@angular/core";
6
- export class TruGridValidationDialogModule {
7
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TruGridValidationDialogModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
8
- static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.0.2", ngImport: i0, type: TruGridValidationDialogModule, declarations: [TruGridValidationDialog], imports: [CommonModule, FormsModule], exports: [TruGridValidationDialog] });
9
- static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TruGridValidationDialogModule, imports: [CommonModule, FormsModule] });
10
- }
11
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TruGridValidationDialogModule, decorators: [{
12
- type: NgModule,
13
- args: [{
14
- declarations: [TruGridValidationDialog],
15
- imports: [CommonModule, FormsModule],
16
- exports: [TruGridValidationDialog]
17
- }]
18
- }] });
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LWdyaWQtdmFsaWRhdGlvbi1kaWFsb2ctbW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHJ1LWNvbW1vbi1saWIvc3JjL2xpYi9jb21wb25lbnRzL2dyaWQtdmFsaWRhdGlvbi1kaWFsb2cvdHJ1LWdyaWQtdmFsaWRhdGlvbi1kaWFsb2ctbW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUU3QyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQzs7QUFPdkUsTUFBTSxPQUFPLDZCQUE2Qjt1R0FBN0IsNkJBQTZCO3dHQUE3Qiw2QkFBNkIsaUJBSnpCLHVCQUF1QixhQUM1QixZQUFZLEVBQUUsV0FBVyxhQUN6Qix1QkFBdUI7d0dBRXRCLDZCQUE2QixZQUg5QixZQUFZLEVBQUUsV0FBVzs7MkZBR3hCLDZCQUE2QjtrQkFMekMsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyx1QkFBdUIsQ0FBQztvQkFDdkMsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLFdBQVcsQ0FBQztvQkFDcEMsT0FBTyxFQUFFLENBQUMsdUJBQXVCLENBQUM7aUJBQ25DIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XHJcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2Zvcm1zXCI7XHJcblxyXG5pbXBvcnQgeyBUcnVHcmlkVmFsaWRhdGlvbkRpYWxvZyB9IGZyb20gXCIuL3RydS1ncmlkLXZhbGlkYXRpb24tZGlhbG9nXCI7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW1RydUdyaWRWYWxpZGF0aW9uRGlhbG9nXSxcclxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBGb3Jtc01vZHVsZV0sXHJcbiAgZXhwb3J0czogW1RydUdyaWRWYWxpZGF0aW9uRGlhbG9nXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgVHJ1R3JpZFZhbGlkYXRpb25EaWFsb2dNb2R1bGUgeyB9XHJcbiJdfQ==
@@ -1,80 +0,0 @@
1
- import { Component, EventEmitter, Input, Output } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- import * as i1 from "../../services/tru-util";
4
- import * as i2 from "@angular/common";
5
- export class TruGridValidationDialog {
6
- renderer;
7
- elementRef;
8
- util;
9
- config;
10
- close = new EventEmitter();
11
- errorMsg = '';
12
- rowElement;
13
- cellElement;
14
- listeners = [];
15
- constructor(renderer, elementRef, util) {
16
- this.renderer = renderer;
17
- this.elementRef = elementRef;
18
- this.util = util;
19
- }
20
- onAcceptAll = () => {
21
- let entity = this.config.entity;
22
- let originalValues = entity.entityAspect.originalValues;
23
- for (const key in this.config.mergeData?.getAll()) {
24
- entity[key] = this.config.mergeData?.get(key).value;
25
- if (originalValues.hasOwnProperty(key))
26
- delete originalValues[key];
27
- }
28
- ;
29
- if (Object.keys(originalValues).length === 0 && originalValues.constructor === Object)
30
- entity.entityAspect.setUnchanged();
31
- entity.Merge_Data_Set.clearAll();
32
- entity.entityAspect.validateEntity();
33
- this.close.emit();
34
- };
35
- onAccept = () => {
36
- let entity = this.config.entity;
37
- let originalValues = entity.entityAspect.originalValues;
38
- let propertyName = this.config.propertyName;
39
- entity[propertyName] = this.config.mergeData?.get(propertyName).value;
40
- this.config.mergeData?.clear(propertyName);
41
- if (originalValues.hasOwnProperty(propertyName) && (Object.keys(originalValues).length === 0 && originalValues.constructor === Object))
42
- delete originalValues[propertyName];
43
- if (this.config.mergeData?.isEmpty())
44
- entity.entityAspect.setUnchanged();
45
- entity.entityAspect.validateEntity();
46
- this.close.emit();
47
- };
48
- onDecline = () => {
49
- let entity = this.config.entity;
50
- this.config.mergeData?.clearAll();
51
- entity.entityAspect.validateEntity();
52
- this.close.emit();
53
- };
54
- ngOnInit() { }
55
- ngAfterViewInit() {
56
- this.rowElement = this.util.findClosestAncestorByClass(this.elementRef.nativeElement, '.ag-row');
57
- this.cellElement = this.util.findClosestAncestorByClass(this.elementRef.nativeElement, '.ag-cell-value');
58
- this.rowElement.style.zIndex = '10000000000';
59
- this.cellElement.classList.add('show');
60
- this.errorMsg = this.config.errorMsg;
61
- }
62
- ngOnDestroy() {
63
- this.rowElement = this.util.findClosestAncestorByClass(this.elementRef.nativeElement, '.ag-row');
64
- this.cellElement = this.util.findClosestAncestorByClass(this.elementRef.nativeElement, '.ag-cell-value');
65
- this.rowElement.style.zIndex = 'auto';
66
- this.cellElement.classList.remove('show');
67
- this.listeners.forEach(l => l());
68
- }
69
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TruGridValidationDialog, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i1.TruUtil }], target: i0.ɵɵFactoryTarget.Component });
70
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: TruGridValidationDialog, selector: "tru-grid-validation-dialog", inputs: { config: "config" }, outputs: { close: "close" }, ngImport: i0, template: "<i class=\"icon-warning-sign icon-white\"></i>{{config.errorMsg}}\r\n<div *ngIf=\"config.mergeData\">\r\n <button class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onAcceptAll()\">Accept All</button>\r\n <button class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onAccept()\">Accept</button>\r\n <button class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onDecline()\">Decline</button>\r\n</div>\r\n", styles: ["::ng-deep .ag-row .ag-cell-value .invalid{position:absolute;left:0;top:22px;-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;font-size:12px}::ng-deep .ag-row .ag-cell-value.hide .invalid{display:none!important}::ng-deep .ag-row .ag-cell-value.show .invalid{display:inline-block!important}::ng-deep .ag-row .ag-cell-value.invalid.show{overflow:visible!important}.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}::ng-deep .ag-row .ag-cell-value .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}::ng-deep .mat-mdc-form-field.invalid .mdc-line-ripple:before{border-bottom-color:red!important}::ng-deep .mat-mdc-form-field.invalid .mdc-line-ripple:after{border-bottom-color:red!important}.invalid{font-family:Calibri,Helvetica,Arial,sans-serif!important}i{line-height:24px!important}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
71
- }
72
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TruGridValidationDialog, decorators: [{
73
- type: Component,
74
- args: [{ selector: 'tru-grid-validation-dialog', template: "<i class=\"icon-warning-sign icon-white\"></i>{{config.errorMsg}}\r\n<div *ngIf=\"config.mergeData\">\r\n <button class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onAcceptAll()\">Accept All</button>\r\n <button class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onAccept()\">Accept</button>\r\n <button class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onDecline()\">Decline</button>\r\n</div>\r\n", styles: ["::ng-deep .ag-row .ag-cell-value .invalid{position:absolute;left:0;top:22px;-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;font-size:12px}::ng-deep .ag-row .ag-cell-value.hide .invalid{display:none!important}::ng-deep .ag-row .ag-cell-value.show .invalid{display:inline-block!important}::ng-deep .ag-row .ag-cell-value.invalid.show{overflow:visible!important}.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}::ng-deep .ag-row .ag-cell-value .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}::ng-deep .mat-mdc-form-field.invalid .mdc-line-ripple:before{border-bottom-color:red!important}::ng-deep .mat-mdc-form-field.invalid .mdc-line-ripple:after{border-bottom-color:red!important}.invalid{font-family:Calibri,Helvetica,Arial,sans-serif!important}i{line-height:24px!important}\n"] }]
75
- }], ctorParameters: () => [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i1.TruUtil }], propDecorators: { config: [{
76
- type: Input
77
- }], close: [{
78
- type: Output
79
- }] } });
80
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tru-grid-validation-dialog.js","sourceRoot":"","sources":["../../../../../../projects/tru-common-lib/src/lib/components/grid-validation-dialog/tru-grid-validation-dialog.ts","../../../../../../projects/tru-common-lib/src/lib/components/grid-validation-dialog/tru-grid-validation-dialog.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, OnDestroy, OnInit, Output, Renderer2 } from '@angular/core';\r\nimport { TruUtil } from '../../services/tru-util';\r\nimport { TruGridValidationDialogConfig } from './tru-grid-validation-dialog-config';\r\n\r\n@Component({\r\n  selector: 'tru-grid-validation-dialog',\r\n  templateUrl: './tru-grid-validation-dialog.html',\r\n  styleUrls: ['./tru-grid-validation-dialog.css']\r\n})\r\nexport class TruGridValidationDialog implements OnInit, OnDestroy {\r\n  @Input() config!: TruGridValidationDialogConfig;\r\n  @Output() close = new EventEmitter();\r\n\r\n  errorMsg: string = '';\r\n\r\n  private rowElement!: HTMLElement;\r\n  private cellElement!: HTMLElement;\r\n  private listeners: Array<() => void> = [];\r\n\r\n  constructor(\r\n    private renderer: Renderer2,\r\n    private elementRef: ElementRef, \r\n    private util: TruUtil) { }\r\n\r\n  onAcceptAll = () => {\r\n    let entity = this.config.entity as any;\r\n    let originalValues = entity.entityAspect.originalValues;\r\n\r\n    for (const key in this.config.mergeData?.getAll()) {\r\n      entity[key] = this.config.mergeData?.get(key)!.value;\r\n      if (originalValues.hasOwnProperty(key))\r\n        delete originalValues[key];\r\n    };\r\n\r\n    if (Object.keys(originalValues).length === 0 && originalValues.constructor === Object)\r\n      entity.entityAspect.setUnchanged();\r\n\r\n    entity.Merge_Data_Set.clearAll();\r\n\r\n    entity.entityAspect.validateEntity();\r\n    this.close.emit();\r\n  }\r\n\r\n  onAccept = () => {\r\n    let entity = this.config.entity as any;\r\n    let originalValues = entity.entityAspect.originalValues;\r\n    let propertyName = this.config.propertyName;\r\n\r\n    entity[propertyName] = this.config.mergeData?.get(propertyName)!.value;\r\n    this.config.mergeData?.clear(propertyName);\r\n\r\n    if (originalValues.hasOwnProperty(propertyName) && (Object.keys(originalValues).length === 0 && originalValues.constructor === Object))\r\n      delete originalValues[propertyName];\r\n\r\n    if (this.config.mergeData?.isEmpty())\r\n      entity.entityAspect.setUnchanged();\r\n\r\n    entity.entityAspect.validateEntity();\r\n    this.close.emit();\r\n  }\r\n\r\n  onDecline = () => {\r\n    let entity = this.config.entity as any;\r\n    this.config.mergeData?.clearAll();\r\n    entity.entityAspect.validateEntity();\r\n    this.close.emit();\r\n  }\r\n\r\n  ngOnInit() {}\r\n\r\n  ngAfterViewInit(): void {\r\n    this.rowElement = this.util.findClosestAncestorByClass(this.elementRef.nativeElement, '.ag-row');\r\n    this.cellElement = this.util.findClosestAncestorByClass(this.elementRef.nativeElement, '.ag-cell-value');\r\n    this.rowElement.style.zIndex = '10000000000';\r\n    this.cellElement.classList.add('show');\r\n    this.errorMsg = this.config.errorMsg;\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.rowElement = this.util.findClosestAncestorByClass(this.elementRef.nativeElement, '.ag-row');\r\n    this.cellElement = this.util.findClosestAncestorByClass(this.elementRef.nativeElement, '.ag-cell-value');\r\n    this.rowElement.style.zIndex = 'auto';\r\n    this.cellElement.classList.remove('show');\r\n    this.listeners.forEach(l => l());\r\n  }\r\n}\r\n\r\n","<i class=\"icon-warning-sign icon-white\"></i>{{config.errorMsg}}\r\n<div *ngIf=\"config.mergeData\">\r\n  <button class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onAcceptAll()\">Accept All</button>\r\n  <button class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onAccept()\">Accept</button>\r\n  <button class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onDecline()\">Decline</button>\r\n</div>\r\n"]}
@@ -1,19 +0,0 @@
1
- import { NgModule } from '@angular/core';
2
- import { CommonModule } from '@angular/common';
3
- import { FormsModule } from '@angular/forms';
4
- import { TruBreezeGridValidator } from './tru-breeze-grid-validator';
5
- import * as i0 from "@angular/core";
6
- export class TruBreezeGridValidatorModule {
7
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TruBreezeGridValidatorModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
8
- static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.0.2", ngImport: i0, type: TruBreezeGridValidatorModule, declarations: [TruBreezeGridValidator], imports: [CommonModule, FormsModule], exports: [TruBreezeGridValidator] });
9
- static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TruBreezeGridValidatorModule, imports: [CommonModule, FormsModule] });
10
- }
11
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TruBreezeGridValidatorModule, decorators: [{
12
- type: NgModule,
13
- args: [{
14
- declarations: [TruBreezeGridValidator],
15
- imports: [CommonModule, FormsModule],
16
- exports: [TruBreezeGridValidator]
17
- }]
18
- }] });
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LWJyZWV6ZS1ncmlkLXZhbGlkYXRvci1tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90cnUtY29tbW9uLWxpYi9zcmMvbGliL2RpcmVjdGl2ZXMvYnJlZXplLWdyaWQtdmFsaWRhdG9yL3RydS1icmVlemUtZ3JpZC12YWxpZGF0b3ItbW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQzs7QUFPckUsTUFBTSxPQUFPLDRCQUE0Qjt1R0FBNUIsNEJBQTRCO3dHQUE1Qiw0QkFBNEIsaUJBSnhCLHNCQUFzQixhQUMzQixZQUFZLEVBQUUsV0FBVyxhQUN6QixzQkFBc0I7d0dBRXJCLDRCQUE0QixZQUg3QixZQUFZLEVBQUUsV0FBVzs7MkZBR3hCLDRCQUE0QjtrQkFMeEMsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQztvQkFDdEMsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLFdBQVcsQ0FBQztvQkFDcEMsT0FBTyxFQUFFLENBQUMsc0JBQXNCLENBQUM7aUJBQ2xDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IFRydUJyZWV6ZUdyaWRWYWxpZGF0b3IgfSBmcm9tICcuL3RydS1icmVlemUtZ3JpZC12YWxpZGF0b3InO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFtUcnVCcmVlemVHcmlkVmFsaWRhdG9yXSxcclxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBGb3Jtc01vZHVsZV0sXHJcbiAgZXhwb3J0czogW1RydUJyZWV6ZUdyaWRWYWxpZGF0b3JdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBUcnVCcmVlemVHcmlkVmFsaWRhdG9yTW9kdWxlIHsgfVxyXG4iXX0=
@@ -1,151 +0,0 @@
1
- import { Directive, Input } from '@angular/core';
2
- import { TruGridValidationDialog } from '../../components/grid-validation-dialog/tru-grid-validation-dialog';
3
- import { TruValidationDialog } from '../../components/validation-dialog/tru-validation-dialog';
4
- import * as i0 from "@angular/core";
5
- import * as i1 from "../../services/tru-data-context";
6
- export class TruBreezeGridValidator {
7
- el;
8
- dataContext;
9
- viewContainerRef;
10
- componentFactoryResolver;
11
- entity;
12
- config;
13
- gridApi;
14
- isSubProperty = false;
15
- constructor(el, dataContext, viewContainerRef, componentFactoryResolver) {
16
- this.el = el;
17
- this.dataContext = dataContext;
18
- this.viewContainerRef = viewContainerRef;
19
- this.componentFactoryResolver = componentFactoryResolver;
20
- }
21
- configModel = {};
22
- mergeData;
23
- dialogRef = null;
24
- subs = [];
25
- currentDialog = null;
26
- getMergeData = () => {
27
- if (this.config.propertyPath?.includes('/')) {
28
- let propertyNameParts = this.config.propertyPath.split('/');
29
- propertyNameParts.pop();
30
- let targetProperty;
31
- propertyNameParts.forEach((name) => {
32
- if (!targetProperty) {
33
- let targetPropertyName = 'o' + name;
34
- targetProperty = this.entity[targetPropertyName];
35
- }
36
- else {
37
- let targetPropertyName = 'o' + name;
38
- targetProperty = targetProperty[targetPropertyName];
39
- }
40
- });
41
- if (targetProperty && targetProperty.Merge_Data) {
42
- return targetProperty.Merge_Data_Set;
43
- }
44
- return undefined;
45
- }
46
- else {
47
- return this.entity.Merge_Data_Set?.get(this.config.propertyName) ? this.entity.Merge_Data_Set : undefined;
48
- }
49
- };
50
- parseErrorMessages = (validationErrors) => {
51
- let errorMsg = '';
52
- validationErrors.forEach((error) => {
53
- errorMsg += error.errorMessage + '; ';
54
- });
55
- return errorMsg;
56
- };
57
- addValidationDialog = (config) => {
58
- let componentFactory = this.componentFactoryResolver.resolveComponentFactory(TruGridValidationDialog);
59
- let component = this.viewContainerRef.createComponent(componentFactory, 0, this.viewContainerRef.injector);
60
- component.instance.config = config;
61
- this.currentDialog = component;
62
- this.dialogRef = component;
63
- };
64
- addSubPropertyValidationDialog = (config) => {
65
- let componentFactory = this.componentFactoryResolver.resolveComponentFactory(TruValidationDialog);
66
- let component = this.viewContainerRef.createComponent(componentFactory, 0, this.viewContainerRef.injector);
67
- component.instance.config = config;
68
- this.currentDialog = component;
69
- this.dialogRef = component;
70
- };
71
- removeValidationDialog = () => {
72
- if (this.currentDialog) {
73
- this.currentDialog.destroy();
74
- this.currentDialog = null;
75
- }
76
- };
77
- valErrsChanged = (validationObject) => {
78
- let validationObjectEntity = validationObject.entity;
79
- let validationTableName = validationObjectEntity.constructor.name;
80
- const entityPkeyName = validationTableName + 'Ref';
81
- const validationObjectEntitypkeyName = validationTableName + 'Ref';
82
- let properties = [];
83
- properties.push(this.config.propertyName?.split('.').join(""));
84
- let subProperties = this.config.subProperties;
85
- properties = properties.concat(subProperties);
86
- let addedPropertyValdations = validationObject.added.filter((v) => {
87
- return properties.includes(v.propertyName);
88
- });
89
- let removedPropertyValdations = validationObject.removed.filter((v) => {
90
- return properties.includes(v.propertyName);
91
- });
92
- this.mergeData = this.getMergeData();
93
- //if (
94
- // this.config.rootTable === validationTableName &&
95
- // this.entity[entityPkeyName] === validationObjectEntity[validationObjectEntitypkeyName] &&
96
- // (addedPropertyValdations.length || this.mergeData)) {
97
- // this.removeValidationDialog();
98
- // if (this.isSubProperty) {
99
- // this.addSubPropertyValidationDialog(new TruValidationDialogConfig(
100
- // this.entity,
101
- // this.config.propertyName as string,
102
- // this.parseErrorMessages(addedPropertyValdations),
103
- // this.mergeData
104
- // ));
105
- // } else {
106
- // this.addValidationDialog(new TruGridValidationDialogConfig(
107
- // this.entity,
108
- // this.config.propertyName as string,
109
- // this.parseErrorMessages(addedPropertyValdations),
110
- // this.mergeData
111
- // ));
112
- // }
113
- //}
114
- if (this.config.rootTable === validationTableName &&
115
- this.entity[entityPkeyName] === validationObjectEntity[validationObjectEntitypkeyName] &&
116
- (removedPropertyValdations.length)) {
117
- this.removeValidationDialog();
118
- }
119
- };
120
- ngOnInit() { }
121
- ngAfterViewInit() {
122
- this.subs.push(this.dataContext.validationChangeDetection.subscribe(entities => {
123
- this.valErrsChanged(entities);
124
- }));
125
- this.entity.entityAspect.validateEntity();
126
- }
127
- ngOnChanges(changes) {
128
- this.entity.entityAspect.validateEntity();
129
- }
130
- ngOnDestroy() {
131
- this.subs.forEach(s => s.unsubscribe());
132
- }
133
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TruBreezeGridValidator, deps: [{ token: i0.ElementRef }, { token: i1.TruDataContext }, { token: i0.ViewContainerRef }, { token: i0.ComponentFactoryResolver }], target: i0.ɵɵFactoryTarget.Directive });
134
- static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.2", type: TruBreezeGridValidator, selector: "[truBreezeGridValidator]", inputs: { entity: ["truBreezeGridValidator", "entity"], config: "config", gridApi: "gridApi", isSubProperty: "isSubProperty" }, usesOnChanges: true, ngImport: i0 });
135
- }
136
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TruBreezeGridValidator, decorators: [{
137
- type: Directive,
138
- args: [{
139
- selector: '[truBreezeGridValidator]'
140
- }]
141
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.TruDataContext }, { type: i0.ViewContainerRef }, { type: i0.ComponentFactoryResolver }], propDecorators: { entity: [{
142
- type: Input,
143
- args: ['truBreezeGridValidator']
144
- }], config: [{
145
- type: Input
146
- }], gridApi: [{
147
- type: Input
148
- }], isSubProperty: [{
149
- type: Input
150
- }] } });
151
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tru-breeze-grid-validator.js","sourceRoot":"","sources":["../../../../../../projects/tru-common-lib/src/lib/directives/breeze-grid-validator/tru-breeze-grid-validator.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentFactoryResolver, ComponentRef, Directive, ElementRef, Input, OnDestroy, OnInit, SimpleChanges, ViewContainerRef } from '@angular/core';\r\nimport { GridApi } from 'ag-grid-community';\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 { TruListControlConfigBase } from '../../base-classes/tru-list-control-config-base';\r\nimport { TruMergeData } from '../../classes/tru-merge-data';\r\nimport { TruMergeDataSet } from '../../classes/tru-merge-data-set';\r\nimport { TruGridValidationDialog } from '../../components/grid-validation-dialog/tru-grid-validation-dialog';\r\nimport { TruGridValidationDialogConfig } from '../../components/grid-validation-dialog/tru-grid-validation-dialog-config';\r\nimport { 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: '[truBreezeGridValidator]'\r\n})\r\nexport class TruBreezeGridValidator implements OnInit, OnDestroy {\r\n  @Input('truBreezeGridValidator') entity!: TruEntityBase;\r\n  @Input() config!: TruEditControlConfigBase<any> | TruListControlConfigBase<any>;\r\n  @Input() gridApi!: GridApi | undefined;\r\n  @Input() isSubProperty: boolean = false;\r\n\r\n  constructor(\r\n    private el: ElementRef,\r\n    private dataContext: TruDataContext,\r\n    private viewContainerRef: ViewContainerRef,\r\n    private componentFactoryResolver: ComponentFactoryResolver) {\r\n  }\r\n\r\n  configModel: any = {};\r\n  mergeData: any;\r\n\r\n  private dialogRef: ComponentRef<any> | null = null;\r\n  private subs: Array<Subscription> = [];\r\n  private currentDialog: ComponentRef<TruGridValidationDialog> | ComponentRef<TruValidationDialog> | null = null\r\n\r\n  private getMergeData = (): TruMergeDataSet | undefined => {\r\n    if (this.config.propertyPath?.includes('/')) {\r\n      let propertyNameParts = this.config.propertyPath.split('/');\r\n      propertyNameParts.pop();\r\n      let targetProperty: any;\r\n      propertyNameParts.forEach((name) => {\r\n        if (!targetProperty) {\r\n          let targetPropertyName = 'o' + name as keyof typeof this.entity;\r\n          targetProperty = this.entity[targetPropertyName];\r\n        } else {\r\n          let targetPropertyName = 'o' + name as keyof typeof this.entity;\r\n          targetProperty = targetProperty[targetPropertyName];\r\n        }\r\n      });\r\n      if (targetProperty && targetProperty.Merge_Data) {\r\n        return targetProperty.Merge_Data_Set;\r\n      }\r\n      return undefined;\r\n    } else {\r\n      return this.entity.Merge_Data_Set?.get(this.config.propertyName as string) ? this.entity.Merge_Data_Set : undefined;\r\n    }\r\n  }\r\n\r\n  private parseErrorMessages = (validationErrors: Array<ValidationError>): string => {\r\n    let errorMsg: string = '';\r\n    validationErrors.forEach((error) => {\r\n      errorMsg += error.errorMessage + '; ';\r\n    });\r\n    return errorMsg;\r\n  }\r\n\r\n  private addValidationDialog = (config: TruGridValidationDialogConfig) => {\r\n    let componentFactory = this.componentFactoryResolver.resolveComponentFactory(TruGridValidationDialog);\r\n    let component = this.viewContainerRef.createComponent<TruGridValidationDialog>(componentFactory, 0, this.viewContainerRef.injector);\r\n    component.instance.config = config;\r\n    this.currentDialog = component;\r\n    this.dialogRef = component;\r\n  }\r\n\r\n  private addSubPropertyValidationDialog = (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 properties: Array<string> = [];\r\n    properties.push(this.config.propertyName?.split('.').join(\"\") as string);\r\n    let subProperties = this.config.subProperties;\r\n    properties = properties.concat(subProperties);\r\n    let addedPropertyValdations = validationObject.added.filter((v: any) => {\r\n      return properties.includes(v.propertyName);\r\n    });\r\n\r\n    let removedPropertyValdations = validationObject.removed.filter((v: any) => {\r\n      return properties.includes(v.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    //  if (this.isSubProperty) {\r\n    //    this.addSubPropertyValidationDialog(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 {\r\n    //    this.addValidationDialog(new TruGridValidationDialogConfig(\r\n    //      this.entity,\r\n    //      this.config.propertyName as string,\r\n    //      this.parseErrorMessages(addedPropertyValdations),\r\n    //      this.mergeData\r\n    //    ));\r\n    //  }\r\n    //}\r\n\r\n    if (\r\n      this.config.rootTable === validationTableName &&\r\n      this.entity[entityPkeyName] === validationObjectEntity[validationObjectEntitypkeyName] &&\r\n      (removedPropertyValdations.length)) {\r\n      this.removeValidationDialog();\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void { }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.subs.push(this.dataContext.validationChangeDetection.subscribe(entities => {\r\n      this.valErrsChanged(entities);\r\n    }));\r\n    this.entity.entityAspect.validateEntity();    \r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    this.entity.entityAspect.validateEntity();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subs.forEach(s => s.unsubscribe());\r\n  }\r\n}\r\n"]}
@@ -1,13 +0,0 @@
1
- import { TruEntityBase } from "../../base-classes/tru-entity-base";
2
- import { TruMergeDataSet } from "../../classes/tru-merge-data-set";
3
- export declare class TruGridValidationDialogConfig {
4
- private _entity;
5
- private _propertyName;
6
- private _errorMsg;
7
- private _mergeData;
8
- get entity(): TruEntityBase;
9
- get propertyName(): string;
10
- get errorMsg(): string;
11
- get mergeData(): TruMergeDataSet | null;
12
- constructor(entity: TruEntityBase, propertyName: string, errorMsg: string, mergeData?: TruMergeDataSet | null);
13
- }
@@ -1,9 +0,0 @@
1
- import * as i0 from "@angular/core";
2
- import * as i1 from "./tru-grid-validation-dialog";
3
- import * as i2 from "@angular/common";
4
- import * as i3 from "@angular/forms";
5
- export declare class TruGridValidationDialogModule {
6
- static ɵfac: i0.ɵɵFactoryDeclaration<TruGridValidationDialogModule, never>;
7
- static ɵmod: i0.ɵɵNgModuleDeclaration<TruGridValidationDialogModule, [typeof i1.TruGridValidationDialog], [typeof i2.CommonModule, typeof i3.FormsModule], [typeof i1.TruGridValidationDialog]>;
8
- static ɵinj: i0.ɵɵInjectorDeclaration<TruGridValidationDialogModule>;
9
- }
@@ -1,24 +0,0 @@
1
- import { ElementRef, EventEmitter, OnDestroy, OnInit, Renderer2 } from '@angular/core';
2
- import { TruUtil } from '../../services/tru-util';
3
- import { TruGridValidationDialogConfig } from './tru-grid-validation-dialog-config';
4
- import * as i0 from "@angular/core";
5
- export declare class TruGridValidationDialog implements OnInit, OnDestroy {
6
- private renderer;
7
- private elementRef;
8
- private util;
9
- config: TruGridValidationDialogConfig;
10
- close: EventEmitter<any>;
11
- errorMsg: string;
12
- private rowElement;
13
- private cellElement;
14
- private listeners;
15
- constructor(renderer: Renderer2, elementRef: ElementRef, util: TruUtil);
16
- onAcceptAll: () => void;
17
- onAccept: () => void;
18
- onDecline: () => void;
19
- ngOnInit(): void;
20
- ngAfterViewInit(): void;
21
- ngOnDestroy(): void;
22
- static ɵfac: i0.ɵɵFactoryDeclaration<TruGridValidationDialog, never>;
23
- static ɵcmp: i0.ɵɵComponentDeclaration<TruGridValidationDialog, "tru-grid-validation-dialog", never, { "config": { "alias": "config"; "required": false; }; }, { "close": "close"; }, never, never, false, never>;
24
- }
@@ -1,9 +0,0 @@
1
- import * as i0 from "@angular/core";
2
- import * as i1 from "./tru-breeze-grid-validator";
3
- import * as i2 from "@angular/common";
4
- import * as i3 from "@angular/forms";
5
- export declare class TruBreezeGridValidatorModule {
6
- static ɵfac: i0.ɵɵFactoryDeclaration<TruBreezeGridValidatorModule, never>;
7
- static ɵmod: i0.ɵɵNgModuleDeclaration<TruBreezeGridValidatorModule, [typeof i1.TruBreezeGridValidator], [typeof i2.CommonModule, typeof i3.FormsModule], [typeof i1.TruBreezeGridValidator]>;
8
- static ɵinj: i0.ɵɵInjectorDeclaration<TruBreezeGridValidatorModule>;
9
- }
@@ -1,35 +0,0 @@
1
- import { ComponentFactoryResolver, ElementRef, OnDestroy, OnInit, SimpleChanges, ViewContainerRef } from '@angular/core';
2
- import { GridApi } from 'ag-grid-community';
3
- import { TruEditControlConfigBase } from '../../base-classes/tru-edit-control-config-base';
4
- import { TruEntityBase } from '../../base-classes/tru-entity-base';
5
- import { TruListControlConfigBase } from '../../base-classes/tru-list-control-config-base';
6
- import { TruDataContext } from '../../services/tru-data-context';
7
- import * as i0 from "@angular/core";
8
- export declare class TruBreezeGridValidator implements OnInit, OnDestroy {
9
- private el;
10
- private dataContext;
11
- private viewContainerRef;
12
- private componentFactoryResolver;
13
- entity: TruEntityBase;
14
- config: TruEditControlConfigBase<any> | TruListControlConfigBase<any>;
15
- gridApi: GridApi | undefined;
16
- isSubProperty: boolean;
17
- constructor(el: ElementRef, dataContext: TruDataContext, viewContainerRef: ViewContainerRef, componentFactoryResolver: ComponentFactoryResolver);
18
- configModel: any;
19
- mergeData: any;
20
- private dialogRef;
21
- private subs;
22
- private currentDialog;
23
- private getMergeData;
24
- private parseErrorMessages;
25
- private addValidationDialog;
26
- private addSubPropertyValidationDialog;
27
- private removeValidationDialog;
28
- valErrsChanged: (validationObject: any) => void;
29
- ngOnInit(): void;
30
- ngAfterViewInit(): void;
31
- ngOnChanges(changes: SimpleChanges): void;
32
- ngOnDestroy(): void;
33
- static ɵfac: i0.ɵɵFactoryDeclaration<TruBreezeGridValidator, never>;
34
- static ɵdir: i0.ɵɵDirectiveDeclaration<TruBreezeGridValidator, "[truBreezeGridValidator]", never, { "entity": { "alias": "truBreezeGridValidator"; "required": false; }; "config": { "alias": "config"; "required": false; }; "gridApi": { "alias": "gridApi"; "required": false; }; "isSubProperty": { "alias": "isSubProperty"; "required": false; }; }, {}, never, never, false, never>;
35
- }