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.
@@ -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: { "document:click": "onDocumentClick($event)", "window:touchmove": "onDocumentScroll($event)", "window:touchend": "onDocumentScroll($event)", "window:wheel": "onDocumentScroll($event)" } }, ngImport: i0 }); }
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: { onDocumentClick: [{
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, Inject, Optional, Input, NgModule } from '@angular/core';
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
- this.keyboard = new SimpleKeyboard('.simple-keyboard', {
91
- onKeyPress: (button) => this.handleKeyPress(button),
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 }], propDecorators: { handleKeyUp: [{
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: { "document:click": "onDocumentClick($event)", "window:touchmove": "onDocumentScroll($event)", "window:touchend": "onDocumentScroll($event)", "window:wheel": "onDocumentScroll($event)" } }, ngImport: i0 }); }
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: { onDocumentClick: [{
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