@trudb/tru-common-lib 0.1.704 → 0.1.706

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.
@@ -70,8 +70,10 @@ export class TruDesktopWindowStateMonitor {
70
70
  }
71
71
  ngOnChanges(changes) {
72
72
  this.setWindowState();
73
- this.tabListener();
74
- this.focusListener();
73
+ if (this.tabListener)
74
+ this.tabListener();
75
+ if (this.focusListener)
76
+ this.focusListener();
75
77
  this.tabListener = this.renderer.listen('document', 'keydown', this.onKeydown.bind(this));
76
78
  this.focusListener = this.renderer.listen('document', 'focusin', this.onFocusIn.bind(this));
77
79
  this.windowEventHandler.activeStateChanged(this.active);
@@ -92,4 +94,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
92
94
  type: Input,
93
95
  args: ['truDesktopWindowStateMonitor']
94
96
  }] } });
95
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tru-desktop-window-state-monitor.js","sourceRoot":"","sources":["../../../../../../../../projects/tru-common-lib/src/lib/components/desktop/directives/window-state-monitor/tru-desktop-window-state-monitor.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Directive, ElementRef, HostListener, Input, Renderer2, SimpleChanges } from '@angular/core';\r\nimport { TruWindowEventHandler } from '../../services/tru-window-event-handler';\r\nimport { TruUtil } from '../../../../services/tru-util';\r\n\r\n@Directive({\r\n  selector: '[truDesktopWindowStateMonitor]'\r\n})\r\nexport class TruDesktopWindowStateMonitor {\r\n  @Input('truDesktopWindowStateMonitor') active: boolean = true;\r\n\r\n  private tabListener!: () => void;\r\n  private focusListener!: () => void;\r\n  private focusableElements: Array<HTMLElement> = [];\r\n\r\n  constructor(\r\n    private el: ElementRef,\r\n    private renderer: Renderer2,\r\n    private windowEventHandler: TruWindowEventHandler) { }\r\n\r\n  private setWindowState = () => {\r\n    if (this.active)\r\n      this.el.nativeElement.classList.remove('desktop-window-disabled');\r\n    else\r\n      this.el.nativeElement.classList.add('desktop-window-disabled');\r\n  }\r\n\r\n  private getFocusableChildElements = () => {\r\n    return this.el.nativeElement.querySelectorAll('a[href],input,select,textarea,button,mat-select,mat-tab,.mdc-tab,.ag-header-cell,.ag-cell,[tabindex]:not([tabindex=\"-1\"]');\r\n  }\r\n\r\n  private focusAppropriateElement = (event: KeyboardEvent) => {\r\n    let target = event.target;\r\n    this.focusableElements = this.getFocusableChildElements();\r\n    let firstFocusableElement = this.focusableElements[0];\r\n    let lastFocusableElement = this.focusableElements[this.focusableElements.length - 1];\r\n    if (target !== null && !this.el.nativeElement.contains(target)) {\r\n      firstFocusableElement.focus();\r\n    } else {\r\n      if (event.key === 'Tab') {\r\n        if (event.shiftKey) {\r\n          if (document.activeElement === firstFocusableElement) {\r\n            event.preventDefault();\r\n            lastFocusableElement.focus();\r\n          }\r\n        } else {\r\n          if (document.activeElement === lastFocusableElement) {\r\n            event.preventDefault();\r\n            firstFocusableElement.focus();\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  onKeydown(event: KeyboardEvent) {\r\n    if (event.key === 'Tab') {\r\n      if (this.active) {\r\n        this.focusAppropriateElement(event);\r\n      } else {\r\n        event.preventDefault();\r\n      }\r\n    }\r\n  }\r\n\r\n  onFocusIn(event: FocusEvent) {\r\n    if (this.active) {\r\n      let target = event.target;\r\n      this.focusableElements = this.getFocusableChildElements();\r\n      let firstFocusableElement = this.focusableElements[0];\r\n      if (target !== null && !this.el.nativeElement.contains(target)) {\r\n        firstFocusableElement.focus();\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    this.setWindowState();\r\n    this.tabListener();\r\n    this.focusListener();\r\n    this.tabListener = this.renderer.listen('document', 'keydown', this.onKeydown.bind(this));\r\n    this.focusListener = this.renderer.listen('document', 'focusin', this.onFocusIn.bind(this));\r\n    this.windowEventHandler.activeStateChanged(this.active);\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.tabListener();\r\n    this.focusListener();\r\n  }\r\n}\r\n"]}
97
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tru-desktop-window-state-monitor.js","sourceRoot":"","sources":["../../../../../../../../projects/tru-common-lib/src/lib/components/desktop/directives/window-state-monitor/tru-desktop-window-state-monitor.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Directive, ElementRef, HostListener, Input, Renderer2, SimpleChanges } from '@angular/core';\r\nimport { TruWindowEventHandler } from '../../services/tru-window-event-handler';\r\nimport { TruUtil } from '../../../../services/tru-util';\r\n\r\n@Directive({\r\n  selector: '[truDesktopWindowStateMonitor]'\r\n})\r\nexport class TruDesktopWindowStateMonitor {\r\n  @Input('truDesktopWindowStateMonitor') active: boolean = true;\r\n\r\n  private tabListener!: () => void;\r\n  private focusListener!: () => void;\r\n  private focusableElements: Array<HTMLElement> = [];\r\n\r\n  constructor(\r\n    private el: ElementRef,\r\n    private renderer: Renderer2,\r\n    private windowEventHandler: TruWindowEventHandler) { }\r\n\r\n  private setWindowState = () => {\r\n    if (this.active)\r\n      this.el.nativeElement.classList.remove('desktop-window-disabled');\r\n    else\r\n      this.el.nativeElement.classList.add('desktop-window-disabled');\r\n  }\r\n\r\n  private getFocusableChildElements = () => {\r\n    return this.el.nativeElement.querySelectorAll('a[href],input,select,textarea,button,mat-select,mat-tab,.mdc-tab,.ag-header-cell,.ag-cell,[tabindex]:not([tabindex=\"-1\"]');\r\n  }\r\n\r\n  private focusAppropriateElement = (event: KeyboardEvent) => {\r\n    let target = event.target;\r\n    this.focusableElements = this.getFocusableChildElements();\r\n    let firstFocusableElement = this.focusableElements[0];\r\n    let lastFocusableElement = this.focusableElements[this.focusableElements.length - 1];\r\n    if (target !== null && !this.el.nativeElement.contains(target)) {\r\n      firstFocusableElement.focus();\r\n    } else {\r\n      if (event.key === 'Tab') {\r\n        if (event.shiftKey) {\r\n          if (document.activeElement === firstFocusableElement) {\r\n            event.preventDefault();\r\n            lastFocusableElement.focus();\r\n          }\r\n        } else {\r\n          if (document.activeElement === lastFocusableElement) {\r\n            event.preventDefault();\r\n            firstFocusableElement.focus();\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  onKeydown(event: KeyboardEvent) {\r\n    if (event.key === 'Tab') {\r\n      if (this.active) {\r\n        this.focusAppropriateElement(event);\r\n      } else {\r\n        event.preventDefault();\r\n      }\r\n    }\r\n  }\r\n\r\n  onFocusIn(event: FocusEvent) {\r\n    if (this.active) {\r\n      let target = event.target;\r\n      this.focusableElements = this.getFocusableChildElements();\r\n      let firstFocusableElement = this.focusableElements[0];\r\n      if (target !== null && !this.el.nativeElement.contains(target)) {\r\n        firstFocusableElement.focus();\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    this.setWindowState();\r\n    if (this.tabListener)\r\n      this.tabListener();\r\n    if (this.focusListener)\r\n      this.focusListener();\r\n    this.tabListener = this.renderer.listen('document', 'keydown', this.onKeydown.bind(this));\r\n    this.focusListener = this.renderer.listen('document', 'focusin', this.onFocusIn.bind(this));\r\n    this.windowEventHandler.activeStateChanged(this.active);\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.tabListener();\r\n    this.focusListener();\r\n  }\r\n}\r\n"]}
@@ -8313,8 +8313,10 @@ class TruDesktopWindowStateMonitor {
8313
8313
  }
8314
8314
  ngOnChanges(changes) {
8315
8315
  this.setWindowState();
8316
- this.tabListener();
8317
- this.focusListener();
8316
+ if (this.tabListener)
8317
+ this.tabListener();
8318
+ if (this.focusListener)
8319
+ this.focusListener();
8318
8320
  this.tabListener = this.renderer.listen('document', 'keydown', this.onKeydown.bind(this));
8319
8321
  this.focusListener = this.renderer.listen('document', 'focusin', this.onFocusIn.bind(this));
8320
8322
  this.windowEventHandler.activeStateChanged(this.active);