systelab-virtual-keyboard 17.0.0 → 17.2.0
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/README.md +1 -1
- package/esm2022/lib/constants.mjs +7 -7
- package/esm2022/lib/systelab-virtual-keyboard-overlay.service.mjs +35 -19
- package/esm2022/lib/systelab-virtual-keyboard.component.mjs +13 -22
- package/esm2022/lib/systelab-virtual-keyboard.config.mjs +1 -1
- package/esm2022/lib/systelab-virtual-keyboard.directive.mjs +41 -20
- package/fesm2022/systelab-virtual-keyboard.mjs +91 -63
- package/fesm2022/systelab-virtual-keyboard.mjs.map +1 -1
- package/lib/constants.d.ts +2 -2
- package/lib/constants.d.ts.map +1 -1
- package/lib/systelab-virtual-keyboard-overlay.service.d.ts +6 -2
- package/lib/systelab-virtual-keyboard-overlay.service.d.ts.map +1 -1
- package/lib/systelab-virtual-keyboard.component.d.ts +1 -2
- package/lib/systelab-virtual-keyboard.component.d.ts.map +1 -1
- package/lib/systelab-virtual-keyboard.config.d.ts +1 -0
- package/lib/systelab-virtual-keyboard.config.d.ts.map +1 -1
- package/lib/systelab-virtual-keyboard.directive.d.ts +3 -1
- package/lib/systelab-virtual-keyboard.directive.d.ts.map +1 -1
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -42,4 +42,4 @@ The configuration params are describe into the interface [SystelabVirtualKeyboar
|
|
|
42
42
|
| layout | SystelabVirtualKeyboardLayouts | | Usually the virtual keyboard select the layout between *default* or *numeric* depending on the input type. But with the config object you can override this behaviour and force the desired layout. The available layouts are described in the enum *SystelabVirtualKeyboardLayouts*
|
|
43
43
|
| inputMethod | SystelabVirtualKeyboardInputMethods | | The method detected for the keyboard to click or touch the keys
|
|
44
44
|
| showButton | boolean | false | Show or hide the button for showing the keyboard
|
|
45
|
-
|
|
45
|
+
| showOnMouseClick | boolean | false | Shows virtual keyboard upon mouse click on input field
|
|
@@ -28,10 +28,10 @@ export var SystelabVirtualKeyboardInputMethods;
|
|
|
28
28
|
SystelabVirtualKeyboardInputMethods["onlyMouseEvents"] = "onlyMouseEvents";
|
|
29
29
|
SystelabVirtualKeyboardInputMethods["onlyTouchEvents"] = "onlyTouchEvents";
|
|
30
30
|
})(SystelabVirtualKeyboardInputMethods || (SystelabVirtualKeyboardInputMethods = {}));
|
|
31
|
-
export var
|
|
32
|
-
(function (
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
})(
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
31
|
+
export var SystelabVirtualKeyboardInputModes;
|
|
32
|
+
(function (SystelabVirtualKeyboardInputModes) {
|
|
33
|
+
SystelabVirtualKeyboardInputModes["text"] = "text";
|
|
34
|
+
SystelabVirtualKeyboardInputModes["numeric"] = "numeric";
|
|
35
|
+
SystelabVirtualKeyboardInputModes["password"] = "password";
|
|
36
|
+
})(SystelabVirtualKeyboardInputModes || (SystelabVirtualKeyboardInputModes = {}));
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvc3lzdGVsYWItdmlydHVhbC1rZXlib2FyZC9zcmMvbGliL2NvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7OztHQU9HO0FBRUgsTUFBTSxDQUFOLElBQVksNkJBU1g7QUFURCxXQUFZLDZCQUE2QjtJQUNyQyxnREFBZSxDQUFBO0lBQ2Ysa0RBQWlCLENBQUE7SUFDakIsa0RBQWlCLENBQUE7SUFDakIsZ0RBQWUsQ0FBQTtJQUNmLHFEQUFvQixDQUFBO0lBQ3BCLHdEQUF1QixDQUFBO0lBQ3ZCLGtEQUFpQixDQUFBO0lBQ2pCLDhDQUFhLENBQUE7QUFDakIsQ0FBQyxFQVRXLDZCQUE2QixLQUE3Qiw2QkFBNkIsUUFTeEM7QUFFRCxNQUFNLENBQU4sSUFBWSw4QkFJWDtBQUpELFdBQVksOEJBQThCO0lBQ3RDLHFEQUFtQixDQUFBO0lBQ25CLGlEQUFlLENBQUE7SUFDZixxREFBbUIsQ0FBQTtBQUN2QixDQUFDLEVBSlcsOEJBQThCLEtBQTlCLDhCQUE4QixRQUl6QztBQUVELE1BQU0sQ0FBTixJQUFZLG1DQUdYO0FBSEQsV0FBWSxtQ0FBbUM7SUFDM0MsMEVBQW1DLENBQUE7SUFDbkMsMEVBQW1DLENBQUE7QUFDdkMsQ0FBQyxFQUhXLG1DQUFtQyxLQUFuQyxtQ0FBbUMsUUFHOUM7QUFFRCxNQUFNLENBQU4sSUFBWSxpQ0FJWDtBQUpELFdBQVksaUNBQWlDO0lBQ3pDLGtEQUFhLENBQUE7SUFDYix3REFBbUIsQ0FBQTtJQUNuQiwwREFBcUIsQ0FBQTtBQUN6QixDQUFDLEVBSlcsaUNBQWlDLEtBQWpDLGlDQUFpQyxRQUk1QyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjAgLSAyMDI0IC0gSW5zdHJ1bWVudGF0aW9uIExhYm9yYXRvcnkgQ29tcGFueSBhbmQgU3lzdGVsYWIgVGVjaG5vbG9naWVzLCBTQS4gQWxsIHJpZ2h0cyByZXNlcnZlZC5cbiAqIE5PVElDRTogIEFsbCBpbmZvcm1hdGlvbiBjb250YWluZWQgaGVyZWluIGlzIGFuZCByZW1haW5zIHRoZSBwcm9wZXJ0eSBvZiBJbnN0cnVtZW50YXRpb24gTGFib3JhdG9yeSBDb21wYW55IGFuZCBpdHNcbiAqIGFmZmlsaWF0ZXMsIGlmIGFueS4gIFRoZSBpbnRlbGxlY3R1YWwgYW5kIHRlY2huaWNhbCBjb25jZXB0cyBjb250YWluZWQgaGVyZWluIGFyZSBwcm9wcmlldGFyeSB0byBJbnN0cnVtZW50YXRpb25cbiAqIExhYm9yYXRvcnkgQ29tcGFueSBhbmQgaXRzIGFmZmlsaWF0ZXMgYW5kIG1heSBiZSBjb3ZlcmVkIGJ5IFUuUy4gYW5kIGZvcmVpZ24gcGF0ZW50cyBhbmQgcGF0ZW50IGFwcGxpY2F0aW9ucywgYW5kL29yXG4gKiBhcmUgcHJvdGVjdGVkIGJ5IHRyYWRlIHNlY3JldCBvciBjb3B5cmlnaHQgbGF3LiBEaXNzZW1pbmF0aW9uIG9mIHRoaXMgaW5mb3JtYXRpb24gb3IgcmVwcm9kdWN0aW9uIG9mIHRoaXMgbWF0ZXJpYWwgaXNcbiAqIHN0cmljdGx5IGZvcmJpZGRlbiB1bmxlc3MgcHJpb3Igd3JpdHRlbiBwZXJtaXNzaW9uIGlzIEluc3RydW1lbnRhdGlvbiBMYWJvcmF0b3J5IENvbXBhbnkuXG4gKi9cblxuZXhwb3J0IGVudW0gU3lzdGVsYWJWaXJ0dWFsS2V5Ym9hcmRCdXR0b24ge1xuICAgIERvbmUgPSAne2RvbmV9JyxcbiAgICBFbnRlciA9ICd7ZW50ZXJ9JyxcbiAgICBTaGlmdCA9ICd7c2hpZnR9JyxcbiAgICBMb2NrID0gJ3tsb2NrfScsXG4gICAgQmFja3NwYWNlID0gJ3tia3NwfScsXG4gICAgTGFuZ3VhZ2UgPSAne2xhbmd1YWdlfScsXG4gICAgU3BhY2UgPSAne3NwYWNlfScsXG4gICAgVGFiID0gJ3t0YWJ9Jyxcbn1cblxuZXhwb3J0IGVudW0gU3lzdGVsYWJWaXJ0dWFsS2V5Ym9hcmRMYXlvdXRzIHtcbiAgICBkZWZhdWx0ID0gJ2RlZmF1bHQnLFxuICAgIHNoaWZ0ID0gJ3NoaWZ0JyxcbiAgICBudW1lcmljID0gJ251bWVyaWMnLFxufVxuXG5leHBvcnQgZW51bSBTeXN0ZWxhYlZpcnR1YWxLZXlib2FyZElucHV0TWV0aG9kcyB7XG4gICAgb25seU1vdXNlRXZlbnRzID0gJ29ubHlNb3VzZUV2ZW50cycsXG4gICAgb25seVRvdWNoRXZlbnRzID0gJ29ubHlUb3VjaEV2ZW50cycsXG59XG5cbmV4cG9ydCBlbnVtIFN5c3RlbGFiVmlydHVhbEtleWJvYXJkSW5wdXRNb2RlcyB7XG4gICAgdGV4dCA9ICd0ZXh0JyxcbiAgICBudW1lcmljID0gJ251bWVyaWMnLFxuICAgIHBhc3N3b3JkID0gJ3Bhc3N3b3JkJyxcbn1cbiJdfQ==
|
|
@@ -7,7 +7,8 @@ import * as i1 from "@angular/cdk/overlay";
|
|
|
7
7
|
export class SystelabVirtualKeyboardOverlayService {
|
|
8
8
|
constructor(overlay) {
|
|
9
9
|
this.overlay = overlay;
|
|
10
|
-
this.
|
|
10
|
+
this.clickAlreadyHandled = false;
|
|
11
|
+
this.touchEndAlreadyHandled = false;
|
|
11
12
|
this.initListener();
|
|
12
13
|
}
|
|
13
14
|
isCreated() {
|
|
@@ -38,8 +39,11 @@ export class SystelabVirtualKeyboardOverlayService {
|
|
|
38
39
|
updatePosition() {
|
|
39
40
|
this.updatePositionStrategy(this.inputOrigin, this.fixedBottom);
|
|
40
41
|
}
|
|
41
|
-
|
|
42
|
-
this.
|
|
42
|
+
setClickAlreadyHandled() {
|
|
43
|
+
this.clickAlreadyHandled = true;
|
|
44
|
+
}
|
|
45
|
+
setTouchEndAlreadyHandled() {
|
|
46
|
+
this.touchEndAlreadyHandled = true;
|
|
43
47
|
}
|
|
44
48
|
destroy() {
|
|
45
49
|
if (this.overlayRef) {
|
|
@@ -50,25 +54,33 @@ export class SystelabVirtualKeyboardOverlayService {
|
|
|
50
54
|
}
|
|
51
55
|
initListener() {
|
|
52
56
|
document.addEventListener('click', this.handleClick.bind(this));
|
|
57
|
+
document.addEventListener('touchend', this.handleTouchEnd.bind(this));
|
|
53
58
|
}
|
|
54
59
|
handleClick(event) {
|
|
55
|
-
if (this.
|
|
56
|
-
this.
|
|
60
|
+
if (this.clickAlreadyHandled) {
|
|
61
|
+
this.clickAlreadyHandled = false;
|
|
57
62
|
return;
|
|
58
63
|
}
|
|
59
|
-
console.log('Document clicked:', event);
|
|
60
64
|
event.stopPropagation();
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
65
|
+
this.handleEventTarget(event.target);
|
|
66
|
+
}
|
|
67
|
+
handleTouchEnd(event) {
|
|
68
|
+
if (this.touchEndAlreadyHandled) {
|
|
69
|
+
this.touchEndAlreadyHandled = false;
|
|
70
|
+
return;
|
|
71
|
+
}
|
|
72
|
+
event.stopPropagation();
|
|
73
|
+
this.handleEventTarget(event.target);
|
|
74
|
+
}
|
|
75
|
+
handleEventTarget(target) {
|
|
76
|
+
const showKeyboardButtonTarget = target?.classList.contains('virtual-keyboard-show-button');
|
|
77
|
+
const virtualKeyboardTarget = document.querySelector('.simple-keyboard')?.contains(target);
|
|
78
|
+
const inputElementTarget = this.inputOrigin?.contains(target);
|
|
79
|
+
const containsShowButton = this.showKeyboardButtonElement?.contains(target);
|
|
80
|
+
if (!virtualKeyboardTarget &&
|
|
81
|
+
!inputElementTarget &&
|
|
70
82
|
!containsShowButton &&
|
|
71
|
-
!
|
|
83
|
+
!showKeyboardButtonTarget) {
|
|
72
84
|
if (this.isCreated()) {
|
|
73
85
|
this.destroy();
|
|
74
86
|
}
|
|
@@ -78,10 +90,14 @@ export class SystelabVirtualKeyboardOverlayService {
|
|
|
78
90
|
return this.overlayRef?.hasAttached();
|
|
79
91
|
}
|
|
80
92
|
updatePositionStrategy(inputOrigin, fixedBottom) {
|
|
81
|
-
this.overlayRef
|
|
93
|
+
if (!!this.overlayRef) {
|
|
94
|
+
this.overlayRef.updatePositionStrategy(this.getPositionStrategy(inputOrigin, fixedBottom));
|
|
95
|
+
}
|
|
82
96
|
}
|
|
83
97
|
updateSize() {
|
|
84
|
-
this.overlayRef
|
|
98
|
+
if (!!this.overlayRef) {
|
|
99
|
+
this.overlayRef.updateSize(this.getOverlaySize());
|
|
100
|
+
}
|
|
85
101
|
}
|
|
86
102
|
getPositionStrategy(inputOrigin, fixedBottom) {
|
|
87
103
|
if (fixedBottom) {
|
|
@@ -157,4 +173,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImpor
|
|
|
157
173
|
providedIn: 'root',
|
|
158
174
|
}]
|
|
159
175
|
}], ctorParameters: () => [{ type: i1.Overlay }] });
|
|
160
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"systelab-virtual-keyboard-overlay.service.js","sourceRoot":"","sources":["../../../../projects/systelab-virtual-keyboard/src/lib/systelab-virtual-keyboard-overlay.service.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2020 - 2024 - Instrumentation Laboratory Company and Systelab Technologies, SA. All rights reserved.\n * NOTICE:  All information contained herein is and remains the property of Instrumentation Laboratory Company and its\n * affiliates, if any.  The intellectual and technical concepts contained herein are proprietary to Instrumentation\n * Laboratory Company and its affiliates and may be covered by U.S. and foreign patents and patent applications, and/or\n * are protected by trade secret or copyright law. Dissemination of this information or reproduction of this material is\n * strictly forbidden unless prior written permission is Instrumentation Laboratory Company.\n */\n\nimport { Overlay, OverlayRef, OverlaySizeConfig, PositionStrategy } from '@angular/cdk/overlay';\nimport { ComponentRef, Injectable } from '@angular/core';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { SystelabVirtualKeyboardLayouts } from './constants';\nimport { SystelabVirtualKeyboardComponent } from './systelab-virtual-keyboard.component';\n\ninterface PositionStrategyOrigin {\n  x: number;\n  y: number;\n  width?: number;\n  height?: number;\n}\n\n@Injectable({\n    providedIn: 'root',\n})\nexport class SystelabVirtualKeyboardOverlayService {\n    private overlayRef!: OverlayRef;\n    private inputOrigin: HTMLInputElement;\n    private fixedBottom: boolean;\n    private showKeyboardButtonElement: HTMLElement;\n    private open: boolean;\n    private layout: SystelabVirtualKeyboardLayouts;\n    private focusDispatched: boolean = false;\n\n    constructor(private readonly overlay: Overlay) {\n        this.initListener();\n    }\n\n    public isCreated(): boolean {\n        return !!this.overlayRef;\n    }\n\n    public isOpen(): boolean {\n        return this.open;\n    }\n\n    public create(\n        inputOrigin: HTMLInputElement,\n        showKeyboardButtonElement: HTMLElement,\n        fixedBottom: boolean,\n        layout: SystelabVirtualKeyboardLayouts = SystelabVirtualKeyboardLayouts.default,\n    ): ComponentRef<SystelabVirtualKeyboardComponent> {\n        this.inputOrigin = inputOrigin;\n        this.fixedBottom = fixedBottom;\n        this.showKeyboardButtonElement = showKeyboardButtonElement;\n        this.layout = layout;\n        this.overlayRef = this.overlay.create({\n            hasBackdrop: false,\n            scrollStrategy: this.overlay.scrollStrategies.reposition(),\n            disposeOnNavigation: true,\n        });\n        this.overlayRef.addPanelClass('virtual-keyboard-overlay-pane');\n        if (fixedBottom) {\n            this.overlayRef.addPanelClass('virtual-keyboard-fixed-bottom');\n        }\n\n        this.updatePositionStrategy(inputOrigin, fixedBottom);\n        this.updateSize();\n\n        this.open = true;\n        return this.overlayRef.attach(new ComponentPortal(SystelabVirtualKeyboardComponent));\n    }\n\n    public updatePosition(): void {\n        this.updatePositionStrategy(this.inputOrigin, this.fixedBottom);\n    }\n\n    public setFocusDispatched(dispatched: boolean): void {\n        this.focusDispatched = dispatched;\n    }\n\n    public destroy(): void {\n        if (this.overlayRef) {\n            this.overlayRef.dispose();\n        }\n        this.overlayRef = null;\n        this.open = false;\n    }\n\n    private initListener() {\n        document.addEventListener('click', this.handleClick.bind(this));\n    }\n\n    private handleClick(event: MouseEvent) {\n        if (this.focusDispatched) {\n            this.focusDispatched = false;\n            return;\n        }\n        console.log('Document clicked:', event);\n        event.stopPropagation();\n        const simpleKeyboardElement = document.querySelector('.simple-keyboard');\n        const showKeyboardButtonClicked = (event.target as HTMLElement)?.classList.contains('virtual-keyboard-show-button');\n\n        const containsKeyboard = simpleKeyboardElement?.contains(event.target as Node);\n        const containsElementRef = this.inputOrigin?.contains(event.target as Node);\n        // const containsFocusedElement = this.focusedElement?.contains(event.target as Node);\n        const containsShowButton = this.showKeyboardButtonElement?.contains(event.target as Node);\n        if (\n            !containsKeyboard &&\n      !containsElementRef &&\n      // !containsFocusedElement &&\n      !containsShowButton &&\n      !showKeyboardButtonClicked\n        ) {\n            if (this.isCreated()) {\n                this.destroy();\n            }\n        }\n    }\n\n    public hasAttached(): boolean {\n        return this.overlayRef?.hasAttached();\n    }\n\n    private updatePositionStrategy(inputOrigin: HTMLInputElement, fixedBottom: boolean): void {\n        this.overlayRef.updatePositionStrategy(this.getPositionStrategy(inputOrigin, fixedBottom));\n    }\n\n    private updateSize(): void {\n        this.overlayRef.updateSize(this.getOverlaySize());\n    }\n\n    private getPositionStrategy(inputOrigin: HTMLInputElement, fixedBottom: boolean): PositionStrategy {\n        if (fixedBottom) {\n            return this.overlay.position().global().centerHorizontally().bottom('0');\n        }\n\n        const pointWithDimensions: PositionStrategyOrigin = this.computePositionStrategyOrigin(inputOrigin);\n\n        return this.overlay\n            .position()\n            .flexibleConnectedTo(pointWithDimensions)\n            .withFlexibleDimensions(false)\n            .withLockedPosition(true)\n            .withPush(false)\n            .withPositions([\n                {\n                    originX: 'start',\n                    originY: 'bottom',\n                    overlayX: 'start',\n                    overlayY: 'top',\n                },\n                {\n                    originX: 'start',\n                    originY: 'top',\n                    overlayX: 'start',\n                    overlayY: 'bottom',\n                },\n                {\n                    originX: 'end',\n                    originY: 'bottom',\n                    overlayX: 'end',\n                    overlayY: 'top',\n                },\n                {\n                    originX: 'end',\n                    originY: 'top',\n                    overlayX: 'end',\n                    overlayY: 'bottom',\n                },\n            ]);\n    }\n\n    private getOverlaySize(): OverlaySizeConfig {\n        const overlayWidth = this.layout === SystelabVirtualKeyboardLayouts.numeric ? '400px' : '1200px';\n\n        return {\n            width: overlayWidth,\n            maxWidth: overlayWidth,\n            minWidth: overlayWidth,\n        };\n    }\n\n    private computePositionStrategyOrigin(inputOrigin: HTMLInputElement): PositionStrategyOrigin {\n        const overlayOffsetX = this.computeOverlayOffsetX(inputOrigin);\n        const { width: overlayWidthString } = this.getOverlaySize();\n        const overlayWidth = Number((overlayWidthString as string).replace('px', ''));\n        const {x, y, width, height} = inputOrigin.getBoundingClientRect();\n        return {\n            width,\n            height,\n            x: width < overlayWidth ? x - overlayOffsetX : x + overlayOffsetX,\n            y,\n        };\n    }\n\n    private computeOverlayOffsetX(inputOrigin: HTMLInputElement): number {\n        const { width: overlayWidthString } = this.getOverlaySize();\n        const overlayWidth = Number((overlayWidthString as string).replace('px', ''));\n        const inputWidth = inputOrigin.getBoundingClientRect().width;\n\n        const extraWidth = overlayWidth - inputWidth;\n\n        return Math.abs(extraWidth) / 2;\n    }\n}\n"]}
|
|
176
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"systelab-virtual-keyboard-overlay.service.js","sourceRoot":"","sources":["../../../../projects/systelab-virtual-keyboard/src/lib/systelab-virtual-keyboard-overlay.service.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2020 - 2024 - Instrumentation Laboratory Company and Systelab Technologies, SA. All rights reserved.\n * NOTICE:  All information contained herein is and remains the property of Instrumentation Laboratory Company and its\n * affiliates, if any.  The intellectual and technical concepts contained herein are proprietary to Instrumentation\n * Laboratory Company and its affiliates and may be covered by U.S. and foreign patents and patent applications, and/or\n * are protected by trade secret or copyright law. Dissemination of this information or reproduction of this material is\n * strictly forbidden unless prior written permission is Instrumentation Laboratory Company.\n */\n\nimport { Overlay, OverlayRef, OverlaySizeConfig, PositionStrategy } from '@angular/cdk/overlay';\nimport { ComponentRef, Injectable } from '@angular/core';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { SystelabVirtualKeyboardLayouts } from './constants';\nimport { SystelabVirtualKeyboardComponent } from './systelab-virtual-keyboard.component';\n\ninterface PositionStrategyOrigin {\n  x: number;\n  y: number;\n  width?: number;\n  height?: number;\n}\n\n@Injectable({\n    providedIn: 'root',\n})\nexport class SystelabVirtualKeyboardOverlayService {\n    private overlayRef!: OverlayRef;\n    private inputOrigin: HTMLInputElement;\n    private fixedBottom: boolean;\n    private showKeyboardButtonElement: HTMLElement;\n    private open: boolean;\n    private layout: SystelabVirtualKeyboardLayouts;\n    private clickAlreadyHandled: boolean = false;\n    private touchEndAlreadyHandled: boolean = false;\n\n    constructor(private readonly overlay: Overlay) {\n        this.initListener();\n    }\n\n    public isCreated(): boolean {\n        return !!this.overlayRef;\n    }\n\n    public isOpen(): boolean {\n        return this.open;\n    }\n\n    public create(\n        inputOrigin: HTMLInputElement,\n        showKeyboardButtonElement: HTMLElement,\n        fixedBottom: boolean,\n        layout: SystelabVirtualKeyboardLayouts = SystelabVirtualKeyboardLayouts.default,\n    ): ComponentRef<SystelabVirtualKeyboardComponent> {\n        this.inputOrigin = inputOrigin;\n        this.fixedBottom = fixedBottom;\n        this.showKeyboardButtonElement = showKeyboardButtonElement;\n        this.layout = layout;\n        this.overlayRef = this.overlay.create({\n            hasBackdrop: false,\n            scrollStrategy: this.overlay.scrollStrategies.reposition(),\n            disposeOnNavigation: true,\n        });\n        this.overlayRef.addPanelClass('virtual-keyboard-overlay-pane');\n        if (fixedBottom) {\n            this.overlayRef.addPanelClass('virtual-keyboard-fixed-bottom');\n        }\n\n        this.updatePositionStrategy(inputOrigin, fixedBottom);\n        this.updateSize();\n\n        this.open = true;\n        return this.overlayRef.attach(new ComponentPortal(SystelabVirtualKeyboardComponent));\n    }\n\n    public updatePosition(): void {\n        this.updatePositionStrategy(this.inputOrigin, this.fixedBottom);\n    }\n\n    public setClickAlreadyHandled(): void {\n        this.clickAlreadyHandled = true;\n    }\n\n    public setTouchEndAlreadyHandled(): void {\n        this.touchEndAlreadyHandled = true;\n    }\n\n    public destroy(): void {\n        if (this.overlayRef) {\n            this.overlayRef.dispose();\n        }\n        this.overlayRef = null;\n        this.open = false;\n    }\n\n    private initListener() {\n        document.addEventListener('click', this.handleClick.bind(this));\n        document.addEventListener('touchend', this.handleTouchEnd.bind(this));\n    }\n\n    private handleClick(event: MouseEvent) {\n        if (this.clickAlreadyHandled) {\n            this.clickAlreadyHandled = false;\n            return;\n        }\n\n        event.stopPropagation();\n        this.handleEventTarget(event.target);\n    }\n\n    private handleTouchEnd(event: TouchEvent) {\n        if (this.touchEndAlreadyHandled) {\n            this.touchEndAlreadyHandled = false;\n            return;\n        }\n\n        event.stopPropagation();\n        this.handleEventTarget(event.target);\n    }\n\n    private handleEventTarget(target: EventTarget) {\n        const showKeyboardButtonTarget: boolean = (target as HTMLElement)?.classList.contains('virtual-keyboard-show-button');\n        const virtualKeyboardTarget: boolean = document.querySelector('.simple-keyboard')?.contains(target as Node);\n        const inputElementTarget: boolean = this.inputOrigin?.contains(target as Node);\n        const containsShowButton: boolean = this.showKeyboardButtonElement?.contains(target as Node);\n\n        if (!virtualKeyboardTarget &&\n            !inputElementTarget &&\n            !containsShowButton &&\n            !showKeyboardButtonTarget) {\n            if (this.isCreated()) {\n                this.destroy();\n            }\n        }\n    }\n\n    public hasAttached(): boolean {\n        return this.overlayRef?.hasAttached();\n    }\n\n    private updatePositionStrategy(inputOrigin: HTMLInputElement, fixedBottom: boolean): void {\n        if (!!this.overlayRef) {\n            this.overlayRef.updatePositionStrategy(this.getPositionStrategy(inputOrigin, fixedBottom));\n        }\n    }\n\n    private updateSize(): void {\n        if (!!this.overlayRef) {\n            this.overlayRef.updateSize(this.getOverlaySize());\n        }\n    }\n\n    private getPositionStrategy(inputOrigin: HTMLInputElement, fixedBottom: boolean): PositionStrategy {\n        if (fixedBottom) {\n            return this.overlay.position().global().centerHorizontally().bottom('0');\n        }\n\n        const pointWithDimensions: PositionStrategyOrigin = this.computePositionStrategyOrigin(inputOrigin);\n\n        return this.overlay\n            .position()\n            .flexibleConnectedTo(pointWithDimensions)\n            .withFlexibleDimensions(false)\n            .withLockedPosition(true)\n            .withPush(false)\n            .withPositions([\n                {\n                    originX: 'start',\n                    originY: 'bottom',\n                    overlayX: 'start',\n                    overlayY: 'top',\n                },\n                {\n                    originX: 'start',\n                    originY: 'top',\n                    overlayX: 'start',\n                    overlayY: 'bottom',\n                },\n                {\n                    originX: 'end',\n                    originY: 'bottom',\n                    overlayX: 'end',\n                    overlayY: 'top',\n                },\n                {\n                    originX: 'end',\n                    originY: 'top',\n                    overlayX: 'end',\n                    overlayY: 'bottom',\n                },\n            ]);\n    }\n\n    private getOverlaySize(): OverlaySizeConfig {\n        const overlayWidth = this.layout === SystelabVirtualKeyboardLayouts.numeric ? '400px' : '1200px';\n\n        return {\n            width: overlayWidth,\n            maxWidth: overlayWidth,\n            minWidth: overlayWidth,\n        };\n    }\n\n    private computePositionStrategyOrigin(inputOrigin: HTMLInputElement): PositionStrategyOrigin {\n        const overlayOffsetX = this.computeOverlayOffsetX(inputOrigin);\n        const { width: overlayWidthString } = this.getOverlaySize();\n        const overlayWidth = Number((overlayWidthString as string).replace('px', ''));\n        const {x, y, width, height} = inputOrigin.getBoundingClientRect();\n        return {\n            width,\n            height,\n            x: width < overlayWidth ? x - overlayOffsetX : x + overlayOffsetX,\n            y,\n        };\n    }\n\n    private computeOverlayOffsetX(inputOrigin: HTMLInputElement): number {\n        const { width: overlayWidthString } = this.getOverlaySize();\n        const overlayWidth = Number((overlayWidthString as string).replace('px', ''));\n        const inputWidth = inputOrigin.getBoundingClientRect().width;\n\n        const extraWidth = overlayWidth - inputWidth;\n\n        return Math.abs(extraWidth) / 2;\n    }\n}\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Component, EventEmitter, HostListener, Inject, Optional, Output } from '@angular/core';
|
|
2
2
|
import { SimpleKeyboard } from 'simple-keyboard';
|
|
3
|
-
import { SystelabVirtualKeyboardButton, SystelabVirtualKeyboardInputMethods,
|
|
3
|
+
import { SystelabVirtualKeyboardButton, SystelabVirtualKeyboardInputMethods, SystelabVirtualKeyboardLayouts } from './constants';
|
|
4
4
|
import { VIRTUAL_KEYBOARD_CONFIG } from './systelab-virtual-keyboard.config';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
export class SystelabVirtualKeyboardComponent {
|
|
@@ -65,20 +65,12 @@ export class SystelabVirtualKeyboardComponent {
|
|
|
65
65
|
const inputType = this.activeInputElement?.type;
|
|
66
66
|
console.log('Layout:', `${inputType}_${this.selectedLayout}`);
|
|
67
67
|
}
|
|
68
|
-
|
|
69
|
-
let selectionEnd;
|
|
70
|
-
if (this.isInputNumeric(input)) {
|
|
71
|
-
selectionStart = this.activeInputElement.value.toString().length;
|
|
72
|
-
selectionEnd = this.activeInputElement.value.toString().length;
|
|
73
|
-
}
|
|
74
|
-
else {
|
|
75
|
-
selectionStart = this.activeInputElement.selectionStart;
|
|
76
|
-
selectionEnd = this.activeInputElement.selectionEnd;
|
|
77
|
-
}
|
|
68
|
+
const { selectionStart, selectionEnd } = this.activeInputElement;
|
|
78
69
|
this.setCaretPosition(selectionStart, selectionEnd);
|
|
79
70
|
if (this.debug) {
|
|
80
71
|
console.log('Caret start at:', this.caretPosition, this.caretPositionEnd);
|
|
81
72
|
}
|
|
73
|
+
this.focusActiveInput();
|
|
82
74
|
}
|
|
83
75
|
setLayout(layout) {
|
|
84
76
|
this.selectedLayout = layout;
|
|
@@ -137,14 +129,6 @@ export class SystelabVirtualKeyboardComponent {
|
|
|
137
129
|
}
|
|
138
130
|
return keyboardOptions;
|
|
139
131
|
}
|
|
140
|
-
isInputAlphabetic(activeInputElement) {
|
|
141
|
-
const inputType = activeInputElement?.type;
|
|
142
|
-
return inputType && [SystelabVirtualKeyboardInputTypes.text, SystelabVirtualKeyboardInputTypes.password].some((i) => i === inputType);
|
|
143
|
-
}
|
|
144
|
-
isInputNumeric(activeInputElement) {
|
|
145
|
-
const inputType = activeInputElement?.type;
|
|
146
|
-
return inputType && [SystelabVirtualKeyboardInputTypes.number].some((i) => i === inputType);
|
|
147
|
-
}
|
|
148
132
|
handleKeyPress(button, e) {
|
|
149
133
|
if (this.debug) {
|
|
150
134
|
console.log('Key press:', button);
|
|
@@ -187,7 +171,7 @@ export class SystelabVirtualKeyboardComponent {
|
|
|
187
171
|
output = this.addStringAt(output, ' ', ...commonParams);
|
|
188
172
|
}
|
|
189
173
|
else if (button === SystelabVirtualKeyboardButton.Tab) {
|
|
190
|
-
|
|
174
|
+
// Do nothing for tab
|
|
191
175
|
}
|
|
192
176
|
else if (button === SystelabVirtualKeyboardButton.Enter) {
|
|
193
177
|
if (this.isTextarea) {
|
|
@@ -340,6 +324,10 @@ export class SystelabVirtualKeyboardComponent {
|
|
|
340
324
|
}
|
|
341
325
|
}
|
|
342
326
|
}
|
|
327
|
+
focusActiveInput() {
|
|
328
|
+
this.activeInputElement?.focus();
|
|
329
|
+
this.activeInputElement?.setSelectionRange(this.caretPosition, this.caretPositionEnd);
|
|
330
|
+
}
|
|
343
331
|
updateCaretPosition(length, minus = false) {
|
|
344
332
|
const newCaretPos = this.computeNewCaretPosition(length, minus);
|
|
345
333
|
this.setCaretPosition(newCaretPos);
|
|
@@ -368,7 +356,7 @@ export class SystelabVirtualKeyboardComponent {
|
|
|
368
356
|
this.caretPositionEnd = endPosition;
|
|
369
357
|
}
|
|
370
358
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.9", ngImport: i0, type: SystelabVirtualKeyboardComponent, deps: [{ token: i0.ElementRef }, { token: VIRTUAL_KEYBOARD_CONFIG, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
371
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.9", type: SystelabVirtualKeyboardComponent, isStandalone: true, selector: "systelab-virtual-keyboard.component", outputs: { closePanel: "closePanel" }, host: { listeners: { "window:keyup": "handleKeyUp($event)", "window:pointerup": "handleMouseUp($event)", "window:select": "handleSelect($event)", "window:selectionchange": "handleSelectionChange($event)" } }, ngImport: i0, template: "<!--\n ~ Copyright (c) 2020 - 2024 - Instrumentation Laboratory Company and Systelab Technologies, SA. All rights reserved.\n ~ NOTICE: All information contained herein is and remains the property of Instrumentation Laboratory Company and its\n ~ affiliates, if any. The intellectual and technical concepts contained herein are proprietary to Instrumentation\n ~ Laboratory Company and its affiliates and may be covered by U.S. and foreign patents and patent applications, and/or\n ~ are protected by trade secret or copyright law. Dissemination of this information or reproduction of this material is\n ~ strictly forbidden unless prior written permission is Instrumentation Laboratory Company.\n -->\n\n<div class=\"simple-keyboard\"></div>\n", styles: [":host{width:100%}.simple-keyboard.hg-theme-default.myTheme{font-family:Lato,HelveticaNeue-Light,Helvetica Neue Light,Helvetica Neue,Helvetica,Arial,Lucida Grande,sans-serif}\n"] }); }
|
|
359
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.9", type: SystelabVirtualKeyboardComponent, isStandalone: true, selector: "systelab-virtual-keyboard.component", outputs: { closePanel: "closePanel" }, host: { listeners: { "window:keyup": "handleKeyUp($event)", "window:pointerup": "handleMouseUp($event)", "window:mouseup": "handleMouseUp($event)", "window:select": "handleSelect($event)", "window:selectionchange": "handleSelectionChange($event)" } }, ngImport: i0, template: "<!--\n ~ Copyright (c) 2020 - 2024 - Instrumentation Laboratory Company and Systelab Technologies, SA. All rights reserved.\n ~ NOTICE: All information contained herein is and remains the property of Instrumentation Laboratory Company and its\n ~ affiliates, if any. The intellectual and technical concepts contained herein are proprietary to Instrumentation\n ~ Laboratory Company and its affiliates and may be covered by U.S. and foreign patents and patent applications, and/or\n ~ are protected by trade secret or copyright law. Dissemination of this information or reproduction of this material is\n ~ strictly forbidden unless prior written permission is Instrumentation Laboratory Company.\n -->\n\n<div class=\"simple-keyboard\"></div>\n", styles: [":host{width:100%}.simple-keyboard.hg-theme-default.myTheme{font-family:Lato,HelveticaNeue-Light,Helvetica Neue Light,Helvetica Neue,Helvetica,Arial,Lucida Grande,sans-serif}\n"] }); }
|
|
372
360
|
}
|
|
373
361
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImport: i0, type: SystelabVirtualKeyboardComponent, decorators: [{
|
|
374
362
|
type: Component,
|
|
@@ -384,6 +372,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImpor
|
|
|
384
372
|
}], handleMouseUp: [{
|
|
385
373
|
type: HostListener,
|
|
386
374
|
args: ['window:pointerup', ['$event']]
|
|
375
|
+
}, {
|
|
376
|
+
type: HostListener,
|
|
377
|
+
args: ['window:mouseup', ['$event']]
|
|
387
378
|
}], handleSelect: [{
|
|
388
379
|
type: HostListener,
|
|
389
380
|
args: ['window:select', ['$event']]
|
|
@@ -393,4 +384,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImpor
|
|
|
393
384
|
}], closePanel: [{
|
|
394
385
|
type: Output
|
|
395
386
|
}] } });
|
|
396
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"systelab-virtual-keyboard.component.js","sourceRoot":"","sources":["../../../../projects/systelab-virtual-keyboard/src/lib/systelab-virtual-keyboard.component.ts","../../../../projects/systelab-virtual-keyboard/src/lib/systelab-virtual-keyboard.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostListener,\n    Inject,\n    Optional,\n    Output\n} from '@angular/core';\nimport { SimpleKeyboard } from 'simple-keyboard';\nimport {\n    SystelabVirtualKeyboardButton,\n    SystelabVirtualKeyboardInputMethods,\n    SystelabVirtualKeyboardInputTypes,\n    SystelabVirtualKeyboardLayouts\n} from './constants';\nimport { SystelabVirtualKeyboardConfig, VIRTUAL_KEYBOARD_CONFIG } from './systelab-virtual-keyboard.config';\nimport { KeyboardOptions } from 'simple-keyboard/build/interfaces';\n\n@Component({\n    selector: 'systelab-virtual-keyboard.component',\n    standalone: true,\n    imports: [],\n    templateUrl: './systelab-virtual-keyboard.component.html',\n    styleUrl: 'systelab-virtual-keyboard.component.scss',\n})\nexport class SystelabVirtualKeyboardComponent implements AfterViewInit {\n    @HostListener('window:keyup', ['$event'])\n    handleKeyUp(event: KeyboardEvent): void {\n        if (event.isTrusted) {\n            this.caretEventHandler(event);\n        }\n    }\n\n    @HostListener('window:pointerup', ['$event'])\n    handleMouseUp(event: PointerEvent): void {\n        this.caretEventHandler(event);\n    }\n\n    @HostListener('window:select', ['$event'])\n    handleSelect(event: Event): void {\n        this.caretEventHandler(event);\n    }\n\n    @HostListener('window:selectionchange', ['$event'])\n    handleSelectionChange(event: Event): void {\n        this.caretEventHandler(event);\n    }\n\n    get maxLength(): number {\n        return this.activeInputElement?.maxLength ?? -1;\n    }\n\n    get isTextarea(): boolean {\n        return this.activeInputElement?.type === 'textarea';\n    }\n\n    public debug = false;\n    private selectedLayout: SystelabVirtualKeyboardLayouts = SystelabVirtualKeyboardLayouts.default;\n    private keyboard: SimpleKeyboard;\n    private caretPosition: number | null = null;\n    private caretPositionEnd: number | null = null;\n    private activeInputElement!: HTMLInputElement | HTMLTextAreaElement | null;\n    private shiftPressed: boolean = false;\n\n    @Output() closePanel = new EventEmitter<void>();\n\n    constructor(private elementRef: ElementRef<HTMLInputElement>, @Optional() @Inject(VIRTUAL_KEYBOARD_CONFIG) private virtualKeyboardConfig: SystelabVirtualKeyboardConfig,) {\n    }\n\n    ngAfterViewInit() {\n        const layout = {\n            [SystelabVirtualKeyboardLayouts.default]: [\n                '` 1 2 3 4 5 6 7 8 9 0 - = {bksp}',\n                '{tab} q w e r t y u i o p [ ] \\\\',\n                \"{lock} a s d f g h j k l ; ' {enter}\",\n                '{shift} z x c v b n m , . / {shift}',\n                '{space}',\n            ],\n            [SystelabVirtualKeyboardLayouts.shift]: [\n                '~ ! @ # $ % ^ &amp; * ( ) _ + {bksp}',\n                '{tab} Q W E R T Y U I O P { } |',\n                '{lock} A S D F G H J K L : \" {enter}',\n                '{shift} Z X C V B N M &lt; &gt; ? {shift}',\n                '{space}',\n            ],\n            [SystelabVirtualKeyboardLayouts.numeric]: ['7 8 9', '4 5 6', '1 2 3', '0 {bksp}'],\n        };\n\n        const keyboardOptions: KeyboardOptions = this.prepareKeyboardConfig();\n        this.keyboard = new SimpleKeyboard('.simple-keyboard', keyboardOptions);\n        this.setLayout(this.selectedLayout);\n        if (this.debug) {\n            console.log('Layout: ', layout);\n        }\n    }\n\n    public setActiveInput(input: HTMLInputElement | HTMLTextAreaElement): void {\n        this.activeInputElement = input;\n\n        if (this.debug) {\n            const inputType = this.activeInputElement?.type;\n            console.log('Layout:', `${inputType}_${this.selectedLayout}`);\n        }\n\n        let selectionStart: number;\n        let selectionEnd: number;\n        if (this.isInputNumeric(input)) {\n            selectionStart = this.activeInputElement.value.toString().length;\n            selectionEnd = this.activeInputElement.value.toString().length;\n        } else {\n            selectionStart = this.activeInputElement.selectionStart;\n            selectionEnd = this.activeInputElement.selectionEnd;\n        }\n\n        this.setCaretPosition(selectionStart, selectionEnd);\n\n        if (this.debug) {\n            console.log('Caret start at:', this.caretPosition, this.caretPositionEnd);\n        }\n    }\n\n    public setLayout(layout: SystelabVirtualKeyboardLayouts): void {\n        this.selectedLayout = layout;\n        if (this.keyboard) {\n            this.keyboard.setOptions({\n                layoutName: layout,\n            });\n        }\n    }\n\n    private prepareKeyboardConfig(): KeyboardOptions {\n        const layout = {\n            [SystelabVirtualKeyboardLayouts.default]: [\n                '` 1 2 3 4 5 6 7 8 9 0 - = {bksp}',\n                '{tab} q w e r t y u i o p [ ] \\\\',\n                \"{lock} a s d f g h j k l ; ' {enter}\",\n                '{shift} z x c v b n m , . / {shift}',\n                '{space}',\n            ],\n            [SystelabVirtualKeyboardLayouts.shift]: [\n                '~ ! @ # $ % ^ &amp; * ( ) _ + {bksp}',\n                '{tab} Q W E R T Y U I O P { } |',\n                '{lock} A S D F G H J K L : \" {enter}',\n                '{shift} Z X C V B N M &lt; &gt; ? {shift}',\n                '{space}',\n            ],\n            [SystelabVirtualKeyboardLayouts.numeric]: ['7 8 9', '4 5 6', '1 2 3', '0 {bksp}'],\n        };\n\n        let keyboardOptions: KeyboardOptions = {\n            onKeyPress: (button) => this.handleKeyPress(button),\n            mergeDisplay: true,\n            theme: 'hg-theme-default hg-layout-default myTheme',\n            display: {\n                [SystelabVirtualKeyboardButton.Backspace]: 'delete',\n            },\n            buttonTheme: [\n                {\n                    class: 'virtual-keyboard-delete-button',\n                    buttons: `${SystelabVirtualKeyboardButton.Backspace}`,\n                },\n            ],\n            layout,\n        };\n\n        if (this.virtualKeyboardConfig?.hasOwnProperty('inputMethod')) {\n            if (this.virtualKeyboardConfig.inputMethod === SystelabVirtualKeyboardInputMethods.onlyMouseEvents) {\n                keyboardOptions = {\n                    ...keyboardOptions,\n                    useMouseEvents: true,\n                }\n            } else if (this.virtualKeyboardConfig.inputMethod === SystelabVirtualKeyboardInputMethods.onlyTouchEvents) {\n                keyboardOptions = {\n                    ...keyboardOptions,\n                    useTouchEvents: true,\n                }\n            }\n        }\n\n        return keyboardOptions;\n    }\n\n    private isInputAlphabetic(activeInputElement: HTMLInputElement | HTMLTextAreaElement): boolean {\n        const inputType = activeInputElement?.type;\n        return inputType && [SystelabVirtualKeyboardInputTypes.text, SystelabVirtualKeyboardInputTypes.password].some((i) => i === inputType);\n    }\n\n    private isInputNumeric(activeInputElement: HTMLInputElement | HTMLTextAreaElement): boolean {\n        const inputType = activeInputElement?.type;\n        return inputType && [SystelabVirtualKeyboardInputTypes.number].some((i) => i === inputType);\n    }\n\n    private handleKeyPress(button: string, e?: Event): void {\n        if (this.debug) {\n            console.log('Key press:', button);\n        }\n\n        if (button[0] === '&' && button.length > 1) {\n            button = new DOMParser().parseFromString(button, 'text/html').body.textContent;\n        }\n\n        if (button === SystelabVirtualKeyboardButton.Shift || button === SystelabVirtualKeyboardButton.Lock) {\n            this.shiftPressed = button === SystelabVirtualKeyboardButton.Shift;\n            this.toggleShiftLayout();\n        } else if (button === SystelabVirtualKeyboardButton.Done) {\n            this.closePanel.emit();\n            return;\n        }\n\n        if (!this.isAcceptedNonStandardButton(button) && !this.isStandardButton(button)) {\n            return;\n        }\n\n        const output = this.handleButtonOutput(button);\n\n        if (this.activeInputElement) {\n            this.activeInputElement.value = output;\n\n            if (this.debug) {\n                console.log('Caret at:', this.caretPosition, this.caretPositionEnd, 'Button', e);\n            }\n        }\n\n        this.dispatchEvents(button);\n\n        if (this.shiftPressed) {\n            this.toggleShiftLayout();\n        }\n        this.shiftPressed = button === SystelabVirtualKeyboardButton.Shift;\n    }\n\n    private handleButtonOutput(button: string): string {\n        const commonParams: [number, number, boolean] = this.getCommonParams();\n        let output = this.activeInputElement?.value || '';\n        if (!this.isStandardButton(button)) {\n            if (button === SystelabVirtualKeyboardButton.Backspace) {\n                output = this.removeAt(output, ...commonParams);\n            } else if (button === SystelabVirtualKeyboardButton.Space) {\n                output = this.addStringAt(output, ' ', ...commonParams);\n            } else if (button === SystelabVirtualKeyboardButton.Tab) {\n                output = this.addStringAt(output, '\\t', ...commonParams);\n            } else if (button === SystelabVirtualKeyboardButton.Enter) {\n                if (this.isTextarea) {\n                    output = this.addStringAt(output, '\\n', ...commonParams);\n                }\n            } else {\n                return;\n            }\n        } else {\n            output = this.addStringAt(output, button, ...commonParams);\n        }\n\n        return output;\n    }\n\n    private getCommonParams(): [number, number, boolean] {\n        return [this.caretPosition || 0, this.caretPositionEnd || 0, true];\n    }\n\n    private isAcceptedNonStandardButton(button: string): boolean {\n        return [\n            SystelabVirtualKeyboardButton.Backspace.toString(),\n            SystelabVirtualKeyboardButton.Space.toString(),\n            SystelabVirtualKeyboardButton.Tab.toString(),\n            SystelabVirtualKeyboardButton.Enter.toString(),\n        ].includes(button);\n    }\n\n    private dispatchEvents(button: string) {\n        const {key, code} = this.convertFromButtonToCode(button);\n\n        const eventInit: KeyboardEventInit = {\n            bubbles: true,\n            cancelable: true,\n            shiftKey: this.selectedLayout === SystelabVirtualKeyboardLayouts.shift,\n            key: key,\n            code: code,\n            location: 0,\n        };\n\n        // Simulate all needed events on base element\n        this.activeInputElement?.dispatchEvent(new KeyboardEvent('keydown', eventInit));\n        this.activeInputElement?.dispatchEvent(new KeyboardEvent('keypress', eventInit));\n        this.activeInputElement?.dispatchEvent(new Event('input', {bubbles: true}));\n        this.activeInputElement?.dispatchEvent(new KeyboardEvent('keyup', eventInit));\n    }\n\n    /*\n     * AUXILIARY METHODS\n     * */\n    private convertFromButtonToCode(button: string): { key: string; code: string } {\n        let key: string;\n        let code: string;\n        if (button.includes('{') && button.includes('}')) {\n            // Capitalize name\n            key = button.slice(1, button.length - 1).toLowerCase();\n            key = key.charAt(0).toUpperCase() + key.slice(1);\n            code = key;\n\n            // Fix to standard key code\n            if (code.toLowerCase() === SystelabVirtualKeyboardButton.Backspace.slice(1, SystelabVirtualKeyboardButton.Backspace.length - 1).toLowerCase()) {\n                code = 'Backspace';\n            }\n        } else {\n            key = button;\n            code = Number.isInteger(Number(button)) ? `Digit${button}` : `Key${button.toUpperCase()}`;\n        }\n\n        return {key, code};\n    }\n\n    private toggleShiftLayout(): void {\n        const currentLayout = this.keyboard.options.layoutName;\n        const selectedLayout: SystelabVirtualKeyboardLayouts =\n            currentLayout === SystelabVirtualKeyboardLayouts.default ? SystelabVirtualKeyboardLayouts.shift : SystelabVirtualKeyboardLayouts.default;\n\n        this.setLayout(selectedLayout);\n    }\n\n    private isStandardButton(button: string) {\n        return button && !(button[0] === '{' && button[button.length - 1] === '}');\n    }\n\n    /*\n     * OUTPUT STRING METHODS\n     * */\n    private removeAt(source: string, position = source.length, positionEnd = source.length, moveCaret = false): string {\n        if (position === 0 && positionEnd === 0) {\n            return source;\n        }\n\n        let output: string;\n\n        if (position === positionEnd) {\n            if (position && position >= 0) {\n                output = source.slice(0, position - 1) + source.slice(position);\n                if (moveCaret) {\n                    this.updateCaretPosition(1, true);\n                }\n            } else {\n                output = source.slice(0, -1);\n                if (moveCaret) {\n                    this.updateCaretPosition(1, true);\n                }\n            }\n        } else {\n            output = source.slice(0, position) + source.slice(positionEnd);\n            if (moveCaret) {\n                this.setCaretPosition(position);\n            }\n        }\n\n        return output;\n    }\n\n    private addStringAt(source: string, str: string, position = source.length, positionEnd = source.length, moveCaret = false): string {\n        if (this.maxLength !== -1 && source.length >= this.maxLength) {\n            return source;\n        }\n\n        let output: string;\n\n        if (!position && position !== 0) {\n            output = source + str;\n        } else {\n            output = [source.slice(0, position), str, source.slice(positionEnd)].join('');\n            if (moveCaret) {\n                this.updateCaretPosition(str.length, false);\n            }\n        }\n\n        return output;\n    }\n\n    /*\n       * CARET METHODS\n       * */\n    private caretEventHandler(event: any) {\n        let targetTagName = '';\n        if (event.target.tagName) {\n            targetTagName = event.target.tagName.toLowerCase();\n        }\n\n        const isTextInput =\n            targetTagName === 'textarea' ||\n            (targetTagName === 'input' && ['text', 'search', 'email', 'password', 'url', 'tel'].includes(event.target.type));\n\n        const isKeyboard =\n            event.target === this.elementRef.nativeElement || (event.target && this.elementRef.nativeElement.contains(event.target));\n\n        if (isTextInput && this.activeInputElement == event.target) {\n            /**\n             * Tracks current cursor position\n             * As keys are pressed, text will be added/removed at that position within the input.\n             */\n            this.setCaretPosition(event.target.selectionStart, event.target.selectionEnd);\n\n            if (this.debug) {\n                console.log('Caret at:', this.caretPosition, this.caretPositionEnd, event && event.target.tagName.toLowerCase(), event);\n            }\n        } else if (event.type === 'pointerup' && this.activeInputElement === document.activeElement) {\n            return;\n        } else if (!isKeyboard && event?.type !== 'selectionchange') {\n            /**\n             * we must ensure caretPosition doesn't persist once reactivated.\n             */\n            this.setCaretPosition(null);\n\n            if (this.debug) {\n                console.log(`Caret position reset due to \"${event?.type}\" event`, event);\n            }\n        }\n    }\n\n    private updateCaretPosition(length: number, minus = false) {\n        const newCaretPos = this.computeNewCaretPosition(length, minus);\n        this.setCaretPosition(newCaretPos);\n        // Scroll to bottom\n        setTimeout(() => {\n            this.activeInputElement?.scrollTo({\n                top: this.activeInputElement.scrollHeight,\n            } as ScrollToOptions);\n        });\n    }\n\n    private computeNewCaretPosition(length: number, minus = false) {\n        let caretPosition = this.caretPosition;\n\n        if (caretPosition != null) {\n            if (minus) {\n                if (caretPosition > 0) caretPosition = caretPosition - length;\n            } else {\n                caretPosition = caretPosition + length;\n            }\n        }\n        return caretPosition;\n    }\n\n    private setCaretPosition(position: number | null, endPosition = position): void {\n        this.caretPosition = position;\n        this.caretPositionEnd = endPosition;\n    }\n}\n","<!--\n  ~ Copyright (c) 2020 - 2024 - Instrumentation Laboratory Company and Systelab Technologies, SA. All rights reserved.\n  ~ NOTICE:  All information contained herein is and remains the property of Instrumentation Laboratory Company and its\n  ~ affiliates, if any.  The intellectual and technical concepts contained herein are proprietary to Instrumentation\n  ~ Laboratory Company and its affiliates and may be covered by U.S. and foreign patents and patent applications, and/or\n  ~ are protected by trade secret or copyright law. Dissemination of this information or reproduction of this material is\n  ~ strictly forbidden unless prior written permission is Instrumentation Laboratory Company.\n  -->\n\n<div class=\"simple-keyboard\"></div>\n"]}
|
|
387
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"systelab-virtual-keyboard.component.js","sourceRoot":"","sources":["../../../../projects/systelab-virtual-keyboard/src/lib/systelab-virtual-keyboard.component.ts","../../../../projects/systelab-virtual-keyboard/src/lib/systelab-virtual-keyboard.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostListener,\n    Inject,\n    Optional,\n    Output\n} from '@angular/core';\nimport { SimpleKeyboard } from 'simple-keyboard';\nimport {\n    SystelabVirtualKeyboardButton,\n    SystelabVirtualKeyboardInputMethods,\n    SystelabVirtualKeyboardLayouts\n} from './constants';\nimport { SystelabVirtualKeyboardConfig, VIRTUAL_KEYBOARD_CONFIG } from './systelab-virtual-keyboard.config';\nimport { KeyboardOptions } from 'simple-keyboard/build/interfaces';\n\n@Component({\n    selector: 'systelab-virtual-keyboard.component',\n    standalone: true,\n    imports: [],\n    templateUrl: './systelab-virtual-keyboard.component.html',\n    styleUrl: 'systelab-virtual-keyboard.component.scss',\n})\nexport class SystelabVirtualKeyboardComponent implements AfterViewInit {\n    @HostListener('window:keyup', ['$event'])\n    handleKeyUp(event: KeyboardEvent): void {\n        if (event.isTrusted) {\n            this.caretEventHandler(event);\n        }\n    }\n\n    @HostListener('window:pointerup', ['$event'])\n    @HostListener('window:mouseup', ['$event'])\n    handleMouseUp(event: PointerEvent): void {\n        this.caretEventHandler(event);\n    }\n\n    @HostListener('window:select', ['$event'])\n    handleSelect(event: Event): void {\n        this.caretEventHandler(event);\n    }\n\n    @HostListener('window:selectionchange', ['$event'])\n    handleSelectionChange(event: Event): void {\n        this.caretEventHandler(event);\n    }\n\n    get maxLength(): number {\n        return this.activeInputElement?.maxLength ?? -1;\n    }\n\n    get isTextarea(): boolean {\n        return this.activeInputElement?.type === 'textarea';\n    }\n\n    public debug = false;\n    private selectedLayout: SystelabVirtualKeyboardLayouts = SystelabVirtualKeyboardLayouts.default;\n    private keyboard: SimpleKeyboard;\n    private caretPosition: number | null = null;\n    private caretPositionEnd: number | null = null;\n    private activeInputElement!: HTMLInputElement | HTMLTextAreaElement | null;\n    private shiftPressed: boolean = false;\n\n    @Output() closePanel = new EventEmitter<void>();\n\n    constructor(private elementRef: ElementRef<HTMLInputElement>, @Optional() @Inject(VIRTUAL_KEYBOARD_CONFIG) private virtualKeyboardConfig: SystelabVirtualKeyboardConfig,) {\n    }\n\n    ngAfterViewInit() {\n        const layout = {\n            [SystelabVirtualKeyboardLayouts.default]: [\n                '` 1 2 3 4 5 6 7 8 9 0 - = {bksp}',\n                '{tab} q w e r t y u i o p [ ] \\\\',\n                \"{lock} a s d f g h j k l ; ' {enter}\",\n                '{shift} z x c v b n m , . / {shift}',\n                '{space}',\n            ],\n            [SystelabVirtualKeyboardLayouts.shift]: [\n                '~ ! @ # $ % ^ &amp; * ( ) _ + {bksp}',\n                '{tab} Q W E R T Y U I O P { } |',\n                '{lock} A S D F G H J K L : \" {enter}',\n                '{shift} Z X C V B N M &lt; &gt; ? {shift}',\n                '{space}',\n            ],\n            [SystelabVirtualKeyboardLayouts.numeric]: ['7 8 9', '4 5 6', '1 2 3', '0 {bksp}'],\n        };\n\n        const keyboardOptions: KeyboardOptions = this.prepareKeyboardConfig();\n        this.keyboard = new SimpleKeyboard('.simple-keyboard', keyboardOptions);\n        this.setLayout(this.selectedLayout);\n        if (this.debug) {\n            console.log('Layout: ', layout);\n        }\n    }\n\n    public setActiveInput(input: HTMLInputElement | HTMLTextAreaElement): void {\n        this.activeInputElement = input;\n\n        if (this.debug) {\n            const inputType = this.activeInputElement?.type;\n            console.log('Layout:', `${inputType}_${this.selectedLayout}`);\n        }\n\n        const { selectionStart, selectionEnd } = this.activeInputElement;\n        this.setCaretPosition(selectionStart, selectionEnd);\n\n        if (this.debug) {\n            console.log('Caret start at:', this.caretPosition, this.caretPositionEnd);\n        }\n        this.focusActiveInput();\n    }\n\n    public setLayout(layout: SystelabVirtualKeyboardLayouts): void {\n        this.selectedLayout = layout;\n        if (this.keyboard) {\n            this.keyboard.setOptions({\n                layoutName: layout,\n            });\n        }\n    }\n\n    private prepareKeyboardConfig(): KeyboardOptions {\n        const layout = {\n            [SystelabVirtualKeyboardLayouts.default]: [\n                '` 1 2 3 4 5 6 7 8 9 0 - = {bksp}',\n                '{tab} q w e r t y u i o p [ ] \\\\',\n                \"{lock} a s d f g h j k l ; ' {enter}\",\n                '{shift} z x c v b n m , . / {shift}',\n                '{space}',\n            ],\n            [SystelabVirtualKeyboardLayouts.shift]: [\n                '~ ! @ # $ % ^ &amp; * ( ) _ + {bksp}',\n                '{tab} Q W E R T Y U I O P { } |',\n                '{lock} A S D F G H J K L : \" {enter}',\n                '{shift} Z X C V B N M &lt; &gt; ? {shift}',\n                '{space}',\n            ],\n            [SystelabVirtualKeyboardLayouts.numeric]: ['7 8 9', '4 5 6', '1 2 3', '0 {bksp}'],\n        };\n\n        let keyboardOptions: KeyboardOptions = {\n            onKeyPress: (button) => this.handleKeyPress(button),\n            mergeDisplay: true,\n            theme: 'hg-theme-default hg-layout-default myTheme',\n            display: {\n                [SystelabVirtualKeyboardButton.Backspace]: 'delete',\n            },\n            buttonTheme: [\n                {\n                    class: 'virtual-keyboard-delete-button',\n                    buttons: `${SystelabVirtualKeyboardButton.Backspace}`,\n                },\n            ],\n            layout,\n        };\n\n        if (this.virtualKeyboardConfig?.hasOwnProperty('inputMethod')) {\n            if (this.virtualKeyboardConfig.inputMethod === SystelabVirtualKeyboardInputMethods.onlyMouseEvents) {\n                keyboardOptions = {\n                    ...keyboardOptions,\n                    useMouseEvents: true,\n                }\n            } else if (this.virtualKeyboardConfig.inputMethod === SystelabVirtualKeyboardInputMethods.onlyTouchEvents) {\n                keyboardOptions = {\n                    ...keyboardOptions,\n                    useTouchEvents: true,\n                }\n            }\n        }\n\n        return keyboardOptions;\n    }\n\n    private handleKeyPress(button: string, e?: Event): void {\n        if (this.debug) {\n            console.log('Key press:', button);\n        }\n\n        if (button[0] === '&' && button.length > 1) {\n            button = new DOMParser().parseFromString(button, 'text/html').body.textContent;\n        }\n\n        if (button === SystelabVirtualKeyboardButton.Shift || button === SystelabVirtualKeyboardButton.Lock) {\n            this.shiftPressed = button === SystelabVirtualKeyboardButton.Shift;\n            this.toggleShiftLayout();\n        } else if (button === SystelabVirtualKeyboardButton.Done) {\n            this.closePanel.emit();\n            return;\n        }\n\n        if (!this.isAcceptedNonStandardButton(button) && !this.isStandardButton(button)) {\n            return;\n        }\n\n        const output = this.handleButtonOutput(button);\n\n        if (this.activeInputElement) {\n            this.activeInputElement.value = output;\n\n            if (this.debug) {\n                console.log('Caret at:', this.caretPosition, this.caretPositionEnd, 'Button', e);\n            }\n        }\n\n        this.dispatchEvents(button);\n\n        if (this.shiftPressed) {\n            this.toggleShiftLayout();\n        }\n        this.shiftPressed = button === SystelabVirtualKeyboardButton.Shift;\n    }\n\n    private handleButtonOutput(button: string): string {\n        const commonParams: [number, number, boolean] = this.getCommonParams();\n        let output = this.activeInputElement?.value || '';\n        if (!this.isStandardButton(button)) {\n            if (button === SystelabVirtualKeyboardButton.Backspace) {\n                output = this.removeAt(output, ...commonParams);\n            } else if (button === SystelabVirtualKeyboardButton.Space) {\n                output = this.addStringAt(output, ' ', ...commonParams);\n            } else if (button === SystelabVirtualKeyboardButton.Tab) {\n                // Do nothing for tab\n            } else if (button === SystelabVirtualKeyboardButton.Enter) {\n                if (this.isTextarea) {\n                    output = this.addStringAt(output, '\\n', ...commonParams);\n                }\n            } else {\n                return;\n            }\n        } else {\n            output = this.addStringAt(output, button, ...commonParams);\n        }\n\n        return output;\n    }\n\n    private getCommonParams(): [number, number, boolean] {\n        return [this.caretPosition || 0, this.caretPositionEnd || 0, true];\n    }\n\n    private isAcceptedNonStandardButton(button: string): boolean {\n        return [\n            SystelabVirtualKeyboardButton.Backspace.toString(),\n            SystelabVirtualKeyboardButton.Space.toString(),\n            SystelabVirtualKeyboardButton.Tab.toString(),\n            SystelabVirtualKeyboardButton.Enter.toString(),\n        ].includes(button);\n    }\n\n    private dispatchEvents(button: string) {\n        const {key, code} = this.convertFromButtonToCode(button);\n\n        const eventInit: KeyboardEventInit = {\n            bubbles: true,\n            cancelable: true,\n            shiftKey: this.selectedLayout === SystelabVirtualKeyboardLayouts.shift,\n            key: key,\n            code: code,\n            location: 0,\n        };\n        // Simulate all needed events on base element\n        this.activeInputElement?.dispatchEvent(new KeyboardEvent('keydown', eventInit));\n        this.activeInputElement?.dispatchEvent(new KeyboardEvent('keypress', eventInit));\n        this.activeInputElement?.dispatchEvent(new Event('input', {bubbles: true}));\n        this.activeInputElement?.dispatchEvent(new KeyboardEvent('keyup', eventInit));\n    }\n\n    /*\n     * AUXILIARY METHODS\n     * */\n    private convertFromButtonToCode(button: string): { key: string; code: string } {\n        let key: string;\n        let code: string;\n        if (button.includes('{') && button.includes('}')) {\n            // Capitalize name\n            key = button.slice(1, button.length - 1).toLowerCase();\n            key = key.charAt(0).toUpperCase() + key.slice(1);\n            code = key;\n\n            // Fix to standard key code\n            if (code.toLowerCase() === SystelabVirtualKeyboardButton.Backspace.slice(1, SystelabVirtualKeyboardButton.Backspace.length - 1).toLowerCase()) {\n                code = 'Backspace';\n            }\n        } else {\n            key = button;\n            code = Number.isInteger(Number(button)) ? `Digit${button}` : `Key${button.toUpperCase()}`;\n        }\n\n        return {key, code};\n    }\n\n    private toggleShiftLayout(): void {\n        const currentLayout = this.keyboard.options.layoutName;\n        const selectedLayout: SystelabVirtualKeyboardLayouts =\n            currentLayout === SystelabVirtualKeyboardLayouts.default ? SystelabVirtualKeyboardLayouts.shift : SystelabVirtualKeyboardLayouts.default;\n\n        this.setLayout(selectedLayout);\n    }\n\n    private isStandardButton(button: string) {\n        return button && !(button[0] === '{' && button[button.length - 1] === '}');\n    }\n\n    /*\n     * OUTPUT STRING METHODS\n     * */\n    private removeAt(source: string, position = source.length, positionEnd = source.length, moveCaret = false): string {\n        if (position === 0 && positionEnd === 0) {\n            return source;\n        }\n\n        let output: string;\n\n        if (position === positionEnd) {\n            if (position && position >= 0) {\n                output = source.slice(0, position - 1) + source.slice(position);\n                if (moveCaret) {\n                    this.updateCaretPosition(1, true);\n                }\n            } else {\n                output = source.slice(0, -1);\n                if (moveCaret) {\n                    this.updateCaretPosition(1, true);\n                }\n            }\n        } else {\n            output = source.slice(0, position) + source.slice(positionEnd);\n            if (moveCaret) {\n                this.setCaretPosition(position);\n            }\n        }\n\n        return output;\n    }\n\n    private addStringAt(source: string, str: string, position = source.length, positionEnd = source.length, moveCaret = false): string {\n        if (this.maxLength !== -1 && source.length >= this.maxLength) {\n            return source;\n        }\n\n        let output: string;\n\n        if (!position && position !== 0) {\n            output = source + str;\n        } else {\n            output = [source.slice(0, position), str, source.slice(positionEnd)].join('');\n            if (moveCaret) {\n                this.updateCaretPosition(str.length, false);\n            }\n        }\n\n        return output;\n    }\n\n    /*\n       * CARET METHODS\n       * */\n    private caretEventHandler(event: any) {\n        let targetTagName = '';\n        if (event.target.tagName) {\n            targetTagName = event.target.tagName.toLowerCase();\n        }\n\n        const isTextInput =\n            targetTagName === 'textarea' ||\n            (targetTagName === 'input' && ['text', 'search', 'email', 'password', 'url', 'tel'].includes(event.target.type));\n\n        const isKeyboard =\n            event.target === this.elementRef.nativeElement || (event.target && this.elementRef.nativeElement.contains(event.target));\n\n        if (isTextInput && this.activeInputElement == event.target) {\n            /**\n             * Tracks current cursor position\n             * As keys are pressed, text will be added/removed at that position within the input.\n             */\n            this.setCaretPosition(event.target.selectionStart, event.target.selectionEnd);\n\n            if (this.debug) {\n                console.log('Caret at:', this.caretPosition, this.caretPositionEnd, event && event.target.tagName.toLowerCase(), event);\n            }\n        } else if (event.type === 'pointerup' && this.activeInputElement === document.activeElement) {\n            return;\n        } else if (!isKeyboard && event?.type !== 'selectionchange') {\n            /**\n             * we must ensure caretPosition doesn't persist once reactivated.\n             */\n            this.setCaretPosition(null);\n\n            if (this.debug) {\n                console.log(`Caret position reset due to \"${event?.type}\" event`, event);\n            }\n        }\n    }\n\n    private focusActiveInput(): void {\n        this.activeInputElement?.focus();\n        this.activeInputElement?.setSelectionRange(\n            this.caretPosition,\n            this.caretPositionEnd\n        );\n    }\n\n    private updateCaretPosition(length: number, minus = false) {\n        const newCaretPos = this.computeNewCaretPosition(length, minus);\n        this.setCaretPosition(newCaretPos);\n        // Scroll to bottom\n        setTimeout(() => {\n            this.activeInputElement?.scrollTo({\n                top: this.activeInputElement.scrollHeight,\n            } as ScrollToOptions);\n        });\n    }\n\n    private computeNewCaretPosition(length: number, minus = false) {\n        let caretPosition = this.caretPosition;\n\n        if (caretPosition != null) {\n            if (minus) {\n                if (caretPosition > 0) caretPosition = caretPosition - length;\n            } else {\n                caretPosition = caretPosition + length;\n            }\n        }\n        return caretPosition;\n    }\n\n    private setCaretPosition(position: number | null, endPosition = position): void {\n        this.caretPosition = position;\n        this.caretPositionEnd = endPosition;\n    }\n}\n","<!--\n  ~ Copyright (c) 2020 - 2024 - Instrumentation Laboratory Company and Systelab Technologies, SA. All rights reserved.\n  ~ NOTICE:  All information contained herein is and remains the property of Instrumentation Laboratory Company and its\n  ~ affiliates, if any.  The intellectual and technical concepts contained herein are proprietary to Instrumentation\n  ~ Laboratory Company and its affiliates and may be covered by U.S. and foreign patents and patent applications, and/or\n  ~ are protected by trade secret or copyright law. Dissemination of this information or reproduction of this material is\n  ~ strictly forbidden unless prior written permission is Instrumentation Laboratory Company.\n  -->\n\n<div class=\"simple-keyboard\"></div>\n"]}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
import { InjectionToken } from '@angular/core';
|
|
2
2
|
export const VIRTUAL_KEYBOARD_CONFIG = new InjectionToken('VIRTUAL_KEYBOARD_CONFIG');
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3lzdGVsYWItdmlydHVhbC1rZXlib2FyZC5jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9zeXN0ZWxhYi12aXJ0dWFsLWtleWJvYXJkL3NyYy9saWIvc3lzdGVsYWItdmlydHVhbC1rZXlib2FyZC5jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUcvQyxNQUFNLENBQUMsTUFBTSx1QkFBdUIsR0FBRyxJQUFJLGNBQWMsQ0FBZ0MseUJBQXlCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGlvblRva2VuIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTeXN0ZWxhYlZpcnR1YWxLZXlib2FyZElucHV0TWV0aG9kcywgU3lzdGVsYWJWaXJ0dWFsS2V5Ym9hcmRMYXlvdXRzIH0gZnJvbSAnLi9jb25zdGFudHMnO1xuXG5leHBvcnQgY29uc3QgVklSVFVBTF9LRVlCT0FSRF9DT05GSUcgPSBuZXcgSW5qZWN0aW9uVG9rZW48U3lzdGVsYWJWaXJ0dWFsS2V5Ym9hcmRDb25maWc+KCdWSVJUVUFMX0tFWUJPQVJEX0NPTkZJRycpO1xuXG5leHBvcnQgaW50ZXJmYWNlIFN5c3RlbGFiVmlydHVhbEtleWJvYXJkQ29uZmlnIHtcbiAgICBsYXlvdXQ/OiBTeXN0ZWxhYlZpcnR1YWxLZXlib2FyZExheW91dHM7XG4gICAgaW5wdXRNZXRob2Q/
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3lzdGVsYWItdmlydHVhbC1rZXlib2FyZC5jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9zeXN0ZWxhYi12aXJ0dWFsLWtleWJvYXJkL3NyYy9saWIvc3lzdGVsYWItdmlydHVhbC1rZXlib2FyZC5jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUcvQyxNQUFNLENBQUMsTUFBTSx1QkFBdUIsR0FBRyxJQUFJLGNBQWMsQ0FBZ0MseUJBQXlCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGlvblRva2VuIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTeXN0ZWxhYlZpcnR1YWxLZXlib2FyZElucHV0TWV0aG9kcywgU3lzdGVsYWJWaXJ0dWFsS2V5Ym9hcmRMYXlvdXRzIH0gZnJvbSAnLi9jb25zdGFudHMnO1xuXG5leHBvcnQgY29uc3QgVklSVFVBTF9LRVlCT0FSRF9DT05GSUcgPSBuZXcgSW5qZWN0aW9uVG9rZW48U3lzdGVsYWJWaXJ0dWFsS2V5Ym9hcmRDb25maWc+KCdWSVJUVUFMX0tFWUJPQVJEX0NPTkZJRycpO1xuXG5leHBvcnQgaW50ZXJmYWNlIFN5c3RlbGFiVmlydHVhbEtleWJvYXJkQ29uZmlnIHtcbiAgICBsYXlvdXQ/OiBTeXN0ZWxhYlZpcnR1YWxLZXlib2FyZExheW91dHM7XG4gICAgaW5wdXRNZXRob2Q/OiBTeXN0ZWxhYlZpcnR1YWxLZXlib2FyZElucHV0TWV0aG9kcztcbiAgICBzaG93SWNvbj86IGJvb2xlYW47XG4gICAgc2hvd09uTW91c2VDbGljaz86IGJvb2xlYW47XG59XG4iXX0=
|