ngx-touch-keyboard 3.3.0 → 4.0.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.
package/README.md CHANGED
@@ -1,129 +1,141 @@
1
1
  # AngularTouchKeyboard
2
2
 
3
+ An Angular touch keyboard component that provides a customizable on-screen keyboard for input elements.
4
+
3
5
  [![MIT licensed](https://img.shields.io/badge/license-MIT-blue.svg)](LICENSE) [![npm version](https://badge.fury.io/js/ngx-touch-keyboard.svg)](http://badge.fury.io/js/ngx-touch-keyboard) [![Build Status](https://github.com/mohsen77sk/angular-touch-keyboard/workflows/main/badge.svg)](https://github.com/mohsen77sk/angular-touch-keyboard/actions)
4
6
 
5
- ## What is this?
7
+ ![angular touch keyboard](https://mohsen77sk.github.io/angular-touch-keyboard/assets/images/angularTouchKeyboard.png)
6
8
 
7
- Virtual Keyboard for Angular applications.
9
+ ## Features
8
10
 
9
- ![angular touch keyboard](https://mohsen77sk.github.io/angular-touch-keyboard/assets/images/angularTouchKeyboard.png)
11
+ - 📱 Responsive virtual keyboard
12
+ - 🌐 Multiple locale support
13
+ - 🎯 Flexible positioning
14
+ - 🖥️ Full-screen mode support
15
+ - 🎨 Customizable appearance
16
+ - 🔧 Material Design integration
10
17
 
11
18
  ## Demo
12
19
 
13
20
  [https://mohsen77sk.github.io/angular-touch-keyboard/](https://mohsen77sk.github.io/angular-touch-keyboard/)
14
21
 
15
- ## Install
16
-
17
- ### Step 1: Install [ngx-touch-keyboard](https://www.npmjs.com/package/ngx-touch-keyboard)
22
+ ## Installation
18
23
 
19
- ```sh
24
+ ```bash
20
25
  npm install @angular/cdk ngx-touch-keyboard
21
26
  ```
22
27
 
23
- ### Step 2: Import the module
28
+ ## Compatibility
29
+
30
+ The version of this library is synchronized with the major version of Angular to ensure compatibility.
31
+
32
+ | Angular Version | Package Version |
33
+ | --------------- | --------------- |
34
+ | >= 18.0.0 | 4.x |
35
+ | >= 16.0.0 | 3.x |
36
+ | >= 14.0.0 | 2.x |
37
+
38
+ ## Basic Usage
24
39
 
25
- Add `ngxTouchKeyboardModule` as an import in your app's root NgModule.
40
+ Import the `NgxTouchKeyboardModule` in your app.module.ts:
26
41
 
27
42
  ```typescript
28
- import { ngxTouchKeyboardModule } from 'ngx-touch-keyboard';
43
+ import { NgxTouchKeyboardModule } from 'ngx-touch-keyboard';
44
+
29
45
  @NgModule({
30
- ...
31
46
  imports: [
32
- ...
33
- ngxTouchKeyboardModule,
47
+ NgxTouchKeyboardModule
34
48
  ],
35
- ...
36
49
  })
37
50
  export class AppModule { }
38
51
  ```
39
52
 
40
- ### Compatibility
41
-
42
- #### Version [`3.0.0`]
53
+ If you want to set the custom locale, provide `NGX_TOUCH_KEYBOARD_LOCALE` by custom locale
43
54
 
44
- * `@angular/core`: `^16.0.0` || `^17.0.0` || `^18.0.0`
45
- * `@angular/cdk`: `^16.0.0` || `^17.0.0` || `^18.0.0`
55
+ - default locale is `enUS`
46
56
 
47
- #### Version [`2.0.0`]
57
+ ```typescript
58
+ import { NGX_TOUCH_KEYBOARD_LOCALE, faIR } from 'ngx-touch-keyboard';
48
59
 
49
- * `@angular/core`: `^14.0.0` || `^15.0.0`
50
- * `@angular/cdk`: `^14.0.0` || `^15.0.0`
60
+ @NgModule({
61
+ providers: [
62
+ { provide: NGX_TOUCH_KEYBOARD_LOCALE, useValue: faIR }
63
+ ],
64
+ })
65
+ export class AppModule { }
66
+ ```
51
67
 
52
- ## Localization
68
+ Add the directive to your input elements:
53
69
 
54
- AngularTouchKeyboard is localized in 7 keyboard-specific locales:
70
+ ```html
71
+ <input ngxTouchKeyboard [(ngxTouchKeyboardOpen)]="isOpen">
72
+ ```
55
73
 
56
- * `en-US` English (United States) (default)
57
- * `en-UK` English (United Kingdom)
58
- * `fa-IR` Persian (Iran)
59
- * `he-IL` Hebrew (Israel)
60
- * `ka-GE` Georgian (Georgia)
61
- * `ru-RU` Russian (Russia)
62
- * `sv-SE` Swedish (Sweden)
74
+ ## API Reference
63
75
 
64
- ## Usage
76
+ ### Directives
65
77
 
66
- Simple usage example
78
+ #### NgxTouchKeyboard
67
79
 
68
- ```html
69
- <input
70
- type="text"
71
- ngxTouchKeyboard
72
- #touchKeyboard="ngxTouchKeyboard"
73
- (focus)="touchKeyboard.openPanel()"
74
- />
80
+ ```typescript
81
+ @Directive({
82
+ selector: 'input[ngxTouchKeyboard], textarea[ngxTouchKeyboard]'
83
+ })
75
84
  ```
76
85
 
77
- Locale usage example
86
+ ### Inputs
87
+
88
+ | Name | Type | Default | Description |
89
+ | --------------------------------- | ------------------------ | ------- | ---------------------------------------------- |
90
+ | `ngxTouchKeyboardOpen` | `boolean` | `false` | Controls the visibility of the keyboard |
91
+ | `ngxTouchKeyboardLocale` | `Locale` | `enUS` | Sets the keyboard locale |
92
+ | `ngxTouchKeyboardFullScreen` | `boolean` | `false` | Enables full-screen mode |
93
+ | `ngxTouchKeyboardDebug` | `boolean` | `false` | Enables debug mode |
94
+ | `ngxConnectedTouchKeyboardOrigin` | `NgxTouchKeyboardOrigin` | `null` | Sets a custom origin for the keyboard position |
95
+
96
+ ### Methods
97
+
98
+ - `openPanel()`: Opens the keyboard panel
99
+ - `closePanel()`: Closes the keyboard panel
100
+ - `togglePanel()`: Toggles the keyboard panel visibility
101
+
102
+ ## Material Design Integration
103
+
104
+ The component automatically detects and integrates with Angular Material form fields, providing proper positioning and styling.
105
+
106
+ ## Advanced Usage
107
+
108
+ ### Custom locale
78
109
 
79
110
  ```html
80
- <input
81
- type="text"
82
- ngxTouchKeyboard="fa-IR"
83
- #touchKeyboard="ngxTouchKeyboard"
84
- (focus)="touchKeyboard.openPanel()"
85
- />
111
+ <input ngxTouchKeyboard [ngxTouchKeyboardLocale]="faIR">
86
112
  ```
87
113
 
88
- Material usage example
114
+ ### Full-Screen Mode
89
115
 
90
116
  ```html
91
- <mat-form-field>
92
- <mat-label>Default</mat-label>
93
- <input
94
- matInput
95
- type="text"
96
- ngxTouchKeyboard
97
- #touchKeyboard="ngxTouchKeyboard"
98
- />
99
- <button
100
- mat-icon-button
101
- matSuffix
102
- type="button"
103
- (click)="touchKeyboard.togglePanel()"
104
- >
105
- <mat-icon> keyboard </mat-icon>
106
- </button>
107
- </mat-form-field>
117
+ <input ngxTouchKeyboard [ngxTouchKeyboardFullScreen]="true">
108
118
  ```
109
119
 
110
- ### Properties
120
+ ### Custom Position Origin
111
121
 
112
- | Property | Description |
113
- | ---------------------------- | ----------------------------------------------------------- |
114
- | `ngxTouchKeyboard` | Required to initialize Virtual Keyboard to specified input. |
115
- | `ngxTouchKeyboardDebug` | Debug mode is on. |
116
- | `ngxTouchKeyboardFullScreen` | Full screen mode is on. |
122
+ ```html
123
+ <div ngxTouchKeyboardOrigin #origin="ngxTouchKeyboardOrigin">
124
+ <input ngxTouchKeyboard [ngxConnectedTouchKeyboardOrigin]="origin">
125
+ </div>
126
+ ```
117
127
 
118
- ### Methods
128
+ ## Localization
119
129
 
120
- Here's the list of all available methods:
130
+ AngularTouchKeyboard is localized in 7 keyboard-specific locales:
121
131
 
122
- | Methods | Description |
123
- | --------------------- | --------------------- |
124
- | `openPanel(): void` | Open keyboard panel |
125
- | `closePanel(): void` | Close keyboard panel |
126
- | `togglePanel(): void` | Toggle keyboard panel |
132
+ * `en-US` English (United States) (default)
133
+ * `en-UK` English (United Kingdom)
134
+ * `fa-IR` Persian (Iran)
135
+ * `he-IL` Hebrew (Israel)
136
+ * `ka-GE` Georgian (Georgia)
137
+ * `ru-RU` Russian (Russia)
138
+ * `sv-SE` Swedish (Sweden)
127
139
 
128
140
  ## Themes
129
141
 
@@ -167,6 +179,10 @@ The most useful commands for development are:
167
179
  * `npm run start` to start a development server
168
180
  * `npm run build-demo` to build the demo locally (it will be published automatically by GitHub Actions)
169
181
 
182
+ ## Contributing
183
+
184
+ Contributions are welcome! Please feel free to submit a Pull Request.
185
+
170
186
  ## License
171
187
 
172
188
  [The MIT License (MIT)](LICENSE)
@@ -1,3 +1,7 @@
1
+ /**
2
+ * A collection of constants representing special function buttons for a touch keyboard.
3
+ * Each constant is a string that corresponds to a specific keyboard action.
4
+ */
1
5
  export const fnButton = {
2
6
  DONE: `{done}`,
3
7
  ENTER: `{enter}`,
@@ -7,6 +11,9 @@ export const fnButton = {
7
11
  SPACE: `{space}`,
8
12
  TAB: `{tab}`,
9
13
  };
14
+ /**
15
+ * An object containing SVG icons for various keyboard functions.
16
+ */
10
17
  export const fnDisplay = {
11
18
  DONE: `<svg xmlns="http://www.w3.org/2000/svg" height="20" width="20" viewBox="0 0 24 24"><path d="m12 15-5-5h10Z"/></svg>`,
12
19
  ENTER: `<svg xmlns="http://www.w3.org/2000/svg" height="20" width="20" viewBox="0 0 24 24"><path d="m9 18-6-6 6-6 1.4 1.4L6.8 11H19V7h2v6H6.8l3.6 3.6Z"/></svg>`,
@@ -16,4 +23,4 @@ export const fnDisplay = {
16
23
  SPACE: ` `,
17
24
  TAB: `<svg xmlns="http://www.w3.org/2000/svg" height="20" width="20" viewBox="0 0 24 24"><path d="m12 18-1.425-1.4 3.6-3.6H2v-2h12.175L10.6 7.4 12 6l6 6Zm8 0V6h2v12Z"/></svg>`,
18
25
  };
19
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../../projects/ngx-touch-keyboard/src/lib/Locale/constants.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,QAAQ,GAAG;IACtB,IAAI,EAAE,QAAQ;IACd,KAAK,EAAE,SAAS;IAChB,KAAK,EAAE,SAAS;IAChB,SAAS,EAAE,aAAa;IACxB,QAAQ,EAAE,YAAY;IACtB,KAAK,EAAE,SAAS;IAChB,GAAG,EAAE,OAAO;CACb,CAAC;AAEF,MAAM,CAAC,MAAM,SAAS,GAAG;IACvB,IAAI,EAAE,qHAAqH;IAC3H,KAAK,EAAE,yJAAyJ;IAChK,KAAK,EAAE,65CAA65C;IACp6C,SAAS,EAAE,w3DAAw3D;IACn4D,QAAQ,EAAE,u1CAAu1C;IACj2C,KAAK,EAAE,GAAG;IACV,GAAG,EAAE,0KAA0K;CAChL,CAAC","sourcesContent":["export const fnButton = {\r\n  DONE: `{done}`,\r\n  ENTER: `{enter}`,\r\n  SHIFT: `{shift}`,\r\n  BACKSPACE: `{backspace}`,\r\n  LANGUAGE: `{language}`,\r\n  SPACE: `{space}`,\r\n  TAB: `{tab}`,\r\n};\r\n\r\nexport const fnDisplay = {\r\n  DONE: `<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"20\" width=\"20\" viewBox=\"0 0 24 24\"><path d=\"m12 15-5-5h10Z\"/></svg>`,\r\n  ENTER: `<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"20\" width=\"20\" viewBox=\"0 0 24 24\"><path d=\"m9 18-6-6 6-6 1.4 1.4L6.8 11H19V7h2v6H6.8l3.6 3.6Z\"/></svg>`,\r\n  SHIFT: `<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"20\" width=\"20\" viewBox=\"0 0 24 24\"><path d=\"M10.8796773,2.4676627 C10.7983669,2.53542133 10.7233714,2.61041687 10.6556128,2.69172724 L2.79065437,12.1296773 C2.17191723,12.8721619 2.27223434,13.9756501 3.01471891,14.5943872 L3.15432027,14.6993778 C3.44275103,14.8945506 3.78413686,15 4.13504161,15 L6.999,15 L7,20.25 C7,21.2164983 7.78350169,22 8.75,22 L15.25,22 L15.3935272,21.9941988 C16.2928897,21.9211923 17,21.1681734 17,20.25 L16.999,15 L19.8649584,15 C20.8314567,15 21.6149584,14.2164983 21.6149584,13.25 C21.6149584,12.8406111 21.47143,12.4441786 21.2093456,12.1296773 L13.3443872,2.69172724 C12.7600244,1.99049181 11.7432755,1.8620539 11.0066223,2.37118457 L10.8796773,2.4676627 Z M12.1920553,3.65200384 L20.0570137,13.0899539 C20.0944543,13.1348827 20.1149584,13.1915159 20.1149584,13.25 C20.1149584,13.3880712 20.0030296,13.5 19.8649584,13.5 L16.25,13.5 C15.8357864,13.5 15.5,13.8357864 15.5,14.25 L15.5,20.25 C15.5,20.3880712 15.3880712,20.5 15.25,20.5 L8.75,20.5 C8.61192881,20.5 8.5,20.3880712 8.5,20.25 L8.5,14.25 C8.5,13.8357864 8.16421356,13.5 7.75,13.5 L4.13504161,13.5 C4.07655749,13.5 4.01992426,13.4794959 3.97499551,13.4420553 C3.86892629,13.3536643 3.85459527,13.1960231 3.94298629,13.0899539 L11.8079447,3.65200384 C11.8176245,3.64038807 11.8283381,3.62967442 11.8399539,3.61999462 C11.9460231,3.5316036 12.1036643,3.54593461 12.1920553,3.65200384 Z\"></path></svg>`,\r\n  BACKSPACE: `<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"20\" width=\"20\" viewBox=\"0 0 24 24\"><path d=\"M18.75,4 C20.4830315,4 21.8992459,5.35645477 21.9948552,7.06557609 L22,7.25 L22,16.75 C22,18.4830315 20.6435452,19.8992459 18.9344239,19.9948552 L18.75,20 L10.2488122,20 C9.48467584,20 8.74731983,19.7308489 8.16441163,19.243553 L8.00936186,19.1052839 L3.01367221,14.3552839 C1.71288481,13.1184697 1.66102433,11.0613371 2.89783857,9.76054971 L3.01367221,9.64471607 L8.00936186,4.89471607 C8.56313355,4.36817906 9.28295917,4.05514987 10.0411712,4.00663485 L10.2488122,4 L18.75,4 Z M18.75,5.5 L10.2488122,5.5 C9.85605678,5.5 9.47644043,5.63205173 9.16975262,5.87226779 L9.04295431,5.98177019 L4.04726465,10.7317702 L3.98489269,10.7941421 C3.3580909,11.4533647 3.34595643,12.473346 3.93064574,13.1462921 L4.04726465,13.2682298 L9.04295431,18.0182298 C9.32758521,18.2888625 9.69368599,18.4547433 10.0814672,18.4919848 L10.2488122,18.5 L18.75,18.5 C19.6681734,18.5 20.4211923,17.7928897 20.4941988,16.8935272 L20.5,16.75 L20.5,7.25 C20.5,6.3318266 19.7928897,5.57880766 18.8935272,5.5058012 L18.75,5.5 Z M11.4462117,8.39705176 L11.5303301,8.46966991 L14.000116,10.939 L16.4696699,8.46966991 C16.7625631,8.1767767 17.2374369,8.1767767 17.5303301,8.46966991 C17.7965966,8.73593648 17.8208027,9.15260016 17.6029482,9.44621165 L17.5303301,9.53033009 L15.061116,12 L17.5303301,14.4696699 C17.8232233,14.7625631 17.8232233,15.2374369 17.5303301,15.5303301 C17.2640635,15.7965966 16.8473998,15.8208027 16.5537883,15.6029482 L16.4696699,15.5303301 L14.000116,13.061 L11.5303301,15.5303301 C11.2374369,15.8232233 10.7625631,15.8232233 10.4696699,15.5303301 C10.2034034,15.2640635 10.1791973,14.8473998 10.3970518,14.5537883 L10.4696699,14.4696699 L12.939116,12 L10.4696699,9.53033009 C10.1767767,9.23743687 10.1767767,8.76256313 10.4696699,8.46966991 C10.7359365,8.20340335 11.1526002,8.1791973 11.4462117,8.39705176 Z\"></path></svg>`,\r\n  LANGUAGE: `<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"20\" width=\"20\" viewBox=\"0 0 24 24\"><path d=\"M12 22q-2.05 0-3.875-.788-1.825-.787-3.187-2.15-1.363-1.362-2.15-3.187Q2 14.05 2 12q0-2.075.788-3.887.787-1.813 2.15-3.175Q6.3 3.575 8.125 2.787 9.95 2 12 2q2.075 0 3.887.787 1.813.788 3.175 2.151 1.363 1.362 2.15 3.175Q22 9.925 22 12q0 2.05-.788 3.875-.787 1.825-2.15 3.187-1.362 1.363-3.175 2.15Q14.075 22 12 22Zm0-2.05q.65-.9 1.125-1.875T13.9 16h-3.8q.3 1.1.775 2.075.475.975 1.125 1.875Zm-2.6-.4q-.45-.825-.787-1.713Q8.275 16.95 8.05 16H5.1q.725 1.25 1.812 2.175Q8 19.1 9.4 19.55Zm5.2 0q1.4-.45 2.487-1.375Q18.175 17.25 18.9 16h-2.95q-.225.95-.562 1.837-.338.888-.788 1.713ZM4.25 14h3.4q-.075-.5-.113-.988Q7.5 12.525 7.5 12t.037-1.012q.038-.488.113-.988h-3.4q-.125.5-.188.988Q4 11.475 4 12t.062 1.012q.063.488.188.988Zm5.4 0h4.7q.075-.5.113-.988.037-.487.037-1.012t-.037-1.012q-.038-.488-.113-.988h-4.7q-.075.5-.112.988Q9.5 11.475 9.5 12t.038 1.012q.037.488.112.988Zm6.7 0h3.4q.125-.5.188-.988Q20 12.525 20 12t-.062-1.012q-.063-.488-.188-.988h-3.4q.075.5.112.988.038.487.038 1.012t-.038 1.012q-.037.488-.112.988Zm-.4-6h2.95q-.725-1.25-1.813-2.175Q16 4.9 14.6 4.45q.45.825.788 1.712.337.888.562 1.838ZM10.1 8h3.8q-.3-1.1-.775-2.075Q12.65 4.95 12 4.05q-.65.9-1.125 1.875T10.1 8Zm-5 0h2.95q.225-.95.563-1.838.337-.887.787-1.712Q8 4.9 6.912 5.825 5.825 6.75 5.1 8Z\"/></svg>`,\r\n  SPACE: ` `,\r\n  TAB: `<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"20\" width=\"20\" viewBox=\"0 0 24 24\"><path d=\"m12 18-1.425-1.4 3.6-3.6H2v-2h12.175L10.6 7.4 12 6l6 6Zm8 0V6h2v12Z\"/></svg>`,\r\n};\r\n"]}
26
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../../projects/ngx-touch-keyboard/src/lib/Locale/constants.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,MAAM,CAAC,MAAM,QAAQ,GAAG;IACtB,IAAI,EAAE,QAAQ;IACd,KAAK,EAAE,SAAS;IAChB,KAAK,EAAE,SAAS;IAChB,SAAS,EAAE,aAAa;IACxB,QAAQ,EAAE,YAAY;IACtB,KAAK,EAAE,SAAS;IAChB,GAAG,EAAE,OAAO;CACb,CAAC;AAEF;;GAEG;AACH,MAAM,CAAC,MAAM,SAAS,GAAG;IACvB,IAAI,EAAE,qHAAqH;IAC3H,KAAK,EAAE,yJAAyJ;IAChK,KAAK,EAAE,65CAA65C;IACp6C,SAAS,EAAE,w3DAAw3D;IACn4D,QAAQ,EAAE,u1CAAu1C;IACj2C,KAAK,EAAE,GAAG;IACV,GAAG,EAAE,0KAA0K;CAChL,CAAC","sourcesContent":["/**\r\n * A collection of constants representing special function buttons for a touch keyboard.\r\n * Each constant is a string that corresponds to a specific keyboard action.\r\n */\r\nexport const fnButton = {\r\n  DONE: `{done}`,\r\n  ENTER: `{enter}`,\r\n  SHIFT: `{shift}`,\r\n  BACKSPACE: `{backspace}`,\r\n  LANGUAGE: `{language}`,\r\n  SPACE: `{space}`,\r\n  TAB: `{tab}`,\r\n};\r\n\r\n/**\r\n * An object containing SVG icons for various keyboard functions.\r\n */\r\nexport const fnDisplay = {\r\n  DONE: `<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"20\" width=\"20\" viewBox=\"0 0 24 24\"><path d=\"m12 15-5-5h10Z\"/></svg>`,\r\n  ENTER: `<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"20\" width=\"20\" viewBox=\"0 0 24 24\"><path d=\"m9 18-6-6 6-6 1.4 1.4L6.8 11H19V7h2v6H6.8l3.6 3.6Z\"/></svg>`,\r\n  SHIFT: `<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"20\" width=\"20\" viewBox=\"0 0 24 24\"><path d=\"M10.8796773,2.4676627 C10.7983669,2.53542133 10.7233714,2.61041687 10.6556128,2.69172724 L2.79065437,12.1296773 C2.17191723,12.8721619 2.27223434,13.9756501 3.01471891,14.5943872 L3.15432027,14.6993778 C3.44275103,14.8945506 3.78413686,15 4.13504161,15 L6.999,15 L7,20.25 C7,21.2164983 7.78350169,22 8.75,22 L15.25,22 L15.3935272,21.9941988 C16.2928897,21.9211923 17,21.1681734 17,20.25 L16.999,15 L19.8649584,15 C20.8314567,15 21.6149584,14.2164983 21.6149584,13.25 C21.6149584,12.8406111 21.47143,12.4441786 21.2093456,12.1296773 L13.3443872,2.69172724 C12.7600244,1.99049181 11.7432755,1.8620539 11.0066223,2.37118457 L10.8796773,2.4676627 Z M12.1920553,3.65200384 L20.0570137,13.0899539 C20.0944543,13.1348827 20.1149584,13.1915159 20.1149584,13.25 C20.1149584,13.3880712 20.0030296,13.5 19.8649584,13.5 L16.25,13.5 C15.8357864,13.5 15.5,13.8357864 15.5,14.25 L15.5,20.25 C15.5,20.3880712 15.3880712,20.5 15.25,20.5 L8.75,20.5 C8.61192881,20.5 8.5,20.3880712 8.5,20.25 L8.5,14.25 C8.5,13.8357864 8.16421356,13.5 7.75,13.5 L4.13504161,13.5 C4.07655749,13.5 4.01992426,13.4794959 3.97499551,13.4420553 C3.86892629,13.3536643 3.85459527,13.1960231 3.94298629,13.0899539 L11.8079447,3.65200384 C11.8176245,3.64038807 11.8283381,3.62967442 11.8399539,3.61999462 C11.9460231,3.5316036 12.1036643,3.54593461 12.1920553,3.65200384 Z\"></path></svg>`,\r\n  BACKSPACE: `<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"20\" width=\"20\" viewBox=\"0 0 24 24\"><path d=\"M18.75,4 C20.4830315,4 21.8992459,5.35645477 21.9948552,7.06557609 L22,7.25 L22,16.75 C22,18.4830315 20.6435452,19.8992459 18.9344239,19.9948552 L18.75,20 L10.2488122,20 C9.48467584,20 8.74731983,19.7308489 8.16441163,19.243553 L8.00936186,19.1052839 L3.01367221,14.3552839 C1.71288481,13.1184697 1.66102433,11.0613371 2.89783857,9.76054971 L3.01367221,9.64471607 L8.00936186,4.89471607 C8.56313355,4.36817906 9.28295917,4.05514987 10.0411712,4.00663485 L10.2488122,4 L18.75,4 Z M18.75,5.5 L10.2488122,5.5 C9.85605678,5.5 9.47644043,5.63205173 9.16975262,5.87226779 L9.04295431,5.98177019 L4.04726465,10.7317702 L3.98489269,10.7941421 C3.3580909,11.4533647 3.34595643,12.473346 3.93064574,13.1462921 L4.04726465,13.2682298 L9.04295431,18.0182298 C9.32758521,18.2888625 9.69368599,18.4547433 10.0814672,18.4919848 L10.2488122,18.5 L18.75,18.5 C19.6681734,18.5 20.4211923,17.7928897 20.4941988,16.8935272 L20.5,16.75 L20.5,7.25 C20.5,6.3318266 19.7928897,5.57880766 18.8935272,5.5058012 L18.75,5.5 Z M11.4462117,8.39705176 L11.5303301,8.46966991 L14.000116,10.939 L16.4696699,8.46966991 C16.7625631,8.1767767 17.2374369,8.1767767 17.5303301,8.46966991 C17.7965966,8.73593648 17.8208027,9.15260016 17.6029482,9.44621165 L17.5303301,9.53033009 L15.061116,12 L17.5303301,14.4696699 C17.8232233,14.7625631 17.8232233,15.2374369 17.5303301,15.5303301 C17.2640635,15.7965966 16.8473998,15.8208027 16.5537883,15.6029482 L16.4696699,15.5303301 L14.000116,13.061 L11.5303301,15.5303301 C11.2374369,15.8232233 10.7625631,15.8232233 10.4696699,15.5303301 C10.2034034,15.2640635 10.1791973,14.8473998 10.3970518,14.5537883 L10.4696699,14.4696699 L12.939116,12 L10.4696699,9.53033009 C10.1767767,9.23743687 10.1767767,8.76256313 10.4696699,8.46966991 C10.7359365,8.20340335 11.1526002,8.1791973 11.4462117,8.39705176 Z\"></path></svg>`,\r\n  LANGUAGE: `<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"20\" width=\"20\" viewBox=\"0 0 24 24\"><path d=\"M12 22q-2.05 0-3.875-.788-1.825-.787-3.187-2.15-1.363-1.362-2.15-3.187Q2 14.05 2 12q0-2.075.788-3.887.787-1.813 2.15-3.175Q6.3 3.575 8.125 2.787 9.95 2 12 2q2.075 0 3.887.787 1.813.788 3.175 2.151 1.363 1.362 2.15 3.175Q22 9.925 22 12q0 2.05-.788 3.875-.787 1.825-2.15 3.187-1.362 1.363-3.175 2.15Q14.075 22 12 22Zm0-2.05q.65-.9 1.125-1.875T13.9 16h-3.8q.3 1.1.775 2.075.475.975 1.125 1.875Zm-2.6-.4q-.45-.825-.787-1.713Q8.275 16.95 8.05 16H5.1q.725 1.25 1.812 2.175Q8 19.1 9.4 19.55Zm5.2 0q1.4-.45 2.487-1.375Q18.175 17.25 18.9 16h-2.95q-.225.95-.562 1.837-.338.888-.788 1.713ZM4.25 14h3.4q-.075-.5-.113-.988Q7.5 12.525 7.5 12t.037-1.012q.038-.488.113-.988h-3.4q-.125.5-.188.988Q4 11.475 4 12t.062 1.012q.063.488.188.988Zm5.4 0h4.7q.075-.5.113-.988.037-.487.037-1.012t-.037-1.012q-.038-.488-.113-.988h-4.7q-.075.5-.112.988Q9.5 11.475 9.5 12t.038 1.012q.037.488.112.988Zm6.7 0h3.4q.125-.5.188-.988Q20 12.525 20 12t-.062-1.012q-.063-.488-.188-.988h-3.4q.075.5.112.988.038.487.038 1.012t-.038 1.012q-.037.488-.112.988Zm-.4-6h2.95q-.725-1.25-1.813-2.175Q16 4.9 14.6 4.45q.45.825.788 1.712.337.888.562 1.838ZM10.1 8h3.8q-.3-1.1-.775-2.075Q12.65 4.95 12 4.05q-.65.9-1.125 1.875T10.1 8Zm-5 0h2.95q.225-.95.563-1.838.337-.887.787-1.712Q8 4.9 6.912 5.825 5.825 6.75 5.1 8Z\"/></svg>`,\r\n  SPACE: ` `,\r\n  TAB: `<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"20\" width=\"20\" viewBox=\"0 0 24 24\"><path d=\"m12 18-1.425-1.4 3.6-3.6H2v-2h12.175L10.6 7.4 12 6l6 6Zm8 0V6h2v12Z\"/></svg>`,\r\n};\r\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC10b3VjaC1rZXlib2FyZC9zcmMvbGliL0xvY2FsZS90eXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIExheW91dCB7XHJcbiAgW2tleTogc3RyaW5nXTogQXJyYXk8QXJyYXk8c3RyaW5nPj47XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgRGlzcGxheSB7XHJcbiAgW2tleTogc3RyaW5nXTogc3RyaW5nO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIExvY2FsZSB7XHJcbiAgY29kZTogc3RyaW5nO1xyXG4gIGRpcjogJ2x0cicgfCAncnRsJztcclxuICBsYXlvdXRzOiBMYXlvdXQ7XHJcbiAgZGlzcGxheTogRGlzcGxheTtcclxufVxyXG4iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC10b3VjaC1rZXlib2FyZC9zcmMvbGliL0xvY2FsZS90eXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcclxuICogUmVwcmVzZW50cyBhIGtleWJvYXJkIGxheW91dCB3aGVyZSBlYWNoIGtleSBpcyBhc3NvY2lhdGVkIHdpdGggYSAyRCBhcnJheSBvZiBzdHJpbmdzLlxyXG4gKlxyXG4gKiBAaW50ZXJmYWNlIExheW91dFxyXG4gKiBAcHJvcGVydHkge09iamVjdC48c3RyaW5nLCBzdHJpbmdbXVtdPn0gW2tleTogc3RyaW5nXSAtIEEgbWFwcGluZyBvZiBrZXlzIHRvIHRoZWlyIHJlc3BlY3RpdmUgMkQgYXJyYXkgb2Ygc3RyaW5ncy5cclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgTGF5b3V0IHtcclxuICBba2V5OiBzdHJpbmddOiBBcnJheTxBcnJheTxzdHJpbmc+PjtcclxufVxyXG5cclxuLyoqXHJcbiAqIFJlcHJlc2VudHMgYSBkaXNwbGF5IGNvbmZpZ3VyYXRpb24gd2hlcmUgZWFjaCBrZXkgaXMgYXNzb2NpYXRlZCB3aXRoIGEgc3RyaW5nIHZhbHVlLlxyXG4gKlxyXG4gKiBAaW50ZXJmYWNlIERpc3BsYXlcclxuICogQHByb3BlcnR5IHtzdHJpbmd9IFtrZXldIC0gVGhlIGtleSByZXByZXNlbnRpbmcgYSBzcGVjaWZpYyBkaXNwbGF5IGVsZW1lbnQuXHJcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBba2V5OiBzdHJpbmddIC0gVGhlIHN0cmluZyB2YWx1ZSBhc3NvY2lhdGVkIHdpdGggdGhlIGtleS5cclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgRGlzcGxheSB7XHJcbiAgW2tleTogc3RyaW5nXTogc3RyaW5nO1xyXG59XHJcblxyXG4vKipcclxuICogUmVwcmVzZW50cyBhIGxvY2FsZSBjb25maWd1cmF0aW9uIGZvciB0aGUgdG91Y2gga2V5Ym9hcmQuXHJcbiAqXHJcbiAqIEBpbnRlcmZhY2UgTG9jYWxlXHJcbiAqXHJcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBjb2RlIC0gVGhlIGxvY2FsZSBjb2RlIChlLmcuLCAnZW4tVVMnLCAnZnItRlInKS5cclxuICogQHByb3BlcnR5IHsnbHRyJyB8ICdydGwnfSBkaXIgLSBUaGUgdGV4dCBkaXJlY3Rpb24gb2YgdGhlIGxvY2FsZSwgZWl0aGVyICdsdHInIChsZWZ0LXRvLXJpZ2h0KSBvciAncnRsJyAocmlnaHQtdG8tbGVmdCkuXHJcbiAqIEBwcm9wZXJ0eSB7TGF5b3V0fSBsYXlvdXRzIC0gVGhlIGtleWJvYXJkIGxheW91dHMgYXNzb2NpYXRlZCB3aXRoIHRoZSBsb2NhbGUuXHJcbiAqIEBwcm9wZXJ0eSB7RGlzcGxheX0gZGlzcGxheSAtIFRoZSBkaXNwbGF5IHNldHRpbmdzIGZvciB0aGUgbG9jYWxlLlxyXG4gKi9cclxuZXhwb3J0IGludGVyZmFjZSBMb2NhbGUge1xyXG4gIGNvZGU6IHN0cmluZztcclxuICBkaXI6ICdsdHInIHwgJ3J0bCc7XHJcbiAgbGF5b3V0czogTGF5b3V0O1xyXG4gIGRpc3BsYXk6IERpc3BsYXk7XHJcbn1cclxuIl19