systelab-virtual-keyboard 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +37 -0
- package/esm2022/lib/constants.mjs +32 -0
- package/esm2022/lib/systelab-virtual-keyboard-overlay.service.mjs +123 -0
- package/esm2022/lib/systelab-virtual-keyboard.component.mjs +352 -0
- package/esm2022/lib/systelab-virtual-keyboard.config.mjs +3 -0
- package/esm2022/lib/systelab-virtual-keyboard.directive.mjs +190 -0
- package/esm2022/lib/systelab-virtual-keyboard.module.mjs +45 -0
- package/esm2022/public-api.mjs +7 -0
- package/esm2022/systelab-virtual-keyboard.mjs +5 -0
- package/fesm2022/systelab-virtual-keyboard.mjs +739 -0
- package/fesm2022/systelab-virtual-keyboard.mjs.map +1 -0
- package/index.d.ts +6 -0
- package/lib/constants.d.ts +21 -0
- package/lib/constants.d.ts.map +1 -0
- package/lib/systelab-virtual-keyboard-overlay.service.d.ts +26 -0
- package/lib/systelab-virtual-keyboard-overlay.service.d.ts.map +1 -0
- package/lib/systelab-virtual-keyboard.component.d.ts +43 -0
- package/lib/systelab-virtual-keyboard.component.d.ts.map +1 -0
- package/lib/systelab-virtual-keyboard.config.d.ts +7 -0
- package/lib/systelab-virtual-keyboard.config.d.ts.map +1 -0
- package/lib/systelab-virtual-keyboard.directive.d.ts +42 -0
- package/lib/systelab-virtual-keyboard.directive.d.ts.map +1 -0
- package/lib/systelab-virtual-keyboard.module.d.ts +15 -0
- package/lib/systelab-virtual-keyboard.module.d.ts.map +1 -0
- package/package.json +28 -0
- package/public-api.d.ts +5 -0
- package/public-api.d.ts.map +1 -0
- package/systelab-virtual-keyboard.d.ts.map +1 -0
|
@@ -0,0 +1,190 @@
|
|
|
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
|
+
import { Directive, HostListener, Inject, Input, Optional, } from '@angular/core';
|
|
10
|
+
import { DOCUMENT } from '@angular/common';
|
|
11
|
+
import { SystelabVirtualKeyboardInputTypes, SystelabVirtualKeyboardLayouts } from './constants';
|
|
12
|
+
import { VIRTUAL_KEYBOARD_CONFIG } from './systelab-virtual-keyboard.config';
|
|
13
|
+
import * as i0 from "@angular/core";
|
|
14
|
+
import * as i1 from "./systelab-virtual-keyboard-overlay.service";
|
|
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
|
+
onDocumentScroll() {
|
|
29
|
+
if (this.overlayService.isCreated()) {
|
|
30
|
+
// update position and size on scroll
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
set vkEnabled(enabled) {
|
|
34
|
+
if (typeof enabled === 'string') {
|
|
35
|
+
this.enabled = true;
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
this.enabled = enabled;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
;
|
|
42
|
+
get vkEnabled() {
|
|
43
|
+
return this.enabled;
|
|
44
|
+
}
|
|
45
|
+
get vkFixedBottom() {
|
|
46
|
+
return this.fixedBottom;
|
|
47
|
+
}
|
|
48
|
+
set vkFixedBottom(fixedBottom) {
|
|
49
|
+
if (typeof fixedBottom === 'string') {
|
|
50
|
+
this.fixedBottom = true;
|
|
51
|
+
}
|
|
52
|
+
else {
|
|
53
|
+
this.fixedBottom = fixedBottom;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
get vkDebug() {
|
|
57
|
+
return this.debug;
|
|
58
|
+
}
|
|
59
|
+
set vkDebug(debug) {
|
|
60
|
+
this.debug = debug;
|
|
61
|
+
}
|
|
62
|
+
get vkConfig() {
|
|
63
|
+
return this.config;
|
|
64
|
+
}
|
|
65
|
+
set vkConfig(config) {
|
|
66
|
+
this.config = config;
|
|
67
|
+
}
|
|
68
|
+
constructor(elementRef, overlayService, renderer, document, virtualKeyboardConfig) {
|
|
69
|
+
this.elementRef = elementRef;
|
|
70
|
+
this.overlayService = overlayService;
|
|
71
|
+
this.renderer = renderer;
|
|
72
|
+
this.document = document;
|
|
73
|
+
this.virtualKeyboardConfig = virtualKeyboardConfig;
|
|
74
|
+
this.enabled = false;
|
|
75
|
+
this.fixedBottom = false;
|
|
76
|
+
this.debug = false;
|
|
77
|
+
this.config = this.virtualKeyboardConfig;
|
|
78
|
+
}
|
|
79
|
+
ngOnInit() {
|
|
80
|
+
this.attachKeyboardIcon();
|
|
81
|
+
}
|
|
82
|
+
ngAfterViewInit() {
|
|
83
|
+
if (this.vkEnabled) {
|
|
84
|
+
const keyboardIcon = this.elementRef.nativeElement.parentElement.querySelector('i');
|
|
85
|
+
keyboardIcon.addEventListener('click', this.togglePanel.bind(this));
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
ngOnDestroy() {
|
|
89
|
+
if (this.overlayService.isCreated()) {
|
|
90
|
+
this.overlayService.destroy();
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
togglePanel() {
|
|
94
|
+
if (this.overlayService.isOpen()) {
|
|
95
|
+
this.closePanel();
|
|
96
|
+
}
|
|
97
|
+
else {
|
|
98
|
+
this.openPanel();
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
openPanel() {
|
|
102
|
+
if (this.overlayService.isCreated()) {
|
|
103
|
+
this.overlayService.destroy();
|
|
104
|
+
}
|
|
105
|
+
if (this.overlayService.hasAttached()) {
|
|
106
|
+
return;
|
|
107
|
+
}
|
|
108
|
+
const currentLayout = this.getLayout(this.elementRef.nativeElement);
|
|
109
|
+
this.panelRef = this.overlayService.create(this.inputOrigin(), this.vkFixedBottom, currentLayout);
|
|
110
|
+
this.panelRef.instance.debug = this.vkDebug;
|
|
111
|
+
this.panelRef.instance.setActiveInput(this.elementRef.nativeElement);
|
|
112
|
+
this.panelRef.instance.setLayout(currentLayout);
|
|
113
|
+
this.panelRef.instance.closePanel.subscribe(() => this.closePanel());
|
|
114
|
+
}
|
|
115
|
+
getLayout(activeInputElement) {
|
|
116
|
+
if (this.config?.hasOwnProperty('layout')) {
|
|
117
|
+
return this.config.layout;
|
|
118
|
+
}
|
|
119
|
+
if (this.isInputAlphabetic(activeInputElement)) {
|
|
120
|
+
return SystelabVirtualKeyboardLayouts.default;
|
|
121
|
+
}
|
|
122
|
+
else if (this.isInputNumeric(activeInputElement)) {
|
|
123
|
+
return SystelabVirtualKeyboardLayouts.numeric;
|
|
124
|
+
}
|
|
125
|
+
else {
|
|
126
|
+
return SystelabVirtualKeyboardLayouts.default;
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
isInputAlphabetic(activeInputElement) {
|
|
130
|
+
const inputType = activeInputElement?.type;
|
|
131
|
+
return inputType && [SystelabVirtualKeyboardInputTypes.text, SystelabVirtualKeyboardInputTypes.password].some((i) => i === inputType);
|
|
132
|
+
}
|
|
133
|
+
isInputNumeric(activeInputElement) {
|
|
134
|
+
const inputType = activeInputElement?.type;
|
|
135
|
+
return inputType && [SystelabVirtualKeyboardInputTypes.number].some((i) => i === inputType);
|
|
136
|
+
}
|
|
137
|
+
closePanel() {
|
|
138
|
+
this.overlayService.destroy();
|
|
139
|
+
}
|
|
140
|
+
inputOrigin() {
|
|
141
|
+
return this.elementRef.nativeElement;
|
|
142
|
+
}
|
|
143
|
+
attachKeyboardIcon() {
|
|
144
|
+
if (this.vkEnabled) {
|
|
145
|
+
const child = this.document.createElement('i');
|
|
146
|
+
child.classList.add('fa');
|
|
147
|
+
child.classList.add('fa-keyboard');
|
|
148
|
+
child.classList.add('virtual-keyboard-show-button');
|
|
149
|
+
this.renderer.appendChild(this.elementRef.nativeElement.parentElement, child);
|
|
150
|
+
this.showKeyboardButtonElement = child;
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
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 }); }
|
|
155
|
+
}
|
|
156
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImport: i0, type: SystelabVirtualKeyboardDirective, decorators: [{
|
|
157
|
+
type: Directive,
|
|
158
|
+
args: [{
|
|
159
|
+
selector: 'input[vkEnabled], textarea[vkEnabled]',
|
|
160
|
+
}]
|
|
161
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.SystelabVirtualKeyboardOverlayService }, { type: i0.Renderer2 }, { type: undefined, decorators: [{
|
|
162
|
+
type: Inject,
|
|
163
|
+
args: [DOCUMENT]
|
|
164
|
+
}] }, { type: undefined, decorators: [{
|
|
165
|
+
type: Optional
|
|
166
|
+
}, {
|
|
167
|
+
type: Inject,
|
|
168
|
+
args: [VIRTUAL_KEYBOARD_CONFIG]
|
|
169
|
+
}] }], propDecorators: { onDocumentClick: [{
|
|
170
|
+
type: HostListener,
|
|
171
|
+
args: ['document:click', ['$event']]
|
|
172
|
+
}], onDocumentScroll: [{
|
|
173
|
+
type: HostListener,
|
|
174
|
+
args: ['window:touchmove', ['$event']]
|
|
175
|
+
}, {
|
|
176
|
+
type: HostListener,
|
|
177
|
+
args: ['window:touchend', ['$event']]
|
|
178
|
+
}, {
|
|
179
|
+
type: HostListener,
|
|
180
|
+
args: ['window:wheel', ['$event']]
|
|
181
|
+
}], vkEnabled: [{
|
|
182
|
+
type: Input
|
|
183
|
+
}], vkFixedBottom: [{
|
|
184
|
+
type: Input
|
|
185
|
+
}], vkDebug: [{
|
|
186
|
+
type: Input
|
|
187
|
+
}], vkConfig: [{
|
|
188
|
+
type: Input
|
|
189
|
+
}] } });
|
|
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"]}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { SystelabVirtualKeyboardDirective } from './systelab-virtual-keyboard.directive';
|
|
4
|
+
import { OverlayModule } from '@angular/cdk/overlay';
|
|
5
|
+
import { VIRTUAL_KEYBOARD_CONFIG } from './systelab-virtual-keyboard.config';
|
|
6
|
+
import { SystelabVirtualKeyboardOverlayService } from './systelab-virtual-keyboard-overlay.service';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
export const factory = () => {
|
|
9
|
+
const systelabVirtualKeyboardModuleCreated = factory._systelabVirtualKeyboardModuleCreated || false;
|
|
10
|
+
if (systelabVirtualKeyboardModuleCreated) {
|
|
11
|
+
throw new Error('SystelabVirtualKeyboardModuleCreated.forRoot imported to many times');
|
|
12
|
+
}
|
|
13
|
+
factory._systelabVirtualKeyboardModuleCreated = true;
|
|
14
|
+
};
|
|
15
|
+
export class SystelabVirtualKeyboardModule {
|
|
16
|
+
static forRoot(conf) {
|
|
17
|
+
return {
|
|
18
|
+
ngModule: SystelabVirtualKeyboardModule,
|
|
19
|
+
providers: [
|
|
20
|
+
SystelabVirtualKeyboardOverlayService,
|
|
21
|
+
{
|
|
22
|
+
provide: VIRTUAL_KEYBOARD_CONFIG, useValue: conf
|
|
23
|
+
}
|
|
24
|
+
]
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
static forChild() {
|
|
28
|
+
return {
|
|
29
|
+
ngModule: SystelabVirtualKeyboardModule,
|
|
30
|
+
providers: [],
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.9", ngImport: i0, type: SystelabVirtualKeyboardModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
34
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.0.9", ngImport: i0, type: SystelabVirtualKeyboardModule, declarations: [SystelabVirtualKeyboardDirective], imports: [CommonModule, OverlayModule], exports: [SystelabVirtualKeyboardDirective] }); }
|
|
35
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.0.9", ngImport: i0, type: SystelabVirtualKeyboardModule, imports: [CommonModule, OverlayModule] }); }
|
|
36
|
+
}
|
|
37
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImport: i0, type: SystelabVirtualKeyboardModule, decorators: [{
|
|
38
|
+
type: NgModule,
|
|
39
|
+
args: [{
|
|
40
|
+
imports: [CommonModule, OverlayModule],
|
|
41
|
+
declarations: [SystelabVirtualKeyboardDirective],
|
|
42
|
+
exports: [SystelabVirtualKeyboardDirective],
|
|
43
|
+
}]
|
|
44
|
+
}] });
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3lzdGVsYWItdmlydHVhbC1rZXlib2FyZC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9zeXN0ZWxhYi12aXJ0dWFsLWtleWJvYXJkL3NyYy9saWIvc3lzdGVsYWItdmlydHVhbC1rZXlib2FyZC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUF1QixRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDOUQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxnQ0FBZ0MsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQ3pGLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUNyRCxPQUFPLEVBQWlDLHVCQUF1QixFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDNUcsT0FBTyxFQUFFLHFDQUFxQyxFQUFFLE1BQU0sNkNBQTZDLENBQUM7O0FBRXBHLE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxHQUFHLEVBQUU7SUFDMUIsTUFBTSxvQ0FBb0MsR0FBSSxPQUFlLENBQUMscUNBQXFDLElBQUksS0FBSyxDQUFDO0lBQzdHLElBQUksb0NBQW9DLEVBQUU7UUFDeEMsTUFBTSxJQUFJLEtBQUssQ0FBQyxxRUFBcUUsQ0FBQyxDQUFDO0tBQ3hGO0lBQ0EsT0FBZSxDQUFDLHFDQUFxQyxHQUFHLElBQUksQ0FBQztBQUNoRSxDQUFDLENBQUM7QUFPRixNQUFNLE9BQU8sNkJBQTZCO0lBQ2pDLE1BQU0sQ0FBQyxPQUFPLENBQUMsSUFBb0M7UUFDeEQsT0FBTztZQUNMLFFBQVEsRUFBRSw2QkFBNkI7WUFDdkMsU0FBUyxFQUFFO2dCQUNULHFDQUFxQztnQkFDckM7b0JBQ0UsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFFBQVEsRUFBRSxJQUFJO2lCQUNqRDthQUNGO1NBQ0YsQ0FBQztJQUNKLENBQUM7SUFFTSxNQUFNLENBQUMsUUFBUTtRQUNwQixPQUFPO1lBQ0wsUUFBUSxFQUFFLDZCQUE2QjtZQUN2QyxTQUFTLEVBQUUsRUFBRTtTQUNkLENBQUM7SUFDSixDQUFDOzhHQWxCVSw2QkFBNkI7K0dBQTdCLDZCQUE2QixpQkFIekIsZ0NBQWdDLGFBRHJDLFlBQVksRUFBRSxhQUFhLGFBRTNCLGdDQUFnQzsrR0FFL0IsNkJBQTZCLFlBSjlCLFlBQVksRUFBRSxhQUFhOzsyRkFJMUIsNkJBQTZCO2tCQUx6QyxRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxhQUFhLENBQUM7b0JBQ3RDLFlBQVksRUFBRSxDQUFDLGdDQUFnQyxDQUFDO29CQUNoRCxPQUFPLEVBQUUsQ0FBQyxnQ0FBZ0MsQ0FBQztpQkFDNUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBNb2R1bGVXaXRoUHJvdmlkZXJzLCBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IFN5c3RlbGFiVmlydHVhbEtleWJvYXJkRGlyZWN0aXZlIH0gZnJvbSAnLi9zeXN0ZWxhYi12aXJ0dWFsLWtleWJvYXJkLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBPdmVybGF5TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xuaW1wb3J0IHsgU3lzdGVsYWJWaXJ0dWFsS2V5Ym9hcmRDb25maWcsIFZJUlRVQUxfS0VZQk9BUkRfQ09ORklHIH0gZnJvbSAnLi9zeXN0ZWxhYi12aXJ0dWFsLWtleWJvYXJkLmNvbmZpZyc7XG5pbXBvcnQgeyBTeXN0ZWxhYlZpcnR1YWxLZXlib2FyZE92ZXJsYXlTZXJ2aWNlIH0gZnJvbSAnLi9zeXN0ZWxhYi12aXJ0dWFsLWtleWJvYXJkLW92ZXJsYXkuc2VydmljZSc7XG5cbmV4cG9ydCBjb25zdCBmYWN0b3J5ID0gKCkgPT4ge1xuICBjb25zdCBzeXN0ZWxhYlZpcnR1YWxLZXlib2FyZE1vZHVsZUNyZWF0ZWQgPSAoZmFjdG9yeSBhcyBhbnkpLl9zeXN0ZWxhYlZpcnR1YWxLZXlib2FyZE1vZHVsZUNyZWF0ZWQgfHwgZmFsc2U7XG4gIGlmIChzeXN0ZWxhYlZpcnR1YWxLZXlib2FyZE1vZHVsZUNyZWF0ZWQpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ1N5c3RlbGFiVmlydHVhbEtleWJvYXJkTW9kdWxlQ3JlYXRlZC5mb3JSb290IGltcG9ydGVkIHRvIG1hbnkgdGltZXMnKTtcbiAgfVxuICAoZmFjdG9yeSBhcyBhbnkpLl9zeXN0ZWxhYlZpcnR1YWxLZXlib2FyZE1vZHVsZUNyZWF0ZWQgPSB0cnVlO1xufTtcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgT3ZlcmxheU1vZHVsZV0sXG4gIGRlY2xhcmF0aW9uczogW1N5c3RlbGFiVmlydHVhbEtleWJvYXJkRGlyZWN0aXZlXSxcbiAgZXhwb3J0czogW1N5c3RlbGFiVmlydHVhbEtleWJvYXJkRGlyZWN0aXZlXSxcbn0pXG5leHBvcnQgY2xhc3MgU3lzdGVsYWJWaXJ0dWFsS2V5Ym9hcmRNb2R1bGUge1xuICBwdWJsaWMgc3RhdGljIGZvclJvb3QoY29uZj86IFN5c3RlbGFiVmlydHVhbEtleWJvYXJkQ29uZmlnKTogTW9kdWxlV2l0aFByb3ZpZGVyczxTeXN0ZWxhYlZpcnR1YWxLZXlib2FyZE1vZHVsZT4ge1xuICAgIHJldHVybiB7XG4gICAgICBuZ01vZHVsZTogU3lzdGVsYWJWaXJ0dWFsS2V5Ym9hcmRNb2R1bGUsXG4gICAgICBwcm92aWRlcnM6IFtcbiAgICAgICAgU3lzdGVsYWJWaXJ0dWFsS2V5Ym9hcmRPdmVybGF5U2VydmljZSxcbiAgICAgICAge1xuICAgICAgICAgIHByb3ZpZGU6IFZJUlRVQUxfS0VZQk9BUkRfQ09ORklHLCB1c2VWYWx1ZTogY29uZlxuICAgICAgICB9XG4gICAgICBdXG4gICAgfTtcbiAgfVxuXG4gIHB1YmxpYyBzdGF0aWMgZm9yQ2hpbGQoKTogTW9kdWxlV2l0aFByb3ZpZGVyczxTeXN0ZWxhYlZpcnR1YWxLZXlib2FyZE1vZHVsZT4ge1xuICAgIHJldHVybiB7XG4gICAgICBuZ01vZHVsZTogU3lzdGVsYWJWaXJ0dWFsS2V5Ym9hcmRNb2R1bGUsXG4gICAgICBwcm92aWRlcnM6IFtdLFxuICAgIH07XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Public API Surface of systelab-virtual-keyboard
|
|
3
|
+
*/
|
|
4
|
+
export * from './lib/constants';
|
|
5
|
+
export * from './lib/systelab-virtual-keyboard.directive';
|
|
6
|
+
export * from './lib/systelab-virtual-keyboard.module';
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL3N5c3RlbGFiLXZpcnR1YWwta2V5Ym9hcmQvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGlCQUFpQixDQUFDO0FBRWhDLGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyx3Q0FBd0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2Ygc3lzdGVsYWItdmlydHVhbC1rZXlib2FyZFxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbnN0YW50cyc7XG5leHBvcnQgeyBTeXN0ZWxhYlZpcnR1YWxLZXlib2FyZENvbmZpZyB9IGZyb20gJy4vbGliL3N5c3RlbGFiLXZpcnR1YWwta2V5Ym9hcmQuY29uZmlnJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3N5c3RlbGFiLXZpcnR1YWwta2V5Ym9hcmQuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3N5c3RlbGFiLXZpcnR1YWwta2V5Ym9hcmQubW9kdWxlJztcbiJdfQ==
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './public-api';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3lzdGVsYWItdmlydHVhbC1rZXlib2FyZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL3N5c3RlbGFiLXZpcnR1YWwta2V5Ym9hcmQvc3JjL3N5c3RlbGFiLXZpcnR1YWwta2V5Ym9hcmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
|