@trudb/tru-common-lib 0.1.701 → 0.1.703

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.
@@ -1,18 +1,17 @@
1
- import { Directive, HostListener, Input } from '@angular/core';
1
+ import { Directive, Input } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
- import * as i1 from "../../../../services/tru-util";
4
- import * as i2 from "../../services/tru-window-event-handler";
3
+ import * as i1 from "../../services/tru-window-event-handler";
5
4
  export class TruDesktopWindowStateMonitor {
6
5
  el;
7
- cdRef;
8
- util;
6
+ renderer;
9
7
  windowEventHandler;
10
8
  active = true;
9
+ tabListener;
10
+ focusListener;
11
11
  focusableElements = [];
12
- constructor(el, cdRef, util, windowEventHandler) {
12
+ constructor(el, renderer, windowEventHandler) {
13
13
  this.el = el;
14
- this.cdRef = cdRef;
15
- this.util = util;
14
+ this.renderer = renderer;
16
15
  this.windowEventHandler = windowEventHandler;
17
16
  }
18
17
  setWindowState = () => {
@@ -24,32 +23,39 @@ export class TruDesktopWindowStateMonitor {
24
23
  getFocusableChildElements = () => {
25
24
  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"]');
26
25
  };
27
- onKeydown(event) {
28
- if (this.active) {
29
- let target = event.target;
30
- this.focusableElements = this.getFocusableChildElements();
31
- let firstFocusableElement = this.focusableElements[0];
32
- let lastFocusableElement = this.focusableElements[this.focusableElements.length - 1];
33
- if (target !== null && !this.el.nativeElement.contains(target)) {
34
- firstFocusableElement.focus();
35
- }
36
- else {
37
- if (event.key === 'Tab') {
38
- if (event.shiftKey) {
39
- if (document.activeElement === firstFocusableElement) {
40
- event.preventDefault();
41
- lastFocusableElement.focus();
42
- }
26
+ focusAppropriateElement = (event) => {
27
+ let target = event.target;
28
+ this.focusableElements = this.getFocusableChildElements();
29
+ let firstFocusableElement = this.focusableElements[0];
30
+ let lastFocusableElement = this.focusableElements[this.focusableElements.length - 1];
31
+ if (target !== null && !this.el.nativeElement.contains(target)) {
32
+ firstFocusableElement.focus();
33
+ }
34
+ else {
35
+ if (event.key === 'Tab') {
36
+ if (event.shiftKey) {
37
+ if (document.activeElement === firstFocusableElement) {
38
+ event.preventDefault();
39
+ lastFocusableElement.focus();
43
40
  }
44
- else {
45
- if (document.activeElement === lastFocusableElement) {
46
- event.preventDefault();
47
- firstFocusableElement.focus();
48
- }
41
+ }
42
+ else {
43
+ if (document.activeElement === lastFocusableElement) {
44
+ event.preventDefault();
45
+ firstFocusableElement.focus();
49
46
  }
50
47
  }
51
48
  }
52
49
  }
50
+ };
51
+ onKeydown(event) {
52
+ if (event.key === 'Tab')
53
+ if (this.active) {
54
+ this.focusAppropriateElement(event);
55
+ }
56
+ else {
57
+ event.preventDefault();
58
+ }
53
59
  }
54
60
  onFocusIn(event) {
55
61
  if (this.active) {
@@ -63,24 +69,30 @@ export class TruDesktopWindowStateMonitor {
63
69
  }
64
70
  ngOnChanges(changes) {
65
71
  this.setWindowState();
72
+ if (this.active) {
73
+ this.tabListener = this.renderer.listen('document', 'keydown', this.onKeydown.bind(this));
74
+ this.focusListener = this.renderer.listen('document', 'focusin', this.onFocusIn.bind(this));
75
+ }
76
+ else {
77
+ this.tabListener();
78
+ this.focusListener();
79
+ }
66
80
  this.windowEventHandler.activeStateChanged(this.active);
67
81
  }
68
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruDesktopWindowStateMonitor, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.TruUtil }, { token: i2.TruWindowEventHandler }], target: i0.ɵɵFactoryTarget.Directive });
69
- static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.5", type: TruDesktopWindowStateMonitor, selector: "[truDesktopWindowStateMonitor]", inputs: { active: ["truDesktopWindowStateMonitor", "active"] }, host: { listeners: { "document:keydown.tab": "onKeydown($event)", "document:focusin": "onFocusIn($event)" } }, usesOnChanges: true, ngImport: i0 });
82
+ ngOnDestroy() {
83
+ this.tabListener();
84
+ this.focusListener();
85
+ }
86
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruDesktopWindowStateMonitor, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.TruWindowEventHandler }], target: i0.ɵɵFactoryTarget.Directive });
87
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.5", type: TruDesktopWindowStateMonitor, selector: "[truDesktopWindowStateMonitor]", inputs: { active: ["truDesktopWindowStateMonitor", "active"] }, usesOnChanges: true, ngImport: i0 });
70
88
  }
71
89
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruDesktopWindowStateMonitor, decorators: [{
72
90
  type: Directive,
73
91
  args: [{
74
92
  selector: '[truDesktopWindowStateMonitor]'
75
93
  }]
76
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1.TruUtil }, { type: i2.TruWindowEventHandler }], propDecorators: { active: [{
94
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i1.TruWindowEventHandler }], propDecorators: { active: [{
77
95
  type: Input,
78
96
  args: ['truDesktopWindowStateMonitor']
79
- }], onKeydown: [{
80
- type: HostListener,
81
- args: ['document:keydown.tab', ['$event']]
82
- }], onFocusIn: [{
83
- type: HostListener,
84
- args: ['document:focusin', ['$event']]
85
97
  }] } });
86
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LWRlc2t0b3Atd2luZG93LXN0YXRlLW1vbml0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90cnUtY29tbW9uLWxpYi9zcmMvbGliL2NvbXBvbmVudHMvZGVza3RvcC9kaXJlY3RpdmVzL3dpbmRvdy1zdGF0ZS1tb25pdG9yL3RydS1kZXNrdG9wLXdpbmRvdy1zdGF0ZS1tb25pdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBcUIsU0FBUyxFQUFjLFlBQVksRUFBRSxLQUFLLEVBQWlCLE1BQU0sZUFBZSxDQUFDOzs7O0FBTzdHLE1BQU0sT0FBTyw0QkFBNEI7SUFNN0I7SUFDQTtJQUNBO0lBQ0E7SUFSNkIsTUFBTSxHQUFZLElBQUksQ0FBQztJQUV0RCxpQkFBaUIsR0FBdUIsRUFBRSxDQUFDO0lBRW5ELFlBQ1UsRUFBYyxFQUNkLEtBQXdCLEVBQ3hCLElBQWEsRUFDYixrQkFBeUM7UUFIekMsT0FBRSxHQUFGLEVBQUUsQ0FBWTtRQUNkLFVBQUssR0FBTCxLQUFLLENBQW1CO1FBQ3hCLFNBQUksR0FBSixJQUFJLENBQVM7UUFDYix1QkFBa0IsR0FBbEIsa0JBQWtCLENBQXVCO0lBQUksQ0FBQztJQUVoRCxjQUFjLEdBQUcsR0FBRyxFQUFFO1FBQzVCLElBQUksSUFBSSxDQUFDLE1BQU07WUFDYixJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLHlCQUF5QixDQUFDLENBQUM7O1lBRWxFLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMseUJBQXlCLENBQUMsQ0FBQztJQUNuRSxDQUFDLENBQUE7SUFFTyx5QkFBeUIsR0FBRyxHQUFHLEVBQUU7UUFDdkMsT0FBTyxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxnQkFBZ0IsQ0FBQywwSEFBMEgsQ0FBQyxDQUFDO0lBQzVLLENBQUMsQ0FBQTtJQUdELFNBQVMsQ0FBQyxLQUFvQjtRQUM1QixJQUFJLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUNoQixJQUFJLE1BQU0sR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDO1lBQzFCLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxJQUFJLENBQUMseUJBQXlCLEVBQUUsQ0FBQztZQUMxRCxJQUFJLHFCQUFxQixHQUFHLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUN0RCxJQUFJLG9CQUFvQixHQUFHLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDO1lBQ3JGLElBQUksTUFBTSxLQUFLLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDO2dCQUMvRCxxQkFBcUIsQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUNoQyxDQUFDO2lCQUFNLENBQUM7Z0JBQ04sSUFBSSxLQUFLLENBQUMsR0FBRyxLQUFLLEtBQUssRUFBRSxDQUFDO29CQUN4QixJQUFJLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQzt3QkFDbkIsSUFBSSxRQUFRLENBQUMsYUFBYSxLQUFLLHFCQUFxQixFQUFFLENBQUM7NEJBQ3JELEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQzs0QkFDdkIsb0JBQW9CLENBQUMsS0FBSyxFQUFFLENBQUM7d0JBQy9CLENBQUM7b0JBQ0gsQ0FBQzt5QkFBTSxDQUFDO3dCQUNOLElBQUksUUFBUSxDQUFDLGFBQWEsS0FBSyxvQkFBb0IsRUFBRSxDQUFDOzRCQUNwRCxLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7NEJBQ3ZCLHFCQUFxQixDQUFDLEtBQUssRUFBRSxDQUFDO3dCQUNoQyxDQUFDO29CQUNILENBQUM7Z0JBQ0gsQ0FBQztZQUNILENBQUM7UUFDSCxDQUFDO0lBQ0gsQ0FBQztJQUdELFNBQVMsQ0FBQyxLQUFpQjtRQUN6QixJQUFJLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUNoQixJQUFJLE1BQU0sR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDO1lBQzFCLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxJQUFJLENBQUMseUJBQXlCLEVBQUUsQ0FBQztZQUMxRCxJQUFJLHFCQUFxQixHQUFHLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUN0RCxJQUFJLE1BQU0sS0FBSyxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQztnQkFDL0QscUJBQXFCLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDaEMsQ0FBQztRQUNILENBQUM7SUFDSCxDQUFDO0lBRUQsV0FBVyxDQUFDLE9BQXNCO1FBQ2hDLElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUN0QixJQUFJLENBQUMsa0JBQWtCLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzFELENBQUM7dUdBaEVVLDRCQUE0QjsyRkFBNUIsNEJBQTRCOzsyRkFBNUIsNEJBQTRCO2tCQUh4QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxnQ0FBZ0M7aUJBQzNDO3lLQUV3QyxNQUFNO3NCQUE1QyxLQUFLO3VCQUFDLDhCQUE4QjtnQkFzQnJDLFNBQVM7c0JBRFIsWUFBWTt1QkFBQyxzQkFBc0IsRUFBRSxDQUFDLFFBQVEsQ0FBQztnQkE0QmhELFNBQVM7c0JBRFIsWUFBWTt1QkFBQyxrQkFBa0IsRUFBRSxDQUFDLFFBQVEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdG9yUmVmLCBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIEhvc3RMaXN0ZW5lciwgSW5wdXQsIFNpbXBsZUNoYW5nZXMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgVHJ1V2luZG93RXZlbnRIYW5kbGVyIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvdHJ1LXdpbmRvdy1ldmVudC1oYW5kbGVyJztcclxuaW1wb3J0IHsgVHJ1VXRpbCB9IGZyb20gJy4uLy4uLy4uLy4uL3NlcnZpY2VzL3RydS11dGlsJztcclxuXHJcbkBEaXJlY3RpdmUoe1xyXG4gIHNlbGVjdG9yOiAnW3RydURlc2t0b3BXaW5kb3dTdGF0ZU1vbml0b3JdJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgVHJ1RGVza3RvcFdpbmRvd1N0YXRlTW9uaXRvciB7XHJcbiAgQElucHV0KCd0cnVEZXNrdG9wV2luZG93U3RhdGVNb25pdG9yJykgYWN0aXZlOiBib29sZWFuID0gdHJ1ZTtcclxuXHJcbiAgcHJpdmF0ZSBmb2N1c2FibGVFbGVtZW50czogQXJyYXk8SFRNTEVsZW1lbnQ+ID0gW107XHJcblxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgcHJpdmF0ZSBlbDogRWxlbWVudFJlZixcclxuICAgIHByaXZhdGUgY2RSZWY6IENoYW5nZURldGVjdG9yUmVmLFxyXG4gICAgcHJpdmF0ZSB1dGlsOiBUcnVVdGlsLFxyXG4gICAgcHJpdmF0ZSB3aW5kb3dFdmVudEhhbmRsZXI6IFRydVdpbmRvd0V2ZW50SGFuZGxlcikgeyB9XHJcblxyXG4gIHByaXZhdGUgc2V0V2luZG93U3RhdGUgPSAoKSA9PiB7XHJcbiAgICBpZiAodGhpcy5hY3RpdmUpXHJcbiAgICAgIHRoaXMuZWwubmF0aXZlRWxlbWVudC5jbGFzc0xpc3QucmVtb3ZlKCdkZXNrdG9wLXdpbmRvdy1kaXNhYmxlZCcpO1xyXG4gICAgZWxzZVxyXG4gICAgICB0aGlzLmVsLm5hdGl2ZUVsZW1lbnQuY2xhc3NMaXN0LmFkZCgnZGVza3RvcC13aW5kb3ctZGlzYWJsZWQnKTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgZ2V0Rm9jdXNhYmxlQ2hpbGRFbGVtZW50cyA9ICgpID0+IHtcclxuICAgIHJldHVybiB0aGlzLmVsLm5hdGl2ZUVsZW1lbnQucXVlcnlTZWxlY3RvckFsbCgnYVtocmVmXSxpbnB1dCxzZWxlY3QsdGV4dGFyZWEsYnV0dG9uLG1hdC1zZWxlY3QsbWF0LXRhYiwubWRjLXRhYiwuYWctaGVhZGVyLWNlbGwsLmFnLWNlbGwsW3RhYmluZGV4XTpub3QoW3RhYmluZGV4PVwiLTFcIl0nKTtcclxuICB9XHJcblxyXG4gIEBIb3N0TGlzdGVuZXIoJ2RvY3VtZW50OmtleWRvd24udGFiJywgWyckZXZlbnQnXSlcclxuICBvbktleWRvd24oZXZlbnQ6IEtleWJvYXJkRXZlbnQpIHtcclxuICAgIGlmICh0aGlzLmFjdGl2ZSkge1xyXG4gICAgICBsZXQgdGFyZ2V0ID0gZXZlbnQudGFyZ2V0O1xyXG4gICAgICB0aGlzLmZvY3VzYWJsZUVsZW1lbnRzID0gdGhpcy5nZXRGb2N1c2FibGVDaGlsZEVsZW1lbnRzKCk7XHJcbiAgICAgIGxldCBmaXJzdEZvY3VzYWJsZUVsZW1lbnQgPSB0aGlzLmZvY3VzYWJsZUVsZW1lbnRzWzBdO1xyXG4gICAgICBsZXQgbGFzdEZvY3VzYWJsZUVsZW1lbnQgPSB0aGlzLmZvY3VzYWJsZUVsZW1lbnRzW3RoaXMuZm9jdXNhYmxlRWxlbWVudHMubGVuZ3RoIC0gMV07XHJcbiAgICAgIGlmICh0YXJnZXQgIT09IG51bGwgJiYgIXRoaXMuZWwubmF0aXZlRWxlbWVudC5jb250YWlucyh0YXJnZXQpKSB7XHJcbiAgICAgICAgZmlyc3RGb2N1c2FibGVFbGVtZW50LmZvY3VzKCk7XHJcbiAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgaWYgKGV2ZW50LmtleSA9PT0gJ1RhYicpIHtcclxuICAgICAgICAgIGlmIChldmVudC5zaGlmdEtleSkge1xyXG4gICAgICAgICAgICBpZiAoZG9jdW1lbnQuYWN0aXZlRWxlbWVudCA9PT0gZmlyc3RGb2N1c2FibGVFbGVtZW50KSB7XHJcbiAgICAgICAgICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcclxuICAgICAgICAgICAgICBsYXN0Rm9jdXNhYmxlRWxlbWVudC5mb2N1cygpO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICB9IGVsc2Uge1xyXG4gICAgICAgICAgICBpZiAoZG9jdW1lbnQuYWN0aXZlRWxlbWVudCA9PT0gbGFzdEZvY3VzYWJsZUVsZW1lbnQpIHtcclxuICAgICAgICAgICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xyXG4gICAgICAgICAgICAgIGZpcnN0Rm9jdXNhYmxlRWxlbWVudC5mb2N1cygpO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG4gICAgICB9XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBASG9zdExpc3RlbmVyKCdkb2N1bWVudDpmb2N1c2luJywgWyckZXZlbnQnXSlcclxuICBvbkZvY3VzSW4oZXZlbnQ6IEZvY3VzRXZlbnQpIHtcclxuICAgIGlmICh0aGlzLmFjdGl2ZSkge1xyXG4gICAgICBsZXQgdGFyZ2V0ID0gZXZlbnQudGFyZ2V0O1xyXG4gICAgICB0aGlzLmZvY3VzYWJsZUVsZW1lbnRzID0gdGhpcy5nZXRGb2N1c2FibGVDaGlsZEVsZW1lbnRzKCk7XHJcbiAgICAgIGxldCBmaXJzdEZvY3VzYWJsZUVsZW1lbnQgPSB0aGlzLmZvY3VzYWJsZUVsZW1lbnRzWzBdO1xyXG4gICAgICBpZiAodGFyZ2V0ICE9PSBudWxsICYmICF0aGlzLmVsLm5hdGl2ZUVsZW1lbnQuY29udGFpbnModGFyZ2V0KSkge1xyXG4gICAgICAgIGZpcnN0Rm9jdXNhYmxlRWxlbWVudC5mb2N1cygpO1xyXG4gICAgICB9XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XHJcbiAgICB0aGlzLnNldFdpbmRvd1N0YXRlKCk7XHJcbiAgICB0aGlzLndpbmRvd0V2ZW50SGFuZGxlci5hY3RpdmVTdGF0ZUNoYW5nZWQodGhpcy5hY3RpdmUpO1xyXG4gIH1cclxufVxyXG4iXX0=
98
+ //# 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  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.active) {\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    } else {\r\n      this.tabListener();\r\n      this.focusListener();\r\n    }\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"]}
@@ -8246,15 +8246,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
8246
8246
 
8247
8247
  class TruDesktopWindowStateMonitor {
8248
8248
  el;
8249
- cdRef;
8250
- util;
8249
+ renderer;
8251
8250
  windowEventHandler;
8252
8251
  active = true;
8252
+ tabListener;
8253
+ focusListener;
8253
8254
  focusableElements = [];
8254
- constructor(el, cdRef, util, windowEventHandler) {
8255
+ constructor(el, renderer, windowEventHandler) {
8255
8256
  this.el = el;
8256
- this.cdRef = cdRef;
8257
- this.util = util;
8257
+ this.renderer = renderer;
8258
8258
  this.windowEventHandler = windowEventHandler;
8259
8259
  }
8260
8260
  setWindowState = () => {
@@ -8266,32 +8266,39 @@ class TruDesktopWindowStateMonitor {
8266
8266
  getFocusableChildElements = () => {
8267
8267
  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"]');
8268
8268
  };
8269
- onKeydown(event) {
8270
- if (this.active) {
8271
- let target = event.target;
8272
- this.focusableElements = this.getFocusableChildElements();
8273
- let firstFocusableElement = this.focusableElements[0];
8274
- let lastFocusableElement = this.focusableElements[this.focusableElements.length - 1];
8275
- if (target !== null && !this.el.nativeElement.contains(target)) {
8276
- firstFocusableElement.focus();
8277
- }
8278
- else {
8279
- if (event.key === 'Tab') {
8280
- if (event.shiftKey) {
8281
- if (document.activeElement === firstFocusableElement) {
8282
- event.preventDefault();
8283
- lastFocusableElement.focus();
8284
- }
8269
+ focusAppropriateElement = (event) => {
8270
+ let target = event.target;
8271
+ this.focusableElements = this.getFocusableChildElements();
8272
+ let firstFocusableElement = this.focusableElements[0];
8273
+ let lastFocusableElement = this.focusableElements[this.focusableElements.length - 1];
8274
+ if (target !== null && !this.el.nativeElement.contains(target)) {
8275
+ firstFocusableElement.focus();
8276
+ }
8277
+ else {
8278
+ if (event.key === 'Tab') {
8279
+ if (event.shiftKey) {
8280
+ if (document.activeElement === firstFocusableElement) {
8281
+ event.preventDefault();
8282
+ lastFocusableElement.focus();
8285
8283
  }
8286
- else {
8287
- if (document.activeElement === lastFocusableElement) {
8288
- event.preventDefault();
8289
- firstFocusableElement.focus();
8290
- }
8284
+ }
8285
+ else {
8286
+ if (document.activeElement === lastFocusableElement) {
8287
+ event.preventDefault();
8288
+ firstFocusableElement.focus();
8291
8289
  }
8292
8290
  }
8293
8291
  }
8294
8292
  }
8293
+ };
8294
+ onKeydown(event) {
8295
+ if (event.key === 'Tab')
8296
+ if (this.active) {
8297
+ this.focusAppropriateElement(event);
8298
+ }
8299
+ else {
8300
+ event.preventDefault();
8301
+ }
8295
8302
  }
8296
8303
  onFocusIn(event) {
8297
8304
  if (this.active) {
@@ -8305,25 +8312,31 @@ class TruDesktopWindowStateMonitor {
8305
8312
  }
8306
8313
  ngOnChanges(changes) {
8307
8314
  this.setWindowState();
8315
+ if (this.active) {
8316
+ this.tabListener = this.renderer.listen('document', 'keydown', this.onKeydown.bind(this));
8317
+ this.focusListener = this.renderer.listen('document', 'focusin', this.onFocusIn.bind(this));
8318
+ }
8319
+ else {
8320
+ this.tabListener();
8321
+ this.focusListener();
8322
+ }
8308
8323
  this.windowEventHandler.activeStateChanged(this.active);
8309
8324
  }
8310
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruDesktopWindowStateMonitor, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: TruUtil }, { token: TruWindowEventHandler }], target: i0.ɵɵFactoryTarget.Directive });
8311
- static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.5", type: TruDesktopWindowStateMonitor, selector: "[truDesktopWindowStateMonitor]", inputs: { active: ["truDesktopWindowStateMonitor", "active"] }, host: { listeners: { "document:keydown.tab": "onKeydown($event)", "document:focusin": "onFocusIn($event)" } }, usesOnChanges: true, ngImport: i0 });
8325
+ ngOnDestroy() {
8326
+ this.tabListener();
8327
+ this.focusListener();
8328
+ }
8329
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruDesktopWindowStateMonitor, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: TruWindowEventHandler }], target: i0.ɵɵFactoryTarget.Directive });
8330
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.5", type: TruDesktopWindowStateMonitor, selector: "[truDesktopWindowStateMonitor]", inputs: { active: ["truDesktopWindowStateMonitor", "active"] }, usesOnChanges: true, ngImport: i0 });
8312
8331
  }
8313
8332
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruDesktopWindowStateMonitor, decorators: [{
8314
8333
  type: Directive,
8315
8334
  args: [{
8316
8335
  selector: '[truDesktopWindowStateMonitor]'
8317
8336
  }]
8318
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: TruUtil }, { type: TruWindowEventHandler }], propDecorators: { active: [{
8337
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: TruWindowEventHandler }], propDecorators: { active: [{
8319
8338
  type: Input,
8320
8339
  args: ['truDesktopWindowStateMonitor']
8321
- }], onKeydown: [{
8322
- type: HostListener,
8323
- args: ['document:keydown.tab', ['$event']]
8324
- }], onFocusIn: [{
8325
- type: HostListener,
8326
- args: ['document:focusin', ['$event']]
8327
8340
  }] } });
8328
8341
 
8329
8342
  class TruDesktopWindow {