UNPKG

ngx-otp-input

Version:

One Time Password input library for Angular (14+)

131 lines 22.4 kB
import { Component, EventEmitter, Input, Output, } from '@angular/core'; import { CommonModule } from '@angular/common'; import { FormArray, FormControl, ReactiveFormsModule, Validators, } from '@angular/forms'; import { PasteDirective } from './directives/paste.directive'; import { AutoFocusDirective } from './directives/autoFocus.directive'; import { InputNavigationsDirective, } from './directives/inputNavigations.directive'; import { AutoBlurDirective } from './directives/autoBlur.directive'; import { AriaLabelsDirective } from './directives/ariaLabels.directive'; import { defaultOptions } from './default.config'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; import * as i2 from "@angular/forms"; export var NgxOtpStatus; (function (NgxOtpStatus) { NgxOtpStatus["SUCCESS"] = "success"; NgxOtpStatus["FAILED"] = "failed"; })(NgxOtpStatus || (NgxOtpStatus = {})); export class NgxOtpInputComponent { constructor() { this.ngxOtpOptions = defaultOptions; this.disabled = false; this.otpChange = new EventEmitter(); this.otpComplete = new EventEmitter(); } set options(customOptions) { this.ngxOtpOptions = { ...defaultOptions, ...customOptions }; } // For testing purposes get ngxOtpOptionsInUse() { return this.ngxOtpOptions; } get inputType() { return this.ngxOtpOptions.hideInputValues ? 'password' : 'text'; } get isOTPSuccess() { return this.status === NgxOtpStatus.SUCCESS; } get isOTPFailed() { return this.status === NgxOtpStatus.FAILED; } ngOnInit() { this.initOtpInputArray(); } ngOnChanges(changes) { const otpChange = changes['otp']; if (otpChange?.currentValue) { if (!otpChange.firstChange) { this.setInitialOtp(otpChange.currentValue); } else { this.ngxOtpOptions.autoFocus = false; } } } initOtpInputArray() { this.ngxOtpInputArray = new FormArray(Array.from({ length: this.ngxOtpOptions.otpLength }, () => new FormControl('', Validators.required))); if (this.otp) { this.setInitialOtp(this.otp); } } setInitialOtp(otp) { if (this.ngxOtpOptions.regexp.test(otp)) { const otpValueArray = otp.split(''); otpValueArray.forEach((value, index) => { this.ngxOtpInputArray.controls[index].setValue(value ?? ''); }); this.emitOtpValueChange(); if (otpValueArray.length !== this.ngxOtpOptions.otpLength) { console.warn('OTP length does not match the provided otpLength option!'); } } else { throw new Error('Invalid OTP provided for the component <ngx-otp-input>'); } } handleInputChanges($event) { const [index, value] = $event; this.ngxOtpInputArray.controls[index].setValue(value); this.emitOtpValueChange(); } handlePasteChange($event) { if ($event.length === this.ngxOtpOptions.otpLength) { this.ngxOtpInputArray.setValue($event); } else { $event.map((value, index) => { this.ngxOtpInputArray.controls[index]?.setValue?.(value); }); } this.emitOtpValueChange(); } emitOtpValueChange() { this.otpChange.emit(this.ngxOtpInputArray.value); if (this.ngxOtpInputArray.valid) { this.otpComplete.emit(this.ngxOtpInputArray.value.join('')); } } isInputFilled(index) { return !!this.ngxOtpInputArray.controls[index].value; } reset() { this.ngxOtpInputArray.reset(); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: NgxOtpInputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.1", type: NgxOtpInputComponent, isStandalone: true, selector: "ngx-otp-input", inputs: { options: "options", status: "status", disabled: "disabled", otp: "otp" }, outputs: { otpChange: "otpChange", otpComplete: "otpComplete" }, usesOnChanges: true, ngImport: i0, template: "<form\n ngxOtpPaste\n ngxInputNavigations\n [regexp]=\"ngxOtpOptions.regexp!\"\n [isFormValid]=\"ngxOtpInputArray.valid\"\n [ngxAutoFocus]=\"ngxOtpOptions.autoFocus!\"\n [ngxAutoBlur]=\"ngxOtpOptions.autoBlur!\"\n [ngxOtpAriaLabels]=\"ngxOtpOptions.ariaLabels!\"\n [ngClass]=\"{\n 'ngx-blinking-cursor': ngxOtpOptions.showBlinkingCursor\n }\"\n (valueChange)=\"handleInputChanges($event)\"\n (handlePaste)=\"handlePasteChange($event)\"\n class=\"ngx-otp-input-form\"\n data-testid=\"ngx-otp-input-form\"\n>\n <input\n *ngFor=\"let control of ngxOtpInputArray.controls; let i = index\"\n #otpInputElement\n [value]=\"control.value\"\n [type]=\"inputType\"\n [inputMode]=\"ngxOtpOptions.inputMode\"\n [disabled]=\"disabled\"\n [ngClass]=\"{\n 'ngx-otp-input-disabled': disabled,\n 'ngx-otp-input-filled': isInputFilled(i),\n 'ngx-otp-input-success': isOTPSuccess,\n 'ngx-otp-input-failed': isOTPFailed\n }\"\n class=\"ngx-otp-input-box\"\n maxlength=\"1\"\n spellcheck=\"false\"\n autocomplete=\"off\"\n autocapitalize=\"off\"\n autocorrect=\"off\"\n data-testid=\"ngx-otp-input-box\"\n />\n</form>\n", styles: [".ngx-otp-input-form{display:inline-flex;gap:.5rem;caret-color:transparent}.ngx-blinking-cursor{caret-color:initial}.ngx-otp-input-box{width:30px;height:35px;padding:.5rem;font-size:1.5rem;text-align:center;border:1px solid #c4c4c4;border-radius:.5rem;outline:none}.ngx-otp-input-box:focus{border-color:#007bff}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: PasteDirective, selector: "[ngxOtpPaste]", inputs: ["regexp"], outputs: ["handlePaste"] }, { kind: "directive", type: AutoFocusDirective, selector: "[ngxAutoFocus]", inputs: ["ngxAutoFocus"] }, { kind: "directive", type: InputNavigationsDirective, selector: "[ngxInputNavigations]", inputs: ["regexp"], outputs: ["valueChange"] }, { kind: "directive", type: AutoBlurDirective, selector: "[ngxAutoBlur]", inputs: ["ngxAutoBlur", "isFormValid"] }, { kind: "directive", type: AriaLabelsDirective, selector: "[ngxOtpAriaLabels]", inputs: ["ngxOtpAriaLabels"] }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: NgxOtpInputComponent, decorators: [{ type: Component, args: [{ standalone: true, imports: [ CommonModule, ReactiveFormsModule, PasteDirective, AutoFocusDirective, InputNavigationsDirective, AutoBlurDirective, AriaLabelsDirective, ], selector: 'ngx-otp-input', template: "<form\n ngxOtpPaste\n ngxInputNavigations\n [regexp]=\"ngxOtpOptions.regexp!\"\n [isFormValid]=\"ngxOtpInputArray.valid\"\n [ngxAutoFocus]=\"ngxOtpOptions.autoFocus!\"\n [ngxAutoBlur]=\"ngxOtpOptions.autoBlur!\"\n [ngxOtpAriaLabels]=\"ngxOtpOptions.ariaLabels!\"\n [ngClass]=\"{\n 'ngx-blinking-cursor': ngxOtpOptions.showBlinkingCursor\n }\"\n (valueChange)=\"handleInputChanges($event)\"\n (handlePaste)=\"handlePasteChange($event)\"\n class=\"ngx-otp-input-form\"\n data-testid=\"ngx-otp-input-form\"\n>\n <input\n *ngFor=\"let control of ngxOtpInputArray.controls; let i = index\"\n #otpInputElement\n [value]=\"control.value\"\n [type]=\"inputType\"\n [inputMode]=\"ngxOtpOptions.inputMode\"\n [disabled]=\"disabled\"\n [ngClass]=\"{\n 'ngx-otp-input-disabled': disabled,\n 'ngx-otp-input-filled': isInputFilled(i),\n 'ngx-otp-input-success': isOTPSuccess,\n 'ngx-otp-input-failed': isOTPFailed\n }\"\n class=\"ngx-otp-input-box\"\n maxlength=\"1\"\n spellcheck=\"false\"\n autocomplete=\"off\"\n autocapitalize=\"off\"\n autocorrect=\"off\"\n data-testid=\"ngx-otp-input-box\"\n />\n</form>\n", styles: [".ngx-otp-input-form{display:inline-flex;gap:.5rem;caret-color:transparent}.ngx-blinking-cursor{caret-color:initial}.ngx-otp-input-box{width:30px;height:35px;padding:.5rem;font-size:1.5rem;text-align:center;border:1px solid #c4c4c4;border-radius:.5rem;outline:none}.ngx-otp-input-box:focus{border-color:#007bff}\n"] }] }], propDecorators: { options: [{ type: Input }], status: [{ type: Input }], disabled: [{ type: Input }], otp: [{ type: Input }], otpChange: [{ type: Output }], otpComplete: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-otp-input.component.js","sourceRoot":"","sources":["../../../../projects/ngx-otp-input/src/lib/ngx-otp-input.component.ts","../../../../projects/ngx-otp-input/src/lib/ngx-otp-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport {\n  FormArray,\n  FormControl,\n  ReactiveFormsModule,\n  Validators,\n} from '@angular/forms';\nimport { PasteDirective } from './directives/paste.directive';\nimport { AutoFocusDirective } from './directives/autoFocus.directive';\nimport {\n  InputNavigationsDirective,\n  OtpValueChangeEvent,\n} from './directives/inputNavigations.directive';\nimport { AutoBlurDirective } from './directives/autoBlur.directive';\nimport { AriaLabelsDirective } from './directives/ariaLabels.directive';\nimport { NgxOtpInputComponentOptions, defaultOptions } from './default.config';\n\nexport enum NgxOtpStatus {\n  SUCCESS = 'success',\n  FAILED = 'failed',\n}\n\n@Component({\n  standalone: true,\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    PasteDirective,\n    AutoFocusDirective,\n    InputNavigationsDirective,\n    AutoBlurDirective,\n    AriaLabelsDirective,\n  ],\n  selector: 'ngx-otp-input',\n  templateUrl: 'ngx-otp-input.component.html',\n  styleUrls: ['ngx-otp-input.component.scss'],\n})\nexport class NgxOtpInputComponent implements OnInit, OnChanges {\n  protected ngxOtpInputArray!: FormArray;\n  protected ngxOtpOptions: NgxOtpInputComponentOptions = defaultOptions;\n\n  @Input() set options(customOptions: NgxOtpInputComponentOptions) {\n    this.ngxOtpOptions = { ...defaultOptions, ...customOptions };\n  }\n\n  @Input() status: NgxOtpStatus | null | undefined;\n  @Input() disabled = false;\n  @Input() otp: string | null | undefined;\n  @Output() otpChange = new EventEmitter<string[]>();\n  @Output() otpComplete = new EventEmitter<string>();\n\n  // For testing purposes\n  get ngxOtpOptionsInUse(): NgxOtpInputComponentOptions {\n    return this.ngxOtpOptions;\n  }\n\n  get inputType(): string {\n    return this.ngxOtpOptions.hideInputValues ? 'password' : 'text';\n  }\n\n  get isOTPSuccess(): boolean {\n    return this.status === NgxOtpStatus.SUCCESS;\n  }\n\n  get isOTPFailed(): boolean {\n    return this.status === NgxOtpStatus.FAILED;\n  }\n\n  ngOnInit(): void {\n    this.initOtpInputArray();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const otpChange = changes['otp'];\n    if (otpChange?.currentValue) {\n      if (!otpChange.firstChange) {\n        this.setInitialOtp(otpChange.currentValue);\n      } else {\n        this.ngxOtpOptions.autoFocus = false;\n      }\n    }\n  }\n\n  private initOtpInputArray(): void {\n    this.ngxOtpInputArray = new FormArray(\n      Array.from(\n        { length: this.ngxOtpOptions.otpLength! },\n        () => new FormControl('', Validators.required),\n      ),\n    );\n    if (this.otp) {\n      this.setInitialOtp(this.otp);\n    }\n  }\n\n  private setInitialOtp(otp: string): void {\n    if (this.ngxOtpOptions.regexp!.test(otp)) {\n      const otpValueArray = otp.split('');\n      otpValueArray.forEach((value, index) => {\n        this.ngxOtpInputArray.controls[index].setValue(value ?? '');\n      });\n      this.emitOtpValueChange();\n      if (otpValueArray.length !== this.ngxOtpOptions.otpLength) {\n        console.warn(\n          'OTP length does not match the provided otpLength option!',\n        );\n      }\n    } else {\n      throw new Error('Invalid OTP provided for the component <ngx-otp-input>');\n    }\n  }\n\n  protected handleInputChanges($event: OtpValueChangeEvent) {\n    const [index, value] = $event;\n    this.ngxOtpInputArray.controls[index].setValue(value);\n    this.emitOtpValueChange();\n  }\n\n  protected handlePasteChange($event: string[]): void {\n    if ($event.length === this.ngxOtpOptions.otpLength) {\n      this.ngxOtpInputArray.setValue($event);\n    } else {\n      $event.map((value, index) => {\n        this.ngxOtpInputArray.controls[index]?.setValue?.(value);\n      });\n    }\n    this.emitOtpValueChange();\n  }\n\n  private emitOtpValueChange(): void {\n    this.otpChange.emit(this.ngxOtpInputArray.value);\n    if (this.ngxOtpInputArray.valid) {\n      this.otpComplete.emit(this.ngxOtpInputArray.value.join(''));\n    }\n  }\n\n  protected isInputFilled(index: number): boolean {\n    return !!this.ngxOtpInputArray.controls[index].value;\n  }\n\n  reset(): void {\n    this.ngxOtpInputArray.reset();\n  }\n}\n","<form\n  ngxOtpPaste\n  ngxInputNavigations\n  [regexp]=\"ngxOtpOptions.regexp!\"\n  [isFormValid]=\"ngxOtpInputArray.valid\"\n  [ngxAutoFocus]=\"ngxOtpOptions.autoFocus!\"\n  [ngxAutoBlur]=\"ngxOtpOptions.autoBlur!\"\n  [ngxOtpAriaLabels]=\"ngxOtpOptions.ariaLabels!\"\n  [ngClass]=\"{\n    'ngx-blinking-cursor': ngxOtpOptions.showBlinkingCursor\n  }\"\n  (valueChange)=\"handleInputChanges($event)\"\n  (handlePaste)=\"handlePasteChange($event)\"\n  class=\"ngx-otp-input-form\"\n  data-testid=\"ngx-otp-input-form\"\n>\n  <input\n    *ngFor=\"let control of ngxOtpInputArray.controls; let i = index\"\n    #otpInputElement\n    [value]=\"control.value\"\n    [type]=\"inputType\"\n    [inputMode]=\"ngxOtpOptions.inputMode\"\n    [disabled]=\"disabled\"\n    [ngClass]=\"{\n      'ngx-otp-input-disabled': disabled,\n      'ngx-otp-input-filled': isInputFilled(i),\n      'ngx-otp-input-success': isOTPSuccess,\n      'ngx-otp-input-failed': isOTPFailed\n    }\"\n    class=\"ngx-otp-input-box\"\n    maxlength=\"1\"\n    spellcheck=\"false\"\n    autocomplete=\"off\"\n    autocapitalize=\"off\"\n    autocorrect=\"off\"\n    data-testid=\"ngx-otp-input-box\"\n  />\n</form>\n"]}