@firestitch/2fa
Advanced tools
Comparing version 12.4.2 to 12.4.3
@@ -5,2 +5,3 @@ import { ChangeDetectorRef } from '@angular/core'; | ||
import { FsFormDirective } from '@firestitch/form'; | ||
import { Observable } from 'rxjs'; | ||
import { TwoFactorManageService } from '../../services'; | ||
@@ -20,4 +21,4 @@ import * as i0 from "@angular/core"; | ||
constructor(_data: any, _dialogRef: MatDialogRef<EmailComponent>, _cdRef: ChangeDetectorRef, _message: FsMessage); | ||
resend(): void; | ||
submit: () => import("rxjs").Observable<any>; | ||
resend: () => Observable<void>; | ||
submit: () => Observable<any>; | ||
codeCompleted(): void; | ||
@@ -24,0 +25,0 @@ codeChanged(code: any): void; |
@@ -5,2 +5,3 @@ import { ChangeDetectorRef } from '@angular/core'; | ||
import { FsFormDirective } from '@firestitch/form'; | ||
import { Observable } from 'rxjs'; | ||
import { TwoFactorManageService } from '../../services'; | ||
@@ -21,4 +22,4 @@ import * as i0 from "@angular/core"; | ||
constructor(_data: any, _dialogRef: MatDialogRef<NumberComponent>, _cdRef: ChangeDetectorRef, _message: FsMessage); | ||
resend(): void; | ||
submit: () => import("rxjs").Observable<any>; | ||
resend: () => Observable<void>; | ||
submit: () => Observable<any>; | ||
codeCompleted(): void; | ||
@@ -25,0 +26,0 @@ codeChanged(code: any): void; |
@@ -1,7 +0,14 @@ | ||
import { EventEmitter } from '@angular/core'; | ||
import { ChangeDetectorRef } from '@angular/core'; | ||
import { Observable } from 'rxjs'; | ||
import * as i0 from "@angular/core"; | ||
export declare class ResendComponent { | ||
resend: EventEmitter<any>; | ||
private _cdRef; | ||
resend: () => Observable<any>; | ||
resendInProgress: boolean; | ||
private _destroy$; | ||
constructor(_cdRef: ChangeDetectorRef); | ||
resendClick(): void; | ||
ngOnDestroy(): void; | ||
static ɵfac: i0.ɵɵFactoryDeclaration<ResendComponent, never>; | ||
static ɵcmp: i0.ɵɵComponentDeclaration<ResendComponent, "app-resend", never, {}, { "resend": "resend"; }, never, never>; | ||
static ɵcmp: i0.ɵɵComponentDeclaration<ResendComponent, "app-resend", never, { "resend": "resend"; }, {}, never, never>; | ||
} |
import * as i0 from "@angular/core"; | ||
import * as i1 from "./components/resend/resend.component"; | ||
import * as i2 from "@angular/common"; | ||
import * as i3 from "@angular/material/progress-spinner"; | ||
export declare class ResendModule { | ||
static ɵfac: i0.ɵɵFactoryDeclaration<ResendModule, never>; | ||
static ɵmod: i0.ɵɵNgModuleDeclaration<ResendModule, [typeof i1.ResendComponent], never, [typeof i1.ResendComponent]>; | ||
static ɵmod: i0.ɵɵNgModuleDeclaration<ResendModule, [typeof i1.ResendComponent], [typeof i2.CommonModule, typeof i3.MatProgressSpinnerModule], [typeof i1.ResendComponent]>; | ||
static ɵinj: i0.ɵɵInjectorDeclaration<ResendModule>; | ||
} |
@@ -20,3 +20,2 @@ import { AfterViewInit, ChangeDetectorRef, EventEmitter, OnDestroy, OnInit } from '@angular/core'; | ||
codeCompleted: EventEmitter<unknown>; | ||
resendInProgress: boolean; | ||
code: string; | ||
@@ -31,3 +30,3 @@ trustedDevice: boolean; | ||
ngAfterViewInit(): void; | ||
resendCode(): void; | ||
resendCode: () => Observable<void>; | ||
showVerificationMethods(): void; | ||
@@ -34,0 +33,0 @@ static ɵfac: i0.ɵɵFactoryDeclaration<Fs2faVerificationComponent, never>; |
@@ -13,13 +13,12 @@ import * as i0 from "@angular/core"; | ||
import * as i11 from "@angular/material/checkbox"; | ||
import * as i12 from "@angular/material/progress-spinner"; | ||
import * as i13 from "@firestitch/form"; | ||
import * as i14 from "@firestitch/radiogroup"; | ||
import * as i15 from "@firestitch/dialog"; | ||
import * as i16 from "@firestitch/skeleton"; | ||
import * as i17 from "../resend/resend.module"; | ||
import * as i18 from "../code-input/code-input.module"; | ||
import * as i12 from "@firestitch/form"; | ||
import * as i13 from "@firestitch/radiogroup"; | ||
import * as i14 from "@firestitch/dialog"; | ||
import * as i15 from "@firestitch/skeleton"; | ||
import * as i16 from "../resend/resend.module"; | ||
import * as i17 from "../code-input/code-input.module"; | ||
export declare class Fs2faVerificationModule { | ||
static ɵfac: i0.ɵɵFactoryDeclaration<Fs2faVerificationModule, never>; | ||
static ɵmod: i0.ɵɵNgModuleDeclaration<Fs2faVerificationModule, [typeof i1.Fs2faVerificationComponent, typeof i2.Fs2faVerificationCodeComponent, typeof i3.Fs2faVerificationMethodsComponent], [typeof i4.CommonModule, typeof i5.FormsModule, typeof i6.MatFormFieldModule, typeof i7.MatInputModule, typeof i8.MatButtonModule, typeof i9.MatIconModule, typeof i10.MatRadioModule, typeof i11.MatCheckboxModule, typeof i12.MatProgressSpinnerModule, typeof i13.FsFormModule, typeof i14.FsRadioGroupModule, typeof i15.FsDialogModule, typeof i16.FsSkeletonModule, typeof i16.FsSkeletonModule, typeof i17.ResendModule, typeof i18.CodeInputModule], [typeof i1.Fs2faVerificationComponent]>; | ||
static ɵmod: i0.ɵɵNgModuleDeclaration<Fs2faVerificationModule, [typeof i1.Fs2faVerificationComponent, typeof i2.Fs2faVerificationCodeComponent, typeof i3.Fs2faVerificationMethodsComponent], [typeof i4.CommonModule, typeof i5.FormsModule, typeof i6.MatFormFieldModule, typeof i7.MatInputModule, typeof i8.MatButtonModule, typeof i9.MatIconModule, typeof i10.MatRadioModule, typeof i11.MatCheckboxModule, typeof i12.FsFormModule, typeof i13.FsRadioGroupModule, typeof i14.FsDialogModule, typeof i15.FsSkeletonModule, typeof i15.FsSkeletonModule, typeof i16.ResendModule, typeof i17.CodeInputModule], [typeof i1.Fs2faVerificationComponent]>; | ||
static ɵinj: i0.ɵɵInjectorDeclaration<Fs2faVerificationModule>; | ||
} |
@@ -27,2 +27,8 @@ import { Component, Inject, ChangeDetectionStrategy, ChangeDetectorRef, ViewChild, } from '@angular/core'; | ||
this.verificationMethod = null; | ||
this.resend = () => { | ||
return this.twoFactorManageService.verificationMethodResend() | ||
.pipe(tap(() => { | ||
this._message.success('Resent verification code'); | ||
})); | ||
}; | ||
this.submit = () => { | ||
@@ -52,8 +58,2 @@ return of(true) | ||
} | ||
resend() { | ||
this.twoFactorManageService.verificationMethodResend() | ||
.subscribe(() => { | ||
this._message.success('Resent verification code'); | ||
}); | ||
} | ||
codeCompleted() { | ||
@@ -69,3 +69,3 @@ if (!this.form.submitting) { | ||
EmailComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: EmailComponent, deps: [{ token: MAT_DIALOG_DATA }, { token: i1.MatDialogRef }, { token: i0.ChangeDetectorRef }, { token: i2.FsMessage }], target: i0.ɵɵFactoryTarget.Component }); | ||
EmailComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: EmailComponent, selector: "ng-component", viewQueries: [{ propertyName: "form", first: true, predicate: FsFormDirective, descendants: true }], ngImport: i0, template: "<form fsForm [submit]=\"submit\">\n <fs-dialog>\n <h1 mat-dialog-title>\n Email Setup\n </h1>\n <mat-dialog-content>\n <ng-container *ngIf=\"verificationMethod; else notVerificationMethod\">\n <p>The app just sent you an email with a verification code.</p>\n \n <app-code-input \n [code]=\"code\"\n (codeChanged)=\"codeChanged($event)\"\n (codeCompleted)=\"codeCompleted()\">\n </app-code-input> \n\n <app-resend (resend)=\"resend()\"></app-resend>\n </ng-container>\n\n <ng-template #notVerificationMethod>\n <p>The app will only use this email for verifying your account security. </p>\n <mat-form-field>\n <mat-label>Email</mat-label>\n <input\n matInput\n [required]=\"true\"\n [(ngModel)]=\"email\"\n [fsFormEmail]=\"true\"\n name=\"email\">\n </mat-form-field>\n <mat-checkbox \n name=\"default\"\n [(ngModel)]=\"default\"\n [disableRipple]=\"true\">\n Make this the default 2-step verification method\n </mat-checkbox>\n </ng-template>\n </mat-dialog-content>\n <mat-dialog-actions>\n <button\n mat-button\n color=\"primary\"\n type=\"submit\">\n Next\n </button>\n <button\n mat-button\n type=\"button\"\n [mat-dialog-close]=\"undefined\">\n Cancel\n </button>\n </mat-dialog-actions>\n </fs-dialog>\n</form>\n", styles: [":host ::ng-deep mat-checkbox .mat-ripple{display:none}mat-form-field{width:100%}mat-dialog-content{width:400px}p{margin-top:0}app-code-input{margin-bottom:5px;display:block}\n"], components: [{ type: i3.FsDialogComponent, selector: "fs-dialog", inputs: ["mobileMode"] }, { type: i4.CodeInputComponent, selector: "app-code-input", inputs: ["codeLength", "code"], outputs: ["codeCompleted", "codeChanged"] }, { type: i5.ResendComponent, selector: "app-resend", outputs: ["resend"] }, { type: i6.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i7.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"] }, { type: i8.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }], directives: [{ type: i9.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i9.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i9.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i10.FsFormDirective, selector: "[fsForm]", inputs: ["wrapperSelector", "messageSelector", "hintSelector", "labelSelector", "autocomplete", "shortcuts", "confirm", "confirmDialog", "confirmDrawer", "confirmBrowser", "confirmTabs", "dirtySubmitButton", "submit", "successDelay", "errorDelay", "tabGroup"], outputs: ["fsForm", "invalid", "valid", "submitted", "reseted", "cleared"] }, { type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { type: i11.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.MatLabel, selector: "mat-label" }, { type: i12.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i9.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i9.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i9.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i10.FsFormRequiredDirective, selector: "[fsFormRequired],[ngModel][required]", inputs: ["fsFormRequired", "required", "fsFormRequiredMessage"] }, { type: i10.FsFormEmailDirective, selector: "[fsFormEmail]", inputs: ["fsFormEmail", "fsFormEmailMessage"] }, { type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]" }, { type: i10.FsSubmitButtonDirective, selector: "button[type=\"submit\"]", inputs: ["name", "dirtySubmit"] }, { type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["type", "mat-dialog-close", "aria-label", "matDialogClose"], exportAs: ["matDialogClose"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); | ||
EmailComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: EmailComponent, selector: "ng-component", viewQueries: [{ propertyName: "form", first: true, predicate: FsFormDirective, descendants: true }], ngImport: i0, template: "<form fsForm [submit]=\"submit\">\n <fs-dialog>\n <h1 mat-dialog-title>\n Email Setup\n </h1>\n <mat-dialog-content>\n <ng-container *ngIf=\"verificationMethod; else notVerificationMethod\">\n <p>The app just sent you an email with a verification code.</p>\n \n <app-code-input \n [code]=\"code\"\n (codeChanged)=\"codeChanged($event)\"\n (codeCompleted)=\"codeCompleted()\">\n </app-code-input> \n\n <app-resend [resend]=\"resend\"></app-resend>\n </ng-container>\n\n <ng-template #notVerificationMethod>\n <p>The app will only use this email for verifying your account security. </p>\n <mat-form-field>\n <mat-label>Email</mat-label>\n <input\n matInput\n [required]=\"true\"\n [(ngModel)]=\"email\"\n [fsFormEmail]=\"true\"\n name=\"email\">\n </mat-form-field>\n <mat-checkbox \n name=\"default\"\n [(ngModel)]=\"default\"\n [disableRipple]=\"true\">\n Make this the default 2-step verification method\n </mat-checkbox>\n </ng-template>\n </mat-dialog-content>\n <mat-dialog-actions>\n <button\n mat-button\n color=\"primary\"\n type=\"submit\">\n Next\n </button>\n <button\n mat-button\n type=\"button\"\n [mat-dialog-close]=\"undefined\">\n Cancel\n </button>\n </mat-dialog-actions>\n </fs-dialog>\n</form>\n", styles: [":host ::ng-deep mat-checkbox .mat-ripple{display:none}mat-form-field{width:100%}mat-dialog-content{width:400px}p{margin-top:0}app-code-input{margin-bottom:5px;display:block}\n"], components: [{ type: i3.FsDialogComponent, selector: "fs-dialog", inputs: ["mobileMode"] }, { type: i4.CodeInputComponent, selector: "app-code-input", inputs: ["codeLength", "code"], outputs: ["codeCompleted", "codeChanged"] }, { type: i5.ResendComponent, selector: "app-resend", inputs: ["resend"] }, { type: i6.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i7.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"] }, { type: i8.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }], directives: [{ type: i9.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i9.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i9.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i10.FsFormDirective, selector: "[fsForm]", inputs: ["wrapperSelector", "messageSelector", "hintSelector", "labelSelector", "autocomplete", "shortcuts", "confirm", "confirmDialog", "confirmDrawer", "confirmBrowser", "confirmTabs", "dirtySubmitButton", "submit", "successDelay", "errorDelay", "tabGroup"], outputs: ["fsForm", "invalid", "valid", "submitted", "reseted", "cleared"] }, { type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { type: i11.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.MatLabel, selector: "mat-label" }, { type: i12.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i9.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i9.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i9.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i10.FsFormRequiredDirective, selector: "[fsFormRequired],[ngModel][required]", inputs: ["fsFormRequired", "required", "fsFormRequiredMessage"] }, { type: i10.FsFormEmailDirective, selector: "[fsFormEmail]", inputs: ["fsFormEmail", "fsFormEmailMessage"] }, { type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]" }, { type: i10.FsSubmitButtonDirective, selector: "button[type=\"submit\"]", inputs: ["name", "dirtySubmit"] }, { type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["type", "mat-dialog-close", "aria-label", "matDialogClose"], exportAs: ["matDialogClose"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: EmailComponent, decorators: [{ | ||
@@ -85,2 +85,2 @@ type: Component, | ||
}] } }); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"email.component.js","sourceRoot":"","sources":["../../../../../../../src/app/modules/manage/components/email/email.component.ts","../../../../../../../src/app/modules/manage/components/email/email.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component, Inject, ChangeDetectionStrategy, ChangeDetectorRef, ViewChild,\n} from '@angular/core';\n\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\n\n\nimport { FsMessage } from '@firestitch/message';\nimport { FsFormDirective } from '@firestitch/form';\n\nimport { of } from 'rxjs';\nimport { switchMap, tap } from 'rxjs/operators';\nimport { TwoFactorManageService } from '../../services';\n\n\n@Component({\n  templateUrl: './email.component.html',\n  styleUrls: ['./email.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class EmailComponent {\n\n  @ViewChild(FsFormDirective, { static: false })\n  public form: FsFormDirective;\n\n  public email;\n  public code;\n  public default;\n  public verificationMethod = null;\n  public twoFactorManageService: TwoFactorManageService;\n\n  constructor(\n    @Inject(MAT_DIALOG_DATA) private _data: any,\n    private _dialogRef: MatDialogRef<EmailComponent>,\n    private _cdRef: ChangeDetectorRef,\n    private _message: FsMessage,\n  ) {\n    this.twoFactorManageService = _data.twoFactorManageService;\n    this.default = !this.twoFactorManageService.hasVerificationMethods;\n  }\n\n  public resend(): void {\n    this.twoFactorManageService.verificationMethodResend()\n      .subscribe(() => {\n        this._message.success('Resent verification code');\n      });\n  }\n\n  public submit = () => {\n    return of(true)\n      .pipe(\n        switchMap(() => {\n          return this.verificationMethod ?\n            this.twoFactorManageService.verificationMethodVerify(this.code)\n              .pipe(\n                tap((verificationMethod) => {\n                  this._message.success('Created email verification method');\n                  this._dialogRef.close(verificationMethod);\n                }),\n              ) :\n            this.twoFactorManageService.verificationMethodCreate({\n              type: 'email',\n              email: this.email,\n              default: this.default,\n            })\n              .pipe(\n                tap((verificationMethod) => {\n                  this.verificationMethod = verificationMethod;\n                  this.form.clear();\n                  this._cdRef.markForCheck();\n                }),\n              );\n        }),\n      );\n  };\n\n  public codeCompleted(): void {\n    if(!this.form.submitting) {\n      this.form.triggerSubmit();\n    }\n  }\n\n  public codeChanged(code): void {\n    this.code = code;\n  }\n\n}\n","<form fsForm [submit]=\"submit\">\n  <fs-dialog>\n    <h1 mat-dialog-title>\n      Email Setup\n    </h1>\n    <mat-dialog-content>\n      <ng-container *ngIf=\"verificationMethod; else notVerificationMethod\">\n        <p>The app just sent you an email with a verification code.</p>\n        \n        <app-code-input  \n          [code]=\"code\"\n          (codeChanged)=\"codeChanged($event)\"\n          (codeCompleted)=\"codeCompleted()\">\n        </app-code-input> \n\n        <app-resend (resend)=\"resend()\"></app-resend>\n      </ng-container>\n\n      <ng-template #notVerificationMethod>\n        <p>The app will only use this email for verifying your account security. </p>\n        <mat-form-field>\n          <mat-label>Email</mat-label>\n          <input\n            matInput\n            [required]=\"true\"\n            [(ngModel)]=\"email\"\n            [fsFormEmail]=\"true\"\n            name=\"email\">\n        </mat-form-field>\n        <mat-checkbox \n            name=\"default\"\n            [(ngModel)]=\"default\"\n            [disableRipple]=\"true\">\n          Make this the default 2-step verification method\n        </mat-checkbox>\n      </ng-template>\n    </mat-dialog-content>\n    <mat-dialog-actions>\n      <button\n          mat-button\n          color=\"primary\"\n          type=\"submit\">\n        Next\n      </button>\n      <button\n          mat-button\n          type=\"button\"\n          [mat-dialog-close]=\"undefined\">\n        Cancel\n      </button>\n    </mat-dialog-actions>\n  </fs-dialog>\n</form>\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"email.component.js","sourceRoot":"","sources":["../../../../../../../src/app/modules/manage/components/email/email.component.ts","../../../../../../../src/app/modules/manage/components/email/email.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component, Inject, ChangeDetectionStrategy, ChangeDetectorRef, ViewChild,\n} from '@angular/core';\n\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\n\n\nimport { FsMessage } from '@firestitch/message';\nimport { FsFormDirective } from '@firestitch/form';\n\nimport { Observable, of } from 'rxjs';\nimport { switchMap, tap } from 'rxjs/operators';\nimport { TwoFactorManageService } from '../../services';\n\n\n@Component({\n  templateUrl: './email.component.html',\n  styleUrls: ['./email.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class EmailComponent {\n\n  @ViewChild(FsFormDirective, { static: false })\n  public form: FsFormDirective;\n\n  public email;\n  public code;\n  public default;\n  public verificationMethod = null;\n  public twoFactorManageService: TwoFactorManageService;\n\n  constructor(\n    @Inject(MAT_DIALOG_DATA) private _data: any,\n    private _dialogRef: MatDialogRef<EmailComponent>,\n    private _cdRef: ChangeDetectorRef,\n    private _message: FsMessage,\n  ) {\n    this.twoFactorManageService = _data.twoFactorManageService;\n    this.default = !this.twoFactorManageService.hasVerificationMethods;\n  }\n\n  public resend = (): Observable<void> => {\n    return this.twoFactorManageService.verificationMethodResend()\n    .pipe(\n      tap(() => {\n        this._message.success('Resent verification code');\n      }),\n    );\n  }\n\n  public submit = () => {\n    return of(true)\n      .pipe(\n        switchMap(() => {\n          return this.verificationMethod ?\n            this.twoFactorManageService.verificationMethodVerify(this.code)\n              .pipe(\n                tap((verificationMethod) => {\n                  this._message.success('Created email verification method');\n                  this._dialogRef.close(verificationMethod);\n                }),\n              ) :\n            this.twoFactorManageService.verificationMethodCreate({\n              type: 'email',\n              email: this.email,\n              default: this.default,\n            })\n              .pipe(\n                tap((verificationMethod) => {\n                  this.verificationMethod = verificationMethod;\n                  this.form.clear();\n                  this._cdRef.markForCheck();\n                }),\n              );\n        }),\n      );\n  };\n\n  public codeCompleted(): void {\n    if(!this.form.submitting) {\n      this.form.triggerSubmit();\n    }\n  }\n\n  public codeChanged(code): void {\n    this.code = code;\n  }\n\n}\n","<form fsForm [submit]=\"submit\">\n  <fs-dialog>\n    <h1 mat-dialog-title>\n      Email Setup\n    </h1>\n    <mat-dialog-content>\n      <ng-container *ngIf=\"verificationMethod; else notVerificationMethod\">\n        <p>The app just sent you an email with a verification code.</p>\n        \n        <app-code-input  \n          [code]=\"code\"\n          (codeChanged)=\"codeChanged($event)\"\n          (codeCompleted)=\"codeCompleted()\">\n        </app-code-input> \n\n        <app-resend [resend]=\"resend\"></app-resend>\n      </ng-container>\n\n      <ng-template #notVerificationMethod>\n        <p>The app will only use this email for verifying your account security. </p>\n        <mat-form-field>\n          <mat-label>Email</mat-label>\n          <input\n            matInput\n            [required]=\"true\"\n            [(ngModel)]=\"email\"\n            [fsFormEmail]=\"true\"\n            name=\"email\">\n        </mat-form-field>\n        <mat-checkbox \n            name=\"default\"\n            [(ngModel)]=\"default\"\n            [disableRipple]=\"true\">\n          Make this the default 2-step verification method\n        </mat-checkbox>\n      </ng-template>\n    </mat-dialog-content>\n    <mat-dialog-actions>\n      <button\n          mat-button\n          color=\"primary\"\n          type=\"submit\">\n        Next\n      </button>\n      <button\n          mat-button\n          type=\"button\"\n          [mat-dialog-close]=\"undefined\">\n        Cancel\n      </button>\n    </mat-dialog-actions>\n  </fs-dialog>\n</form>\n"]} |
@@ -27,2 +27,8 @@ import { Component, Inject, ChangeDetectionStrategy, ChangeDetectorRef, ViewChild, } from '@angular/core'; | ||
this.verificationMethod = null; | ||
this.resend = () => { | ||
return this.twoFactorManageService.verificationMethodResend() | ||
.pipe(tap(() => { | ||
this._message.success('Resent verification code'); | ||
})); | ||
}; | ||
this.submit = () => { | ||
@@ -54,8 +60,2 @@ return of(true) | ||
} | ||
resend() { | ||
this.twoFactorManageService.verificationMethodResend() | ||
.subscribe(() => { | ||
this._message.success('Resent verification code'); | ||
}); | ||
} | ||
codeCompleted() { | ||
@@ -71,3 +71,3 @@ if (!this.form.submitting) { | ||
NumberComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: NumberComponent, deps: [{ token: MAT_DIALOG_DATA }, { token: i1.MatDialogRef }, { token: i0.ChangeDetectorRef }, { token: i2.FsMessage }], target: i0.ɵɵFactoryTarget.Component }); | ||
NumberComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: NumberComponent, selector: "ng-component", viewQueries: [{ propertyName: "form", first: true, predicate: FsFormDirective, descendants: true }], ngImport: i0, template: "<form fsForm [submit]=\"submit\" autocomplete=\"off\">\n <fs-dialog>\n <h1 mat-dialog-title>\n Text Message Setup\n </h1>\n <mat-dialog-content>\n <ng-container *ngIf=\"verificationMethod; else notVerificationMethod\">\n <p>The app just sent you a text message with a verification code.</p>\n\n <app-code-input \n [code]=\"code\"\n (codeChanged)=\"codeChanged($event)\"\n (codeCompleted)=\"codeCompleted()\">\n </app-code-input> \n \n <app-resend (resend)=\"resend()\"></app-resend>\n </ng-container>\n\n <ng-template #notVerificationMethod>\n <p>The app will only use this number for verifying your account security. Message and data rates may apply by your cell phone provider.</p>\n <mat-form-field>\n <mat-label>Phone number</mat-label>\n <fs-phone-field\n [(ngModel)]=\"phone\"\n [country]=\"defaultCountry\"\n name=\"phone\"\n autocomplete=\"off\"\n [required]=\"true\">\n </fs-phone-field>\n </mat-form-field>\n <mat-checkbox \n name=\"default\"\n [(ngModel)]=\"default\"\n [disableRipple]=\"true\">\n Make this the default 2-step verification method\n </mat-checkbox>\n </ng-template>\n </mat-dialog-content>\n <mat-dialog-actions>\n <button\n mat-button\n color=\"primary\"\n type=\"submit\">\n Next\n </button>\n <button\n mat-button\n type=\"button\"\n [mat-dialog-close]=\"undefined\">\n Cancel\n </button>\n </mat-dialog-actions>\n </fs-dialog>\n</form>\n", styles: [":host ::ng-deep mat-checkbox .mat-ripple{display:none}app-code-input{margin-bottom:5px;display:block}mat-form-field{width:100%}mat-dialog-content{width:400px}p{margin-top:0}\n"], components: [{ type: i3.FsDialogComponent, selector: "fs-dialog", inputs: ["mobileMode"] }, { type: i4.CodeInputComponent, selector: "app-code-input", inputs: ["codeLength", "code"], outputs: ["codeCompleted", "codeChanged"] }, { type: i5.ResendComponent, selector: "app-resend", outputs: ["resend"] }, { type: i6.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i7.FsPhoneFieldComponent, selector: "fs-phone-field", inputs: ["allowNumberExt", "placeholder", "required", "disabled", "mode", "country"] }, { type: i8.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"] }, { type: i9.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }], directives: [{ type: i10.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i10.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i10.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i11.FsFormDirective, selector: "[fsForm]", inputs: ["wrapperSelector", "messageSelector", "hintSelector", "labelSelector", "autocomplete", "shortcuts", "confirm", "confirmDialog", "confirmDrawer", "confirmBrowser", "confirmTabs", "dirtySubmitButton", "submit", "successDelay", "errorDelay", "tabGroup"], outputs: ["fsForm", "invalid", "valid", "submitted", "reseted", "cleared"] }, { type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { type: i12.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.MatLabel, selector: "mat-label" }, { type: i10.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i10.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i11.FsFormRequiredDirective, selector: "[fsFormRequired],[ngModel][required]", inputs: ["fsFormRequired", "required", "fsFormRequiredMessage"] }, { type: i10.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]" }, { type: i11.FsSubmitButtonDirective, selector: "button[type=\"submit\"]", inputs: ["name", "dirtySubmit"] }, { type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["type", "mat-dialog-close", "aria-label", "matDialogClose"], exportAs: ["matDialogClose"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); | ||
NumberComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: NumberComponent, selector: "ng-component", viewQueries: [{ propertyName: "form", first: true, predicate: FsFormDirective, descendants: true }], ngImport: i0, template: "<form fsForm [submit]=\"submit\" autocomplete=\"off\">\n <fs-dialog>\n <h1 mat-dialog-title>\n Text Message Setup\n </h1>\n <mat-dialog-content>\n <ng-container *ngIf=\"verificationMethod; else notVerificationMethod\">\n <p>The app just sent you a text message with a verification code.</p>\n\n <app-code-input \n [code]=\"code\"\n (codeChanged)=\"codeChanged($event)\"\n (codeCompleted)=\"codeCompleted()\">\n </app-code-input> \n \n <app-resend [resend]=\"resend\"></app-resend>\n </ng-container>\n\n <ng-template #notVerificationMethod>\n <p>The app will only use this number for verifying your account security. Message and data rates may apply by your cell phone provider.</p>\n <mat-form-field>\n <mat-label>Phone number</mat-label>\n <fs-phone-field\n [(ngModel)]=\"phone\"\n [country]=\"defaultCountry\"\n name=\"phone\"\n autocomplete=\"off\"\n [required]=\"true\">\n </fs-phone-field>\n </mat-form-field>\n <mat-checkbox \n name=\"default\"\n [(ngModel)]=\"default\"\n [disableRipple]=\"true\">\n Make this the default 2-step verification method\n </mat-checkbox>\n </ng-template>\n </mat-dialog-content>\n <mat-dialog-actions>\n <button\n mat-button\n color=\"primary\"\n type=\"submit\">\n Next\n </button>\n <button\n mat-button\n type=\"button\"\n [mat-dialog-close]=\"undefined\">\n Cancel\n </button>\n </mat-dialog-actions>\n </fs-dialog>\n</form>\n", styles: [":host ::ng-deep mat-checkbox .mat-ripple{display:none}app-code-input{margin-bottom:5px;display:block}mat-form-field{width:100%}mat-dialog-content{width:400px}p{margin-top:0}\n"], components: [{ type: i3.FsDialogComponent, selector: "fs-dialog", inputs: ["mobileMode"] }, { type: i4.CodeInputComponent, selector: "app-code-input", inputs: ["codeLength", "code"], outputs: ["codeCompleted", "codeChanged"] }, { type: i5.ResendComponent, selector: "app-resend", inputs: ["resend"] }, { type: i6.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i7.FsPhoneFieldComponent, selector: "fs-phone-field", inputs: ["allowNumberExt", "placeholder", "required", "disabled", "mode", "country"] }, { type: i8.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"] }, { type: i9.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }], directives: [{ type: i10.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i10.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i10.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i11.FsFormDirective, selector: "[fsForm]", inputs: ["wrapperSelector", "messageSelector", "hintSelector", "labelSelector", "autocomplete", "shortcuts", "confirm", "confirmDialog", "confirmDrawer", "confirmBrowser", "confirmTabs", "dirtySubmitButton", "submit", "successDelay", "errorDelay", "tabGroup"], outputs: ["fsForm", "invalid", "valid", "submitted", "reseted", "cleared"] }, { type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { type: i12.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.MatLabel, selector: "mat-label" }, { type: i10.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i10.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i11.FsFormRequiredDirective, selector: "[fsFormRequired],[ngModel][required]", inputs: ["fsFormRequired", "required", "fsFormRequiredMessage"] }, { type: i10.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]" }, { type: i11.FsSubmitButtonDirective, selector: "button[type=\"submit\"]", inputs: ["name", "dirtySubmit"] }, { type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["type", "mat-dialog-close", "aria-label", "matDialogClose"], exportAs: ["matDialogClose"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: NumberComponent, decorators: [{ | ||
@@ -87,2 +87,2 @@ type: Component, | ||
}] } }); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number.component.js","sourceRoot":"","sources":["../../../../../../../src/app/modules/manage/components/number/number.component.ts","../../../../../../../src/app/modules/manage/components/number/number.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component, Inject, ChangeDetectionStrategy, ChangeDetectorRef, ViewChild,\n} from '@angular/core';\n\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\n\nimport { FsMessage } from '@firestitch/message';\nimport { FsFormDirective } from '@firestitch/form';\n\nimport { of } from 'rxjs';\nimport { switchMap, tap } from 'rxjs/operators';\nimport { TwoFactorManageService } from '../../services';\n\n\n@Component({\n  templateUrl: './number.component.html',\n  styleUrls: ['./number.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NumberComponent {\n\n  @ViewChild(FsFormDirective, { static: false })\n  public form: FsFormDirective;\n\n  public phone;\n  public code;\n  public default;\n  public verificationMethod = null;\n  public defaultCountry;\n  public twoFactorManageService: TwoFactorManageService;\n\n  constructor(\n    @Inject(MAT_DIALOG_DATA) private _data: any,\n    private _dialogRef: MatDialogRef<NumberComponent>,\n    private _cdRef: ChangeDetectorRef,\n    private _message: FsMessage,\n  ) {\n    this.twoFactorManageService = _data.twoFactorManageService;\n    this.defaultCountry = _data.defaultCountry;\n    this.default = !this.twoFactorManageService.hasVerificationMethods;\n  }\n\n  public resend(): void {\n    this.twoFactorManageService.verificationMethodResend()\n      .subscribe(() => {\n        this._message.success('Resent verification code');\n      });\n  }\n\n  public submit = () => {\n    return of(true)\n      .pipe(\n        switchMap(() => {\n          return this.verificationMethod ?\n            this.twoFactorManageService.verificationMethodVerify(this.code)\n              .pipe(\n                tap((verificationMethod) => {\n                  this._message.success('Created text message verification method');\n                  this._dialogRef.close(verificationMethod);\n                }),\n              ) :\n            this.twoFactorManageService.verificationMethodCreate({\n              type: 'sms',\n              phoneNumber: this.phone.number,\n              phoneCode: this.phone.countryCode,\n              phoneCountry: this.phone.isoCode,\n              default: this.default,\n            }).pipe(\n              tap((verificationMethod) => {\n                this.verificationMethod = verificationMethod;\n                this.form.clear();\n                this._cdRef.markForCheck();\n              }),\n            );\n        }),\n      );\n  };\n\n  public codeCompleted(): void {\n    if(!this.form.submitting) {\n      this.form.triggerSubmit();\n    }\n  }\n\n  public codeChanged(code): void {\n    this.code = code;\n  }\n\n}\n","<form fsForm [submit]=\"submit\" autocomplete=\"off\">\n  <fs-dialog>\n    <h1 mat-dialog-title>\n      Text Message Setup\n    </h1>\n    <mat-dialog-content>\n      <ng-container *ngIf=\"verificationMethod; else notVerificationMethod\">\n        <p>The app just sent you a text message with a verification code.</p>\n\n        <app-code-input  \n          [code]=\"code\"\n          (codeChanged)=\"codeChanged($event)\"\n          (codeCompleted)=\"codeCompleted()\">\n        </app-code-input> \n        \n        <app-resend (resend)=\"resend()\"></app-resend>\n      </ng-container>\n\n      <ng-template #notVerificationMethod>\n        <p>The app will only use this number for verifying your account security. Message and data rates may apply by your cell phone provider.</p>\n        <mat-form-field>\n          <mat-label>Phone number</mat-label>\n          <fs-phone-field\n            [(ngModel)]=\"phone\"\n            [country]=\"defaultCountry\"\n            name=\"phone\"\n            autocomplete=\"off\"\n            [required]=\"true\">\n          </fs-phone-field>\n        </mat-form-field>\n        <mat-checkbox \n            name=\"default\"\n            [(ngModel)]=\"default\"\n            [disableRipple]=\"true\">\n          Make this the default 2-step verification method\n        </mat-checkbox>\n      </ng-template>\n    </mat-dialog-content>\n    <mat-dialog-actions>\n      <button\n          mat-button\n          color=\"primary\"\n          type=\"submit\">\n        Next\n      </button>\n      <button\n          mat-button\n          type=\"button\"\n          [mat-dialog-close]=\"undefined\">\n        Cancel\n      </button>\n    </mat-dialog-actions>\n  </fs-dialog>\n</form>\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number.component.js","sourceRoot":"","sources":["../../../../../../../src/app/modules/manage/components/number/number.component.ts","../../../../../../../src/app/modules/manage/components/number/number.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component, Inject, ChangeDetectionStrategy, ChangeDetectorRef, ViewChild,\n} from '@angular/core';\n\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\n\nimport { FsMessage } from '@firestitch/message';\nimport { FsFormDirective } from '@firestitch/form';\n\nimport { Observable, of } from 'rxjs';\nimport { switchMap, tap } from 'rxjs/operators';\nimport { TwoFactorManageService } from '../../services';\n\n\n@Component({\n  templateUrl: './number.component.html',\n  styleUrls: ['./number.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NumberComponent {\n\n  @ViewChild(FsFormDirective, { static: false })\n  public form: FsFormDirective;\n\n  public phone;\n  public code;\n  public default;\n  public verificationMethod = null;\n  public defaultCountry;\n  public twoFactorManageService: TwoFactorManageService;\n\n  constructor(\n    @Inject(MAT_DIALOG_DATA) private _data: any,\n    private _dialogRef: MatDialogRef<NumberComponent>,\n    private _cdRef: ChangeDetectorRef,\n    private _message: FsMessage,\n  ) {\n    this.twoFactorManageService = _data.twoFactorManageService;\n    this.defaultCountry = _data.defaultCountry;\n    this.default = !this.twoFactorManageService.hasVerificationMethods;\n  }\n\n  public resend = (): Observable<void> => {\n    return this.twoFactorManageService.verificationMethodResend()\n      .pipe(\n        tap(() => {\n          this._message.success('Resent verification code');\n        }),\n      );\n  }\n\n  public submit = () => {\n    return of(true)\n      .pipe(\n        switchMap(() => {\n          return this.verificationMethod ?\n            this.twoFactorManageService.verificationMethodVerify(this.code)\n              .pipe(\n                tap((verificationMethod) => {\n                  this._message.success('Created text message verification method');\n                  this._dialogRef.close(verificationMethod);\n                }),\n              ) :\n            this.twoFactorManageService.verificationMethodCreate({\n              type: 'sms',\n              phoneNumber: this.phone.number,\n              phoneCode: this.phone.countryCode,\n              phoneCountry: this.phone.isoCode,\n              default: this.default,\n            }).pipe(\n              tap((verificationMethod) => {\n                this.verificationMethod = verificationMethod;\n                this.form.clear();\n                this._cdRef.markForCheck();\n              }),\n            );\n        }),\n      );\n  };\n\n  public codeCompleted(): void {\n    if(!this.form.submitting) {\n      this.form.triggerSubmit();\n    }\n  }\n\n  public codeChanged(code): void {\n    this.code = code;\n  }\n\n}\n","<form fsForm [submit]=\"submit\" autocomplete=\"off\">\n  <fs-dialog>\n    <h1 mat-dialog-title>\n      Text Message Setup\n    </h1>\n    <mat-dialog-content>\n      <ng-container *ngIf=\"verificationMethod; else notVerificationMethod\">\n        <p>The app just sent you a text message with a verification code.</p>\n\n        <app-code-input  \n          [code]=\"code\"\n          (codeChanged)=\"codeChanged($event)\"\n          (codeCompleted)=\"codeCompleted()\">\n        </app-code-input> \n        \n        <app-resend [resend]=\"resend\"></app-resend>\n      </ng-container>\n\n      <ng-template #notVerificationMethod>\n        <p>The app will only use this number for verifying your account security. Message and data rates may apply by your cell phone provider.</p>\n        <mat-form-field>\n          <mat-label>Phone number</mat-label>\n          <fs-phone-field\n            [(ngModel)]=\"phone\"\n            [country]=\"defaultCountry\"\n            name=\"phone\"\n            autocomplete=\"off\"\n            [required]=\"true\">\n          </fs-phone-field>\n        </mat-form-field>\n        <mat-checkbox \n            name=\"default\"\n            [(ngModel)]=\"default\"\n            [disableRipple]=\"true\">\n          Make this the default 2-step verification method\n        </mat-checkbox>\n      </ng-template>\n    </mat-dialog-content>\n    <mat-dialog-actions>\n      <button\n          mat-button\n          color=\"primary\"\n          type=\"submit\">\n        Next\n      </button>\n      <button\n          mat-button\n          type=\"button\"\n          [mat-dialog-close]=\"undefined\">\n        Cancel\n      </button>\n    </mat-dialog-actions>\n  </fs-dialog>\n</form>\n"]} |
@@ -1,10 +0,29 @@ | ||
import { Component, ChangeDetectionStrategy, Output, EventEmitter } from '@angular/core'; | ||
import { Component, ChangeDetectionStrategy, Input, ChangeDetectorRef } from '@angular/core'; | ||
import { Subject } from 'rxjs'; | ||
import { finalize, takeUntil } from 'rxjs/operators'; | ||
import * as i0 from "@angular/core"; | ||
import * as i1 from "@angular/material/progress-spinner"; | ||
import * as i2 from "@angular/common"; | ||
export class ResendComponent { | ||
constructor() { | ||
this.resend = new EventEmitter(); | ||
constructor(_cdRef) { | ||
this._cdRef = _cdRef; | ||
this.resendInProgress = false; | ||
this._destroy$ = new Subject(); | ||
} | ||
resendClick() { | ||
this.resendInProgress = true; | ||
this.resend() | ||
.pipe(finalize(() => { | ||
this.resendInProgress = false; | ||
this._cdRef.markForCheck(); | ||
}), takeUntil(this._destroy$)) | ||
.subscribe(); | ||
} | ||
ngOnDestroy() { | ||
this._destroy$.next(); | ||
this._destroy$.complete(); | ||
} | ||
} | ||
ResendComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: ResendComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); | ||
ResendComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: ResendComponent, selector: "app-resend", outputs: { resend: "resend" }, ngImport: i0, template: "<small>Didn't receive a code? <a (click)=\"resend.emit()\">Resend</a></small>", styles: ["small{color:inherit}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); | ||
ResendComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: ResendComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); | ||
ResendComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: ResendComponent, selector: "app-resend", inputs: { resend: "resend" }, ngImport: i0, template: "<ng-container *ngIf=\"!resendInProgress else sending\">\n Didn't receive a code? <a (click)=\"resendClick()\">Resend</a>\n</ng-container>\n<ng-template #sending>\n <div class=\"sending\">\n <mat-spinner [diameter]=\"12\"></mat-spinner> Sending\n </div>\n</ng-template>\n\n", styles: ["small{color:inherit}.sending{display:inline-flex;align-items:center}.sending mat-spinner{margin-right:2px}\n"], components: [{ type: i1.MatSpinner, selector: "mat-spinner", inputs: ["color"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: ResendComponent, decorators: [{ | ||
@@ -18,5 +37,5 @@ type: Component, | ||
}] | ||
}], propDecorators: { resend: [{ | ||
type: Output | ||
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { resend: [{ | ||
type: Input | ||
}] } }); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzZW5kLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvbW9kdWxlcy9yZXNlbmQvY29tcG9uZW50cy9yZXNlbmQvcmVzZW5kLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvbW9kdWxlcy9yZXNlbmQvY29tcG9uZW50cy9yZXNlbmQvcmVzZW5kLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxFQUFFLFlBQVksRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFTekYsTUFBTSxPQUFPLGVBQWU7SUFONUI7UUFRbUIsV0FBTSxHQUFHLElBQUksWUFBWSxFQUFFLENBQUM7S0FFOUM7OzZHQUpZLGVBQWU7aUdBQWYsZUFBZSxpRkNUNUIsK0VBQTJFOzRGRFM5RCxlQUFlO2tCQU4zQixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxZQUFZO29CQUN0QixXQUFXLEVBQUUseUJBQXlCO29CQUN0QyxTQUFTLEVBQUUsQ0FBQyx5QkFBeUIsQ0FBQztvQkFDdEMsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07aUJBQ2hEOzhCQUdrQixNQUFNO3NCQUF0QixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgT3V0cHV0LCBFdmVudEVtaXR0ZXIgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdhcHAtcmVzZW5kJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3Jlc2VuZC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL3Jlc2VuZC5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgUmVzZW5kQ29tcG9uZW50IHtcblxuICBAT3V0cHV0KCkgcHVibGljIHJlc2VuZCA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcbiAgXG59IiwiPHNtYWxsPkRpZG4ndCByZWNlaXZlIGEgY29kZT8gPGEgKGNsaWNrKT1cInJlc2VuZC5lbWl0KClcIj5SZXNlbmQ8L2E+PC9zbWFsbD4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzZW5kLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvbW9kdWxlcy9yZXNlbmQvY29tcG9uZW50cy9yZXNlbmQvcmVzZW5kLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvbW9kdWxlcy9yZXNlbmQvY29tcG9uZW50cy9yZXNlbmQvcmVzZW5kLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsdUJBQXVCLEVBQXdCLEtBQUssRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuSCxPQUFPLEVBQWMsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxRQUFRLEVBQUUsU0FBUyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7Ozs7QUFTckQsTUFBTSxPQUFPLGVBQWU7SUFRMUIsWUFDVSxNQUF5QjtRQUF6QixXQUFNLEdBQU4sTUFBTSxDQUFtQjtRQUw1QixxQkFBZ0IsR0FBRyxLQUFLLENBQUM7UUFFeEIsY0FBUyxHQUFHLElBQUksT0FBTyxFQUFFLENBQUM7SUFJL0IsQ0FBQztJQUVHLFdBQVc7UUFDaEIsSUFBSSxDQUFDLGdCQUFnQixHQUFHLElBQUksQ0FBQztRQUM3QixJQUFJLENBQUMsTUFBTSxFQUFFO2FBQ1YsSUFBSSxDQUNILFFBQVEsQ0FBQyxHQUFHLEVBQUU7WUFDWixJQUFJLENBQUMsZ0JBQWdCLEdBQUcsS0FBSyxDQUFDO1lBQzlCLElBQUksQ0FBQyxNQUFNLENBQUMsWUFBWSxFQUFFLENBQUM7UUFDN0IsQ0FBQyxDQUFDLEVBQ0YsU0FBUyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FDMUI7YUFDQSxTQUFTLEVBQUUsQ0FBQztJQUNqQixDQUFDO0lBRU0sV0FBVztRQUNoQixJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ3RCLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDNUIsQ0FBQzs7NkdBNUJVLGVBQWU7aUdBQWYsZUFBZSxnRkNYNUIsd1JBU0E7NEZERWEsZUFBZTtrQkFOM0IsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsWUFBWTtvQkFDdEIsV0FBVyxFQUFFLHlCQUF5QjtvQkFDdEMsU0FBUyxFQUFFLENBQUMseUJBQXlCLENBQUM7b0JBQ3RDLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO2lCQUNoRDt3R0FHaUIsTUFBTTtzQkFBckIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIE91dHB1dCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgQ2hhbmdlRGV0ZWN0b3JSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE9ic2VydmFibGUsIFN1YmplY3QgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IGZpbmFsaXplLCB0YWtlVW50aWwgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXBwLXJlc2VuZCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9yZXNlbmQuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9yZXNlbmQuY29tcG9uZW50LnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIFJlc2VuZENvbXBvbmVudCB7XG5cbiAgQElucHV0KCkgcHVibGljIHJlc2VuZDogKCkgPT4gT2JzZXJ2YWJsZTxhbnk+O1xuICBcbiAgcHVibGljIHJlc2VuZEluUHJvZ3Jlc3MgPSBmYWxzZTtcblxuICBwcml2YXRlIF9kZXN0cm95JCA9IG5ldyBTdWJqZWN0KCk7XG4gIFxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIF9jZFJlZjogQ2hhbmdlRGV0ZWN0b3JSZWYsXG4gICkge31cblxuICBwdWJsaWMgcmVzZW5kQ2xpY2soKTogdm9pZCB7XG4gICAgdGhpcy5yZXNlbmRJblByb2dyZXNzID0gdHJ1ZTtcbiAgICB0aGlzLnJlc2VuZCgpXG4gICAgICAucGlwZShcbiAgICAgICAgZmluYWxpemUoKCkgPT4ge1xuICAgICAgICAgIHRoaXMucmVzZW5kSW5Qcm9ncmVzcyA9IGZhbHNlOyAgXG4gICAgICAgICAgdGhpcy5fY2RSZWYubWFya0ZvckNoZWNrKCk7ICBcbiAgICAgICAgfSksXG4gICAgICAgIHRha2VVbnRpbCh0aGlzLl9kZXN0cm95JCksXG4gICAgICApXG4gICAgICAuc3Vic2NyaWJlKCk7XG4gIH1cblxuICBwdWJsaWMgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgdGhpcy5fZGVzdHJveSQubmV4dCgpO1xuICAgIHRoaXMuX2Rlc3Ryb3kkLmNvbXBsZXRlKCk7XG4gIH1cblxuXG59IiwiPG5nLWNvbnRhaW5lciAqbmdJZj1cIiFyZXNlbmRJblByb2dyZXNzIGVsc2Ugc2VuZGluZ1wiPlxuICBEaWRuJ3QgcmVjZWl2ZSBhIGNvZGU/IDxhIChjbGljayk9XCJyZXNlbmRDbGljaygpXCI+UmVzZW5kPC9hPlxuPC9uZy1jb250YWluZXI+XG48bmctdGVtcGxhdGUgI3NlbmRpbmc+XG4gIDxkaXYgY2xhc3M9XCJzZW5kaW5nXCI+XG4gICAgPG1hdC1zcGlubmVyIFtkaWFtZXRlcl09XCIxMlwiPjwvbWF0LXNwaW5uZXI+IFNlbmRpbmdcbiAgPC9kaXY+XG48L25nLXRlbXBsYXRlPlxuXG4iXX0= |
@@ -0,2 +1,4 @@ | ||
import { CommonModule } from '@angular/common'; | ||
import { NgModule } from '@angular/core'; | ||
import { MatProgressSpinnerModule } from '@angular/material/progress-spinner'; | ||
import { ResendComponent } from './components/resend'; | ||
@@ -7,8 +9,15 @@ import * as i0 from "@angular/core"; | ||
ResendModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: ResendModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); | ||
ResendModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: ResendModule, declarations: [ResendComponent], exports: [ResendComponent] }); | ||
ResendModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: ResendModule, imports: [[]] }); | ||
ResendModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: ResendModule, declarations: [ResendComponent], imports: [CommonModule, | ||
MatProgressSpinnerModule], exports: [ResendComponent] }); | ||
ResendModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: ResendModule, imports: [[ | ||
CommonModule, | ||
MatProgressSpinnerModule, | ||
]] }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: ResendModule, decorators: [{ | ||
type: NgModule, | ||
args: [{ | ||
imports: [], | ||
imports: [ | ||
CommonModule, | ||
MatProgressSpinnerModule, | ||
], | ||
declarations: [ | ||
@@ -22,2 +31,2 @@ ResendComponent, | ||
}] }); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzZW5kLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvbW9kdWxlcy9yZXNlbmQvcmVzZW5kLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQzs7QUFjdEQsTUFBTSxPQUFPLFlBQVk7OzBHQUFaLFlBQVk7MkdBQVosWUFBWSxpQkFOckIsZUFBZSxhQUdmLGVBQWU7MkdBR04sWUFBWSxZQVZkLEVBRVI7NEZBUVUsWUFBWTtrQkFYeEIsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsRUFFUjtvQkFDRCxZQUFZLEVBQUU7d0JBQ1osZUFBZTtxQkFDaEI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLGVBQWU7cUJBQ2hCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgUmVzZW5kQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3Jlc2VuZCc7XG5cblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgXG4gIF0sXG4gIGRlY2xhcmF0aW9uczogW1xuICAgIFJlc2VuZENvbXBvbmVudCxcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIFJlc2VuZENvbXBvbmVudCxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgUmVzZW5kTW9kdWxlIHtcbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzZW5kLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvbW9kdWxlcy9yZXNlbmQvcmVzZW5kLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV6QyxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUU5RSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUJBQXFCLENBQUM7O0FBZ0J0RCxNQUFNLE9BQU8sWUFBWTs7MEdBQVosWUFBWTsyR0FBWixZQUFZLGlCQU5yQixlQUFlLGFBTGYsWUFBWTtRQUVaLHdCQUF3QixhQU14QixlQUFlOzJHQUdOLFlBQVksWUFaZDtZQUNQLFlBQVk7WUFFWix3QkFBd0I7U0FDekI7NEZBUVUsWUFBWTtrQkFieEIsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFFWix3QkFBd0I7cUJBQ3pCO29CQUNELFlBQVksRUFBRTt3QkFDWixlQUFlO3FCQUNoQjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsZUFBZTtxQkFDaEI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgTWF0UHJvZ3Jlc3NTcGlubmVyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvcHJvZ3Jlc3Mtc3Bpbm5lcic7XG5cbmltcG9ydCB7IFJlc2VuZENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9yZXNlbmQnO1xuXG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG5cbiAgICBNYXRQcm9ncmVzc1NwaW5uZXJNb2R1bGUsXG4gIF0sXG4gIGRlY2xhcmF0aW9uczogW1xuICAgIFJlc2VuZENvbXBvbmVudCxcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIFJlc2VuZENvbXBvbmVudCxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgUmVzZW5kTW9kdWxlIHtcbn1cbiJdfQ== |
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core'; | ||
import { FsDialog } from '@firestitch/dialog'; | ||
import { filter, finalize, takeUntil } from 'rxjs/operators'; | ||
import { filter, finalize, takeUntil, tap } from 'rxjs/operators'; | ||
import { Fs2faVerificationMethodsComponent } from '../2fa-verification-methods/2fa-verification-methods.component'; | ||
@@ -13,5 +13,4 @@ import { Subject } from 'rxjs'; | ||
import * as i4 from "../../../resend/components/resend/resend.component"; | ||
import * as i5 from "@angular/material/progress-spinner"; | ||
import * as i6 from "@angular/common"; | ||
import * as i7 from "@angular/forms"; | ||
import * as i5 from "@angular/common"; | ||
import * as i6 from "@angular/forms"; | ||
export class Fs2faVerificationComponent { | ||
@@ -25,3 +24,2 @@ constructor(_cdRef, _dialog) { | ||
this.codeCompleted = new EventEmitter(); | ||
this.resendInProgress = false; | ||
this.code = ''; | ||
@@ -31,2 +29,10 @@ this.trustedDevice = true; | ||
this._destroy$ = new Subject(); | ||
this.resendCode = () => { | ||
return this.resend() | ||
.pipe(tap(() => { | ||
this.code = ''; | ||
}), finalize(() => { | ||
this.verificationCodeComponent.focus(); | ||
})); | ||
}; | ||
} | ||
@@ -55,13 +61,2 @@ get recipient() { | ||
} | ||
resendCode() { | ||
this.resendInProgress = true; | ||
this.code = ''; | ||
this.resend() | ||
.pipe(finalize(() => { | ||
this.resendInProgress = false; | ||
this._cdRef.markForCheck(); | ||
this.verificationCodeComponent.focus(); | ||
}), takeUntil(this._destroy$)) | ||
.subscribe(); | ||
} | ||
showVerificationMethods() { | ||
@@ -91,3 +86,3 @@ this.getVerificationMethods() | ||
Fs2faVerificationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: Fs2faVerificationComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.FsDialog }], 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", getVerificationMethods: "getVerificationMethods", selectVerificationMethod: "selectVerificationMethod" }, outputs: { verified: "verified", codeChanged: "codeChanged", codeCompleted: "codeCompleted" }, viewQueries: [{ propertyName: "verificationCodeComponent", first: true, predicate: Fs2faVerificationCodeComponent, descendants: true }], ngImport: i0, template: "<div class=\"code-container\">\n <fs-2fa-verification-code\n [recipient]=\"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)]=\"trustedDevice\">\n <small>Trust this device</small>\n </mat-checkbox>\n </div>\n\n <span class=\"resend\">\n <ng-container *ngIf=\"!resendInProgress else sending\">\n <app-resend (resend)=\"resendCode()\"></app-resend>\n </ng-container>\n <ng-template #sending>\n <mat-spinner [diameter]=\"12\"></mat-spinner> <small>Sending</small>\n </ng-template>\n </span>\n</div>", styles: [".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: i2.Fs2faVerificationCodeComponent, selector: "fs-2fa-verification-code", inputs: ["type", "recipient", "code"], outputs: ["codeChanged", "codeCompleted"] }, { type: i3.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"] }, { type: i4.ResendComponent, selector: "app-resend", outputs: ["resend"] }, { type: i5.MatSpinner, selector: "mat-spinner", inputs: ["color"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i7.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], 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", getVerificationMethods: "getVerificationMethods", selectVerificationMethod: "selectVerificationMethod" }, outputs: { verified: "verified", codeChanged: "codeChanged", codeCompleted: "codeCompleted" }, viewQueries: [{ propertyName: "verificationCodeComponent", first: true, predicate: Fs2faVerificationCodeComponent, descendants: true }], ngImport: i0, template: "<div class=\"code-container\">\n <fs-2fa-verification-code\n [recipient]=\"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)]=\"trustedDevice\">\n Trust this device\n </mat-checkbox>\n </div>\n\n <span class=\"resend\">\n <app-resend [resend]=\"resendCode\"></app-resend>\n </span>\n</div>", styles: [".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: i2.Fs2faVerificationCodeComponent, selector: "fs-2fa-verification-code", inputs: ["type", "recipient", "code"], outputs: ["codeChanged", "codeCompleted"] }, { type: i3.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"] }, { type: i4.ResendComponent, selector: "app-resend", inputs: ["resend"] }], 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"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: Fs2faVerificationComponent, decorators: [{ | ||
@@ -123,2 +118,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';\n\nimport { FsDialog } from '@firestitch/dialog';\n\nimport { filter, finalize, takeUntil } from 'rxjs/operators';\n\nimport { IFsVerificationMethod } from '../../../../interfaces/verification-method.interface';\nimport { Fs2faVerificationMethodsComponent } from '../2fa-verification-methods/2fa-verification-methods.component';\nimport { Observable, Subject } from 'rxjs';\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: [\n    './2fa-verification.component.scss',\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\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 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  public resendInProgress = false;\n  public code = '';\n  public trustedDevice = true;\n  public VerificationMethodType = VerificationMethodType;\n\n  private _destroy$ = new Subject<void>();\n\n  constructor(\n    private _cdRef: ChangeDetectorRef,\n    private _dialog: FsDialog,\n  ) {\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(): void {\n    this.resendInProgress = true;\n    this.code = '';\n\n    this.resend()\n      .pipe(\n        finalize(() => {\n          this.resendInProgress = false;  \n          this._cdRef.markForCheck(); \n          this.verificationCodeComponent.focus();  \n        }),\n        takeUntil(this._destroy$),\n      )\n      .subscribe()\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\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]=\"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)]=\"trustedDevice\">\n      <small>Trust this device</small>\n    </mat-checkbox>\n  </div>\n\n  <span class=\"resend\">\n    <ng-container *ngIf=\"!resendInProgress else sending\">\n      <app-resend (resend)=\"resendCode()\"></app-resend>\n    </ng-container>\n    <ng-template #sending>\n      <mat-spinner [diameter]=\"12\"></mat-spinner> <small>Sending</small>\n    </ng-template>\n  </span>\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":"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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';\n\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 { Observable, Subject } from 'rxjs';\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: [\n    './2fa-verification.component.scss',\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\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 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  public code = '';\n  public trustedDevice = true;\n  public VerificationMethodType = VerificationMethodType;\n\n  private _destroy$ = new Subject<void>();\n\n  constructor(\n    private _cdRef: ChangeDetectorRef,\n    private _dialog: FsDialog,\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<void> => {\n    return this.resend()\n    .pipe(\n      tap(() => {\n        this.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\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]=\"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)]=\"trustedDevice\">\n      Trust this device\n    </mat-checkbox>\n  </div>\n\n  <span class=\"resend\">\n    <app-resend [resend]=\"resendCode\"></app-resend>\n  </span>\n</div>"]} |
@@ -10,3 +10,2 @@ import { NgModule } from '@angular/core'; | ||
import { MatCheckboxModule } from '@angular/material/checkbox'; | ||
import { MatProgressSpinnerModule } from '@angular/material/progress-spinner'; | ||
import { FsFormModule } from '@firestitch/form'; | ||
@@ -35,3 +34,2 @@ import { FsSkeletonModule } from '@firestitch/skeleton'; | ||
MatCheckboxModule, | ||
MatProgressSpinnerModule, | ||
FsFormModule, | ||
@@ -53,3 +51,2 @@ FsRadioGroupModule, | ||
MatCheckboxModule, | ||
MatProgressSpinnerModule, | ||
FsFormModule, | ||
@@ -75,3 +72,2 @@ FsRadioGroupModule, | ||
MatCheckboxModule, | ||
MatProgressSpinnerModule, | ||
FsFormModule, | ||
@@ -96,2 +92,2 @@ FsRadioGroupModule, | ||
}] }); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnMtMmZhLXZlcmlmaWNhdGlvbi5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvYXBwL21vZHVsZXMvdmVyaWZpY2F0aW9uL2ZzLTJmYS12ZXJpZmljYXRpb24ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDL0QsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFFOUUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ2hELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzVELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUVwRCxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSwwREFBMEQsQ0FBQztBQUN0RyxPQUFPLEVBQUUsOEJBQThCLEVBQUUsTUFBTSxvRUFBb0UsQ0FBQztBQUNwSCxPQUFPLEVBQUUsaUNBQWlDLEVBQUUsTUFBTSwwRUFBMEUsQ0FBQztBQUU3SCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQzs7QUFtQ3ZELE1BQU0sT0FBTyx1QkFBdUI7O3FIQUF2Qix1QkFBdUI7c0hBQXZCLHVCQUF1QixpQkFUaEMsMEJBQTBCO1FBQzFCLDhCQUE4QjtRQUM5QixpQ0FBaUMsYUF2QmpDLFlBQVk7UUFDWixXQUFXO1FBRVgsa0JBQWtCO1FBQ2xCLGNBQWM7UUFDZCxlQUFlO1FBQ2YsYUFBYTtRQUNiLGNBQWM7UUFDZCxpQkFBaUI7UUFDakIsd0JBQXdCO1FBRXhCLFlBQVk7UUFDWixrQkFBa0I7UUFDbEIsY0FBYztRQUNkLGdCQUFnQjtRQUNoQixnQkFBZ0I7UUFFaEIsWUFBWTtRQUNaLGVBQWUsYUFRZiwwQkFBMEI7c0hBSWpCLHVCQUF1QixhQUZ2QixFQUFFLFlBN0JKO1lBQ1AsWUFBWTtZQUNaLFdBQVc7WUFFWCxrQkFBa0I7WUFDbEIsY0FBYztZQUNkLGVBQWU7WUFDZixhQUFhO1lBQ2IsY0FBYztZQUNkLGlCQUFpQjtZQUNqQix3QkFBd0I7WUFFeEIsWUFBWTtZQUNaLGtCQUFrQjtZQUNsQixjQUFjO1lBQ2QsZ0JBQWdCO1lBQ2hCLGdCQUFnQjtZQUVoQixZQUFZO1lBQ1osZUFBZTtTQUNoQjs0RkFXVSx1QkFBdUI7a0JBaENuQyxRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLFdBQVc7d0JBRVgsa0JBQWtCO3dCQUNsQixjQUFjO3dCQUNkLGVBQWU7d0JBQ2YsYUFBYTt3QkFDYixjQUFjO3dCQUNkLGlCQUFpQjt3QkFDakIsd0JBQXdCO3dCQUV4QixZQUFZO3dCQUNaLGtCQUFrQjt3QkFDbEIsY0FBYzt3QkFDZCxnQkFBZ0I7d0JBQ2hCLGdCQUFnQjt3QkFFaEIsWUFBWTt3QkFDWixlQUFlO3FCQUNoQjtvQkFDRCxZQUFZLEVBQUU7d0JBQ1osMEJBQTBCO3dCQUMxQiw4QkFBOEI7d0JBQzlCLGlDQUFpQztxQkFDbEM7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLDBCQUEwQjtxQkFDM0I7b0JBQ0QsU0FBUyxFQUFFLEVBQUU7aUJBQ2QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuXG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5pbXBvcnQgeyBNYXRSYWRpb01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3JhZGlvJztcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQgeyBNYXRGb3JtRmllbGRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9mb3JtLWZpZWxkJztcbmltcG9ydCB7IE1hdElucHV0TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaW5wdXQnO1xuaW1wb3J0IHsgTWF0Q2hlY2tib3hNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9jaGVja2JveCc7XG5pbXBvcnQgeyBNYXRQcm9ncmVzc1NwaW5uZXJNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9wcm9ncmVzcy1zcGlubmVyJztcblxuaW1wb3J0IHsgRnNGb3JtTW9kdWxlIH0gZnJvbSAnQGZpcmVzdGl0Y2gvZm9ybSc7XG5pbXBvcnQgeyBGc1NrZWxldG9uTW9kdWxlIH0gZnJvbSAnQGZpcmVzdGl0Y2gvc2tlbGV0b24nO1xuaW1wb3J0IHsgRnNSYWRpb0dyb3VwTW9kdWxlIH0gZnJvbSAnQGZpcmVzdGl0Y2gvcmFkaW9ncm91cCc7XG5pbXBvcnQgeyBGc0RpYWxvZ01vZHVsZSB9IGZyb20gJ0BmaXJlc3RpdGNoL2RpYWxvZyc7XG5cbmltcG9ydCB7IEZzMmZhVmVyaWZpY2F0aW9uQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzLzJmYS12ZXJpZmljYXRpb24vMmZhLXZlcmlmaWNhdGlvbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgRnMyZmFWZXJpZmljYXRpb25Db2RlQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzLzJmYS12ZXJpZmljYXRpb24tY29kZS8yZmEtdmVyaWZpY2F0aW9uLWNvZGUuY29tcG9uZW50JztcbmltcG9ydCB7IEZzMmZhVmVyaWZpY2F0aW9uTWV0aG9kc0NvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy8yZmEtdmVyaWZpY2F0aW9uLW1ldGhvZHMvMmZhLXZlcmlmaWNhdGlvbi1tZXRob2RzLmNvbXBvbmVudCc7XG5cbmltcG9ydCB7IENvZGVJbnB1dE1vZHVsZSB9IGZyb20gJy4uL2NvZGUtaW5wdXQnO1xuaW1wb3J0IHsgUmVzZW5kTW9kdWxlIH0gZnJvbSAnLi4vcmVzZW5kL3Jlc2VuZC5tb2R1bGUnO1xuXG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgRm9ybXNNb2R1bGUsXG5cbiAgICBNYXRGb3JtRmllbGRNb2R1bGUsXG4gICAgTWF0SW5wdXRNb2R1bGUsXG4gICAgTWF0QnV0dG9uTW9kdWxlLFxuICAgIE1hdEljb25Nb2R1bGUsXG4gICAgTWF0UmFkaW9Nb2R1bGUsXG4gICAgTWF0Q2hlY2tib3hNb2R1bGUsXG4gICAgTWF0UHJvZ3Jlc3NTcGlubmVyTW9kdWxlLFxuXG4gICAgRnNGb3JtTW9kdWxlLFxuICAgIEZzUmFkaW9Hcm91cE1vZHVsZSxcbiAgICBGc0RpYWxvZ01vZHVsZSxcbiAgICBGc1NrZWxldG9uTW9kdWxlLFxuICAgIEZzU2tlbGV0b25Nb2R1bGUsXG5cbiAgICBSZXNlbmRNb2R1bGUsXG4gICAgQ29kZUlucHV0TW9kdWxlLFxuICBdLFxuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBGczJmYVZlcmlmaWNhdGlvbkNvbXBvbmVudCxcbiAgICBGczJmYVZlcmlmaWNhdGlvbkNvZGVDb21wb25lbnQsXG4gICAgRnMyZmFWZXJpZmljYXRpb25NZXRob2RzQ29tcG9uZW50LFxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgRnMyZmFWZXJpZmljYXRpb25Db21wb25lbnQsXG4gIF0sXG4gIHByb3ZpZGVyczogW10sXG59KVxuZXhwb3J0IGNsYXNzIEZzMmZhVmVyaWZpY2F0aW9uTW9kdWxlIHt9XG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnMtMmZhLXZlcmlmaWNhdGlvbi5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvYXBwL21vZHVsZXMvdmVyaWZpY2F0aW9uL2ZzLTJmYS12ZXJpZmljYXRpb24ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFHL0QsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ2hELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzVELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUVwRCxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSwwREFBMEQsQ0FBQztBQUN0RyxPQUFPLEVBQUUsOEJBQThCLEVBQUUsTUFBTSxvRUFBb0UsQ0FBQztBQUNwSCxPQUFPLEVBQUUsaUNBQWlDLEVBQUUsTUFBTSwwRUFBMEUsQ0FBQztBQUU3SCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQzs7QUFrQ3ZELE1BQU0sT0FBTyx1QkFBdUI7O3FIQUF2Qix1QkFBdUI7c0hBQXZCLHVCQUF1QixpQkFUaEMsMEJBQTBCO1FBQzFCLDhCQUE4QjtRQUM5QixpQ0FBaUMsYUF0QmpDLFlBQVk7UUFDWixXQUFXO1FBRVgsa0JBQWtCO1FBQ2xCLGNBQWM7UUFDZCxlQUFlO1FBQ2YsYUFBYTtRQUNiLGNBQWM7UUFDZCxpQkFBaUI7UUFFakIsWUFBWTtRQUNaLGtCQUFrQjtRQUNsQixjQUFjO1FBQ2QsZ0JBQWdCO1FBQ2hCLGdCQUFnQjtRQUVoQixZQUFZO1FBQ1osZUFBZSxhQVFmLDBCQUEwQjtzSEFJakIsdUJBQXVCLGFBRnZCLEVBQUUsWUE1Qko7WUFDUCxZQUFZO1lBQ1osV0FBVztZQUVYLGtCQUFrQjtZQUNsQixjQUFjO1lBQ2QsZUFBZTtZQUNmLGFBQWE7WUFDYixjQUFjO1lBQ2QsaUJBQWlCO1lBRWpCLFlBQVk7WUFDWixrQkFBa0I7WUFDbEIsY0FBYztZQUNkLGdCQUFnQjtZQUNoQixnQkFBZ0I7WUFFaEIsWUFBWTtZQUNaLGVBQWU7U0FDaEI7NEZBV1UsdUJBQXVCO2tCQS9CbkMsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixXQUFXO3dCQUVYLGtCQUFrQjt3QkFDbEIsY0FBYzt3QkFDZCxlQUFlO3dCQUNmLGFBQWE7d0JBQ2IsY0FBYzt3QkFDZCxpQkFBaUI7d0JBRWpCLFlBQVk7d0JBQ1osa0JBQWtCO3dCQUNsQixjQUFjO3dCQUNkLGdCQUFnQjt3QkFDaEIsZ0JBQWdCO3dCQUVoQixZQUFZO3dCQUNaLGVBQWU7cUJBQ2hCO29CQUNELFlBQVksRUFBRTt3QkFDWiwwQkFBMEI7d0JBQzFCLDhCQUE4Qjt3QkFDOUIsaUNBQWlDO3FCQUNsQztvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsMEJBQTBCO3FCQUMzQjtvQkFDRCxTQUFTLEVBQUUsRUFBRTtpQkFDZCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcbmltcG9ydCB7IE1hdFJhZGlvTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvcmFkaW8nO1xuaW1wb3J0IHsgTWF0QnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcbmltcG9ydCB7IE1hdEZvcm1GaWVsZE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGQnO1xuaW1wb3J0IHsgTWF0SW5wdXRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pbnB1dCc7XG5pbXBvcnQgeyBNYXRDaGVja2JveE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NoZWNrYm94JztcbmltcG9ydCB7IE1hdFByb2dyZXNzU3Bpbm5lck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3Byb2dyZXNzLXNwaW5uZXInO1xuXG5pbXBvcnQgeyBGc0Zvcm1Nb2R1bGUgfSBmcm9tICdAZmlyZXN0aXRjaC9mb3JtJztcbmltcG9ydCB7IEZzU2tlbGV0b25Nb2R1bGUgfSBmcm9tICdAZmlyZXN0aXRjaC9za2VsZXRvbic7XG5pbXBvcnQgeyBGc1JhZGlvR3JvdXBNb2R1bGUgfSBmcm9tICdAZmlyZXN0aXRjaC9yYWRpb2dyb3VwJztcbmltcG9ydCB7IEZzRGlhbG9nTW9kdWxlIH0gZnJvbSAnQGZpcmVzdGl0Y2gvZGlhbG9nJztcblxuaW1wb3J0IHsgRnMyZmFWZXJpZmljYXRpb25Db21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvMmZhLXZlcmlmaWNhdGlvbi8yZmEtdmVyaWZpY2F0aW9uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBGczJmYVZlcmlmaWNhdGlvbkNvZGVDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvMmZhLXZlcmlmaWNhdGlvbi1jb2RlLzJmYS12ZXJpZmljYXRpb24tY29kZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgRnMyZmFWZXJpZmljYXRpb25NZXRob2RzQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzLzJmYS12ZXJpZmljYXRpb24tbWV0aG9kcy8yZmEtdmVyaWZpY2F0aW9uLW1ldGhvZHMuY29tcG9uZW50JztcblxuaW1wb3J0IHsgQ29kZUlucHV0TW9kdWxlIH0gZnJvbSAnLi4vY29kZS1pbnB1dCc7XG5pbXBvcnQgeyBSZXNlbmRNb2R1bGUgfSBmcm9tICcuLi9yZXNlbmQvcmVzZW5kLm1vZHVsZSc7XG5cblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBGb3Jtc01vZHVsZSxcblxuICAgIE1hdEZvcm1GaWVsZE1vZHVsZSxcbiAgICBNYXRJbnB1dE1vZHVsZSxcbiAgICBNYXRCdXR0b25Nb2R1bGUsXG4gICAgTWF0SWNvbk1vZHVsZSxcbiAgICBNYXRSYWRpb01vZHVsZSxcbiAgICBNYXRDaGVja2JveE1vZHVsZSxcblxuICAgIEZzRm9ybU1vZHVsZSxcbiAgICBGc1JhZGlvR3JvdXBNb2R1bGUsXG4gICAgRnNEaWFsb2dNb2R1bGUsXG4gICAgRnNTa2VsZXRvbk1vZHVsZSxcbiAgICBGc1NrZWxldG9uTW9kdWxlLFxuXG4gICAgUmVzZW5kTW9kdWxlLFxuICAgIENvZGVJbnB1dE1vZHVsZSxcbiAgXSxcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgRnMyZmFWZXJpZmljYXRpb25Db21wb25lbnQsXG4gICAgRnMyZmFWZXJpZmljYXRpb25Db2RlQ29tcG9uZW50LFxuICAgIEZzMmZhVmVyaWZpY2F0aW9uTWV0aG9kc0NvbXBvbmVudCxcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIEZzMmZhVmVyaWZpY2F0aW9uQ29tcG9uZW50LFxuICBdLFxuICBwcm92aWRlcnM6IFtdLFxufSlcbmV4cG9ydCBjbGFzcyBGczJmYVZlcmlmaWNhdGlvbk1vZHVsZSB7fVxuIl19 |
{ | ||
"name": "@firestitch/2fa", | ||
"version": "12.4.2", | ||
"version": "12.4.3", | ||
"repository": { | ||
@@ -5,0 +5,0 @@ "type": "git", |
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
Long strings
Supply chain riskContains long string literals, which may be a sign of obfuscated or packed code.
Found 1 instance in 1 package
Long strings
Supply chain riskContains long string literals, which may be a sign of obfuscated or packed code.
Found 1 instance in 1 package
716235
4809