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.
@@ -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 { SystelabVirtualKeyboardInputTypes, SystelabVirtualKeyboardLayouts } from './constants';
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.overlayService.isCreated()) {
18
- this.overlayService.updatePosition();
17
+ if (!this.vkEnabled) {
18
+ return;
19
19
  }
20
+ this.overlayService.updatePosition();
20
21
  }
21
- onFocus() {
22
- console.log('Focused');
23
- if (this.overlayService.isCreated()) {
24
- this.closePanel();
22
+ onClick() {
23
+ if (!this.vkEnabled || !this.config.showOnMouseClick) {
24
+ return;
25
25
  }
26
- this.overlayService.setFocusDispatched(true);
27
- if (!this.overlayService.isOpen()) {
28
- this.openPanel();
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.overlayService.isCreated()) {
90
- this.overlayService.destroy();
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 inputType = activeInputElement?.type;
131
- return inputType && [SystelabVirtualKeyboardInputTypes.text, SystelabVirtualKeyboardInputTypes.password].some((i) => i === inputType);
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 inputType = activeInputElement?.type;
135
- return inputType && [SystelabVirtualKeyboardInputTypes.number].some((i) => i === inputType);
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)", "focus": "onFocus($event)" } }, ngImport: i0 }); }
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
- }], onFocus: [{
199
+ }], onClick: [{
200
+ type: HostListener,
201
+ args: ['click', ['$event']]
202
+ }], onTouchEnd: [{
182
203
  type: HostListener,
183
- args: ['focus', ['$event']]
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 SystelabVirtualKeyboardInputTypes;
40
- (function (SystelabVirtualKeyboardInputTypes) {
41
- SystelabVirtualKeyboardInputTypes["text"] = "text";
42
- SystelabVirtualKeyboardInputTypes["number"] = "number";
43
- SystelabVirtualKeyboardInputTypes["password"] = "password";
44
- })(SystelabVirtualKeyboardInputTypes || (SystelabVirtualKeyboardInputTypes = {}));
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
- let selectionStart;
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
- output = this.addStringAt(output, '\t', ...commonParams);
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.focusDispatched = false;
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
- setFocusDispatched(dispatched) {
474
- this.focusDispatched = dispatched;
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.focusDispatched) {
488
- this.focusDispatched = false;
483
+ if (this.clickAlreadyHandled) {
484
+ this.clickAlreadyHandled = false;
489
485
  return;
490
486
  }
491
- console.log('Document clicked:', event);
492
487
  event.stopPropagation();
493
- const simpleKeyboardElement = document.querySelector('.simple-keyboard');
494
- const showKeyboardButtonClicked = event.target?.classList.contains('virtual-keyboard-show-button');
495
- const containsKeyboard = simpleKeyboardElement?.contains(event.target);
496
- const containsElementRef = this.inputOrigin?.contains(event.target);
497
- // const containsFocusedElement = this.focusedElement?.contains(event.target as Node);
498
- const containsShowButton = this.showKeyboardButtonElement?.contains(event.target);
499
- if (!containsKeyboard &&
500
- !containsElementRef &&
501
- // !containsFocusedElement &&
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
- !showKeyboardButtonClicked) {
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.updatePositionStrategy(this.getPositionStrategy(inputOrigin, fixedBottom));
516
+ if (!!this.overlayRef) {
517
+ this.overlayRef.updatePositionStrategy(this.getPositionStrategy(inputOrigin, fixedBottom));
518
+ }
514
519
  }
515
520
  updateSize() {
516
- this.overlayRef.updateSize(this.getOverlaySize());
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.overlayService.isCreated()) {
604
- this.overlayService.updatePosition();
610
+ if (!this.vkEnabled) {
611
+ return;
605
612
  }
613
+ this.overlayService.updatePosition();
606
614
  }
607
- onFocus() {
608
- console.log('Focused');
609
- if (this.overlayService.isCreated()) {
610
- this.closePanel();
615
+ onClick() {
616
+ if (!this.vkEnabled || !this.config.showOnMouseClick) {
617
+ return;
611
618
  }
612
- this.overlayService.setFocusDispatched(true);
613
- if (!this.overlayService.isOpen()) {
614
- this.openPanel();
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.overlayService.isCreated()) {
676
- this.overlayService.destroy();
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 inputType = activeInputElement?.type;
717
- return inputType && [SystelabVirtualKeyboardInputTypes.text, SystelabVirtualKeyboardInputTypes.password].some((i) => i === inputType);
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 inputType = activeInputElement?.type;
721
- return inputType && [SystelabVirtualKeyboardInputTypes.number].some((i) => i === inputType);
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)", "focus": "onFocus($event)" } }, ngImport: i0 }); }
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
- }], onFocus: [{
792
+ }], onClick: [{
793
+ type: HostListener,
794
+ args: ['click', ['$event']]
795
+ }], onTouchEnd: [{
768
796
  type: HostListener,
769
- args: ['focus', ['$event']]
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, SystelabVirtualKeyboardInputTypes, SystelabVirtualKeyboardLayouts, SystelabVirtualKeyboardModule, factory };
854
+ export { SystelabVirtualKeyboardButton, SystelabVirtualKeyboardDirective, SystelabVirtualKeyboardInputMethods, SystelabVirtualKeyboardInputModes, SystelabVirtualKeyboardLayouts, SystelabVirtualKeyboardModule, factory };
827
855
  //# sourceMappingURL=systelab-virtual-keyboard.mjs.map