systelab-virtual-keyboard 19.0.0 → 20.1.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.
Files changed (30) hide show
  1. package/README.md +11 -0
  2. package/fesm2022/systelab-virtual-keyboard.mjs +197 -117
  3. package/fesm2022/systelab-virtual-keyboard.mjs.map +1 -1
  4. package/index.d.ts +182 -6
  5. package/index.d.ts.map +1 -0
  6. package/package.json +6 -8
  7. package/scss/default-theme.scss +102 -0
  8. package/esm2022/lib/constants.mjs +0 -37
  9. package/esm2022/lib/systelab-virtual-keyboard-overlay.service.mjs +0 -177
  10. package/esm2022/lib/systelab-virtual-keyboard.component.mjs +0 -375
  11. package/esm2022/lib/systelab-virtual-keyboard.config.mjs +0 -3
  12. package/esm2022/lib/systelab-virtual-keyboard.directive.mjs +0 -215
  13. package/esm2022/lib/systelab-virtual-keyboard.module.mjs +0 -45
  14. package/esm2022/public-api.mjs +0 -7
  15. package/esm2022/systelab-virtual-keyboard.mjs +0 -5
  16. package/lib/constants.d.ts +0 -25
  17. package/lib/constants.d.ts.map +0 -1
  18. package/lib/systelab-virtual-keyboard-overlay.service.d.ts +0 -38
  19. package/lib/systelab-virtual-keyboard-overlay.service.d.ts.map +0 -1
  20. package/lib/systelab-virtual-keyboard.component.d.ts +0 -43
  21. package/lib/systelab-virtual-keyboard.component.d.ts.map +0 -1
  22. package/lib/systelab-virtual-keyboard.config.d.ts +0 -10
  23. package/lib/systelab-virtual-keyboard.config.d.ts.map +0 -1
  24. package/lib/systelab-virtual-keyboard.directive.d.ts +0 -44
  25. package/lib/systelab-virtual-keyboard.directive.d.ts.map +0 -1
  26. package/lib/systelab-virtual-keyboard.module.d.ts +0 -15
  27. package/lib/systelab-virtual-keyboard.module.d.ts.map +0 -1
  28. package/public-api.d.ts +0 -5
  29. package/public-api.d.ts.map +0 -1
  30. package/systelab-virtual-keyboard.d.ts.map +0 -1
