@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.
- package/esm2022/lib/components/desktop/directives/window-state-monitor/tru-desktop-window-state-monitor.mjs +51 -39
- package/fesm2022/trudb-tru-common-lib.mjs +48 -35
- package/fesm2022/trudb-tru-common-lib.mjs.map +1 -1
- package/lib/components/desktop/directives/window-state-monitor/tru-desktop-window-state-monitor.d.ts +7 -5
- package/package.json +1 -1
|
@@ -1,18 +1,17 @@
|
|
|
1
|
-
import { Directive,
|
|
1
|
+
import { Directive, Input } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "
|
|
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
|
-
|
|
8
|
-
util;
|
|
6
|
+
renderer;
|
|
9
7
|
windowEventHandler;
|
|
10
8
|
active = true;
|
|
9
|
+
tabListener;
|
|
10
|
+
focusListener;
|
|
11
11
|
focusableElements = [];
|
|
12
|
-
constructor(el,
|
|
12
|
+
constructor(el, renderer, windowEventHandler) {
|
|
13
13
|
this.el = el;
|
|
14
|
-
this.
|
|
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
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
if (event.
|
|
38
|
-
if (
|
|
39
|
-
|
|
40
|
-
|
|
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
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
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
|
-
|
|
69
|
-
|
|
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.
|
|
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,
|
|
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
|
-
|
|
8250
|
-
util;
|
|
8249
|
+
renderer;
|
|
8251
8250
|
windowEventHandler;
|
|
8252
8251
|
active = true;
|
|
8252
|
+
tabListener;
|
|
8253
|
+
focusListener;
|
|
8253
8254
|
focusableElements = [];
|
|
8254
|
-
constructor(el,
|
|
8255
|
+
constructor(el, renderer, windowEventHandler) {
|
|
8255
8256
|
this.el = el;
|
|
8256
|
-
this.
|
|
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
|
-
|
|
8270
|
-
|
|
8271
|
-
|
|
8272
|
-
|
|
8273
|
-
|
|
8274
|
-
|
|
8275
|
-
|
|
8276
|
-
|
|
8277
|
-
|
|
8278
|
-
|
|
8279
|
-
if (event.
|
|
8280
|
-
if (
|
|
8281
|
-
|
|
8282
|
-
|
|
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
|
-
|
|
8287
|
-
|
|
8288
|
-
|
|
8289
|
-
|
|
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
|
-
|
|
8311
|
-
|
|
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.
|
|
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 {
|