@trudb/tru-common-lib 0.1.461 → 0.1.462

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.
@@ -31,6 +31,8 @@ export class TruValidationDialog {
31
31
  entity.entityAspect.setUnchanged();
32
32
  entity.Merge_Data_Set.clearAll();
33
33
  entity.entityAspect.validateEntity();
34
+ if (this.config.context === TruValidationDialogContext.Grid)
35
+ this.elementRef.nativeElement.remove();
34
36
  };
35
37
  onAccept = () => {
36
38
  let entity = this.config.entity;
@@ -43,11 +45,15 @@ export class TruValidationDialog {
43
45
  if (this.config.mergeData?.isEmpty())
44
46
  entity.entityAspect.setUnchanged();
45
47
  entity.entityAspect.validateEntity();
48
+ if (this.config.context === TruValidationDialogContext.Grid)
49
+ this.elementRef.nativeElement.remove();
46
50
  };
47
51
  onDecline = () => {
48
52
  let entity = this.config.entity;
49
53
  this.config.mergeData?.clearAll();
50
54
  entity.entityAspect.validateEntity();
55
+ if (this.config.context === TruValidationDialogContext.Grid)
56
+ this.elementRef.nativeElement.remove();
51
57
  };
52
58
  ngOnInit() {
53
59
  this.errorMsg = this.config.errorMsg;
@@ -106,4 +112,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
106
112
  }], close: [{
107
113
  type: Output
108
114
  }] } });
