ngx-touch-keyboard
Version:
Virtual Keyboard for Angular applications
231 lines • 25.8 kB
JavaScript
import { booleanAttribute, Directive, effect, ElementRef, inject, input, model, } from '@angular/core';
import { ComponentPortal } from '@angular/cdk/portal';
import { Overlay } from '@angular/cdk/overlay';
import { NgxTouchKeyboardComponent } from './ngx-touch-keyboard.component';
import * as i0 from "@angular/core";
/**
* Directive applied to an element to make it usable as an origin for an keyboard using a
* ConnectedPositionStrategy.
*/
export class NgxTouchKeyboardOrigin {
constructor() {
this.elementRef = inject(ElementRef);
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgxTouchKeyboardOrigin, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.0", type: NgxTouchKeyboardOrigin, selector: "[ngxTouchKeyboardOrigin]", exportAs: ["ngxTouchKeyboardOrigin"], ngImport: i0 }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgxTouchKeyboardOrigin, decorators: [{
type: Directive,
args: [{
selector: '[ngxTouchKeyboardOrigin]',
exportAs: 'ngxTouchKeyboardOrigin',
}]
}] });
/**
* This directive provides methods to open, close, and toggle the touch keyboard panel.
* It also handles the creation and configuration of the overlay used to display the keyboard.
*/
export class NgxTouchKeyboardDirective {
/**
* constructor
*/
constructor() {
this._overlay = inject(Overlay);
this._elementRef = inject((ElementRef));
this.open = model(false, {
alias: 'ngxTouchKeyboardOpen',
});
this.locale = input(undefined, {
alias: 'ngxTouchKeyboardLocale',
});
this.debugMode = input(false, {
alias: 'ngxTouchKeyboardDebug',
transform: booleanAttribute,
});
this.fullScreenMode = input(false, {
alias: 'ngxTouchKeyboardFullScreen',
transform: booleanAttribute,
});
this.origin = input(null, {
alias: 'ngxConnectedTouchKeyboardOrigin',
});
effect(() => {
this.open() ? this.openPanel() : this.closePanel();
});
}
// -----------------------------------------------------------------------------------------------------
// @ Lifecycle hooks
// -----------------------------------------------------------------------------------------------------
/**
* On destroy
*/
ngOnDestroy() {
// Dispose the overlay
if (this._overlayRef) {
this._overlayRef.dispose();
}
}
// -----------------------------------------------------------------------------------------------------
// @ Public methods
// -----------------------------------------------------------------------------------------------------
/**
* Open keyboard panel
*/
openPanel() {
// return if panel is attached
if (this._overlayRef?.hasAttached()) {
return;
}
// Create the overlay if it doesn't exist
if (!this._overlayRef) {
this._createOverlay();
}
// Set overlay class
if (this.fullScreenMode()) {
this._overlayRef.addPanelClass('ngx-touch-keyboard-fullScreen');
}
else {
this._overlayRef.removePanelClass('ngx-touch-keyboard-fullScreen');
}
// Update position the overlay
this._overlayRef.updatePositionStrategy(this._getPositionStrategy(this.fullScreenMode()));
// Update size the overlay
this._overlayRef.updateSize(this._getOverlaySize(this.fullScreenMode()));
// Attach the portal to the overlay
this._panelRef = this._overlayRef.attach(new ComponentPortal(NgxTouchKeyboardComponent));
this._panelRef.instance.debug = this.debugMode();
this._panelRef.instance.setLocale(this.locale());
this._panelRef.instance.setActiveInput(this._elementRef.nativeElement);
this._panelRef.instance.closePanel.subscribe(() => this.closePanel());
this.open.set(true);
}
/**
* Close keyboard panel
*/
closePanel() {
this._overlayRef?.detach();
this.open.set(false);
}
/**
* Toggle keyboard panel
*/
togglePanel() {
if (this.open()) {
this.closePanel();
}
else {
this.openPanel();
}
}
// -----------------------------------------------------------------------------------------------------
// @ Private methods
// -----------------------------------------------------------------------------------------------------
/**
* Create the overlay
*
* @private
*/
_createOverlay() {
this._overlayRef = this._overlay.create({
direction: 'ltr',
hasBackdrop: false,
panelClass: 'ngx-touch-keyboard-overlay-pane',
scrollStrategy: this._overlay.scrollStrategies.noop(),
});
}
/**
* Get position strategy
*
* @param fullscreen
* @private
*/
_getPositionStrategy(fullscreen) {
if (fullscreen) {
return this._overlay.position().global().centerHorizontally().bottom('0');
}
return this._overlay
.position()
.flexibleConnectedTo(this._getOriginElement())
.withLockedPosition()
.withPush()
.withPositions([
{
originX: 'start',
originY: 'bottom',
overlayX: 'start',
overlayY: 'top',
},
{
originX: 'start',
originY: 'top',
overlayX: 'start',
overlayY: 'bottom',
},
{
originX: 'end',
originY: 'bottom',
overlayX: 'end',
overlayY: 'top',
},
{
originX: 'end',
originY: 'top',
overlayX: 'end',
overlayY: 'bottom',
},
]);
}
/**
* Get overlay size
*
* @param fullscreen
* @private
*/
_getOverlaySize(fullscreen) {
if (fullscreen) {
return {
width: '100%',
maxWidth: '100%',
minWidth: '100%',
};
}
return {
width: this._getOriginElement().getBoundingClientRect().width,
maxWidth: this._getOriginElement().getBoundingClientRect().width,
minWidth: '260px',
};
}
/**
* Gets the origin element for the keyboard panel.
*
* @private
*/
_getOriginElement() {
if (this.origin()) {
return this.origin()?.elementRef.nativeElement;
}
const element = this._elementRef.nativeElement;
// Material form field <= v14
if (element.classList.contains('mat-input-element')) {
// Return [mat-form-field-flex] element
return element.parentNode?.parentNode;
}
// Material form field > v14
if (element.classList.contains('mat-mdc-input-element')) {
// Return [mat-mdc-text-field-wrapper] element
return element.parentNode?.parentNode?.parentNode;
}
// Return input
return element;
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgxTouchKeyboardDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.0", type: NgxTouchKeyboardDirective, selector: "input[ngxTouchKeyboard], textarea[ngxTouchKeyboard]", inputs: { open: { classPropertyName: "open", publicName: "ngxTouchKeyboardOpen", isSignal: true, isRequired: false, transformFunction: null }, locale: { classPropertyName: "locale", publicName: "ngxTouchKeyboardLocale", isSignal: true, isRequired: false, transformFunction: null }, debugMode: { classPropertyName: "debugMode", publicName: "ngxTouchKeyboardDebug", isSignal: true, isRequired: false, transformFunction: null }, fullScreenMode: { classPropertyName: "fullScreenMode", publicName: "ngxTouchKeyboardFullScreen", isSignal: true, isRequired: false, transformFunction: null }, origin: { classPropertyName: "origin", publicName: "ngxConnectedTouchKeyboardOrigin", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { open: "ngxTouchKeyboardOpenChange" }, exportAs: ["ngxTouchKeyboard"], ngImport: i0 }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgxTouchKeyboardDirective, decorators: [{
type: Directive,
args: [{
selector: 'input[ngxTouchKeyboard], textarea[ngxTouchKeyboard]',
exportAs: 'ngxTouchKeyboard',
}]
}], ctorParameters: () => [] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-touch-keyboard.directive.js","sourceRoot":"","sources":["../../../../projects/ngx-touch-keyboard/src/lib/ngx-touch-keyboard.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  booleanAttribute,\r\n  ComponentRef,\r\n  Directive,\r\n  effect,\r\n  ElementRef,\r\n  inject,\r\n  input,\r\n  model,\r\n  OnDestroy,\r\n} from '@angular/core';\r\nimport { ComponentPortal } from '@angular/cdk/portal';\r\nimport { Overlay, OverlayRef, OverlaySizeConfig, PositionStrategy } from '@angular/cdk/overlay';\r\nimport { NgxTouchKeyboardComponent } from './ngx-touch-keyboard.component';\r\nimport { Locale } from './Locale/type';\r\n\r\n/**\r\n * Directive applied to an element to make it usable as an origin for an keyboard using a\r\n * ConnectedPositionStrategy.\r\n */\r\n@Directive({\r\n  selector: '[ngxTouchKeyboardOrigin]',\r\n  exportAs: 'ngxTouchKeyboardOrigin',\r\n})\r\nexport class NgxTouchKeyboardOrigin {\r\n  elementRef = inject(ElementRef);\r\n}\r\n\r\n/**\r\n * This directive provides methods to open, close, and toggle the touch keyboard panel.\r\n * It also handles the creation and configuration of the overlay used to display the keyboard.\r\n */\r\n@Directive({\r\n  selector: 'input[ngxTouchKeyboard], textarea[ngxTouchKeyboard]',\r\n  exportAs: 'ngxTouchKeyboard',\r\n})\r\nexport class NgxTouchKeyboardDirective implements OnDestroy {\r\n  private _overlay = inject(Overlay);\r\n  private _elementRef = inject(ElementRef<HTMLInputElement>);\r\n\r\n  open = model(false, {\r\n    alias: 'ngxTouchKeyboardOpen',\r\n  });\r\n\r\n  locale = input<Locale | undefined>(undefined, {\r\n    alias: 'ngxTouchKeyboardLocale',\r\n  });\r\n\r\n  debugMode = input(false, {\r\n    alias: 'ngxTouchKeyboardDebug',\r\n    transform: booleanAttribute,\r\n  });\r\n\r\n  fullScreenMode = input(false, {\r\n    alias: 'ngxTouchKeyboardFullScreen',\r\n    transform: booleanAttribute,\r\n  });\r\n\r\n  origin = input<NgxTouchKeyboardOrigin | null>(null, {\r\n    alias: 'ngxConnectedTouchKeyboardOrigin',\r\n  });\r\n\r\n  private _overlayRef!: OverlayRef;\r\n  private _panelRef!: ComponentRef<NgxTouchKeyboardComponent>;\r\n\r\n  /**\r\n   * constructor\r\n   */\r\n  constructor() {\r\n    effect(() => {\r\n      this.open() ? this.openPanel() : this.closePanel();\r\n    });\r\n  }\r\n\r\n  // -----------------------------------------------------------------------------------------------------\r\n  // @ Lifecycle hooks\r\n  // -----------------------------------------------------------------------------------------------------\r\n\r\n  /**\r\n   * On destroy\r\n   */\r\n  ngOnDestroy(): void {\r\n    // Dispose the overlay\r\n    if (this._overlayRef) {\r\n      this._overlayRef.dispose();\r\n    }\r\n  }\r\n\r\n  // -----------------------------------------------------------------------------------------------------\r\n  // @ Public methods\r\n  // -----------------------------------------------------------------------------------------------------\r\n\r\n  /**\r\n   * Open keyboard panel\r\n   */\r\n  openPanel(): void {\r\n    // return if panel is attached\r\n    if (this._overlayRef?.hasAttached()) {\r\n      return;\r\n    }\r\n\r\n    // Create the overlay if it doesn't exist\r\n    if (!this._overlayRef) {\r\n      this._createOverlay();\r\n    }\r\n\r\n    // Set overlay class\r\n    if (this.fullScreenMode()) {\r\n      this._overlayRef.addPanelClass('ngx-touch-keyboard-fullScreen');\r\n    } else {\r\n      this._overlayRef.removePanelClass('ngx-touch-keyboard-fullScreen');\r\n    }\r\n\r\n    // Update position the overlay\r\n    this._overlayRef.updatePositionStrategy(this._getPositionStrategy(this.fullScreenMode()));\r\n\r\n    // Update size the overlay\r\n    this._overlayRef.updateSize(this._getOverlaySize(this.fullScreenMode()));\r\n\r\n    // Attach the portal to the overlay\r\n    this._panelRef = this._overlayRef.attach(new ComponentPortal(NgxTouchKeyboardComponent));\r\n    this._panelRef.instance.debug = this.debugMode();\r\n    this._panelRef.instance.setLocale(this.locale());\r\n    this._panelRef.instance.setActiveInput(this._elementRef.nativeElement);\r\n    this._panelRef.instance.closePanel.subscribe(() => this.closePanel());\r\n    this.open.set(true);\r\n  }\r\n\r\n  /**\r\n   * Close keyboard panel\r\n   */\r\n  closePanel(): void {\r\n    this._overlayRef?.detach();\r\n    this.open.set(false);\r\n  }\r\n\r\n  /**\r\n   * Toggle keyboard panel\r\n   */\r\n  togglePanel(): void {\r\n    if (this.open()) {\r\n      this.closePanel();\r\n    } else {\r\n      this.openPanel();\r\n    }\r\n  }\r\n\r\n  // -----------------------------------------------------------------------------------------------------\r\n  // @ Private methods\r\n  // -----------------------------------------------------------------------------------------------------\r\n\r\n  /**\r\n   * Create the overlay\r\n   *\r\n   * @private\r\n   */\r\n  private _createOverlay(): void {\r\n    this._overlayRef = this._overlay.create({\r\n      direction: 'ltr',\r\n      hasBackdrop: false,\r\n      panelClass: 'ngx-touch-keyboard-overlay-pane',\r\n      scrollStrategy: this._overlay.scrollStrategies.noop(),\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Get position strategy\r\n   *\r\n   * @param fullscreen\r\n   * @private\r\n   */\r\n  private _getPositionStrategy(fullscreen: boolean): PositionStrategy {\r\n    if (fullscreen) {\r\n      return this._overlay.position().global().centerHorizontally().bottom('0');\r\n    }\r\n\r\n    return this._overlay\r\n      .position()\r\n      .flexibleConnectedTo(this._getOriginElement())\r\n      .withLockedPosition()\r\n      .withPush()\r\n      .withPositions([\r\n        {\r\n          originX: 'start',\r\n          originY: 'bottom',\r\n          overlayX: 'start',\r\n          overlayY: 'top',\r\n        },\r\n        {\r\n          originX: 'start',\r\n          originY: 'top',\r\n          overlayX: 'start',\r\n          overlayY: 'bottom',\r\n        },\r\n        {\r\n          originX: 'end',\r\n          originY: 'bottom',\r\n          overlayX: 'end',\r\n          overlayY: 'top',\r\n        },\r\n        {\r\n          originX: 'end',\r\n          originY: 'top',\r\n          overlayX: 'end',\r\n          overlayY: 'bottom',\r\n        },\r\n      ]);\r\n  }\r\n\r\n  /**\r\n   * Get overlay size\r\n   *\r\n   * @param fullscreen\r\n   * @private\r\n   */\r\n  private _getOverlaySize(fullscreen: boolean): OverlaySizeConfig {\r\n    if (fullscreen) {\r\n      return {\r\n        width: '100%',\r\n        maxWidth: '100%',\r\n        minWidth: '100%',\r\n      };\r\n    }\r\n\r\n    return {\r\n      width: this._getOriginElement().getBoundingClientRect().width,\r\n      maxWidth: this._getOriginElement().getBoundingClientRect().width,\r\n      minWidth: '260px',\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Gets the origin element for the keyboard panel.\r\n   *\r\n   * @private\r\n   */\r\n  private _getOriginElement(): any {\r\n    if (this.origin()) {\r\n      return this.origin()?.elementRef.nativeElement;\r\n    }\r\n\r\n    const element = this._elementRef.nativeElement;\r\n\r\n    // Material form field <= v14\r\n    if (element.classList.contains('mat-input-element')) {\r\n      // Return [mat-form-field-flex] element\r\n      return element.parentNode?.parentNode;\r\n    }\r\n\r\n    // Material form field > v14\r\n    if (element.classList.contains('mat-mdc-input-element')) {\r\n      // Return [mat-mdc-text-field-wrapper] element\r\n      return element.parentNode?.parentNode?.parentNode;\r\n    }\r\n\r\n    // Return input\r\n    return element;\r\n  }\r\n}\r\n"]}