| | @@ -90,3 +90,3 @@ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core'; |
| | Fs2faVerificationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: Fs2faVerificationComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.FsDialog }, { token: i2.FsMessage }], target: i0.ɵɵFactoryTarget.Component }); |
| | Fs2faVerificationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: Fs2faVerificationComponent, selector: "fs-2fa-verification", inputs: { verificationMethod: "verificationMethod", resend: "resend", showTrustedDevice: "showTrustedDevice", trustDevice: "trustDevice", trustDays: "trustDays", formatRecipient: "formatRecipient", getVerificationMethods: "getVerificationMethods", selectVerificationMethod: "selectVerificationMethod" }, outputs: { verified: "verified", codeChanged: "codeChanged", codeCompleted: "codeCompleted", trustDeviceChange: "trustDeviceChange" }, viewQueries: [{ propertyName: "verificationCodeComponent", first: true, predicate: Fs2faVerificationCodeComponent, descendants: true }], ngImport: i0, template: "<div class=\"code-container\">\n <fs-2fa-verification-code\n [recipient]=\"(formatRecipient && verificationMethod.type === VerificationMethodType.Sms) ? (recipient | fsPhone) : recipient\"\n [type]=\"verificationMethod.type\"\n [code]=\"code\"\n (codeChanged)=\"codeChanged.emit($event)\"\n (codeCompleted)=\"codeCompleted.emit()\">\n </fs-2fa-verification-code>\n</div>\n\n<div class=\"additional\">\n <div \n class=\"trust-device\"\n *ngIf=\"showTrustedDevice\">\n <mat-checkbox\n name=\"trust-device\"\n [(ngModel)]=\"trustDevice\"\n (ngModelChange)=\"trustDeviceChange.emit($event)\">\n Trust device\n <div class=\"small\">\n Bypass 2-Step Verification on this browser <ng-container *ngIf=\"trustDays\">for {{trustDays}} days</ng-container> unless you clear cookies.\n </div>\n </mat-checkbox>\n </div>\n</div>", styles: [":host ::ng-deep .mat-checkbox{margin:2px 0}:host ::ng-deep .mat-checkbox .mat-checkbox-label{line-height:normal}:host ::ng-deep .mat-checkbox .mat-checkbox-layout{white-space:normal}.code-container{text-align:center;margin-bottom:1.25em}.additional{display:flex;justify-content:space-between;align-items:center;margin:4px 0 5px}.additional small{color:inherit}.additional .resend{cursor:pointer;text-transform:none}.additional .resend mat-spinner{display:inline-block;vertical-align:middle}\n"], components: [{ type: i3.Fs2faVerificationCodeComponent, selector: "fs-2fa-verification-code", inputs: ["type", "recipient", "code"], outputs: ["codeChanged", "codeCompleted"] }, { type: i4.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex", "aria-label", "aria-labelledby", "id", "labelPosition", "name", "required", "checked", "disabled", "indeterminate", "aria-describedby", "value"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i7.FsFormNoFsValidatorsDirective, selector: "[ngModel]:not([required]):not([fsFormRequired]):not([fsFormCompare]):not([fsFormDateRange]):not([fsFormEmail]):not([fsFormEmails]):not([fsFormFunction]):not([fsFormGreater]):not([fsFormInteger]):not([fsFormLesser]):not([fsFormMax]):not([fsFormMaxLength]):not([fsFormMin]):not([fsFormMinLength]):not([fsFormNumeric]):not([fsFormPattern]):not([fsFormPhone]):not([fsFormUrl]):not([validate])" }], pipes: { "fsPhone": i8.FsPhonePipe }, viewProviders: [{ provide: ControlContainer, useExisting: NgForm }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); |
| | Fs2faVerificationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: Fs2faVerificationComponent, selector: "fs-2fa-verification", inputs: { verificationMethod: "verificationMethod", resend: "resend", showTrustedDevice: "showTrustedDevice", trustDevice: "trustDevice", trustDays: "trustDays", formatRecipient: "formatRecipient", getVerificationMethods: "getVerificationMethods", selectVerificationMethod: "selectVerificationMethod" }, outputs: { verified: "verified", codeChanged: "codeChanged", codeCompleted: "codeCompleted", trustDeviceChange: "trustDeviceChange" }, viewQueries: [{ propertyName: "verificationCodeComponent", first: true, predicate: Fs2faVerificationCodeComponent, descendants: true }], ngImport: i0, template: "<div class=\"code-container\">\n <fs-2fa-verification-code\n [recipient]=\"(formatRecipient && verificationMethod.type === VerificationMethodType.Sms) ? (recipient | fsPhone) : recipient\"\n [type]=\"verificationMethod.type\"\n [code]=\"code\"\n (codeChanged)=\"codeChanged.emit($event)\"\n (codeCompleted)=\"codeCompleted.emit()\">\n </fs-2fa-verification-code>\n</div>\n\n<div class=\"additional\">\n <div \n class=\"trust-device\"\n *ngIf=\"showTrustedDevice\">\n <mat-checkbox\n name=\"trust-device\"\n [(ngModel)]=\"trustDevice\"\n (ngModelChange)=\"trustDeviceChange.emit($event)\">\n <div class=\"small\">\n Bypass verification \n <ng-container *ngIf=\"trustDays\">for {{trustDays}} days</ng-container> \n <ng-container *ngIf=\"!trustDays\">for future signins</ng-container> \n unless cookies are cleared\n </div>\n </mat-checkbox>\n </div>\n</div>", styles: [":host ::ng-deep .mat-checkbox{margin:2px 0}:host ::ng-deep .mat-checkbox .mat-checkbox-label{line-height:normal}:host ::ng-deep .mat-checkbox .mat-checkbox-layout{white-space:normal}.code-container{text-align:center}.additional{display:flex;justify-content:space-between;align-items:center;margin:4px 0 5px}.additional small{color:inherit}.additional .resend{cursor:pointer;text-transform:none}.additional .resend mat-spinner{display:inline-block;vertical-align:middle}\n"], components: [{ type: i3.Fs2faVerificationCodeComponent, selector: "fs-2fa-verification-code", inputs: ["type", "recipient", "code"], outputs: ["codeChanged", "codeCompleted"] }, { type: i4.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex", "aria-label", "aria-labelledby", "id", "labelPosition", "name", "required", "checked", "disabled", "indeterminate", "aria-describedby", "value"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i7.FsFormNoFsValidatorsDirective, selector: "[ngModel]:not([required]):not([fsFormRequired]):not([fsFormCompare]):not([fsFormDateRange]):not([fsFormEmail]):not([fsFormEmails]):not([fsFormFunction]):not([fsFormGreater]):not([fsFormInteger]):not([fsFormLesser]):not([fsFormMax]):not([fsFormMaxLength]):not([fsFormMin]):not([fsFormMinLength]):not([fsFormNumeric]):not([fsFormPattern]):not([fsFormPhone]):not([fsFormUrl]):not([validate])" }], pipes: { "fsPhone": i8.FsPhonePipe }, viewProviders: [{ provide: ControlContainer, useExisting: NgForm }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); |
| | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: Fs2faVerificationComponent, decorators: [{ |
| | @@ -129,2 +129,2 @@ type: Component, |
| | }] } }); |
| | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"2fa-verification.component.js","sourceRoot":"","sources":["../../../../../../../src/app/modules/verification/components/2fa-verification/2fa-verification.component.ts","../../../../../../../src/app/modules/verification/components/2fa-verification/2fa-verification.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport { ControlContainer, NgForm } from '@angular/forms';\n\nimport { Observable, Subject } from 'rxjs';\n\nimport { FsMessage } from '@firestitch/message';\nimport { FsDialog } from '@firestitch/dialog';\n\nimport { filter, finalize, takeUntil, tap } from 'rxjs/operators';\n\nimport { IFsVerificationMethod } from '../../../../interfaces/verification-method.interface';\nimport { Fs2faVerificationMethodsComponent } from '../2fa-verification-methods/2fa-verification-methods.component';\nimport { VerificationMethodType } from '../../../../enums/verification-method-type.enum';\nimport { Fs2faVerificationCodeComponent } from '../2fa-verification-code/2fa-verification-code.component';\n\n\n@Component({\n  selector: 'fs-2fa-verification',\n  templateUrl: './2fa-verification.component.html',\n  styleUrls: ['./2fa-verification.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,  \n  viewProviders: [{ provide: ControlContainer, useExisting: NgForm }],\n})\nexport class Fs2faVerificationComponent implements OnDestroy, AfterViewInit, OnInit {\n\n  @ViewChild(Fs2faVerificationCodeComponent)\n  public verificationCodeComponent: Fs2faVerificationCodeComponent;\n\n  @Input()\n  public verificationMethod: IFsVerificationMethod;\n\n  @Input()\n  public resend: () => Observable<void>;\n\n  @Input()\n  public showTrustedDevice = true;\n\n  @Input()\n  public trustDevice = true;\n\n  @Input()\n  public trustDays;\n\n  @Input()\n  public formatRecipient = false;\n\n  @Input()\n  public getVerificationMethods: () => Observable<IFsVerificationMethod[]>;\n\n  @Input()\n  public selectVerificationMethod: (verificationMethod: IFsVerificationMethod) => Observable<IFsVerificationMethod>;\n\n  @Output()\n  public verified = new EventEmitter<unknown>();\n\n  @Output()\n  public codeChanged = new EventEmitter<unknown>();\n\n  @Output()\n  public codeCompleted = new EventEmitter<unknown>();\n\n  @Output()\n  public trustDeviceChange = new EventEmitter<boolean>();\n\n  public code = '';\n  public VerificationMethodType = VerificationMethodType;\n\n  private _destroy$ = new Subject<void>();\n\n  constructor(\n    private _cdRef: ChangeDetectorRef,\n    private _dialog: FsDialog,\n    private _message: FsMessage,\n  ) {}\n\n  public get recipient(): string {\n    if(this.verificationMethod.type === VerificationMethodType.Email) {\n      return this.verificationMethod.email;\n    }\n\n    if(this.verificationMethod.type === VerificationMethodType.Sms) {\n      return this.verificationMethod.phoneNumber;\n    }\n  }\n\n  public ngOnInit(): void {\n    this.codeChanged\n    .pipe(\n      takeUntil(this._destroy$),\n    )\n    .subscribe((code: string) => {\n      this.code = code;\n    });\n  }\n\n  public ngOnDestroy(): void {\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  public ngAfterViewInit(): void {\n    this.verificationCodeComponent.focus();    \n  }\n\n  public resendCode(): Observable<any> {\n    return this.resend()\n      .pipe(\n        tap(() => {\n          this.code = '';\n          this._message.success('Resent Code');\n        }),\n        finalize(() => {\n          this.verificationCodeComponent.focus();  \n        }),\n      );\n  }\n\n  public showVerificationMethods(): void {\n    this.getVerificationMethods()\n    .subscribe((verificationMethods) => {\n      this._dialog.open(\n        Fs2faVerificationMethodsComponent,\n        {\n          data: {\n            verificationMethod: this.verificationMethod,\n            verificationMethods,\n            selectVerificationMethod: this.selectVerificationMethod,\n          }\n        }\n      )\n        .afterClosed()\n        .pipe(\n          filter((verificationMethod) => !!verificationMethod),\n        )\n        .subscribe((verificationMethod) => {\n          this.verificationMethod = verificationMethod;\n          this.code = '';\n          this._cdRef.markForCheck();\n\n          setTimeout(() => {\n            this.verificationCodeComponent.focus();\n          });\n        });\n    });\n  }\n\n}\n","<div class=\"code-container\">\n  <fs-2fa-verification-code\n    [recipient]=\"(formatRecipient && verificationMethod.type === VerificationMethodType.Sms) ? (recipient | fsPhone) : recipient\"\n    [type]=\"verificationMethod.type\"\n    [code]=\"code\"\n    (codeChanged)=\"codeChanged.emit($event)\"\n    (codeCompleted)=\"codeCompleted.emit()\">\n  </fs-2fa-verification-code>\n</div>\n\n<div class=\"additional\">\n  <div \n      class=\"trust-device\"\n      *ngIf=\"showTrustedDevice\">\n    <mat-checkbox\n          name=\"trust-device\"\n          [(ngModel)]=\"trustDevice\"\n          (ngModelChange)=\"trustDeviceChange.emit($event)\">\n        Trust device\n      <div class=\"small\">\n        Bypass 2-Step Verification on this browser <ng-container *ngIf=\"trustDays\">for {{trustDays}} days</ng-container> unless you clear cookies.\n      </div>\n    </mat-checkbox>\n  </div>\n</div>"]} |
| | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"2fa-verification.component.js","sourceRoot":"","sources":["../../../../../../../src/app/modules/verification/components/2fa-verification/2fa-verification.component.ts","../../../../../../../src/app/modules/verification/components/2fa-verification/2fa-verification.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,KAAK,EAGL,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,gBAAgB,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AAE1D,OAAO,EAAc,OAAO,EAAE,MAAM,MAAM,CAAC;AAE3C,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAE9C,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AAGlE,OAAO,EAAE,iCAAiC,EAAE,MAAM,gEAAgE,CAAC;AACnH,OAAO,EAAE,sBAAsB,EAAE,MAAM,iDAAiD,CAAC;AACzF,OAAO,EAAE,8BAA8B,EAAE,MAAM,0DAA0D,CAAC;;;;;;;;;;AAU1G,MAAM,OAAO,0BAA0B;IA8CrC,YACU,MAAyB,EACzB,OAAiB,EACjB,QAAmB;QAFnB,WAAM,GAAN,MAAM,CAAmB;QACzB,YAAO,GAAP,OAAO,CAAU;QACjB,aAAQ,GAAR,QAAQ,CAAW;QArCtB,sBAAiB,GAAG,IAAI,CAAC;QAGzB,gBAAW,GAAG,IAAI,CAAC;QAMnB,oBAAe,GAAG,KAAK,CAAC;QASxB,aAAQ,GAAG,IAAI,YAAY,EAAW,CAAC;QAGvC,gBAAW,GAAG,IAAI,YAAY,EAAW,CAAC;QAG1C,kBAAa,GAAG,IAAI,YAAY,EAAW,CAAC;QAG5C,sBAAiB,GAAG,IAAI,YAAY,EAAW,CAAC;QAEhD,SAAI,GAAG,EAAE,CAAC;QACV,2BAAsB,GAAG,sBAAsB,CAAC;QAE/C,cAAS,GAAG,IAAI,OAAO,EAAQ,CAAC;IAMrC,CAAC;IAEJ,IAAW,SAAS;QAClB,IAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,KAAK,sBAAsB,CAAC,KAAK,EAAE;YAChE,OAAO,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC;SACtC;QAED,IAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,KAAK,sBAAsB,CAAC,GAAG,EAAE;YAC9D,OAAO,IAAI,CAAC,kBAAkB,CAAC,WAAW,CAAC;SAC5C;IACH,CAAC;IAEM,QAAQ;QACb,IAAI,CAAC,WAAW;aACf,IAAI,CACH,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAC1B;aACA,SAAS,CAAC,CAAC,IAAY,EAAE,EAAE;YAC1B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACnB,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACtB,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IAC5B,CAAC;IAEM,eAAe;QACpB,IAAI,CAAC,yBAAyB,CAAC,KAAK,EAAE,CAAC;IACzC,CAAC;IAEM,UAAU;QACf,OAAO,IAAI,CAAC,MAAM,EAAE;aACjB,IAAI,CACH,GAAG,CAAC,GAAG,EAAE;YACP,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;YACf,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QACvC,CAAC,CAAC,EACF,QAAQ,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,yBAAyB,CAAC,KAAK,EAAE,CAAC;QACzC,CAAC,CAAC,CACH,CAAC;IACN,CAAC;IAEM,uBAAuB;QAC5B,IAAI,CAAC,sBAAsB,EAAE;aAC5B,SAAS,CAAC,CAAC,mBAAmB,EAAE,EAAE;YACjC,IAAI,CAAC,OAAO,CAAC,IAAI,CACf,iCAAiC,EACjC;gBACE,IAAI,EAAE;oBACJ,kBAAkB,EAAE,IAAI,CAAC,kBAAkB;oBAC3C,mBAAmB;oBACnB,wBAAwB,EAAE,IAAI,CAAC,wBAAwB;iBACxD;aACF,CACF;iBACE,WAAW,EAAE;iBACb,IAAI,CACH,MAAM,CAAC,CAAC,kBAAkB,EAAE,EAAE,CAAC,CAAC,CAAC,kBAAkB,CAAC,CACrD;iBACA,SAAS,CAAC,CAAC,kBAAkB,EAAE,EAAE;gBAChC,IAAI,CAAC,kBAAkB,GAAG,kBAAkB,CAAC;gBAC7C,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;gBACf,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;gBAE3B,UAAU,CAAC,GAAG,EAAE;oBACd,IAAI,CAAC,yBAAyB,CAAC,KAAK,EAAE,CAAC;gBACzC,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACL,CAAC;;wHAzHU,0BAA0B;4GAA1B,0BAA0B,6iBAE1B,8BAA8B,gDCpC3C,87BA0BM,k0DDMW,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAE,WAAW,EAAE,MAAM,EAAE,CAAC;4FAExD,0BAA0B;kBAPtC,SAAS;mBAAC;oBACT,QAAQ,EAAE,qBAAqB;oBAC/B,WAAW,EAAE,mCAAmC;oBAChD,SAAS,EAAE,CAAC,mCAAmC,CAAC;oBAChD,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,aAAa,EAAE,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAE,WAAW,EAAE,MAAM,EAAE,CAAC;iBACpE;uJAIQ,yBAAyB;sBAD/B,SAAS;uBAAC,8BAA8B;gBAIlC,kBAAkB;sBADxB,KAAK;gBAIC,MAAM;sBADZ,KAAK;gBAIC,iBAAiB;sBADvB,KAAK;gBAIC,WAAW;sBADjB,KAAK;gBAIC,SAAS;sBADf,KAAK;gBAIC,eAAe;sBADrB,KAAK;gBAIC,sBAAsB;sBAD5B,KAAK;gBAIC,wBAAwB;sBAD9B,KAAK;gBAIC,QAAQ;sBADd,MAAM;gBAIA,WAAW;sBADjB,MAAM;gBAIA,aAAa;sBADnB,MAAM;gBAIA,iBAAiB;sBADvB,MAAM","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport { ControlContainer, NgForm } from '@angular/forms';\n\nimport { Observable, Subject } from 'rxjs';\n\nimport { FsMessage } from '@firestitch/message';\nimport { FsDialog } from '@firestitch/dialog';\n\nimport { filter, finalize, takeUntil, tap } from 'rxjs/operators';\n\nimport { IFsVerificationMethod } from '../../../../interfaces/verification-method.interface';\nimport { Fs2faVerificationMethodsComponent } from '../2fa-verification-methods/2fa-verification-methods.component';\nimport { VerificationMethodType } from '../../../../enums/verification-method-type.enum';\nimport { Fs2faVerificationCodeComponent } from '../2fa-verification-code/2fa-verification-code.component';\n\n\n@Component({\n  selector: 'fs-2fa-verification',\n  templateUrl: './2fa-verification.component.html',\n  styleUrls: ['./2fa-verification.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,  \n  viewProviders: [{ provide: ControlContainer, useExisting: NgForm }],\n})\nexport class Fs2faVerificationComponent implements OnDestroy, AfterViewInit, OnInit {\n\n  @ViewChild(Fs2faVerificationCodeComponent)\n  public verificationCodeComponent: Fs2faVerificationCodeComponent;\n\n  @Input()\n  public verificationMethod: IFsVerificationMethod;\n\n  @Input()\n  public resend: () => Observable<void>;\n\n  @Input()\n  public showTrustedDevice = true;\n\n  @Input()\n  public trustDevice = true;\n\n  @Input()\n  public trustDays;\n\n  @Input()\n  public formatRecipient = false;\n\n  @Input()\n  public getVerificationMethods: () => Observable<IFsVerificationMethod[]>;\n\n  @Input()\n  public selectVerificationMethod: (verificationMethod: IFsVerificationMethod) => Observable<IFsVerificationMethod>;\n\n  @Output()\n  public verified = new EventEmitter<unknown>();\n\n  @Output()\n  public codeChanged = new EventEmitter<unknown>();\n\n  @Output()\n  public codeCompleted = new EventEmitter<unknown>();\n\n  @Output()\n  public trustDeviceChange = new EventEmitter<boolean>();\n\n  public code = '';\n  public VerificationMethodType = VerificationMethodType;\n\n  private _destroy$ = new Subject<void>();\n\n  constructor(\n    private _cdRef: ChangeDetectorRef,\n    private _dialog: FsDialog,\n    private _message: FsMessage,\n  ) {}\n\n  public get recipient(): string {\n    if(this.verificationMethod.type === VerificationMethodType.Email) {\n      return this.verificationMethod.email;\n    }\n\n    if(this.verificationMethod.type === VerificationMethodType.Sms) {\n      return this.verificationMethod.phoneNumber;\n    }\n  }\n\n  public ngOnInit(): void {\n    this.codeChanged\n    .pipe(\n      takeUntil(this._destroy$),\n    )\n    .subscribe((code: string) => {\n      this.code = code;\n    });\n  }\n\n  public ngOnDestroy(): void {\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  public ngAfterViewInit(): void {\n    this.verificationCodeComponent.focus();    \n  }\n\n  public resendCode(): Observable<any> {\n    return this.resend()\n      .pipe(\n        tap(() => {\n          this.code = '';\n          this._message.success('Resent Code');\n        }),\n        finalize(() => {\n          this.verificationCodeComponent.focus();  \n        }),\n      );\n  }\n\n  public showVerificationMethods(): void {\n    this.getVerificationMethods()\n    .subscribe((verificationMethods) => {\n      this._dialog.open(\n        Fs2faVerificationMethodsComponent,\n        {\n          data: {\n            verificationMethod: this.verificationMethod,\n            verificationMethods,\n            selectVerificationMethod: this.selectVerificationMethod,\n          }\n        }\n      )\n        .afterClosed()\n        .pipe(\n          filter((verificationMethod) => !!verificationMethod),\n        )\n        .subscribe((verificationMethod) => {\n          this.verificationMethod = verificationMethod;\n          this.code = '';\n          this._cdRef.markForCheck();\n\n          setTimeout(() => {\n            this.verificationCodeComponent.focus();\n          });\n        });\n    });\n  }\n\n}\n","<div class=\"code-container\">\n  <fs-2fa-verification-code\n    [recipient]=\"(formatRecipient && verificationMethod.type === VerificationMethodType.Sms) ? (recipient | fsPhone) : recipient\"\n    [type]=\"verificationMethod.type\"\n    [code]=\"code\"\n    (codeChanged)=\"codeChanged.emit($event)\"\n    (codeCompleted)=\"codeCompleted.emit()\">\n  </fs-2fa-verification-code>\n</div>\n\n<div class=\"additional\">\n  <div \n      class=\"trust-device\"\n      *ngIf=\"showTrustedDevice\">\n    <mat-checkbox\n          name=\"trust-device\"\n          [(ngModel)]=\"trustDevice\"\n          (ngModelChange)=\"trustDeviceChange.emit($event)\">\n      <div class=\"small\">\n        Bypass verification \n        <ng-container *ngIf=\"trustDays\">for {{trustDays}} days</ng-container>  \n        <ng-container *ngIf=\"!trustDays\">for future signins</ng-container> \n        unless cookies are cleared\n      </div>\n    </mat-checkbox>\n  </div>\n</div>"]} |