@@ -0,0 +1,102 @@
1
+ @mixin forceWidth($width) {
2
+ min-width: #{$width} !important;
3
+ max-width: #{$width} !important;
4
+ }
5
+
6
+ :root {
7
+ --systelab-virtual-keyboard-font-family: 'SF Mono', 'Menlo', 'Consolas', 'Courier New', monospace;
8
+ --systelab-virtual-keyboard-background-color: #B2B2B2;
9
+ --systelab-virtual-keyboard-button-color: #E5E5E5;
10
+ --systelab-virtual-keyboard-button-font-color: #000000;
11
+ --systelab-virtual-keyboard-active-special-button-color: #4D4D4D;
12
+ --systelab-virtual-keyboard-active-special-button-font-color: #FFFFFF;
13
+ }
14
+
15
+ :host {
16
+ width: 100%;
17
+ }
18
+
19
+ .systelab-virtual-keyboard-theme {
20
+ font-family: var(--systelab-virtual-keyboard-font-family);
21
+ background-color: var(--systelab-virtual-keyboard-background-color);
22
+
23
+ .hg-row {
24
+ .hg-button {
25
+ box-sizing: border-box;
26
+ height: 65px;
27
+ min-width: 75px;
28
+ max-width: 75px !important;
29
+ border-radius: 10px;
30
+ &:not(:last-child) {
31
+ margin-right: 6.8px !important;
32
+ }
33
+ }
34
+ }
35
+
36
+ &.hg-layout-alpha-numeric,
37
+ &.hg-layout-alpha-numeric-shift,
38
+ &.hg-layout-alpha-numeric-uppercase,
39
+ &.hg-layout-alpha-numeric-uppercase-shift {
40
+ .hg-row {
41
+ &:first-child .hg-button {
42
+ height: 50px;
43
+ }
44
+ }
45
+ .hg-button-shift {
46
+ @include forceWidth(182px);
47
+ }
48
+
49
+ .hg-button-bksp {
50
+ @include forceWidth(125px);
51
+ }
52
+
53
+ .hg-button-tab {
54
+ @include forceWidth(126px);
55
+ }
56
+
57
+ .hg-button-enter,
58
+ .hg-button-lock {
59
+ @include forceWidth(141px);
60
+ }
61
+
62
+ .hg-button-space {
63
+ @include forceWidth(100%);
64
+ }
65
+ }
66
+
67
+ .virtual-keyboard-delete-button,
68
+ .virtual-keyboard-enter-button,
69
+ .virtual-keyboard-function-button {
70
+ background-color: var(--systelab-virtual-keyboard-button-color);
71
+ color: var(--systelab-virtual-keyboard-button-font-color);
72
+ &:first-child {
73
+ justify-content: flex-start;
74
+ align-items: flex-end;
75
+ padding-left: 15px;
76
+ padding-bottom: 15px;
77
+ }
78
+ &:last-child {
79
+ justify-content: flex-end;
80
+ align-items: flex-end;
81
+ padding-right: 15px;
82
+ padding-bottom: 15px;
83
+ }
84
+ }
85
+
86
+ .hg-button-tab {
87
+ justify-content: flex-start;
88
+ align-items: flex-end;
89
+ padding-left: 15px;
90
+ padding-bottom: 15px;
91
+ }
92
+
93
+ .virtual-keyboard-lock-active,
94
+ .virtual-keyboard-shift-active {
95
+ background-color: var(--systelab-virtual-keyboard-active-special-button-color);
96
+ color: var(--systelab-virtual-keyboard-active-special-button-font-color);
97
+ }
98
+
99
+ .virtual-keyboard-uppercase {
100
+ text-transform: uppercase;
101
+ }
102
+ }
@@ -1,37 +0,0 @@
1
- /*
2
- * Copyright (c) 2020 - 2024 - Instrumentation Laboratory Company and Systelab Technologies, SA. All rights reserved.
3
- * NOTICE: All information contained herein is and remains the property of Instrumentation Laboratory Company and its
4
- * affiliates, if any. The intellectual and technical concepts contained herein are proprietary to Instrumentation
5
- * Laboratory Company and its affiliates and may be covered by U.S. and foreign patents and patent applications, and/or
6
- * are protected by trade secret or copyright law. Dissemination of this information or reproduction of this material is
7
- * strictly forbidden unless prior written permission is Instrumentation Laboratory Company.
8
- */
9
- export var SystelabVirtualKeyboardButton;
10
- (function (SystelabVirtualKeyboardButton) {
11
- SystelabVirtualKeyboardButton["Done"] = "{done}";
12
- SystelabVirtualKeyboardButton["Enter"] = "{enter}";
13
- SystelabVirtualKeyboardButton["Shift"] = "{shift}";
14
- SystelabVirtualKeyboardButton["Lock"] = "{lock}";
15
- SystelabVirtualKeyboardButton["Backspace"] = "{bksp}";
16
- SystelabVirtualKeyboardButton["Language"] = "{language}";
17
- SystelabVirtualKeyboardButton["Space"] = "{space}";
18
- SystelabVirtualKeyboardButton["Tab"] = "{tab}";
19
- })(SystelabVirtualKeyboardButton || (SystelabVirtualKeyboardButton = {}));
20
- export var SystelabVirtualKeyboardLayouts;
21
- (function (SystelabVirtualKeyboardLayouts) {
22
- SystelabVirtualKeyboardLayouts["default"] = "default";
23
- SystelabVirtualKeyboardLayouts["shift"] = "shift";
24
- SystelabVirtualKeyboardLayouts["numeric"] = "numeric";
25
- })(SystelabVirtualKeyboardLayouts || (SystelabVirtualKeyboardLayouts = {}));
26
- export var SystelabVirtualKeyboardInputMethods;
27
- (function (SystelabVirtualKeyboardInputMethods) {
28
- SystelabVirtualKeyboardInputMethods["onlyMouseEvents"] = "onlyMouseEvents";
29
- SystelabVirtualKeyboardInputMethods["onlyTouchEvents"] = "onlyTouchEvents";
30
- })(SystelabVirtualKeyboardInputMethods || (SystelabVirtualKeyboardInputMethods = {}));
31
- export var SystelabVirtualKeyboardInputModes;
32
- (function (SystelabVirtualKeyboardInputModes) {
33
- SystelabVirtualKeyboardInputModes["text"] = "text";
34
- SystelabVirtualKeyboardInputModes["numeric"] = "numeric";
35
- SystelabVirtualKeyboardInputModes["password"] = "password";
36
- })(SystelabVirtualKeyboardInputModes || (SystelabVirtualKeyboardInputModes = {}));
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvc3lzdGVsYWItdmlydHVhbC1rZXlib2FyZC9zcmMvbGliL2NvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7OztHQU9HO0FBRUgsTUFBTSxDQUFOLElBQVksNkJBU1g7QUFURCxXQUFZLDZCQUE2QjtJQUNyQyxnREFBZSxDQUFBO0lBQ2Ysa0RBQWlCLENBQUE7SUFDakIsa0RBQWlCLENBQUE7SUFDakIsZ0RBQWUsQ0FBQTtJQUNmLHFEQUFvQixDQUFBO0lBQ3BCLHdEQUF1QixDQUFBO0lBQ3ZCLGtEQUFpQixDQUFBO0lBQ2pCLDhDQUFhLENBQUE7QUFDakIsQ0FBQyxFQVRXLDZCQUE2QixLQUE3Qiw2QkFBNkIsUUFTeEM7QUFFRCxNQUFNLENBQU4sSUFBWSw4QkFJWDtBQUpELFdBQVksOEJBQThCO0lBQ3RDLHFEQUFtQixDQUFBO0lBQ25CLGlEQUFlLENBQUE7SUFDZixxREFBbUIsQ0FBQTtBQUN2QixDQUFDLEVBSlcsOEJBQThCLEtBQTlCLDhCQUE4QixRQUl6QztBQUVELE1BQU0sQ0FBTixJQUFZLG1DQUdYO0FBSEQsV0FBWSxtQ0FBbUM7SUFDM0MsMEVBQW1DLENBQUE7SUFDbkMsMEVBQW1DLENBQUE7QUFDdkMsQ0FBQyxFQUhXLG1DQUFtQyxLQUFuQyxtQ0FBbUMsUUFHOUM7QUFFRCxNQUFNLENBQU4sSUFBWSxpQ0FJWDtBQUpELFdBQVksaUNBQWlDO0lBQ3pDLGtEQUFhLENBQUE7SUFDYix3REFBbUIsQ0FBQTtJQUNuQiwwREFBcUIsQ0FBQTtBQUN6QixDQUFDLEVBSlcsaUNBQWlDLEtBQWpDLGlDQUFpQyxRQUk1QyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjAgLSAyMDI0IC0gSW5zdHJ1bWVudGF0aW9uIExhYm9yYXRvcnkgQ29tcGFueSBhbmQgU3lzdGVsYWIgVGVjaG5vbG9naWVzLCBTQS4gQWxsIHJpZ2h0cyByZXNlcnZlZC5cbiAqIE5PVElDRTogIEFsbCBpbmZvcm1hdGlvbiBjb250YWluZWQgaGVyZWluIGlzIGFuZCByZW1haW5zIHRoZSBwcm9wZXJ0eSBvZiBJbnN0cnVtZW50YXRpb24gTGFib3JhdG9yeSBDb21wYW55IGFuZCBpdHNcbiAqIGFmZmlsaWF0ZXMsIGlmIGFueS4gIFRoZSBpbnRlbGxlY3R1YWwgYW5kIHRlY2huaWNhbCBjb25jZXB0cyBjb250YWluZWQgaGVyZWluIGFyZSBwcm9wcmlldGFyeSB0byBJbnN0cnVtZW50YXRpb25cbiAqIExhYm9yYXRvcnkgQ29tcGFueSBhbmQgaXRzIGFmZmlsaWF0ZXMgYW5kIG1heSBiZSBjb3ZlcmVkIGJ5IFUuUy4gYW5kIGZvcmVpZ24gcGF0ZW50cyBhbmQgcGF0ZW50IGFwcGxpY2F0aW9ucywgYW5kL29yXG4gKiBhcmUgcHJvdGVjdGVkIGJ5IHRyYWRlIHNlY3JldCBvciBjb3B5cmlnaHQgbGF3LiBEaXNzZW1pbmF0aW9uIG9mIHRoaXMgaW5mb3JtYXRpb24gb3IgcmVwcm9kdWN0aW9uIG9mIHRoaXMgbWF0ZXJpYWwgaXNcbiAqIHN0cmljdGx5IGZvcmJpZGRlbiB1bmxlc3MgcHJpb3Igd3JpdHRlbiBwZXJtaXNzaW9uIGlzIEluc3RydW1lbnRhdGlvbiBMYWJvcmF0b3J5IENvbXBhbnkuXG4gKi9cblxuZXhwb3J0IGVudW0gU3lzdGVsYWJWaXJ0dWFsS2V5Ym9hcmRCdXR0b24ge1xuICAgIERvbmUgPSAne2RvbmV9JyxcbiAgICBFbnRlciA9ICd7ZW50ZXJ9JyxcbiAgICBTaGlmdCA9ICd7c2hpZnR9JyxcbiAgICBMb2NrID0gJ3tsb2NrfScsXG4gICAgQmFja3NwYWNlID0gJ3tia3NwfScsXG4gICAgTGFuZ3VhZ2UgPSAne2xhbmd1YWdlfScsXG4gICAgU3BhY2UgPSAne3NwYWNlfScsXG4gICAgVGFiID0gJ3t0YWJ9Jyxcbn1cblxuZXhwb3J0IGVudW0gU3lzdGVsYWJWaXJ0dWFsS2V5Ym9hcmRMYXlvdXRzIHtcbiAgICBkZWZhdWx0ID0gJ2RlZmF1bHQnLFxuICAgIHNoaWZ0ID0gJ3NoaWZ0JyxcbiAgICBudW1lcmljID0gJ251bWVyaWMnLFxufVxuXG5leHBvcnQgZW51bSBTeXN0ZWxhYlZpcnR1YWxLZXlib2FyZElucHV0TWV0aG9kcyB7XG4gICAgb25seU1vdXNlRXZlbnRzID0gJ29ubHlNb3VzZUV2ZW50cycsXG4gICAgb25seVRvdWNoRXZlbnRzID0gJ29ubHlUb3VjaEV2ZW50cycsXG59XG5cbmV4cG9ydCBlbnVtIFN5c3RlbGFiVmlydHVhbEtleWJvYXJkSW5wdXRNb2RlcyB7XG4gICAgdGV4dCA9ICd0ZXh0JyxcbiAgICBudW1lcmljID0gJ251bWVyaWMnLFxuICAgIHBhc3N3b3JkID0gJ3Bhc3N3b3JkJyxcbn1cbiJdfQ==
@@ -1,177 +0,0 @@
1
- import { Injectable } from '@angular/core';
2
- import { ComponentPortal } from '@angular/cdk/portal';
3
- import { SystelabVirtualKeyboardLayouts } from './constants';
4
- import { SystelabVirtualKeyboardComponent } from './systelab-virtual-keyboard.component';
5
- import * as i0 from "@angular/core";
6
- import * as i1 from "@angular/cdk/overlay";
7
- export class SystelabVirtualKeyboardOverlayService {
8
- constructor(overlay) {
9
- this.overlay = overlay;
10
- this.clickAlreadyHandled = false;
11
- this.touchEndAlreadyHandled = false;
12
- this.initListener();
13
- }
14
- isCreated() {
15
- return !!this.overlayRef;
16
- }
17
- isOpen() {
18
- return this.open;
19
- }
20
- create(inputOrigin, showKeyboardButtonElement, fixedBottom, layout = SystelabVirtualKeyboardLayouts.default) {
21
- this.inputOrigin = inputOrigin;
22
- this.fixedBottom = fixedBottom;
23
- this.showKeyboardButtonElement = showKeyboardButtonElement;
24
- this.layout = layout;
25
- this.overlayRef = this.overlay.create({
26
- hasBackdrop: false,
27
- scrollStrategy: this.overlay.scrollStrategies.reposition(),
28
- disposeOnNavigation: true,
29
- backdropClass: 'systelab-virtual-keyboard__backdrop',
30
- panelClass: 'systelab-virtual-keyboard__panel',
31
- });
32
- if (fixedBottom) {
33
- this.overlayRef.addPanelClass('systelab-virtual-keyboard__panel--fixed-bottom');
34
- }
35
- this.updatePositionStrategy(inputOrigin, fixedBottom);
36
- this.updateSize();
37
- this.open = true;
38
- return this.overlayRef.attach(new ComponentPortal(SystelabVirtualKeyboardComponent));
39
- }
40
- updatePosition() {
41
- this.updatePositionStrategy(this.inputOrigin, this.fixedBottom);
42
- }
43
- setClickAlreadyHandled() {
44
- this.clickAlreadyHandled = true;
45
- }
46
- setTouchEndAlreadyHandled() {
47
- this.touchEndAlreadyHandled = true;
48
- }
49
- destroy() {
50
- if (this.overlayRef) {
51
- this.overlayRef.dispose();
52
- }
53
- this.overlayRef = null;
54
- this.open = false;
55
- }
56
- initListener() {
57
- document.addEventListener('click', this.handleClick.bind(this));
58
- document.addEventListener('touchend', this.handleTouchEnd.bind(this));
59
- }
60
- handleClick(event) {
61
- if (this.clickAlreadyHandled) {
62
- this.clickAlreadyHandled = false;
63
- return;
64
- }
65
- event.stopPropagation();
66
- this.handleEventTarget(event.target);
67
- }
68
- handleTouchEnd(event) {
69
- if (this.touchEndAlreadyHandled) {
70
- this.touchEndAlreadyHandled = false;
71
- return;
72
- }
73
- event.stopPropagation();
74
- this.handleEventTarget(event.target);
75
- }
76
- handleEventTarget(target) {
77
- const showKeyboardButtonTarget = target?.classList.contains('virtual-keyboard-show-button');
78
- const virtualKeyboardTarget = document.querySelector('.simple-keyboard')?.contains(target);
79
- const inputElementTarget = this.inputOrigin?.contains(target);
80
- const containsShowButton = this.showKeyboardButtonElement?.contains(target);
81
- if (!virtualKeyboardTarget &&
82
- !inputElementTarget &&
83
- !containsShowButton &&
84
- !showKeyboardButtonTarget) {
85
- if (this.isCreated()) {
86
- this.destroy();
87
- }
88
- }
89
- }
90
- hasAttached() {
91
- return this.overlayRef?.hasAttached();
92
- }
93
- updatePositionStrategy(inputOrigin, fixedBottom) {
94
- if (!!this.overlayRef) {
95
- this.overlayRef.updatePositionStrategy(this.getPositionStrategy(inputOrigin, fixedBottom));
96
- }
97
- }
98
- updateSize() {
99
- if (!!this.overlayRef) {
100
- this.overlayRef.updateSize(this.getOverlaySize());
101
- }
102
- }
103
- getPositionStrategy(inputOrigin, fixedBottom) {
104
- if (fixedBottom) {
105
- return this.overlay.position().global().centerHorizontally().bottom('0');
106
- }
107
- const pointWithDimensions = this.computePositionStrategyOrigin(inputOrigin);
108
- return this.overlay
109
- .position()
110
- .flexibleConnectedTo(pointWithDimensions)
111
- .withFlexibleDimensions(false)
112
- .withLockedPosition(true)
113
- .withPush(false)
114
- .withPositions([
115
- {
116
- originX: 'start',
117
- originY: 'bottom',
118
- overlayX: 'start',
119
- overlayY: 'top',
120
- },
121
- {
122
- originX: 'start',
123
- originY: 'top',
124
- overlayX: 'start',
125
- overlayY: 'bottom',
126
- },
127
- {
128
- originX: 'end',
129
- originY: 'bottom',
130
- overlayX: 'end',
131
- overlayY: 'top',
132
- },
133
- {
134
- originX: 'end',
135
- originY: 'top',
136
- overlayX: 'end',
137
- overlayY: 'bottom',
138
- },
139
- ]);
140
- }
141
- getOverlaySize() {
142
- const overlayWidth = this.layout === SystelabVirtualKeyboardLayouts.numeric ? '400px' : '1200px';
143
- return {
144
- width: overlayWidth,
145
- maxWidth: overlayWidth,
146
- minWidth: overlayWidth,
147
- };
148
- }
149
- computePositionStrategyOrigin(inputOrigin) {
150
- const overlayOffsetX = this.computeOverlayOffsetX(inputOrigin);
151
- const { width: overlayWidthString } = this.getOverlaySize();
152
- const overlayWidth = Number(overlayWidthString.replace('px', ''));
153
- const { x, y, width, height } = inputOrigin.getBoundingClientRect();
154
- return {
155
- width,
156
- height,
157
- x: width < overlayWidth ? x - overlayOffsetX : x + overlayOffsetX,
158
- y,
159
- };
160
- }
161
- computeOverlayOffsetX(inputOrigin) {
162
- const { width: overlayWidthString } = this.getOverlaySize();
163
- const overlayWidth = Number(overlayWidthString.replace('px', ''));
164
- const inputWidth = inputOrigin.getBoundingClientRect().width;
165
- const extraWidth = overlayWidth - inputWidth;
166
- return Math.abs(extraWidth) / 2;
167
- }
168
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.8", ngImport: i0, type: SystelabVirtualKeyboardOverlayService, deps: [{ token: i1.Overlay }], target: i0.ɵɵFactoryTarget.Injectable }); }
169
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "19.2.8", ngImport: i0, type: SystelabVirtualKeyboardOverlayService, providedIn: 'root' }); }
170
- }
171
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.8", ngImport: i0, type: SystelabVirtualKeyboardOverlayService, decorators: [{
172
- type: Injectable,
173
- args: [{
174
- providedIn: 'root',
175
- }]
176
- }], ctorParameters: () => [{ type: i1.Overlay }] });
177
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"systelab-virtual-keyboard-overlay.service.js","sourceRoot":"","sources":["../../../../projects/systelab-virtual-keyboard/src/lib/systelab-virtual-keyboard-overlay.service.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2020 - 2024 - Instrumentation Laboratory Company and Systelab Technologies, SA. All rights reserved.\n * NOTICE:  All information contained herein is and remains the property of Instrumentation Laboratory Company and its\n * affiliates, if any.  The intellectual and technical concepts contained herein are proprietary to Instrumentation\n * Laboratory Company and its affiliates and may be covered by U.S. and foreign patents and patent applications, and/or\n * are protected by trade secret or copyright law. Dissemination of this information or reproduction of this material is\n * strictly forbidden unless prior written permission is Instrumentation Laboratory Company.\n */\n\nimport { Overlay, OverlayRef, OverlaySizeConfig, PositionStrategy } from '@angular/cdk/overlay';\nimport { ComponentRef, Injectable } from '@angular/core';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { SystelabVirtualKeyboardLayouts } from './constants';\nimport { SystelabVirtualKeyboardComponent } from './systelab-virtual-keyboard.component';\n\ninterface PositionStrategyOrigin {\n  x: number;\n  y: number;\n  width?: number;\n  height?: number;\n}\n\n@Injectable({\n    providedIn: 'root',\n})\nexport class SystelabVirtualKeyboardOverlayService {\n    private overlayRef!: OverlayRef;\n    private inputOrigin: HTMLInputElement;\n    private fixedBottom: boolean;\n    private showKeyboardButtonElement: HTMLElement;\n    private open: boolean;\n    private layout: SystelabVirtualKeyboardLayouts;\n    private clickAlreadyHandled: boolean = false;\n    private touchEndAlreadyHandled: boolean = false;\n\n    constructor(private readonly overlay: Overlay) {\n        this.initListener();\n    }\n\n    public isCreated(): boolean {\n        return !!this.overlayRef;\n    }\n\n    public isOpen(): boolean {\n        return this.open;\n    }\n\n    public create(\n        inputOrigin: HTMLInputElement,\n        showKeyboardButtonElement: HTMLElement,\n        fixedBottom: boolean,\n        layout: SystelabVirtualKeyboardLayouts = SystelabVirtualKeyboardLayouts.default,\n    ): ComponentRef<SystelabVirtualKeyboardComponent> {\n        this.inputOrigin = inputOrigin;\n        this.fixedBottom = fixedBottom;\n        this.showKeyboardButtonElement = showKeyboardButtonElement;\n        this.layout = layout;\n        this.overlayRef = this.overlay.create({\n            hasBackdrop: false,\n            scrollStrategy: this.overlay.scrollStrategies.reposition(),\n            disposeOnNavigation: true,\n            backdropClass: 'systelab-virtual-keyboard__backdrop',\n            panelClass: 'systelab-virtual-keyboard__panel',\n        });\n        if (fixedBottom) {\n            this.overlayRef.addPanelClass('systelab-virtual-keyboard__panel--fixed-bottom');\n        }\n\n        this.updatePositionStrategy(inputOrigin, fixedBottom);\n        this.updateSize();\n\n        this.open = true;\n        return this.overlayRef.attach(new ComponentPortal(SystelabVirtualKeyboardComponent));\n    }\n\n    public updatePosition(): void {\n        this.updatePositionStrategy(this.inputOrigin, this.fixedBottom);\n    }\n\n    public setClickAlreadyHandled(): void {\n        this.clickAlreadyHandled = true;\n    }\n\n    public setTouchEndAlreadyHandled(): void {\n        this.touchEndAlreadyHandled = true;\n    }\n\n    public destroy(): void {\n        if (this.overlayRef) {\n            this.overlayRef.dispose();\n        }\n        this.overlayRef = null;\n        this.open = false;\n    }\n\n    private initListener() {\n        document.addEventListener('click', this.handleClick.bind(this));\n        document.addEventListener('touchend', this.handleTouchEnd.bind(this));\n    }\n\n    private handleClick(event: MouseEvent) {\n        if (this.clickAlreadyHandled) {\n            this.clickAlreadyHandled = false;\n            return;\n        }\n\n        event.stopPropagation();\n        this.handleEventTarget(event.target);\n    }\n\n    private handleTouchEnd(event: TouchEvent) {\n        if (this.touchEndAlreadyHandled) {\n            this.touchEndAlreadyHandled = false;\n            return;\n        }\n\n        event.stopPropagation();\n        this.handleEventTarget(event.target);\n    }\n\n    private handleEventTarget(target: EventTarget) {\n        const showKeyboardButtonTarget: boolean = (target as HTMLElement)?.classList.contains('virtual-keyboard-show-button');\n        const virtualKeyboardTarget: boolean = document.querySelector('.simple-keyboard')?.contains(target as Node);\n        const inputElementTarget: boolean = this.inputOrigin?.contains(target as Node);\n        const containsShowButton: boolean = this.showKeyboardButtonElement?.contains(target as Node);\n\n        if (!virtualKeyboardTarget &&\n            !inputElementTarget &&\n            !containsShowButton &&\n            !showKeyboardButtonTarget) {\n            if (this.isCreated()) {\n                this.destroy();\n            }\n        }\n    }\n\n    public hasAttached(): boolean {\n        return this.overlayRef?.hasAttached();\n    }\n\n    private updatePositionStrategy(inputOrigin: HTMLInputElement, fixedBottom: boolean): void {\n        if (!!this.overlayRef) {\n            this.overlayRef.updatePositionStrategy(this.getPositionStrategy(inputOrigin, fixedBottom));\n        }\n    }\n\n    private updateSize(): void {\n        if (!!this.overlayRef) {\n            this.overlayRef.updateSize(this.getOverlaySize());\n        }\n    }\n\n    private getPositionStrategy(inputOrigin: HTMLInputElement, fixedBottom: boolean): PositionStrategy {\n        if (fixedBottom) {\n            return this.overlay.position().global().centerHorizontally().bottom('0');\n        }\n\n        const pointWithDimensions: PositionStrategyOrigin = this.computePositionStrategyOrigin(inputOrigin);\n\n        return this.overlay\n            .position()\n            .flexibleConnectedTo(pointWithDimensions)\n            .withFlexibleDimensions(false)\n            .withLockedPosition(true)\n            .withPush(false)\n            .withPositions([\n                {\n                    originX: 'start',\n                    originY: 'bottom',\n                    overlayX: 'start',\n                    overlayY: 'top',\n                },\n                {\n                    originX: 'start',\n                    originY: 'top',\n                    overlayX: 'start',\n                    overlayY: 'bottom',\n                },\n                {\n                    originX: 'end',\n                    originY: 'bottom',\n                    overlayX: 'end',\n                    overlayY: 'top',\n                },\n                {\n                    originX: 'end',\n                    originY: 'top',\n                    overlayX: 'end',\n                    overlayY: 'bottom',\n                },\n            ]);\n    }\n\n    private getOverlaySize(): OverlaySizeConfig {\n        const overlayWidth = this.layout === SystelabVirtualKeyboardLayouts.numeric ? '400px' : '1200px';\n\n        return {\n            width: overlayWidth,\n            maxWidth: overlayWidth,\n            minWidth: overlayWidth,\n        };\n    }\n\n    private computePositionStrategyOrigin(inputOrigin: HTMLInputElement): PositionStrategyOrigin {\n        const overlayOffsetX = this.computeOverlayOffsetX(inputOrigin);\n        const { width: overlayWidthString } = this.getOverlaySize();\n        const overlayWidth = Number((overlayWidthString as string).replace('px', ''));\n        const {x, y, width, height} = inputOrigin.getBoundingClientRect();\n        return {\n            width,\n            height,\n            x: width < overlayWidth ? x - overlayOffsetX : x + overlayOffsetX,\n            y,\n        };\n    }\n\n    private computeOverlayOffsetX(inputOrigin: HTMLInputElement): number {\n        const { width: overlayWidthString } = this.getOverlaySize();\n        const overlayWidth = Number((overlayWidthString as string).replace('px', ''));\n        const inputWidth = inputOrigin.getBoundingClientRect().width;\n\n        const extraWidth = overlayWidth - inputWidth;\n\n        return Math.abs(extraWidth) / 2;\n    }\n}\n"]}