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
|
@@ -8,25 +8,32 @@
|
|
|
8
8
|
*/
|
|
9
9
|
import { Directive, HostListener, Inject, Input, Optional, } from '@angular/core';
|
|
10
10
|
import { DOCUMENT } from '@angular/common';
|
|
11
|
-
import {
|
|
11
|
+
import { SystelabVirtualKeyboardInputModes, SystelabVirtualKeyboardLayouts } from './constants';
|
|
12
12
|
import { VIRTUAL_KEYBOARD_CONFIG } from './systelab-virtual-keyboard.config';
|
|
13
13
|
import * as i0 from "@angular/core";
|
|
14
14
|
import * as i1 from "./systelab-virtual-keyboard-overlay.service";
|
|
15
15
|
export class SystelabVirtualKeyboardDirective {
|
|
16
16
|
onDocumentScroll() {
|
|
17
|
-
if (this.
|
|
18
|
-
|
|
17
|
+
if (!this.vkEnabled) {
|
|
18
|
+
return;
|
|
19
19
|
}
|
|
20
|
+
this.overlayService.updatePosition();
|
|
20
21
|
}
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
this.closePanel();
|
|
22
|
+
onClick() {
|
|
23
|
+
if (!this.vkEnabled || !this.config.showOnMouseClick) {
|
|
24
|
+
return;
|
|
25
25
|
}
|
|
26
|
-
this.
|
|
27
|
-
|
|
28
|
-
|
|
26
|
+
this.closePanel();
|
|
27
|
+
this.overlayService.setClickAlreadyHandled();
|
|
28
|
+
this.openPanel();
|
|
29
|
+
}
|
|
30
|
+
onTouchEnd() {
|
|
31
|
+
if (!this.vkEnabled) {
|
|
32
|
+
return;
|
|
29
33
|
}
|
|
34
|
+
this.closePanel();
|
|
35
|
+
this.overlayService.setTouchEndAlreadyHandled();
|
|
36
|
+
this.openPanel();
|
|
30
37
|
}
|
|
31
38
|
set vkEnabled(enabled) {
|
|
32
39
|
if (typeof enabled === 'string') {
|
|
@@ -86,11 +93,16 @@ export class SystelabVirtualKeyboardDirective {
|
|
|
86
93
|
}
|
|
87
94
|
}
|
|
88
95
|
ngOnDestroy() {
|
|
89
|
-
if (this.
|
|
90
|
-
this.
|
|
96
|
+
if (this.vkEnabled && this.config?.showIcon) {
|
|
97
|
+
const keyboardIcon = this.elementRef.nativeElement.parentElement.querySelector('i');
|
|
98
|
+
keyboardIcon.removeEventListener('click', this.togglePanel.bind(this));
|
|
91
99
|
}
|
|
100
|
+
this.overlayService.destroy();
|
|
92
101
|
}
|
|
93
102
|
togglePanel() {
|
|
103
|
+
if (!this.vkEnabled) {
|
|
104
|
+
return;
|
|
105
|
+
}
|
|
94
106
|
if (this.overlayService.isOpen()) {
|
|
95
107
|
this.closePanel();
|
|
96
108
|
}
|
|
@@ -99,6 +111,9 @@ export class SystelabVirtualKeyboardDirective {
|
|
|
99
111
|
}
|
|
100
112
|
}
|
|
101
113
|
openPanel() {
|
|
114
|
+
if (!this.vkEnabled) {
|
|
115
|
+
return;
|
|
116
|
+
}
|
|
102
117
|
if (this.overlayService.isCreated()) {
|
|
103
118
|
this.overlayService.destroy();
|
|
104
119
|
}
|
|
@@ -127,12 +142,15 @@ export class SystelabVirtualKeyboardDirective {
|
|
|
127
142
|
}
|
|
128
143
|
}
|
|
129
144
|
isInputAlphabetic(activeInputElement) {
|
|
130
|
-
const
|
|
131
|
-
return
|
|
145
|
+
const inputMode = this.getInputMode(activeInputElement);
|
|
146
|
+
return inputMode && [SystelabVirtualKeyboardInputModes.text, SystelabVirtualKeyboardInputModes.password].some((i) => i === inputMode);
|
|
132
147
|
}
|
|
133
148
|
isInputNumeric(activeInputElement) {
|
|
134
|
-
const
|
|
135
|
-
return
|
|
149
|
+
const inputMode = this.getInputMode(activeInputElement);
|
|
150
|
+
return inputMode && [SystelabVirtualKeyboardInputModes.numeric].some((i) => i === inputMode);
|
|
151
|
+
}
|
|
152
|
+
getInputMode(activeInputElement) {
|
|
153
|
+
return activeInputElement?.inputMode ?? activeInputElement?.type;
|
|
136
154
|
}
|
|
137
155
|
closePanel() {
|
|
138
156
|
this.overlayService.destroy();
|
|
@@ -151,7 +169,7 @@ export class SystelabVirtualKeyboardDirective {
|
|
|
151
169
|
}
|
|
152
170
|
}
|
|
153
171
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.9", ngImport: i0, type: SystelabVirtualKeyboardDirective, deps: [{ token: i0.ElementRef }, { token: i1.SystelabVirtualKeyboardOverlayService }, { token: i0.Renderer2 }, { token: DOCUMENT }, { token: VIRTUAL_KEYBOARD_CONFIG, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
154
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.9", type: SystelabVirtualKeyboardDirective, selector: "input[vkEnabled], textarea[vkEnabled]", inputs: { vkEnabled: "vkEnabled", vkFixedBottom: "vkFixedBottom", vkDebug: "vkDebug", vkConfig: "vkConfig" }, host: { listeners: { "window:touchmove": "onDocumentScroll($event)", "window:touchend": "onDocumentScroll($event)", "window:wheel": "onDocumentScroll($event)", "document:scroll": "onDocumentScroll($event)", "
|
|
172
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.9", type: SystelabVirtualKeyboardDirective, selector: "input[vkEnabled], textarea[vkEnabled]", inputs: { vkEnabled: "vkEnabled", vkFixedBottom: "vkFixedBottom", vkDebug: "vkDebug", vkConfig: "vkConfig" }, host: { listeners: { "window:touchmove": "onDocumentScroll($event)", "window:touchend": "onDocumentScroll($event)", "window:wheel": "onDocumentScroll($event)", "document:scroll": "onDocumentScroll($event)", "click": "onClick($event)", "touchend": "onTouchEnd($event)" } }, ngImport: i0 }); }
|
|
155
173
|
}
|
|
156
174
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImport: i0, type: SystelabVirtualKeyboardDirective, decorators: [{
|
|
157
175
|
type: Directive,
|
|
@@ -178,9 +196,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImpor
|
|
|
178
196
|
}, {
|
|
179
197
|
type: HostListener,
|
|
180
198
|
args: ['document:scroll', ['$event']]
|
|
181
|
-
}],
|
|
199
|
+
}], onClick: [{
|
|
200
|
+
type: HostListener,
|
|
201
|
+
args: ['click', ['$event']]
|
|
202
|
+
}], onTouchEnd: [{
|
|
182
203
|
type: HostListener,
|
|
183
|
-
args: ['
|
|
204
|
+
args: ['touchend', ['$event']]
|
|
184
205
|
}], vkEnabled: [{
|
|
185
206
|
type: Input
|
|
186
207
|
}], vkFixedBottom: [{
|
|
@@ -190,4 +211,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImpor
|
|
|
190
211
|
}], vkConfig: [{
|
|
191
212
|
type: Input
|
|
192
213
|
}] } });
|
|
193
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"systelab-virtual-keyboard.directive.js","sourceRoot":"","sources":["../../../../projects/systelab-virtual-keyboard/src/lib/systelab-virtual-keyboard.directive.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 {\n    AfterViewInit,\n    ComponentRef,\n    Directive,\n    ElementRef,\n    HostListener,\n    Inject,\n    Input,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Renderer2,\n} from '@angular/core';\n\nimport { DOCUMENT } from '@angular/common';\n\nimport { SystelabVirtualKeyboardInputTypes, SystelabVirtualKeyboardLayouts } from './constants';\nimport { SystelabVirtualKeyboardComponent } from './systelab-virtual-keyboard.component';\nimport { SystelabVirtualKeyboardOverlayService } from './systelab-virtual-keyboard-overlay.service';\nimport { SystelabVirtualKeyboardConfig, VIRTUAL_KEYBOARD_CONFIG } from './systelab-virtual-keyboard.config';\n\n@Directive({\n    selector: 'input[vkEnabled], textarea[vkEnabled]',\n})\nexport class SystelabVirtualKeyboardDirective implements OnInit, AfterViewInit, OnDestroy {\n    @HostListener('window:touchmove', ['$event'])\n    @HostListener('window:touchend', ['$event'])\n    @HostListener('window:wheel', ['$event'])\n    @HostListener('document:scroll', ['$event'])\n    onDocumentScroll() {\n        if (this.overlayService.isCreated()) {\n            this.overlayService.updatePosition();\n        }\n    }\n\n    @HostListener('focus', ['$event'])\n    onFocus(): void {\n        console.log('Focused');\n        if (this.overlayService.isCreated()) {\n            this.closePanel();\n        }\n        this.overlayService.setFocusDispatched(true);\n        if (!this.overlayService.isOpen()) {\n            this.openPanel();\n        }\n    }\n\n    private enabled = false;\n\n    @Input()\n    set vkEnabled(enabled: boolean | string) {\n        if (typeof enabled === 'string') {\n            this.enabled = true;\n        } else {\n            this.enabled = enabled;\n        }\n    };\n\n    get vkEnabled(): boolean {\n        return this.enabled;\n    }\n\n    private fixedBottom = false;\n\n    @Input()\n    get vkFixedBottom(): boolean {\n        return this.fixedBottom;\n    }\n\n    set vkFixedBottom(fixedBottom: boolean | string) {\n        if (typeof fixedBottom === 'string') {\n            this.fixedBottom = true;\n        } else {\n            this.fixedBottom = fixedBottom;\n        }\n    }\n\n    private debug = false;\n\n    @Input()\n    get vkDebug(): boolean {\n        return this.debug;\n    }\n\n    set vkDebug(debug: boolean) {\n        this.debug = debug;\n    }\n\n    private config: SystelabVirtualKeyboardConfig;\n\n    @Input()\n    get vkConfig(): SystelabVirtualKeyboardConfig {\n        return this.config;\n    }\n\n    set vkConfig(config: SystelabVirtualKeyboardConfig) {\n        this.config = config;\n    }\n\n    private panelRef!: ComponentRef<SystelabVirtualKeyboardComponent>;\n    private showKeyboardButtonElement: HTMLElement;\n\n    constructor(\n        private readonly elementRef: ElementRef<HTMLInputElement>,\n        private readonly overlayService: SystelabVirtualKeyboardOverlayService,\n        private readonly renderer: Renderer2,\n        @Inject(DOCUMENT) private readonly document: any,\n        @Optional() @Inject(VIRTUAL_KEYBOARD_CONFIG) private virtualKeyboardConfig: SystelabVirtualKeyboardConfig,\n    ) {\n        this.config = this.virtualKeyboardConfig;\n    }\n\n    ngOnInit() {\n        if (this.config?.showIcon) {\n            this.attachKeyboardIcon();\n        }\n    }\n\n    ngAfterViewInit() {\n        if (this.vkEnabled && this.config?.showIcon) {\n            const keyboardIcon = this.elementRef.nativeElement.parentElement.querySelector('i');\n            keyboardIcon.addEventListener('click', this.togglePanel.bind(this));\n        }\n    }\n\n    ngOnDestroy(): void {\n        if (this.overlayService.isCreated()) {\n            this.overlayService.destroy();\n        }\n    }\n\n    private togglePanel(): void {\n        if (this.overlayService.isOpen()) {\n            this.closePanel();\n        } else {\n            this.openPanel();\n        }\n    }\n\n    private openPanel(): void {\n        if (this.overlayService.isCreated()) {\n            this.overlayService.destroy();\n        }\n        if (this.overlayService.hasAttached()) {\n            return;\n        }\n\n        const currentLayout = this.getLayout(this.elementRef.nativeElement);\n\n        this.panelRef = this.overlayService.create(this.inputOrigin(), this.showKeyboardButtonElement, this.vkFixedBottom, currentLayout);\n        this.panelRef.instance.debug = this.vkDebug;\n        this.panelRef.instance.setActiveInput(this.elementRef.nativeElement);\n        this.panelRef.instance.setLayout(currentLayout);\n        this.panelRef.instance.closePanel.subscribe(() => this.closePanel());\n    }\n\n    private getLayout(activeInputElement: HTMLInputElement | HTMLTextAreaElement): SystelabVirtualKeyboardLayouts {\n        if (this.config?.hasOwnProperty('layout')) {\n            return this.config.layout;\n        }\n        if (this.isInputAlphabetic(activeInputElement)) {\n            return SystelabVirtualKeyboardLayouts.default;\n        } else if (this.isInputNumeric(activeInputElement)) {\n            return SystelabVirtualKeyboardLayouts.numeric;\n        } else {\n            return SystelabVirtualKeyboardLayouts.default;\n        }\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 closePanel(): void {\n        this.overlayService.destroy();\n    }\n\n    private inputOrigin(): HTMLInputElement {\n        return this.elementRef.nativeElement;\n    }\n\n    private attachKeyboardIcon() {\n        if (this.vkEnabled) {\n            const child = this.document.createElement('i');\n            child.classList.add('fa');\n            child.classList.add('fa-keyboard');\n            child.classList.add('virtual-keyboard-show-button');\n            this.renderer.appendChild(this.elementRef.nativeElement.parentElement, child);\n            this.showKeyboardButtonElement = child;\n        }\n    }\n}\n"]}
|
|
214
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"systelab-virtual-keyboard.directive.js","sourceRoot":"","sources":["../../../../projects/systelab-virtual-keyboard/src/lib/systelab-virtual-keyboard.directive.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 {\n    AfterViewInit,\n    ComponentRef,\n    Directive,\n    ElementRef,\n    HostListener,\n    Inject,\n    Input,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Renderer2,\n} from '@angular/core';\n\nimport { DOCUMENT } from '@angular/common';\n\nimport { SystelabVirtualKeyboardInputModes, SystelabVirtualKeyboardLayouts } from './constants';\nimport { SystelabVirtualKeyboardComponent } from './systelab-virtual-keyboard.component';\nimport { SystelabVirtualKeyboardOverlayService } from './systelab-virtual-keyboard-overlay.service';\nimport { SystelabVirtualKeyboardConfig, VIRTUAL_KEYBOARD_CONFIG } from './systelab-virtual-keyboard.config';\n\n@Directive({\n    selector: 'input[vkEnabled], textarea[vkEnabled]',\n})\nexport class SystelabVirtualKeyboardDirective implements OnInit, AfterViewInit, OnDestroy {\n    @HostListener('window:touchmove', ['$event'])\n    @HostListener('window:touchend', ['$event'])\n    @HostListener('window:wheel', ['$event'])\n    @HostListener('document:scroll', ['$event'])\n    onDocumentScroll() {\n        if (!this.vkEnabled) {\n            return;\n        }\n        this.overlayService.updatePosition();\n    }\n\n    @HostListener('click', ['$event'])\n    onClick(): void {\n        if (!this.vkEnabled || !this.config.showOnMouseClick) {\n            return;\n        }\n\n        this.closePanel();\n        this.overlayService.setClickAlreadyHandled();\n        this.openPanel();\n    }\n\n    @HostListener('touchend', ['$event'])\n    onTouchEnd(): void {\n        if (!this.vkEnabled) {\n            return;\n        }\n\n        this.closePanel();\n        this.overlayService.setTouchEndAlreadyHandled();\n        this.openPanel();\n    }\n\n    private enabled = false;\n\n    @Input()\n    set vkEnabled(enabled: boolean | string) {\n        if (typeof enabled === 'string') {\n            this.enabled = true;\n        } else {\n            this.enabled = enabled;\n        }\n    };\n\n    get vkEnabled(): boolean {\n        return this.enabled;\n    }\n\n    private fixedBottom = false;\n\n    @Input()\n    get vkFixedBottom(): boolean {\n        return this.fixedBottom;\n    }\n\n    set vkFixedBottom(fixedBottom: boolean | string) {\n        if (typeof fixedBottom === 'string') {\n            this.fixedBottom = true;\n        } else {\n            this.fixedBottom = fixedBottom;\n        }\n    }\n\n    private debug = false;\n\n    @Input()\n    get vkDebug(): boolean {\n        return this.debug;\n    }\n\n    set vkDebug(debug: boolean) {\n        this.debug = debug;\n    }\n\n    private config: SystelabVirtualKeyboardConfig;\n\n    @Input()\n    get vkConfig(): SystelabVirtualKeyboardConfig {\n        return this.config;\n    }\n\n    set vkConfig(config: SystelabVirtualKeyboardConfig) {\n        this.config = config;\n    }\n\n    private panelRef!: ComponentRef<SystelabVirtualKeyboardComponent>;\n    private showKeyboardButtonElement: HTMLElement;\n\n    constructor(\n        private readonly elementRef: ElementRef<HTMLInputElement>,\n        private readonly overlayService: SystelabVirtualKeyboardOverlayService,\n        private readonly renderer: Renderer2,\n        @Inject(DOCUMENT) private readonly document: any,\n        @Optional() @Inject(VIRTUAL_KEYBOARD_CONFIG) private virtualKeyboardConfig: SystelabVirtualKeyboardConfig,\n    ) {\n        this.config = this.virtualKeyboardConfig;\n    }\n\n    ngOnInit() {\n        if (this.config?.showIcon) {\n            this.attachKeyboardIcon();\n        }\n    }\n\n    ngAfterViewInit() {\n        if (this.vkEnabled && this.config?.showIcon) {\n            const keyboardIcon = this.elementRef.nativeElement.parentElement.querySelector('i');\n            keyboardIcon.addEventListener('click', this.togglePanel.bind(this));\n        }\n    }\n\n    ngOnDestroy(): void {\n        if (this.vkEnabled && this.config?.showIcon) {\n            const keyboardIcon = this.elementRef.nativeElement.parentElement.querySelector('i');\n            keyboardIcon.removeEventListener('click', this.togglePanel.bind(this));\n        }\n        this.overlayService.destroy();\n    }\n\n    private togglePanel(): void {\n        if (!this.vkEnabled) {\n            return;\n        }\n        if (this.overlayService.isOpen()) {\n            this.closePanel();\n        } else {\n            this.openPanel();\n        }\n    }\n\n    private openPanel(): void {\n        if (!this.vkEnabled) {\n            return;\n        }\n        if (this.overlayService.isCreated()) {\n            this.overlayService.destroy();\n        }\n        if (this.overlayService.hasAttached()) {\n            return;\n        }\n\n        const currentLayout = this.getLayout(this.elementRef.nativeElement);\n\n        this.panelRef = this.overlayService.create(this.inputOrigin(), this.showKeyboardButtonElement, this.vkFixedBottom, currentLayout);\n        this.panelRef.instance.debug = this.vkDebug;\n        this.panelRef.instance.setActiveInput(this.elementRef.nativeElement);\n        this.panelRef.instance.setLayout(currentLayout);\n        this.panelRef.instance.closePanel.subscribe(() => this.closePanel());\n    }\n\n    private getLayout(activeInputElement: HTMLInputElement | HTMLTextAreaElement): SystelabVirtualKeyboardLayouts {\n        if (this.config?.hasOwnProperty('layout')) {\n            return this.config.layout;\n        }\n        if (this.isInputAlphabetic(activeInputElement)) {\n            return SystelabVirtualKeyboardLayouts.default;\n        } else if (this.isInputNumeric(activeInputElement)) {\n            return SystelabVirtualKeyboardLayouts.numeric;\n        } else {\n            return SystelabVirtualKeyboardLayouts.default;\n        }\n    }\n\n    private isInputAlphabetic(activeInputElement: HTMLInputElement | HTMLTextAreaElement): boolean {\n        const inputMode = this.getInputMode(activeInputElement);\n        return inputMode &&  [SystelabVirtualKeyboardInputModes.text, SystelabVirtualKeyboardInputModes.password].some((i) => i === inputMode);\n    }\n\n    private isInputNumeric(activeInputElement: HTMLInputElement | HTMLTextAreaElement): boolean {\n        const inputMode = this.getInputMode(activeInputElement);\n        return inputMode && [SystelabVirtualKeyboardInputModes.numeric].some((i) => i === inputMode);\n    }\n\n    private getInputMode(activeInputElement: HTMLInputElement | HTMLTextAreaElement): string {\n        return activeInputElement?.inputMode ?? activeInputElement?.type;\n    }\n\n    private closePanel(): void {\n        this.overlayService.destroy();\n    }\n\n    private inputOrigin(): HTMLInputElement {\n        return this.elementRef.nativeElement;\n    }\n\n    private attachKeyboardIcon() {\n        if (this.vkEnabled) {\n            const child = this.document.createElement('i');\n            child.classList.add('fa');\n            child.classList.add('fa-keyboard');\n            child.classList.add('virtual-keyboard-show-button');\n            this.renderer.appendChild(this.elementRef.nativeElement.parentElement, child);\n            this.showKeyboardButtonElement = child;\n        }\n    }\n}\n"]}
|
|
@@ -36,12 +36,12 @@ var SystelabVirtualKeyboardInputMethods;
|
|
|
36
36
|
SystelabVirtualKeyboardInputMethods["onlyMouseEvents"] = "onlyMouseEvents";
|
|
37
37
|
SystelabVirtualKeyboardInputMethods["onlyTouchEvents"] = "onlyTouchEvents";
|
|
38
38
|
})(SystelabVirtualKeyboardInputMethods || (SystelabVirtualKeyboardInputMethods = {}));
|
|
39
|
-
var
|
|
40
|
-
(function (
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
})(
|
|
39
|
+
var SystelabVirtualKeyboardInputModes;
|
|
40
|
+
(function (SystelabVirtualKeyboardInputModes) {
|
|
41
|
+
SystelabVirtualKeyboardInputModes["text"] = "text";
|
|
42
|
+
SystelabVirtualKeyboardInputModes["numeric"] = "numeric";
|
|
43
|
+
SystelabVirtualKeyboardInputModes["password"] = "password";
|
|
44
|
+
})(SystelabVirtualKeyboardInputModes || (SystelabVirtualKeyboardInputModes = {}));
|
|
45
45
|
|
|
46
46
|
const VIRTUAL_KEYBOARD_CONFIG = new InjectionToken('VIRTUAL_KEYBOARD_CONFIG');
|
|
47
47
|
|
|
@@ -107,20 +107,12 @@ class SystelabVirtualKeyboardComponent {
|
|
|
107
107
|
const inputType = this.activeInputElement?.type;
|
|
108
108
|
console.log('Layout:', `${inputType}_${this.selectedLayout}`);
|
|
109
109
|
}
|
|
110
|
-
|
|
111
|
-
let selectionEnd;
|
|
112
|
-
if (this.isInputNumeric(input)) {
|
|
113
|
-
selectionStart = this.activeInputElement.value.toString().length;
|
|
114
|
-
selectionEnd = this.activeInputElement.value.toString().length;
|
|
115
|
-
}
|
|
116
|
-
else {
|
|
117
|
-
selectionStart = this.activeInputElement.selectionStart;
|
|
118
|
-
selectionEnd = this.activeInputElement.selectionEnd;
|
|
119
|
-
}
|
|
110
|
+
const { selectionStart, selectionEnd } = this.activeInputElement;
|
|
120
111
|
this.setCaretPosition(selectionStart, selectionEnd);
|
|
121
112
|
if (this.debug) {
|
|
122
113
|
console.log('Caret start at:', this.caretPosition, this.caretPositionEnd);
|
|
123
114
|
}
|
|
115
|
+
this.focusActiveInput();
|
|
124
116
|
}
|
|
125
117
|
setLayout(layout) {
|
|
126
118
|
this.selectedLayout = layout;
|
|
@@ -179,14 +171,6 @@ class SystelabVirtualKeyboardComponent {
|
|
|
179
171
|
}
|
|
180
172
|
return keyboardOptions;
|
|
181
173
|
}
|
|
182
|
-
isInputAlphabetic(activeInputElement) {
|
|
183
|
-
const inputType = activeInputElement?.type;
|
|
184
|
-
return inputType && [SystelabVirtualKeyboardInputTypes.text, SystelabVirtualKeyboardInputTypes.password].some((i) => i === inputType);
|
|
185
|
-
}
|
|
186
|
-
isInputNumeric(activeInputElement) {
|
|
187
|
-
const inputType = activeInputElement?.type;
|
|
188
|
-
return inputType && [SystelabVirtualKeyboardInputTypes.number].some((i) => i === inputType);
|
|
189
|
-
}
|
|
190
174
|
handleKeyPress(button, e) {
|
|
191
175
|
if (this.debug) {
|
|
192
176
|
console.log('Key press:', button);
|
|
@@ -229,7 +213,7 @@ class SystelabVirtualKeyboardComponent {
|
|
|
229
213
|
output = this.addStringAt(output, ' ', ...commonParams);
|
|
230
214
|
}
|
|
231
215
|
else if (button === SystelabVirtualKeyboardButton.Tab) {
|
|
232
|
-
|
|
216
|
+
// Do nothing for tab
|
|
233
217
|
}
|
|
234
218
|
else if (button === SystelabVirtualKeyboardButton.Enter) {
|
|
235
219
|
if (this.isTextarea) {
|
|
@@ -382,6 +366,10 @@ class SystelabVirtualKeyboardComponent {
|
|
|
382
366
|
}
|
|
383
367
|
}
|
|
384
368
|
}
|
|
369
|
+
focusActiveInput() {
|
|
370
|
+
this.activeInputElement?.focus();
|
|
371
|
+
this.activeInputElement?.setSelectionRange(this.caretPosition, this.caretPositionEnd);
|
|
372
|
+
}
|
|
385
373
|
updateCaretPosition(length, minus = false) {
|
|
386
374
|
const newCaretPos = this.computeNewCaretPosition(length, minus);
|
|
387
375
|
this.setCaretPosition(newCaretPos);
|
|
@@ -410,7 +398,7 @@ class SystelabVirtualKeyboardComponent {
|
|
|
410
398
|
this.caretPositionEnd = endPosition;
|
|
411
399
|
}
|
|
412
400
|
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 }); }
|
|
413
|
-
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"] }); }
|
|
401
|
+
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"] }); }
|
|
414
402
|
}
|
|
415
403
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImport: i0, type: SystelabVirtualKeyboardComponent, decorators: [{
|
|
416
404
|
type: Component,
|
|
@@ -426,6 +414,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImpor
|
|
|
426
414
|
}], handleMouseUp: [{
|
|
427
415
|
type: HostListener,
|
|
428
416
|
args: ['window:pointerup', ['$event']]
|
|
417
|
+
}, {
|
|
418
|
+
type: HostListener,
|
|
419
|
+
args: ['window:mouseup', ['$event']]
|
|
429
420
|
}], handleSelect: [{
|
|
430
421
|
type: HostListener,
|
|
431
422
|
args: ['window:select', ['$event']]
|
|
@@ -439,7 +430,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImpor
|
|
|
439
430
|
class SystelabVirtualKeyboardOverlayService {
|
|
440
431
|
constructor(overlay) {
|
|
441
432
|
this.overlay = overlay;
|
|
442
|
-
this.
|
|
433
|
+
this.clickAlreadyHandled = false;
|
|
434
|
+
this.touchEndAlreadyHandled = false;
|
|
443
435
|
this.initListener();
|
|
444
436
|
}
|
|
445
437
|
isCreated() {
|
|
@@ -470,8 +462,11 @@ class SystelabVirtualKeyboardOverlayService {
|
|
|
470
462
|
updatePosition() {
|
|
471
463
|
this.updatePositionStrategy(this.inputOrigin, this.fixedBottom);
|
|
472
464
|
}
|
|
473
|
-
|
|
474
|
-
this.
|
|
465
|
+
setClickAlreadyHandled() {
|
|
466
|
+
this.clickAlreadyHandled = true;
|
|
467
|
+
}
|
|
468
|
+
setTouchEndAlreadyHandled() {
|
|
469
|
+
this.touchEndAlreadyHandled = true;
|
|
475
470
|
}
|
|
476
471
|
destroy() {
|
|
477
472
|
if (this.overlayRef) {
|
|
@@ -482,25 +477,33 @@ class SystelabVirtualKeyboardOverlayService {
|
|
|
482
477
|
}
|
|
483
478
|
initListener() {
|
|
484
479
|
document.addEventListener('click', this.handleClick.bind(this));
|
|
480
|
+
document.addEventListener('touchend', this.handleTouchEnd.bind(this));
|
|
485
481
|
}
|
|
486
482
|
handleClick(event) {
|
|
487
|
-
if (this.
|
|
488
|
-
this.
|
|
483
|
+
if (this.clickAlreadyHandled) {
|
|
484
|
+
this.clickAlreadyHandled = false;
|
|
489
485
|
return;
|
|
490
486
|
}
|
|
491
|
-
console.log('Document clicked:', event);
|
|
492
487
|
event.stopPropagation();
|
|
493
|
-
|
|
494
|
-
|
|
495
|
-
|
|
496
|
-
|
|
497
|
-
|
|
498
|
-
|
|
499
|
-
|
|
500
|
-
|
|
501
|
-
|
|
488
|
+
this.handleEventTarget(event.target);
|
|
489
|
+
}
|
|
490
|
+
handleTouchEnd(event) {
|
|
491
|
+
if (this.touchEndAlreadyHandled) {
|
|
492
|
+
this.touchEndAlreadyHandled = false;
|
|
493
|
+
return;
|
|
494
|
+
}
|
|
495
|
+
event.stopPropagation();
|
|
496
|
+
this.handleEventTarget(event.target);
|
|
497
|
+
}
|
|
498
|
+
handleEventTarget(target) {
|
|
499
|
+
const showKeyboardButtonTarget = target?.classList.contains('virtual-keyboard-show-button');
|
|
500
|
+
const virtualKeyboardTarget = document.querySelector('.simple-keyboard')?.contains(target);
|
|
501
|
+
const inputElementTarget = this.inputOrigin?.contains(target);
|
|
502
|
+
const containsShowButton = this.showKeyboardButtonElement?.contains(target);
|
|
503
|
+
if (!virtualKeyboardTarget &&
|
|
504
|
+
!inputElementTarget &&
|
|
502
505
|
!containsShowButton &&
|
|
503
|
-
!
|
|
506
|
+
!showKeyboardButtonTarget) {
|
|
504
507
|
if (this.isCreated()) {
|
|
505
508
|
this.destroy();
|
|
506
509
|
}
|
|
@@ -510,10 +513,14 @@ class SystelabVirtualKeyboardOverlayService {
|
|
|
510
513
|
return this.overlayRef?.hasAttached();
|
|
511
514
|
}
|
|
512
515
|
updatePositionStrategy(inputOrigin, fixedBottom) {
|
|
513
|
-
this.overlayRef
|
|
516
|
+
if (!!this.overlayRef) {
|
|
517
|
+
this.overlayRef.updatePositionStrategy(this.getPositionStrategy(inputOrigin, fixedBottom));
|
|
518
|
+
}
|
|
514
519
|
}
|
|
515
520
|
updateSize() {
|
|
516
|
-
this.overlayRef
|
|
521
|
+
if (!!this.overlayRef) {
|
|
522
|
+
this.overlayRef.updateSize(this.getOverlaySize());
|
|
523
|
+
}
|
|
517
524
|
}
|
|
518
525
|
getPositionStrategy(inputOrigin, fixedBottom) {
|
|
519
526
|
if (fixedBottom) {
|
|
@@ -600,19 +607,26 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImpor
|
|
|
600
607
|
*/
|
|
601
608
|
class SystelabVirtualKeyboardDirective {
|
|
602
609
|
onDocumentScroll() {
|
|
603
|
-
if (this.
|
|
604
|
-
|
|
610
|
+
if (!this.vkEnabled) {
|
|
611
|
+
return;
|
|
605
612
|
}
|
|
613
|
+
this.overlayService.updatePosition();
|
|
606
614
|
}
|
|
607
|
-
|
|
608
|
-
|
|
609
|
-
|
|
610
|
-
this.closePanel();
|
|
615
|
+
onClick() {
|
|
616
|
+
if (!this.vkEnabled || !this.config.showOnMouseClick) {
|
|
617
|
+
return;
|
|
611
618
|
}
|
|
612
|
-
this.
|
|
613
|
-
|
|
614
|
-
|
|
619
|
+
this.closePanel();
|
|
620
|
+
this.overlayService.setClickAlreadyHandled();
|
|
621
|
+
this.openPanel();
|
|
622
|
+
}
|
|
623
|
+
onTouchEnd() {
|
|
624
|
+
if (!this.vkEnabled) {
|
|
625
|
+
return;
|
|
615
626
|
}
|
|
627
|
+
this.closePanel();
|
|
628
|
+
this.overlayService.setTouchEndAlreadyHandled();
|
|
629
|
+
this.openPanel();
|
|
616
630
|
}
|
|
617
631
|
set vkEnabled(enabled) {
|
|
618
632
|
if (typeof enabled === 'string') {
|
|
@@ -672,11 +686,16 @@ class SystelabVirtualKeyboardDirective {
|
|
|
672
686
|
}
|
|
673
687
|
}
|
|
674
688
|
ngOnDestroy() {
|
|
675
|
-
if (this.
|
|
676
|
-
this.
|
|
689
|
+
if (this.vkEnabled && this.config?.showIcon) {
|
|
690
|
+
const keyboardIcon = this.elementRef.nativeElement.parentElement.querySelector('i');
|
|
691
|
+
keyboardIcon.removeEventListener('click', this.togglePanel.bind(this));
|
|
677
692
|
}
|
|
693
|
+
this.overlayService.destroy();
|
|
678
694
|
}
|
|
679
695
|
togglePanel() {
|
|
696
|
+
if (!this.vkEnabled) {
|
|
697
|
+
return;
|
|
698
|
+
}
|
|
680
699
|
if (this.overlayService.isOpen()) {
|
|
681
700
|
this.closePanel();
|
|
682
701
|
}
|
|
@@ -685,6 +704,9 @@ class SystelabVirtualKeyboardDirective {
|
|
|
685
704
|
}
|
|
686
705
|
}
|
|
687
706
|
openPanel() {
|
|
707
|
+
if (!this.vkEnabled) {
|
|
708
|
+
return;
|
|
709
|
+
}
|
|
688
710
|
if (this.overlayService.isCreated()) {
|
|
689
711
|
this.overlayService.destroy();
|
|
690
712
|
}
|
|
@@ -713,12 +735,15 @@ class SystelabVirtualKeyboardDirective {
|
|
|
713
735
|
}
|
|
714
736
|
}
|
|
715
737
|
isInputAlphabetic(activeInputElement) {
|
|
716
|
-
const
|
|
717
|
-
return
|
|
738
|
+
const inputMode = this.getInputMode(activeInputElement);
|
|
739
|
+
return inputMode && [SystelabVirtualKeyboardInputModes.text, SystelabVirtualKeyboardInputModes.password].some((i) => i === inputMode);
|
|
718
740
|
}
|
|
719
741
|
isInputNumeric(activeInputElement) {
|
|
720
|
-
const
|
|
721
|
-
return
|
|
742
|
+
const inputMode = this.getInputMode(activeInputElement);
|
|
743
|
+
return inputMode && [SystelabVirtualKeyboardInputModes.numeric].some((i) => i === inputMode);
|
|
744
|
+
}
|
|
745
|
+
getInputMode(activeInputElement) {
|
|
746
|
+
return activeInputElement?.inputMode ?? activeInputElement?.type;
|
|
722
747
|
}
|
|
723
748
|
closePanel() {
|
|
724
749
|
this.overlayService.destroy();
|
|
@@ -737,7 +762,7 @@ class SystelabVirtualKeyboardDirective {
|
|
|
737
762
|
}
|
|
738
763
|
}
|
|
739
764
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.9", ngImport: i0, type: SystelabVirtualKeyboardDirective, deps: [{ token: i0.ElementRef }, { token: SystelabVirtualKeyboardOverlayService }, { token: i0.Renderer2 }, { token: DOCUMENT }, { token: VIRTUAL_KEYBOARD_CONFIG, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
740
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.9", type: SystelabVirtualKeyboardDirective, selector: "input[vkEnabled], textarea[vkEnabled]", inputs: { vkEnabled: "vkEnabled", vkFixedBottom: "vkFixedBottom", vkDebug: "vkDebug", vkConfig: "vkConfig" }, host: { listeners: { "window:touchmove": "onDocumentScroll($event)", "window:touchend": "onDocumentScroll($event)", "window:wheel": "onDocumentScroll($event)", "document:scroll": "onDocumentScroll($event)", "
|
|
765
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.9", type: SystelabVirtualKeyboardDirective, selector: "input[vkEnabled], textarea[vkEnabled]", inputs: { vkEnabled: "vkEnabled", vkFixedBottom: "vkFixedBottom", vkDebug: "vkDebug", vkConfig: "vkConfig" }, host: { listeners: { "window:touchmove": "onDocumentScroll($event)", "window:touchend": "onDocumentScroll($event)", "window:wheel": "onDocumentScroll($event)", "document:scroll": "onDocumentScroll($event)", "click": "onClick($event)", "touchend": "onTouchEnd($event)" } }, ngImport: i0 }); }
|
|
741
766
|
}
|
|
742
767
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImport: i0, type: SystelabVirtualKeyboardDirective, decorators: [{
|
|
743
768
|
type: Directive,
|
|
@@ -764,9 +789,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImpor
|
|
|
764
789
|
}, {
|
|
765
790
|
type: HostListener,
|
|
766
791
|
args: ['document:scroll', ['$event']]
|
|
767
|
-
}],
|
|
792
|
+
}], onClick: [{
|
|
793
|
+
type: HostListener,
|
|
794
|
+
args: ['click', ['$event']]
|
|
795
|
+
}], onTouchEnd: [{
|
|
768
796
|
type: HostListener,
|
|
769
|
-
args: ['
|
|
797
|
+
args: ['touchend', ['$event']]
|
|
770
798
|
}], vkEnabled: [{
|
|
771
799
|
type: Input
|
|
772
800
|
}], vkFixedBottom: [{
|
|
@@ -823,5 +851,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImpor
|
|
|
823
851
|
* Generated bundle index. Do not edit.
|
|
824
852
|
*/
|
|
825
853
|
|
|
826
|
-
export { SystelabVirtualKeyboardButton, SystelabVirtualKeyboardDirective, SystelabVirtualKeyboardInputMethods,
|
|
854
|
+
export { SystelabVirtualKeyboardButton, SystelabVirtualKeyboardDirective, SystelabVirtualKeyboardInputMethods, SystelabVirtualKeyboardInputModes, SystelabVirtualKeyboardLayouts, SystelabVirtualKeyboardModule, factory };
|
|
827
855
|
//# sourceMappingURL=systelab-virtual-keyboard.mjs.map
|