systelab-virtual-keyboard 0.0.1 → 0.0.3
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 +14 -7
- package/esm2022/lib/constants.mjs +6 -1
- package/esm2022/lib/systelab-virtual-keyboard-overlay.service.mjs +27 -2
- package/esm2022/lib/systelab-virtual-keyboard.component.mjs +64 -21
- package/esm2022/lib/systelab-virtual-keyboard.config.mjs +1 -1
- package/esm2022/lib/systelab-virtual-keyboard.directive.mjs +12 -19
- package/fesm2022/systelab-virtual-keyboard.mjs +104 -39
- package/fesm2022/systelab-virtual-keyboard.mjs.map +1 -1
- package/lib/constants.d.ts +4 -0
- package/lib/constants.d.ts.map +1 -1
- package/lib/systelab-virtual-keyboard-overlay.service.d.ts +5 -1
- package/lib/systelab-virtual-keyboard-overlay.service.d.ts.map +1 -1
- package/lib/systelab-virtual-keyboard.component.d.ts +5 -2
- package/lib/systelab-virtual-keyboard.component.d.ts.map +1 -1
- package/lib/systelab-virtual-keyboard.config.d.ts +2 -1
- package/lib/systelab-virtual-keyboard.config.d.ts.map +1 -1
- package/lib/systelab-virtual-keyboard.directive.d.ts +1 -1
- package/lib/systelab-virtual-keyboard.directive.d.ts.map +1 -1
- package/package.json +5 -5
|
@@ -13,23 +13,16 @@ 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
|
-
onDocumentClick(event) {
|
|
17
|
-
const simpleKeyboardElement = document.querySelector('.simple-keyboard');
|
|
18
|
-
const showKeyboardButtonClicked = event.target?.classList.contains('virtual-keyboard-show-button');
|
|
19
|
-
if (!simpleKeyboardElement?.contains(event.target) &&
|
|
20
|
-
!this.elementRef?.nativeElement?.contains(event.target) &&
|
|
21
|
-
!this.showKeyboardButtonElement?.contains(event.target) &&
|
|
22
|
-
!showKeyboardButtonClicked) {
|
|
23
|
-
if (this.overlayService.isCreated()) {
|
|
24
|
-
this.overlayService.destroy();
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
16
|
onDocumentScroll() {
|
|
29
17
|
if (this.overlayService.isCreated()) {
|
|
30
18
|
// update position and size on scroll
|
|
31
19
|
}
|
|
32
20
|
}
|
|
21
|
+
onFocus(event) {
|
|
22
|
+
if (!this.overlayService.isOpen()) {
|
|
23
|
+
this.openPanel();
|
|
24
|
+
}
|
|
25
|
+
}
|
|
33
26
|
set vkEnabled(enabled) {
|
|
34
27
|
if (typeof enabled === 'string') {
|
|
35
28
|
this.enabled = true;
|
|
@@ -106,7 +99,7 @@ export class SystelabVirtualKeyboardDirective {
|
|
|
106
99
|
return;
|
|
107
100
|
}
|
|
108
101
|
const currentLayout = this.getLayout(this.elementRef.nativeElement);
|
|
109
|
-
this.panelRef = this.overlayService.create(this.inputOrigin(), this.vkFixedBottom, currentLayout);
|
|
102
|
+
this.panelRef = this.overlayService.create(this.inputOrigin(), this.showKeyboardButtonElement, this.vkFixedBottom, currentLayout);
|
|
110
103
|
this.panelRef.instance.debug = this.vkDebug;
|
|
111
104
|
this.panelRef.instance.setActiveInput(this.elementRef.nativeElement);
|
|
112
105
|
this.panelRef.instance.setLayout(currentLayout);
|
|
@@ -151,7 +144,7 @@ export class SystelabVirtualKeyboardDirective {
|
|
|
151
144
|
}
|
|
152
145
|
}
|
|
153
146
|
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: { "
|
|
147
|
+
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)", "focus": "onFocus($event)" } }, ngImport: i0 }); }
|
|
155
148
|
}
|
|
156
149
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImport: i0, type: SystelabVirtualKeyboardDirective, decorators: [{
|
|
157
150
|
type: Directive,
|
|
@@ -166,10 +159,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImpor
|
|
|
166
159
|
}, {
|
|
167
160
|
type: Inject,
|
|
168
161
|
args: [VIRTUAL_KEYBOARD_CONFIG]
|
|
169
|
-
}] }], propDecorators: {
|
|
170
|
-
type: HostListener,
|
|
171
|
-
args: ['document:click', ['$event']]
|
|
172
|
-
}], onDocumentScroll: [{
|
|
162
|
+
}] }], propDecorators: { onDocumentScroll: [{
|
|
173
163
|
type: HostListener,
|
|
174
164
|
args: ['window:touchmove', ['$event']]
|
|
175
165
|
}, {
|
|
@@ -178,6 +168,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImpor
|
|
|
178
168
|
}, {
|
|
179
169
|
type: HostListener,
|
|
180
170
|
args: ['window:wheel', ['$event']]
|
|
171
|
+
}], onFocus: [{
|
|
172
|
+
type: HostListener,
|
|
173
|
+
args: ['focus', ['$event']]
|
|
181
174
|
}], vkEnabled: [{
|
|
182
175
|
type: Input
|
|
183
176
|
}], vkFixedBottom: [{
|
|
@@ -187,4 +180,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImpor
|
|
|
187
180
|
}], vkConfig: [{
|
|
188
181
|
type: Input
|
|
189
182
|
}] } });
|
|
190
|
-
//# 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('document:click', ['$event'])\n  onDocumentClick(event: MouseEvent | TouchEvent) {\n    const simpleKeyboardElement = document.querySelector('.simple-keyboard');\n    const showKeyboardButtonClicked = (event.target as HTMLElement)?.classList.contains('virtual-keyboard-show-button');\n    if (\n      !simpleKeyboardElement?.contains(event.target as Node) &&\n      !this.elementRef?.nativeElement?.contains(event.target as Node) &&\n      !this.showKeyboardButtonElement?.contains(event.target as Node) &&\n      !showKeyboardButtonClicked\n    ) {\n      if (this.overlayService.isCreated()) {\n        this.overlayService.destroy();\n      }\n    }\n  }\n\n  @HostListener('window:touchmove', ['$event'])\n  @HostListener('window:touchend', ['$event'])\n  @HostListener('window:wheel', ['$event'])\n  onDocumentScroll() {\n    if (this.overlayService.isCreated()) {\n      // update position and size on scroll\n    }\n  }\n\n  private enabled = false;\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  get vkEnabled(): boolean {\n    return this.enabled;\n  }\n\n  private fixedBottom = false;\n  @Input()\n  get vkFixedBottom(): boolean {\n    return this.fixedBottom;\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  @Input()\n  get vkDebug(): boolean {\n    return this.debug;\n  }\n  set vkDebug(debug: boolean) {\n    this.debug = debug;\n  }\n\n  private config: SystelabVirtualKeyboardConfig;\n  @Input()\n  get vkConfig(): SystelabVirtualKeyboardConfig {\n    return this.config;\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    this.attachKeyboardIcon();\n  }\n\n  ngAfterViewInit() {\n    if (this.vkEnabled) {\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.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(): any {\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"]}
|
|
183
|
+
//# 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  onDocumentScroll() {\n    if (this.overlayService.isCreated()) {\n      // update position and size on scroll\n    }\n  }\n\n  @HostListener('focus', ['$event'])\n  onFocus(event: MouseEvent | TouchEvent): void {\n    if (!this.overlayService.isOpen()) {\n      this.openPanel();\n    }\n  }\n\n  private enabled = false;\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  get vkEnabled(): boolean {\n    return this.enabled;\n  }\n\n  private fixedBottom = false;\n  @Input()\n  get vkFixedBottom(): boolean {\n    return this.fixedBottom;\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  @Input()\n  get vkDebug(): boolean {\n    return this.debug;\n  }\n  set vkDebug(debug: boolean) {\n    this.debug = debug;\n  }\n\n  private config: SystelabVirtualKeyboardConfig;\n  @Input()\n  get vkConfig(): SystelabVirtualKeyboardConfig {\n    return this.config;\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    this.attachKeyboardIcon();\n  }\n\n  ngAfterViewInit() {\n    if (this.vkEnabled) {\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(): any {\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"]}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { InjectionToken, EventEmitter, Component, HostListener, Output, Injectable, Directive,
|
|
2
|
+
import { InjectionToken, EventEmitter, Component, Optional, Inject, HostListener, Output, Injectable, Directive, Input, NgModule } from '@angular/core';
|
|
3
3
|
import { DOCUMENT, CommonModule } from '@angular/common';
|
|
4
4
|
import { ComponentPortal } from '@angular/cdk/portal';
|
|
5
|
-
import SimpleKeyboard from 'simple-keyboard';
|
|
5
|
+
import { SimpleKeyboard } from 'simple-keyboard';
|
|
6
6
|
import * as i1 from '@angular/cdk/overlay';
|
|
7
7
|
import { OverlayModule } from '@angular/cdk/overlay';
|
|
8
8
|
|
|
@@ -31,6 +31,11 @@ var SystelabVirtualKeyboardLayouts;
|
|
|
31
31
|
SystelabVirtualKeyboardLayouts["shift"] = "shift";
|
|
32
32
|
SystelabVirtualKeyboardLayouts["numeric"] = "numeric";
|
|
33
33
|
})(SystelabVirtualKeyboardLayouts || (SystelabVirtualKeyboardLayouts = {}));
|
|
34
|
+
var SystelabVirtualKeyboardInputMethods;
|
|
35
|
+
(function (SystelabVirtualKeyboardInputMethods) {
|
|
36
|
+
SystelabVirtualKeyboardInputMethods["onlyMouseEvents"] = "onlyMouseEvents";
|
|
37
|
+
SystelabVirtualKeyboardInputMethods["onlyTouchEvents"] = "onlyTouchEvents";
|
|
38
|
+
})(SystelabVirtualKeyboardInputMethods || (SystelabVirtualKeyboardInputMethods = {}));
|
|
34
39
|
var SystelabVirtualKeyboardInputTypes;
|
|
35
40
|
(function (SystelabVirtualKeyboardInputTypes) {
|
|
36
41
|
SystelabVirtualKeyboardInputTypes["text"] = "text";
|
|
@@ -61,8 +66,9 @@ class SystelabVirtualKeyboardComponent {
|
|
|
61
66
|
get isTextarea() {
|
|
62
67
|
return this.activeInputElement?.type === 'textarea';
|
|
63
68
|
}
|
|
64
|
-
constructor(elementRef) {
|
|
69
|
+
constructor(elementRef, virtualKeyboardConfig) {
|
|
65
70
|
this.elementRef = elementRef;
|
|
71
|
+
this.virtualKeyboardConfig = virtualKeyboardConfig;
|
|
66
72
|
this.debug = false;
|
|
67
73
|
this.selectedLayout = SystelabVirtualKeyboardLayouts.default;
|
|
68
74
|
this.caretPosition = null;
|
|
@@ -87,20 +93,8 @@ class SystelabVirtualKeyboardComponent {
|
|
|
87
93
|
],
|
|
88
94
|
[SystelabVirtualKeyboardLayouts.numeric]: ['7 8 9', '4 5 6', '1 2 3', '0 {bksp}'],
|
|
89
95
|
};
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
mergeDisplay: true,
|
|
93
|
-
display: {
|
|
94
|
-
[SystelabVirtualKeyboardButton.Backspace]: 'delete',
|
|
95
|
-
},
|
|
96
|
-
buttonTheme: [
|
|
97
|
-
{
|
|
98
|
-
class: 'virtual-keyboard-delete-button',
|
|
99
|
-
buttons: `${SystelabVirtualKeyboardButton.Backspace}`,
|
|
100
|
-
},
|
|
101
|
-
],
|
|
102
|
-
layout,
|
|
103
|
-
});
|
|
96
|
+
const keyboardOptions = this.prepareKeyboardConfig();
|
|
97
|
+
this.keyboard = new SimpleKeyboard('.simple-keyboard', keyboardOptions);
|
|
104
98
|
this.setLayout(this.selectedLayout);
|
|
105
99
|
if (this.debug) {
|
|
106
100
|
console.log('Layout: ', layout);
|
|
@@ -136,6 +130,54 @@ class SystelabVirtualKeyboardComponent {
|
|
|
136
130
|
});
|
|
137
131
|
}
|
|
138
132
|
}
|
|
133
|
+
prepareKeyboardConfig() {
|
|
134
|
+
const layout = {
|
|
135
|
+
[SystelabVirtualKeyboardLayouts.default]: [
|
|
136
|
+
'` 1 2 3 4 5 6 7 8 9 0 - = {bksp}',
|
|
137
|
+
'{tab} q w e r t y u i o p [ ] \\',
|
|
138
|
+
"{lock} a s d f g h j k l ; ' {enter}",
|
|
139
|
+
'{shift} z x c v b n m , . / {shift}',
|
|
140
|
+
'{space}',
|
|
141
|
+
],
|
|
142
|
+
[SystelabVirtualKeyboardLayouts.shift]: [
|
|
143
|
+
'~ ! @ # $ % ^ & * ( ) _ + {bksp}',
|
|
144
|
+
'{tab} Q W E R T Y U I O P { } |',
|
|
145
|
+
'{lock} A S D F G H J K L : " {enter}',
|
|
146
|
+
'{shift} Z X C V B N M < > ? {shift}',
|
|
147
|
+
'{space}',
|
|
148
|
+
],
|
|
149
|
+
[SystelabVirtualKeyboardLayouts.numeric]: ['7 8 9', '4 5 6', '1 2 3', '0 {bksp}'],
|
|
150
|
+
};
|
|
151
|
+
let keyboardOptions = {
|
|
152
|
+
onKeyPress: (button) => this.handleKeyPress(button),
|
|
153
|
+
mergeDisplay: true,
|
|
154
|
+
display: {
|
|
155
|
+
[SystelabVirtualKeyboardButton.Backspace]: 'delete',
|
|
156
|
+
},
|
|
157
|
+
buttonTheme: [
|
|
158
|
+
{
|
|
159
|
+
class: 'virtual-keyboard-delete-button',
|
|
160
|
+
buttons: `${SystelabVirtualKeyboardButton.Backspace}`,
|
|
161
|
+
},
|
|
162
|
+
],
|
|
163
|
+
layout,
|
|
164
|
+
};
|
|
165
|
+
if (this.virtualKeyboardConfig?.hasOwnProperty('inputMethod')) {
|
|
166
|
+
if (this.virtualKeyboardConfig.inputMethod === SystelabVirtualKeyboardInputMethods.onlyMouseEvents) {
|
|
167
|
+
keyboardOptions = {
|
|
168
|
+
...keyboardOptions,
|
|
169
|
+
useMouseEvents: true,
|
|
170
|
+
};
|
|
171
|
+
}
|
|
172
|
+
else if (this.virtualKeyboardConfig.inputMethod === SystelabVirtualKeyboardInputMethods.onlyTouchEvents) {
|
|
173
|
+
keyboardOptions = {
|
|
174
|
+
...keyboardOptions,
|
|
175
|
+
useTouchEvents: true,
|
|
176
|
+
};
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
return keyboardOptions;
|
|
180
|
+
}
|
|
139
181
|
isInputAlphabetic(activeInputElement) {
|
|
140
182
|
const inputType = activeInputElement?.type;
|
|
141
183
|
return inputType && [SystelabVirtualKeyboardInputTypes.text, SystelabVirtualKeyboardInputTypes.password].some((i) => i === inputType);
|
|
@@ -366,13 +408,18 @@ class SystelabVirtualKeyboardComponent {
|
|
|
366
408
|
this.caretPosition = position;
|
|
367
409
|
this.caretPositionEnd = endPosition;
|
|
368
410
|
}
|
|
369
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.9", ngImport: i0, type: SystelabVirtualKeyboardComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
411
|
+
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 }); }
|
|
370
412
|
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%}\n"] }); }
|
|
371
413
|
}
|
|
372
414
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImport: i0, type: SystelabVirtualKeyboardComponent, decorators: [{
|
|
373
415
|
type: Component,
|
|
374
416
|
args: [{ selector: 'systelab-virtual-keyboard.component', standalone: true, imports: [], 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%}\n"] }]
|
|
375
|
-
}], ctorParameters: () => [{ type: i0.ElementRef }
|
|
417
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: undefined, decorators: [{
|
|
418
|
+
type: Optional
|
|
419
|
+
}, {
|
|
420
|
+
type: Inject,
|
|
421
|
+
args: [VIRTUAL_KEYBOARD_CONFIG]
|
|
422
|
+
}] }], propDecorators: { handleKeyUp: [{
|
|
376
423
|
type: HostListener,
|
|
377
424
|
args: ['window:keyup', ['$event']]
|
|
378
425
|
}], handleMouseUp: [{
|
|
@@ -391,6 +438,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImpor
|
|
|
391
438
|
class SystelabVirtualKeyboardOverlayService {
|
|
392
439
|
constructor(overlay) {
|
|
393
440
|
this.overlay = overlay;
|
|
441
|
+
this.initListener();
|
|
394
442
|
}
|
|
395
443
|
isCreated() {
|
|
396
444
|
return !!this.overlayRef;
|
|
@@ -398,7 +446,9 @@ class SystelabVirtualKeyboardOverlayService {
|
|
|
398
446
|
isOpen() {
|
|
399
447
|
return this.open;
|
|
400
448
|
}
|
|
401
|
-
create(inputOrigin, fixedBottom, layout = SystelabVirtualKeyboardLayouts.default) {
|
|
449
|
+
create(inputOrigin, showKeyboardButtonElement, fixedBottom, layout = SystelabVirtualKeyboardLayouts.default) {
|
|
450
|
+
this.inputOrigin = inputOrigin;
|
|
451
|
+
this.showKeyboardButtonElement = showKeyboardButtonElement;
|
|
402
452
|
this.layout = layout;
|
|
403
453
|
this.overlayRef = this.overlay.create({
|
|
404
454
|
hasBackdrop: false,
|
|
@@ -421,6 +471,28 @@ class SystelabVirtualKeyboardOverlayService {
|
|
|
421
471
|
this.overlayRef = null;
|
|
422
472
|
this.open = false;
|
|
423
473
|
}
|
|
474
|
+
initListener() {
|
|
475
|
+
document.addEventListener('click', this.handleClick.bind(this));
|
|
476
|
+
}
|
|
477
|
+
handleClick(event) {
|
|
478
|
+
console.log('Document clicked:', event);
|
|
479
|
+
event.stopPropagation();
|
|
480
|
+
const simpleKeyboardElement = document.querySelector('.simple-keyboard');
|
|
481
|
+
const showKeyboardButtonClicked = event.target?.classList.contains('virtual-keyboard-show-button');
|
|
482
|
+
const containsKeyboard = simpleKeyboardElement?.contains(event.target);
|
|
483
|
+
const containsElementRef = this.inputOrigin?.contains(event.target);
|
|
484
|
+
// const containsFocusedElement = this.focusedElement?.contains(event.target as Node);
|
|
485
|
+
const containsShowButton = this.showKeyboardButtonElement?.contains(event.target);
|
|
486
|
+
if (!containsKeyboard &&
|
|
487
|
+
!containsElementRef &&
|
|
488
|
+
// !containsFocusedElement &&
|
|
489
|
+
!containsShowButton &&
|
|
490
|
+
!showKeyboardButtonClicked) {
|
|
491
|
+
if (this.isCreated()) {
|
|
492
|
+
this.destroy();
|
|
493
|
+
}
|
|
494
|
+
}
|
|
495
|
+
}
|
|
424
496
|
hasAttached() {
|
|
425
497
|
return this.overlayRef?.hasAttached();
|
|
426
498
|
}
|
|
@@ -514,23 +586,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImpor
|
|
|
514
586
|
* strictly forbidden unless prior written permission is Instrumentation Laboratory Company.
|
|
515
587
|
*/
|
|
516
588
|
class SystelabVirtualKeyboardDirective {
|
|
517
|
-
onDocumentClick(event) {
|
|
518
|
-
const simpleKeyboardElement = document.querySelector('.simple-keyboard');
|
|
519
|
-
const showKeyboardButtonClicked = event.target?.classList.contains('virtual-keyboard-show-button');
|
|
520
|
-
if (!simpleKeyboardElement?.contains(event.target) &&
|
|
521
|
-
!this.elementRef?.nativeElement?.contains(event.target) &&
|
|
522
|
-
!this.showKeyboardButtonElement?.contains(event.target) &&
|
|
523
|
-
!showKeyboardButtonClicked) {
|
|
524
|
-
if (this.overlayService.isCreated()) {
|
|
525
|
-
this.overlayService.destroy();
|
|
526
|
-
}
|
|
527
|
-
}
|
|
528
|
-
}
|
|
529
589
|
onDocumentScroll() {
|
|
530
590
|
if (this.overlayService.isCreated()) {
|
|
531
591
|
// update position and size on scroll
|
|
532
592
|
}
|
|
533
593
|
}
|
|
594
|
+
onFocus(event) {
|
|
595
|
+
if (!this.overlayService.isOpen()) {
|
|
596
|
+
this.openPanel();
|
|
597
|
+
}
|
|
598
|
+
}
|
|
534
599
|
set vkEnabled(enabled) {
|
|
535
600
|
if (typeof enabled === 'string') {
|
|
536
601
|
this.enabled = true;
|
|
@@ -607,7 +672,7 @@ class SystelabVirtualKeyboardDirective {
|
|
|
607
672
|
return;
|
|
608
673
|
}
|
|
609
674
|
const currentLayout = this.getLayout(this.elementRef.nativeElement);
|
|
610
|
-
this.panelRef = this.overlayService.create(this.inputOrigin(), this.vkFixedBottom, currentLayout);
|
|
675
|
+
this.panelRef = this.overlayService.create(this.inputOrigin(), this.showKeyboardButtonElement, this.vkFixedBottom, currentLayout);
|
|
611
676
|
this.panelRef.instance.debug = this.vkDebug;
|
|
612
677
|
this.panelRef.instance.setActiveInput(this.elementRef.nativeElement);
|
|
613
678
|
this.panelRef.instance.setLayout(currentLayout);
|
|
@@ -652,7 +717,7 @@ class SystelabVirtualKeyboardDirective {
|
|
|
652
717
|
}
|
|
653
718
|
}
|
|
654
719
|
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 }); }
|
|
655
|
-
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: { "
|
|
720
|
+
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)", "focus": "onFocus($event)" } }, ngImport: i0 }); }
|
|
656
721
|
}
|
|
657
722
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImport: i0, type: SystelabVirtualKeyboardDirective, decorators: [{
|
|
658
723
|
type: Directive,
|
|
@@ -667,10 +732,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImpor
|
|
|
667
732
|
}, {
|
|
668
733
|
type: Inject,
|
|
669
734
|
args: [VIRTUAL_KEYBOARD_CONFIG]
|
|
670
|
-
}] }], propDecorators: {
|
|
671
|
-
type: HostListener,
|
|
672
|
-
args: ['document:click', ['$event']]
|
|
673
|
-
}], onDocumentScroll: [{
|
|
735
|
+
}] }], propDecorators: { onDocumentScroll: [{
|
|
674
736
|
type: HostListener,
|
|
675
737
|
args: ['window:touchmove', ['$event']]
|
|
676
738
|
}, {
|
|
@@ -679,6 +741,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImpor
|
|
|
679
741
|
}, {
|
|
680
742
|
type: HostListener,
|
|
681
743
|
args: ['window:wheel', ['$event']]
|
|
744
|
+
}], onFocus: [{
|
|
745
|
+
type: HostListener,
|
|
746
|
+
args: ['focus', ['$event']]
|
|
682
747
|
}], vkEnabled: [{
|
|
683
748
|
type: Input
|
|
684
749
|
}], vkFixedBottom: [{
|
|
@@ -735,5 +800,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImpor
|
|
|
735
800
|
* Generated bundle index. Do not edit.
|
|
736
801
|
*/
|
|
737
802
|
|
|
738
|
-
export { SystelabVirtualKeyboardButton, SystelabVirtualKeyboardDirective, SystelabVirtualKeyboardInputTypes, SystelabVirtualKeyboardLayouts, SystelabVirtualKeyboardModule, factory };
|
|
803
|
+
export { SystelabVirtualKeyboardButton, SystelabVirtualKeyboardDirective, SystelabVirtualKeyboardInputMethods, SystelabVirtualKeyboardInputTypes, SystelabVirtualKeyboardLayouts, SystelabVirtualKeyboardModule, factory };
|
|
739
804
|
//# sourceMappingURL=systelab-virtual-keyboard.mjs.map
|