109
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tru-validation-dialog.js","sourceRoot":"","sources":["../../../../../../projects/tru-common-lib/src/lib/components/validation-dialog/tru-validation-dialog.ts","../../../../../../projects/tru-common-lib/src/lib/components/validation-dialog/tru-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 { TruValidationDialogConfig } from './tru-validation-dialog-config';\r\nimport { TruValidationDialogContext } from './tru-validation-dialog-context';\r\n\r\n@Component({\r\n  selector: 'tru-validation-dialog',\r\n  templateUrl: './tru-validation-dialog.html',\r\n  styleUrls: ['./tru-validation-dialog.css']\r\n})\r\nexport class TruValidationDialog implements OnInit, OnDestroy {\r\n  @Input() config!: TruValidationDialogConfig;\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  }\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 as string;\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  }\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  }\r\n\r\n  ngOnInit() {\r\n    this.errorMsg = this.config.errorMsg as string;\r\n\r\n    if (this.config.context === TruValidationDialogContext.Control) {\r\n      var invalidTarget = this.util.findClosestAncestorByClass(this.elementRef.nativeElement, '.invalid-target');\r\n      if (invalidTarget) {\r\n        this.listeners.push(this.renderer.listen(invalidTarget, 'mouseenter', (event: MouseEvent) => {\r\n          this.elementRef.nativeElement.childNodes[0].classList.remove('hide');\r\n          this.elementRef.nativeElement.childNodes[0].classList.add('show');\r\n        }));\r\n\r\n        this.listeners.push(this.renderer.listen(invalidTarget, 'mouseleave', (event: MouseEvent) => {\r\n          this.elementRef.nativeElement.childNodes[0].classList.remove('show');\r\n          this.elementRef.nativeElement.childNodes[0].classList.add('hide');\r\n        }));\r\n      }\r\n    } else if (this.config.context === TruValidationDialogContext.Grid) {\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 as string;\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    if (this.config.context === TruValidationDialogContext.Control) {\r\n      let invalidTarget = this.util.findClosestAncestorByClass(this.elementRef.nativeElement, '.invalid-target');\r\n      if (invalidTarget)\r\n        invalidTarget.classList.add('invalid');\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if (this.config.context === TruValidationDialogContext.Control) {\r\n      let invalidTarget = this.util.findClosestAncestorByClass(this.elementRef.nativeElement, '.invalid-target');\r\n      if (invalidTarget)\r\n        invalidTarget.classList.remove('invalid');\r\n    } else if (this.config.context === TruValidationDialogContext.Grid) {\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      if (this.rowElement)\r\n        this.rowElement.style.zIndex = 'auto';\r\n      if (this.cellElement)\r\n        this.cellElement.classList.remove('show');\r\n    }\r\n    this.listeners.forEach(l => l());\r\n  }\r\n}\r\n\r\n","@if (config.context === 0) {\r\n<div class=\"invalid hide\">\r\n  <i class=\"icon-warning-sign icon-white\"></i>{{config.errorMsg}}\r\n  <div *ngIf=\"config.mergeData\">\r\n    <button class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onAcceptAll()\">Accept All</button>\r\n    <button class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onAccept()\">Accept</button>\r\n    <button class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onDecline()\">Decline</button>\r\n  </div>\r\n</div>\r\n<span class=\"invalid-flag\"></span>\r\n}\r\n@else {\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}\r\n"]}
115
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tru-validation-dialog.js","sourceRoot":"","sources":["../../../../../../projects/tru-common-lib/src/lib/components/validation-dialog/tru-validation-dialog.ts","../../../../../../projects/tru-common-lib/src/lib/components/validation-dialog/tru-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 { TruValidationDialogConfig } from './tru-validation-dialog-config';\r\nimport { TruValidationDialogContext } from './tru-validation-dialog-context';\r\n\r\n@Component({\r\n  selector: 'tru-validation-dialog',\r\n  templateUrl: './tru-validation-dialog.html',\r\n  styleUrls: ['./tru-validation-dialog.css']\r\n})\r\nexport class TruValidationDialog implements OnInit, OnDestroy {\r\n  @Input() config!: TruValidationDialogConfig;\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    entity.entityAspect.validateEntity();\r\n\r\n    if (this.config.context === TruValidationDialogContext.Grid)\r\n      this.elementRef.nativeElement.remove();\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 as string;\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\r\n    if (this.config.context === TruValidationDialogContext.Grid)\r\n      this.elementRef.nativeElement.remove();\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\r\n    if (this.config.context === TruValidationDialogContext.Grid)\r\n      this.elementRef.nativeElement.remove();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.errorMsg = this.config.errorMsg as string;\r\n\r\n    if (this.config.context === TruValidationDialogContext.Control) {\r\n      var invalidTarget = this.util.findClosestAncestorByClass(this.elementRef.nativeElement, '.invalid-target');\r\n      if (invalidTarget) {\r\n        this.listeners.push(this.renderer.listen(invalidTarget, 'mouseenter', (event: MouseEvent) => {\r\n          this.elementRef.nativeElement.childNodes[0].classList.remove('hide');\r\n          this.elementRef.nativeElement.childNodes[0].classList.add('show');\r\n        }));\r\n\r\n        this.listeners.push(this.renderer.listen(invalidTarget, 'mouseleave', (event: MouseEvent) => {\r\n          this.elementRef.nativeElement.childNodes[0].classList.remove('show');\r\n          this.elementRef.nativeElement.childNodes[0].classList.add('hide');\r\n        }));\r\n      }\r\n    } else if (this.config.context === TruValidationDialogContext.Grid) {\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 as string;\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    if (this.config.context === TruValidationDialogContext.Control) {\r\n      let invalidTarget = this.util.findClosestAncestorByClass(this.elementRef.nativeElement, '.invalid-target');\r\n      if (invalidTarget)\r\n        invalidTarget.classList.add('invalid');\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if (this.config.context === TruValidationDialogContext.Control) {\r\n      let invalidTarget = this.util.findClosestAncestorByClass(this.elementRef.nativeElement, '.invalid-target');\r\n      if (invalidTarget)\r\n        invalidTarget.classList.remove('invalid');\r\n    } else if (this.config.context === TruValidationDialogContext.Grid) {\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      if (this.rowElement)\r\n        this.rowElement.style.zIndex = 'auto';\r\n      if (this.cellElement)\r\n        this.cellElement.classList.remove('show');\r\n    }\r\n    this.listeners.forEach(l => l());\r\n  }\r\n}\r\n\r\n","@if (config.context === 0) {\r\n<div class=\"invalid hide\">\r\n  <i class=\"icon-warning-sign icon-white\"></i>{{config.errorMsg}}\r\n  <div *ngIf=\"config.mergeData\">\r\n    <button class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onAcceptAll()\">Accept All</button>\r\n    <button class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onAccept()\">Accept</button>\r\n    <button class=\"md-primary md-button ng-scope md-ink-ripple merge-button\" (click)=\"onDecline()\">Decline</button>\r\n  </div>\r\n</div>\r\n<span class=\"invalid-flag\"></span>\r\n}\r\n@else {\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}\r\n"]}
@@ -5641,6 +5641,8 @@ class TruValidationDialog {
5641
5641
  entity.entityAspect.setUnchanged();
5642
5642
  entity.Merge_Data_Set.clearAll();
5643
5643
  entity.entityAspect.validateEntity();
5644
+ if (this.config.context === TruValidationDialogContext.Grid)
5645
+ this.elementRef.nativeElement.remove();
5644
5646
  };
5645
5647
  onAccept = () => {
5646
5648
  let entity = this.config.entity;
@@ -5653,11 +5655,15 @@ class TruValidationDialog {
5653
5655
  if (this.config.mergeData?.isEmpty())
5654
5656
  entity.entityAspect.setUnchanged();
5655
5657
  entity.entityAspect.validateEntity();
5658
+ if (this.config.context === TruValidationDialogContext.Grid)
5659
+ this.elementRef.nativeElement.remove();
5656
5660
  };
5657
5661
  onDecline = () => {
5658
5662
  let entity = this.config.entity;
5659
5663
  this.config.mergeData?.clearAll();
5660
5664
  entity.entityAspect.validateEntity();
5665
+ if (this.config.context === TruValidationDialogContext.Grid)
5666
+ this.elementRef.nativeElement.remove();
5661
5667
  };
5662
5668
  ngOnInit() {
5663
5669
  this.errorMsg = this.config.errorMsg;