@aws-amplify/ui-angular 3.2.16 → 3.2.17

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,6 +1,5 @@
1
- import { __awaiter } from "tslib";
2
1
  import { Component, ContentChildren, Input, ViewEncapsulation, } from '@angular/core';
3
- import { authenticatorTextUtil, configureComponent, defaultAuthHubHandler, listenToAuthHub, } from '@aws-amplify/ui';
2
+ import { authenticatorTextUtil, configureComponent, } from '@aws-amplify/ui';
4
3
  import { AmplifySlotDirective } from '../../../../utilities/amplify-slot/amplify-slot.directive';
5
4
  import { CustomComponentsService } from '../../../../services/custom-components.service';
6
5
  import { VERSION } from '../../../../../version';
@@ -40,10 +39,9 @@ export class AuthenticatorComponent {
40
39
  packageName: '@aws-amplify/ui-angular',
41
40
  version: VERSION,
42
41
  });
43
- const { authService, initializeMachine } = this.authenticator;
44
- this.unsubscribeHub = listenToAuthHub(authService, (data, service) => __awaiter(this, void 0, void 0, function* () {
45
- yield defaultAuthHubHandler(data, service);
46
- /**
42
+ const { initializeMachine } = this.authenticator;
43
+ this.authenticator.hubSubject.subscribe(() => {
44
+ /*
47
45
  * Hub events aren't properly caught by Angular, because they are
48
46
  * synchronous events. Angular tracks async network events and
49
47
  * html events, but not synchronous events like hub.
@@ -51,7 +49,7 @@ export class AuthenticatorComponent {
51
49
  * On any notable hub events, we run change detection manually.
52
50
  */
53
51
  this.changeDetector.detectChanges();
54
- /**
52
+ /*
55
53
  * Hub events that we handle can lead to multiple state changes:
56
54
  * e.g. `authenticated` -> `signOut` -> initialState.
57
55
  *
@@ -60,7 +58,7 @@ export class AuthenticatorComponent {
60
58
  * to true to until we reach initial state.
61
59
  */
62
60
  this.isHandlingHubEvent = true;
63
- }));
61
+ });
64
62
  /**
65
63
  * Subscribes to state machine changes and sends INIT event
66
64
  * once machine reaches 'setup' state.
@@ -103,8 +101,6 @@ export class AuthenticatorComponent {
103
101
  ngOnDestroy() {
104
102
  if (this.unsubscribeMachine)
105
103
  this.unsubscribeMachine();
106
- if (this.unsubscribeHub)
107
- this.unsubscribeHub();
108
104
  }
109
105
  /**
110
106
  * Class Functions
@@ -182,4 +178,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
182
178
  type: ContentChildren,
183
179
  args: [AmplifySlotDirective]
184
180
  }] } });
185
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"authenticator.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ui-angular/src/lib/components/authenticator/components/authenticator/authenticator.component.ts","../../../../../../../../projects/ui-angular/src/lib/components/authenticator/components/authenticator/authenticator.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  Input,\n  OnDestroy,\n  OnInit,\n  QueryList,\n  TemplateRef,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  AuthenticatorMachineOptions,\n  authenticatorTextUtil,\n  configureComponent,\n  defaultAuthHubHandler,\n  listenToAuthHub,\n  SocialProvider,\n} from '@aws-amplify/ui';\nimport { AmplifySlotDirective } from '../../../../utilities/amplify-slot/amplify-slot.directive';\nimport { CustomComponentsService } from '../../../../services/custom-components.service';\nimport { AuthenticatorService } from '../../../../services/authenticator.service';\nimport { VERSION } from '../../../../../version';\n\nconst { getSignInTabText, getSignUpTabText } = authenticatorTextUtil;\n\n@Component({\n  selector: 'amplify-authenticator',\n  templateUrl: './authenticator.component.html',\n  providers: [CustomComponentsService], // make sure custom components are scoped to this authenticator only\n  encapsulation: ViewEncapsulation.None,\n})\nexport class AuthenticatorComponent\n  implements OnInit, AfterContentInit, OnDestroy\n{\n  @Input() formFields: AuthenticatorMachineOptions['formFields'];\n  @Input() initialState: AuthenticatorMachineOptions['initialState'];\n  @Input() loginMechanisms: AuthenticatorMachineOptions['loginMechanisms'];\n  @Input() services: AuthenticatorMachineOptions['services'];\n  @Input() signUpAttributes: AuthenticatorMachineOptions['signUpAttributes'];\n  @Input() socialProviders: SocialProvider[];\n  @Input() variation: 'default' | 'modal';\n  @Input() hideSignUp: boolean;\n\n  @ContentChildren(AmplifySlotDirective)\n  private customComponentQuery: QueryList<AmplifySlotDirective> = null;\n\n  // translated texts\n  public signInTitle = getSignInTabText();\n  public signUpTitle = getSignUpTabText();\n\n  private hasInitialized = false;\n  private isHandlingHubEvent = false;\n  private unsubscribeMachine: () => void;\n  private unsubscribeHub: ReturnType<typeof listenToAuthHub>;\n\n  constructor(\n    private authenticator: AuthenticatorService,\n    private contextService: CustomComponentsService,\n    private changeDetector: ChangeDetectorRef\n  ) {}\n\n  ngOnInit(): void {\n    const {\n      initialState,\n      loginMechanisms,\n      services,\n      signUpAttributes,\n      socialProviders,\n      formFields,\n    } = this;\n\n    configureComponent({\n      packageName: '@aws-amplify/ui-angular',\n      version: VERSION,\n    });\n\n    const { authService, initializeMachine } = this.authenticator;\n\n    this.unsubscribeHub = listenToAuthHub(\n      authService,\n      async (data, service) => {\n        await defaultAuthHubHandler(data, service);\n        /**\n         * Hub events aren't properly caught by Angular, because they are\n         * synchronous events. Angular tracks async network events and\n         * html events, but not synchronous events like hub.\n         *\n         * On any notable hub events, we run change detection manually.\n         */\n        this.changeDetector.detectChanges();\n\n        /**\n         * Hub events that we handle can lead to multiple state changes:\n         * e.g. `authenticated` -> `signOut` -> initialState.\n         *\n         * We want to ensure change detection runs all the way, until\n         * we reach back to the initial state. Setting the below flag\n         * to true to until we reach initial state.\n         */\n        this.isHandlingHubEvent = true;\n      }\n    );\n\n    /**\n     * Subscribes to state machine changes and sends INIT event\n     * once machine reaches 'setup' state.\n     */\n    this.unsubscribeMachine = this.authenticator.subscribe(() => {\n      const { route } = this.authenticator;\n\n      if (this.isHandlingHubEvent) {\n        this.changeDetector.detectChanges();\n\n        const initialStateWithDefault = initialState ?? 'signIn';\n\n        // We can stop manual change detection if we're back to the initial state\n        if (route === initialStateWithDefault) {\n          this.isHandlingHubEvent = false;\n        }\n      }\n\n      if (!this.hasInitialized && route === 'setup') {\n        initializeMachine({\n          initialState,\n          loginMechanisms,\n          services,\n          signUpAttributes,\n          socialProviders,\n          formFields,\n        });\n\n        this.hasInitialized = true;\n      }\n    }).unsubscribe;\n\n    /**\n     * handling translations after content init, because authenticator and its\n     * translations might be initialized before the main app's `ngOnInit` is run.\n     */\n    this.signInTitle = getSignInTabText();\n    this.signUpTitle = getSignUpTabText();\n  }\n\n  /**\n   * Lifecycle Methods\n   */\n  ngAfterContentInit(): void {\n    this.contextService.customComponents = this.mapCustomComponents(\n      this.customComponentQuery\n    );\n  }\n\n  ngOnDestroy(): void {\n    if (this.unsubscribeMachine) this.unsubscribeMachine();\n    if (this.unsubscribeHub) this.unsubscribeHub();\n  }\n\n  /**\n   * Class Functions\n   */\n\n  // context passed to \"authenticated\" slot\n  public get context() {\n    return this.authenticator.slotContext;\n  }\n\n  public get route() {\n    return this.authenticator.route;\n  }\n\n  public onTabChange() {\n    const route = this.authenticator.route;\n    if (route === 'signIn') {\n      this.authenticator.toSignUp();\n    } else {\n      this.authenticator.toSignIn();\n    }\n  }\n\n  public hasTabs() {\n    const { route } = this.authenticator;\n    return route === 'signIn' || route === 'signUp';\n  }\n\n  public hasRouteComponent() {\n    const { route } = this.authenticator;\n\n    switch (route) {\n      case 'authenticated':\n      case 'idle':\n      case 'setup':\n      case 'signOut':\n      case 'transition':\n        return false;\n      default:\n        return true;\n    }\n  }\n\n  private mapCustomComponents(\n    componentQuery: QueryList<AmplifySlotDirective>\n  ): Record<string, TemplateRef<any>> {\n    if (!componentQuery) return {};\n    const customComponents: Record<string, TemplateRef<any>> = {};\n    componentQuery.forEach((component) => {\n      customComponents[component.name] = component.template;\n    });\n\n    return customComponents;\n  }\n}\n","<div\n  data-amplify-authenticator\n  [attr.data-variation]=\"variation\"\n  *ngIf=\"hasRouteComponent()\"\n>\n  <div data-amplify-container>\n    <amplify-slot name=\"header\" [context]=\"context\"></amplify-slot>\n    <div\n      data-amplify-router\n      [attr.data-amplify-router-content]=\"hasTabs() ? undefined : ''\"\n    >\n      <amplify-tabs\n        (tabChange)=\"onTabChange()\"\n        *ngIf=\"(route === 'signIn' || route === 'signUp') && !hideSignUp\"\n      >\n        <amplify-tab-item\n          [title]=\"signInTitle\"\n          [active]=\"route === 'signIn'\"\n          data-amplify-router-content\n        >\n          <!-- signIn component -->\n          <amplify-slot\n            name=\"sign-in\"\n            [context]=\"context\"\n            *ngIf=\"route === 'signIn'\"\n          >\n            <amplify-sign-in></amplify-sign-in>\n          </amplify-slot>\n        </amplify-tab-item>\n        <amplify-tab-item\n          [title]=\"signUpTitle\"\n          [active]=\"route === 'signUp'\"\n          data-amplify-router-content\n        >\n          <!-- signUp component -->\n          <amplify-slot\n            name=\"sign-up\"\n            [context]=\"context\"\n            *ngIf=\"route === 'signUp'\"\n          >\n            <amplify-sign-up></amplify-sign-up>\n          </amplify-slot>\n        </amplify-tab-item>\n      </amplify-tabs>\n\n      <amplify-slot\n        name=\"sign-in\"\n        [context]=\"context\"\n        *ngIf=\"route === 'signIn' && hideSignUp\"\n      >\n        <amplify-sign-in></amplify-sign-in>\n      </amplify-slot>\n\n      <!-- confirmSignUp content -->\n      <amplify-slot\n        name=\"confirm-sign-up\"\n        [context]=\"context\"\n        *ngIf=\"route === 'confirmSignUp'\"\n      >\n        <amplify-confirm-sign-up></amplify-confirm-sign-up>\n      </amplify-slot>\n\n      <!-- confirmSignIn content -->\n      <amplify-slot\n        name=\"confirm-sign-in\"\n        [context]=\"context\"\n        *ngIf=\"route === 'confirmSignIn'\"\n      >\n        <amplify-confirm-sign-in></amplify-confirm-sign-in>\n      </amplify-slot>\n\n      <!-- setupTotp content -->\n      <amplify-slot\n        name=\"setup-totp\"\n        [context]=\"context\"\n        *ngIf=\"route === 'setupTOTP'\"\n      >\n        <amplify-setup-totp></amplify-setup-totp>\n      </amplify-slot>\n\n      <!-- forceNewPassword content -->\n      <amplify-slot\n        name=\"force-new-password\"\n        [context]=\"context\"\n        *ngIf=\"route === 'forceNewPassword'\"\n      >\n        <amplify-force-new-password></amplify-force-new-password>\n      </amplify-slot>\n\n      <!-- resetPassword content -->\n      <amplify-slot\n        name=\"reset-password\"\n        [context]=\"context\"\n        *ngIf=\"route === 'resetPassword'\"\n      >\n        <amplify-reset-password></amplify-reset-password>\n      </amplify-slot>\n\n      <!-- confirmResetPassword content -->\n      <amplify-slot\n        name=\"confirm-reset-password\"\n        [context]=\"context\"\n        *ngIf=\"route === 'confirmResetPassword'\"\n      >\n        <amplify-confirm-reset-password></amplify-confirm-reset-password>\n      </amplify-slot>\n\n      <!-- verifyUser content -->\n      <amplify-slot\n        name=\"verify-user\"\n        [context]=\"context\"\n        *ngIf=\"route === 'verifyUser'\"\n      >\n        <amplify-verify-user></amplify-verify-user>\n      </amplify-slot>\n\n      <!-- confirmVerifyUser content -->\n      <amplify-slot\n        name=\"confirm-verify-user\"\n        [context]=\"context\"\n        *ngIf=\"route === 'confirmVerifyUser'\"\n      >\n        <amplify-confirm-verify-user></amplify-confirm-verify-user>\n      </amplify-slot>\n    </div>\n\n    <amplify-slot name=\"footer\" [context]=\"context\"></amplify-slot>\n  </div>\n</div>\n\n<!-- signedIn content is rendered outside authenticator so it's not styled by authenticator -->\n<amplify-slot\n  name=\"authenticated\"\n  [context]=\"context\"\n  *ngIf=\"route === 'authenticated'\"\n>\n  <ng-content></ng-content>\n</amplify-slot>\n"]}
181
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"authenticator.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ui-angular/src/lib/components/authenticator/components/authenticator/authenticator.component.ts","../../../../../../../../projects/ui-angular/src/lib/components/authenticator/components/authenticator/authenticator.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  Input,\n  OnDestroy,\n  OnInit,\n  QueryList,\n  TemplateRef,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  AuthenticatorMachineOptions,\n  authenticatorTextUtil,\n  configureComponent,\n  SocialProvider,\n} from '@aws-amplify/ui';\nimport { AmplifySlotDirective } from '../../../../utilities/amplify-slot/amplify-slot.directive';\nimport { CustomComponentsService } from '../../../../services/custom-components.service';\nimport { AuthenticatorService } from '../../../../services/authenticator.service';\nimport { VERSION } from '../../../../../version';\n\nconst { getSignInTabText, getSignUpTabText } = authenticatorTextUtil;\n\n@Component({\n  selector: 'amplify-authenticator',\n  templateUrl: './authenticator.component.html',\n  providers: [CustomComponentsService], // make sure custom components are scoped to this authenticator only\n  encapsulation: ViewEncapsulation.None,\n})\nexport class AuthenticatorComponent\n  implements OnInit, AfterContentInit, OnDestroy\n{\n  @Input() formFields: AuthenticatorMachineOptions['formFields'];\n  @Input() initialState: AuthenticatorMachineOptions['initialState'];\n  @Input() loginMechanisms: AuthenticatorMachineOptions['loginMechanisms'];\n  @Input() services: AuthenticatorMachineOptions['services'];\n  @Input() signUpAttributes: AuthenticatorMachineOptions['signUpAttributes'];\n  @Input() socialProviders: SocialProvider[];\n  @Input() variation: 'default' | 'modal';\n  @Input() hideSignUp: boolean;\n\n  @ContentChildren(AmplifySlotDirective)\n  private customComponentQuery: QueryList<AmplifySlotDirective> = null;\n\n  // translated texts\n  public signInTitle = getSignInTabText();\n  public signUpTitle = getSignUpTabText();\n\n  private hasInitialized = false;\n  private isHandlingHubEvent = false;\n  private unsubscribeMachine: () => void;\n\n  constructor(\n    private authenticator: AuthenticatorService,\n    private contextService: CustomComponentsService,\n    private changeDetector: ChangeDetectorRef\n  ) {}\n\n  ngOnInit(): void {\n    const {\n      initialState,\n      loginMechanisms,\n      services,\n      signUpAttributes,\n      socialProviders,\n      formFields,\n    } = this;\n\n    configureComponent({\n      packageName: '@aws-amplify/ui-angular',\n      version: VERSION,\n    });\n\n    const { initializeMachine } = this.authenticator;\n\n    this.authenticator.hubSubject.subscribe(() => {\n      /*\n       * Hub events aren't properly caught by Angular, because they are\n       * synchronous events. Angular tracks async network events and\n       * html events, but not synchronous events like hub.\n       *\n       * On any notable hub events, we run change detection manually.\n       */\n      this.changeDetector.detectChanges();\n\n      /*\n       * Hub events that we handle can lead to multiple state changes:\n       * e.g. `authenticated` -> `signOut` -> initialState.\n       *\n       * We want to ensure change detection runs all the way, until\n       * we reach back to the initial state. Setting the below flag\n       * to true to until we reach initial state.\n       */\n      this.isHandlingHubEvent = true;\n    });\n\n    /**\n     * Subscribes to state machine changes and sends INIT event\n     * once machine reaches 'setup' state.\n     */\n    this.unsubscribeMachine = this.authenticator.subscribe(() => {\n      const { route } = this.authenticator;\n\n      if (this.isHandlingHubEvent) {\n        this.changeDetector.detectChanges();\n\n        const initialStateWithDefault = initialState ?? 'signIn';\n\n        // We can stop manual change detection if we're back to the initial state\n        if (route === initialStateWithDefault) {\n          this.isHandlingHubEvent = false;\n        }\n      }\n\n      if (!this.hasInitialized && route === 'setup') {\n        initializeMachine({\n          initialState,\n          loginMechanisms,\n          services,\n          signUpAttributes,\n          socialProviders,\n          formFields,\n        });\n\n        this.hasInitialized = true;\n      }\n    }).unsubscribe;\n\n    /**\n     * handling translations after content init, because authenticator and its\n     * translations might be initialized before the main app's `ngOnInit` is run.\n     */\n    this.signInTitle = getSignInTabText();\n    this.signUpTitle = getSignUpTabText();\n  }\n\n  /**\n   * Lifecycle Methods\n   */\n  ngAfterContentInit(): void {\n    this.contextService.customComponents = this.mapCustomComponents(\n      this.customComponentQuery\n    );\n  }\n\n  ngOnDestroy(): void {\n    if (this.unsubscribeMachine) this.unsubscribeMachine();\n  }\n\n  /**\n   * Class Functions\n   */\n\n  // context passed to \"authenticated\" slot\n  public get context() {\n    return this.authenticator.slotContext;\n  }\n\n  public get route() {\n    return this.authenticator.route;\n  }\n\n  public onTabChange() {\n    const route = this.authenticator.route;\n    if (route === 'signIn') {\n      this.authenticator.toSignUp();\n    } else {\n      this.authenticator.toSignIn();\n    }\n  }\n\n  public hasTabs() {\n    const { route } = this.authenticator;\n    return route === 'signIn' || route === 'signUp';\n  }\n\n  public hasRouteComponent() {\n    const { route } = this.authenticator;\n\n    switch (route) {\n      case 'authenticated':\n      case 'idle':\n      case 'setup':\n      case 'signOut':\n      case 'transition':\n        return false;\n      default:\n        return true;\n    }\n  }\n\n  private mapCustomComponents(\n    componentQuery: QueryList<AmplifySlotDirective>\n  ): Record<string, TemplateRef<any>> {\n    if (!componentQuery) return {};\n    const customComponents: Record<string, TemplateRef<any>> = {};\n    componentQuery.forEach((component) => {\n      customComponents[component.name] = component.template;\n    });\n\n    return customComponents;\n  }\n}\n","<div\n  data-amplify-authenticator\n  [attr.data-variation]=\"variation\"\n  *ngIf=\"hasRouteComponent()\"\n>\n  <div data-amplify-container>\n    <amplify-slot name=\"header\" [context]=\"context\"></amplify-slot>\n    <div\n      data-amplify-router\n      [attr.data-amplify-router-content]=\"hasTabs() ? undefined : ''\"\n    >\n      <amplify-tabs\n        (tabChange)=\"onTabChange()\"\n        *ngIf=\"(route === 'signIn' || route === 'signUp') && !hideSignUp\"\n      >\n        <amplify-tab-item\n          [title]=\"signInTitle\"\n          [active]=\"route === 'signIn'\"\n          data-amplify-router-content\n        >\n          <!-- signIn component -->\n          <amplify-slot\n            name=\"sign-in\"\n            [context]=\"context\"\n            *ngIf=\"route === 'signIn'\"\n          >\n            <amplify-sign-in></amplify-sign-in>\n          </amplify-slot>\n        </amplify-tab-item>\n        <amplify-tab-item\n          [title]=\"signUpTitle\"\n          [active]=\"route === 'signUp'\"\n          data-amplify-router-content\n        >\n          <!-- signUp component -->\n          <amplify-slot\n            name=\"sign-up\"\n            [context]=\"context\"\n            *ngIf=\"route === 'signUp'\"\n          >\n            <amplify-sign-up></amplify-sign-up>\n          </amplify-slot>\n        </amplify-tab-item>\n      </amplify-tabs>\n\n      <amplify-slot\n        name=\"sign-in\"\n        [context]=\"context\"\n        *ngIf=\"route === 'signIn' && hideSignUp\"\n      >\n        <amplify-sign-in></amplify-sign-in>\n      </amplify-slot>\n\n      <!-- confirmSignUp content -->\n      <amplify-slot\n        name=\"confirm-sign-up\"\n        [context]=\"context\"\n        *ngIf=\"route === 'confirmSignUp'\"\n      >\n        <amplify-confirm-sign-up></amplify-confirm-sign-up>\n      </amplify-slot>\n\n      <!-- confirmSignIn content -->\n      <amplify-slot\n        name=\"confirm-sign-in\"\n        [context]=\"context\"\n        *ngIf=\"route === 'confirmSignIn'\"\n      >\n        <amplify-confirm-sign-in></amplify-confirm-sign-in>\n      </amplify-slot>\n\n      <!-- setupTotp content -->\n      <amplify-slot\n        name=\"setup-totp\"\n        [context]=\"context\"\n        *ngIf=\"route === 'setupTOTP'\"\n      >\n        <amplify-setup-totp></amplify-setup-totp>\n      </amplify-slot>\n\n      <!-- forceNewPassword content -->\n      <amplify-slot\n        name=\"force-new-password\"\n        [context]=\"context\"\n        *ngIf=\"route === 'forceNewPassword'\"\n      >\n        <amplify-force-new-password></amplify-force-new-password>\n      </amplify-slot>\n\n      <!-- resetPassword content -->\n      <amplify-slot\n        name=\"reset-password\"\n        [context]=\"context\"\n        *ngIf=\"route === 'resetPassword'\"\n      >\n        <amplify-reset-password></amplify-reset-password>\n      </amplify-slot>\n\n      <!-- confirmResetPassword content -->\n      <amplify-slot\n        name=\"confirm-reset-password\"\n        [context]=\"context\"\n        *ngIf=\"route === 'confirmResetPassword'\"\n      >\n        <amplify-confirm-reset-password></amplify-confirm-reset-password>\n      </amplify-slot>\n\n      <!-- verifyUser content -->\n      <amplify-slot\n        name=\"verify-user\"\n        [context]=\"context\"\n        *ngIf=\"route === 'verifyUser'\"\n      >\n        <amplify-verify-user></amplify-verify-user>\n      </amplify-slot>\n\n      <!-- confirmVerifyUser content -->\n      <amplify-slot\n        name=\"confirm-verify-user\"\n        [context]=\"context\"\n        *ngIf=\"route === 'confirmVerifyUser'\"\n      >\n        <amplify-confirm-verify-user></amplify-confirm-verify-user>\n      </amplify-slot>\n    </div>\n\n    <amplify-slot name=\"footer\" [context]=\"context\"></amplify-slot>\n  </div>\n</div>\n\n<!-- signedIn content is rendered outside authenticator so it's not styled by authenticator -->\n<amplify-slot\n  name=\"authenticated\"\n  [context]=\"context\"\n  *ngIf=\"route === 'authenticated'\"\n>\n  <ng-content></ng-content>\n</amplify-slot>\n"]}
@@ -1,7 +1,10 @@
1
+ import { __awaiter } from "tslib";
1
2
  import { Injectable } from '@angular/core';
2
- import { Logger } from '@aws-amplify/core';
3
- import { createAuthenticatorMachine, getServiceFacade, } from '@aws-amplify/ui';
3
+ import { Subject } from 'rxjs';
4
4
  import { interpret } from 'xstate';
5
+ import { Auth } from 'aws-amplify';
6
+ import { Logger } from '@aws-amplify/core';
7
+ import { createAuthenticatorMachine, defaultAuthHubHandler, getServiceFacade, listenToAuthHub, } from '@aws-amplify/ui';
5
8
  import { translate } from '@aws-amplify/ui';
6
9
  import * as i0 from "@angular/core";
7
10
  const logger = new Logger('state-machine');
@@ -10,21 +13,18 @@ const logger = new Logger('state-machine');
10
13
  */
11
14
  export class AuthenticatorService {
12
15
  constructor() {
16
+ this._authStatus = 'configuring';
13
17
  const machine = createAuthenticatorMachine();
14
- const authService = interpret(machine).start();
15
- this._machineSubscription = authService.subscribe((state) => {
16
- const newState = state;
17
- this._authState = newState;
18
- this._facade = getServiceFacade({
19
- send: authService.send,
20
- state: newState,
21
- });
22
- });
23
- this._authService = authService;
18
+ this._authService = interpret(machine).start();
19
+ this.setupMachineSubscription();
20
+ this.setupHubListener();
21
+ this.getInitialAuthStatus();
24
22
  }
25
23
  ngOnDestroy() {
26
24
  if (this._machineSubscription)
27
25
  this._machineSubscription.unsubscribe();
26
+ if (this._unsubscribeHub)
27
+ this._unsubscribeHub();
28
28
  }
29
29
  /**
30
30
  * Context facades
@@ -46,8 +46,7 @@ export class AuthenticatorService {
46
46
  return (_a = this._facade) === null || _a === void 0 ? void 0 : _a.route;
47
47
  }
48
48
  get authStatus() {
49
- var _a;
50
- return (_a = this._facade) === null || _a === void 0 ? void 0 : _a.authStatus;
49
+ return this._authStatus;
51
50
  }
52
51
  get user() {
53
52
  var _a;
@@ -123,6 +122,10 @@ export class AuthenticatorService {
123
122
  get slotContext() {
124
123
  return Object.assign(Object.assign({}, this._facade), { $implicit: this._facade });
125
124
  }
125
+ /** @deprecated For internal use only */
126
+ get hubSubject() {
127
+ return this._hubSubject;
128
+ }
126
129
  subscribe(callback) {
127
130
  if (!this._authService) {
128
131
  logger.error('Subscription attempted before machine was created. This is likely a bug on the library, please consider filing a bug.');
@@ -136,6 +139,40 @@ export class AuthenticatorService {
136
139
  send(event) {
137
140
  this.authService.send(event);
138
141
  }
142
+ getInitialAuthStatus() {
143
+ return __awaiter(this, void 0, void 0, function* () {
144
+ try {
145
+ yield Auth.currentAuthenticatedUser();
146
+ this._authStatus = 'authenticated';
147
+ }
148
+ catch (e) {
149
+ this._authStatus = 'unauthenticated';
150
+ }
151
+ });
152
+ }
153
+ setupHubListener() {
154
+ this._hubSubject = new Subject();
155
+ const onSignIn = () => {
156
+ this._authStatus = 'authenticated';
157
+ };
158
+ const onSignOut = () => {
159
+ this._authStatus = 'unauthenticated';
160
+ };
161
+ this._unsubscribeHub = listenToAuthHub(this._authService, (data, service) => __awaiter(this, void 0, void 0, function* () {
162
+ yield defaultAuthHubHandler(data, service, { onSignIn, onSignOut });
163
+ this._hubSubject.next();
164
+ }));
165
+ }
166
+ setupMachineSubscription() {
167
+ this._machineSubscription = this._authService.subscribe((state) => {
168
+ const newState = state;
169
+ this._authState = newState;
170
+ this._facade = getServiceFacade({
171
+ send: this._authService.send,
172
+ state: newState,
173
+ });
174
+ });
175
+ }
139
176
  }
140
177
  AuthenticatorService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: AuthenticatorService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
141
178
  AuthenticatorService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: AuthenticatorService, providedIn: 'root' });
@@ -145,4 +182,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
145
182
  providedIn: 'root', // ensure we have a singleton service
146
183
  }]
147
184
  }], ctorParameters: function () { return []; } });
148
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"authenticator.service.js","sourceRoot":"","sources":["../../../../../projects/ui-angular/src/lib/services/authenticator.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, OnDestroy } from '@angular/core';\nimport { Logger } from '@aws-amplify/core';\nimport {\n  AuthContext,\n  AuthEvent,\n  AuthInterpreter,\n  AuthMachineState,\n  createAuthenticatorMachine,\n  getServiceFacade,\n} from '@aws-amplify/ui';\nimport { Event, interpret, Subscription } from 'xstate';\nimport { AuthSubscriptionCallback } from '../common';\nimport { translate } from '@aws-amplify/ui';\n\nconst logger = new Logger('state-machine');\n\n/**\n * AuthenticatorService provides access to the authenticator state and context.\n */\n@Injectable({\n  providedIn: 'root', // ensure we have a singleton service\n})\nexport class AuthenticatorService implements OnDestroy {\n  private _authState: AuthMachineState;\n  private _authService: AuthInterpreter;\n  private _machineSubscription: Subscription;\n  private _facade: ReturnType<typeof getServiceFacade>;\n\n  constructor() {\n    const machine = createAuthenticatorMachine();\n\n    const authService = interpret(machine).start();\n\n    this._machineSubscription = authService.subscribe((state: unknown) => {\n      const newState = state as AuthMachineState;\n      this._authState = newState;\n      this._facade = getServiceFacade({\n        send: authService.send,\n        state: newState,\n      });\n    });\n\n    this._authService = authService;\n  }\n\n  ngOnDestroy(): void {\n    if (this._machineSubscription) this._machineSubscription.unsubscribe();\n  }\n\n  /**\n   * Context facades\n   */\n\n  public get error() {\n    return translate(this._facade?.error);\n  }\n\n  public get hasValidationErrors() {\n    return this._facade?.hasValidationErrors;\n  }\n\n  public get isPending() {\n    return this._facade?.isPending;\n  }\n\n  public get route() {\n    return this._facade?.route;\n  }\n\n  public get authStatus() {\n    return this._facade?.authStatus;\n  }\n\n  public get user() {\n    return this._facade?.user;\n  }\n\n  public get validationErrors() {\n    return this._facade?.validationErrors;\n  }\n\n  public get codeDeliveryDetails() {\n    return this._facade?.codeDeliveryDetails;\n  }\n\n  public get totpSecretCode() {\n    return this._facade?.totpSecretCode;\n  }\n\n  /**\n   * Service facades\n   */\n\n  public get initializeMachine() {\n    return this._facade.initializeMachine;\n  }\n\n  public get updateForm() {\n    return this._facade.updateForm;\n  }\n\n  public get updateBlur() {\n    return this._facade.updateBlur;\n  }\n\n  public get resendCode() {\n    return this._facade.resendCode;\n  }\n\n  public get signOut() {\n    return this._facade.signOut;\n  }\n\n  public get submitForm() {\n    return this._facade.submitForm;\n  }\n\n  /**\n   * Transition facades\n   */\n\n  public get toFederatedSignIn() {\n    return this._facade.toFederatedSignIn;\n  }\n\n  public get toResetPassword() {\n    return this._facade.toResetPassword;\n  }\n\n  public get toSignIn() {\n    return this._facade.toSignIn;\n  }\n\n  public get toSignUp() {\n    return this._facade.toSignUp;\n  }\n\n  public get skipVerification() {\n    return this._facade.skipVerification;\n  }\n\n  /**\n   * Internal utility functions\n   */\n\n  /** @deprecated For internal use only */\n  public get authState(): AuthMachineState {\n    return this._authState;\n  }\n\n  /** @deprecated For internal use only */\n  public get authService(): AuthInterpreter {\n    return this._authService;\n  }\n\n  /** @deprecated For internal use only */\n  public get context(): AuthContext {\n    return this._authState.context;\n  }\n\n  /** @deprecated For internal use only */\n  public get slotContext() {\n    return {\n      ...this._facade,\n      $implicit: this._facade,\n    };\n  }\n\n  public subscribe(callback: AuthSubscriptionCallback): Subscription {\n    if (!this._authService) {\n      logger.error(\n        'Subscription attempted before machine was created. This is likely a bug on the library, please consider filing a bug.'\n      );\n    }\n\n    const subscription = this._authService.subscribe(() => {\n      callback(this._facade);\n    });\n    return subscription;\n  }\n\n  /** @deprecated For internal use only */\n  public send(event: Event<AuthEvent>) {\n    this.authService.send(event);\n  }\n}\n"]}
185
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"authenticator.service.js","sourceRoot":"","sources":["../../../../../projects/ui-angular/src/lib/services/authenticator.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, OnDestroy } from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { Event, interpret, Subscription } from 'xstate';\n\nimport { Auth } from 'aws-amplify';\nimport { Logger } from '@aws-amplify/core';\nimport {\n  AuthContext,\n  AuthEvent,\n  AuthInterpreter,\n  AuthMachineState,\n  AuthStatus,\n  createAuthenticatorMachine,\n  defaultAuthHubHandler,\n  getServiceFacade,\n  listenToAuthHub,\n} from '@aws-amplify/ui';\nimport { translate } from '@aws-amplify/ui';\n\nimport { AuthSubscriptionCallback } from '../common';\n\nconst logger = new Logger('state-machine');\n\n/**\n * AuthenticatorService provides access to the authenticator state and context.\n */\n@Injectable({\n  providedIn: 'root', // ensure we have a singleton service\n})\nexport class AuthenticatorService implements OnDestroy {\n  private _authState: AuthMachineState;\n  private _authStatus: AuthStatus = 'configuring';\n  private _authService: AuthInterpreter;\n  private _machineSubscription: Subscription;\n  private _facade: ReturnType<typeof getServiceFacade>;\n  private _hubSubject: Subject<void>;\n  private _unsubscribeHub: () => void;\n\n  constructor() {\n    const machine = createAuthenticatorMachine();\n    this._authService = interpret(machine).start();\n\n    this.setupMachineSubscription();\n    this.setupHubListener();\n    this.getInitialAuthStatus();\n  }\n\n  ngOnDestroy(): void {\n    if (this._machineSubscription) this._machineSubscription.unsubscribe();\n    if (this._unsubscribeHub) this._unsubscribeHub();\n  }\n\n  /**\n   * Context facades\n   */\n\n  public get error() {\n    return translate(this._facade?.error);\n  }\n\n  public get hasValidationErrors() {\n    return this._facade?.hasValidationErrors;\n  }\n\n  public get isPending() {\n    return this._facade?.isPending;\n  }\n\n  public get route() {\n    return this._facade?.route;\n  }\n\n  public get authStatus() {\n    return this._authStatus;\n  }\n\n  public get user() {\n    return this._facade?.user;\n  }\n\n  public get validationErrors() {\n    return this._facade?.validationErrors;\n  }\n\n  public get codeDeliveryDetails() {\n    return this._facade?.codeDeliveryDetails;\n  }\n\n  public get totpSecretCode() {\n    return this._facade?.totpSecretCode;\n  }\n\n  /**\n   * Service facades\n   */\n  public get initializeMachine() {\n    return this._facade.initializeMachine;\n  }\n\n  public get updateForm() {\n    return this._facade.updateForm;\n  }\n\n  public get updateBlur() {\n    return this._facade.updateBlur;\n  }\n\n  public get resendCode() {\n    return this._facade.resendCode;\n  }\n\n  public get signOut() {\n    return this._facade.signOut;\n  }\n\n  public get submitForm() {\n    return this._facade.submitForm;\n  }\n\n  /**\n   * Transition facades\n   */\n\n  public get toFederatedSignIn() {\n    return this._facade.toFederatedSignIn;\n  }\n\n  public get toResetPassword() {\n    return this._facade.toResetPassword;\n  }\n\n  public get toSignIn() {\n    return this._facade.toSignIn;\n  }\n\n  public get toSignUp() {\n    return this._facade.toSignUp;\n  }\n\n  public get skipVerification() {\n    return this._facade.skipVerification;\n  }\n\n  /**\n   * Internal utility functions\n   */\n\n  /** @deprecated For internal use only */\n  public get authState(): AuthMachineState {\n    return this._authState;\n  }\n\n  /** @deprecated For internal use only */\n  public get authService(): AuthInterpreter {\n    return this._authService;\n  }\n\n  /** @deprecated For internal use only */\n  public get context(): AuthContext {\n    return this._authState.context;\n  }\n\n  /** @deprecated For internal use only */\n  public get slotContext() {\n    return {\n      ...this._facade,\n      $implicit: this._facade,\n    };\n  }\n\n  /** @deprecated For internal use only */\n  public get hubSubject(): Subject<void> {\n    return this._hubSubject;\n  }\n\n  public subscribe(callback: AuthSubscriptionCallback): Subscription {\n    if (!this._authService) {\n      logger.error(\n        'Subscription attempted before machine was created. This is likely a bug on the library, please consider filing a bug.'\n      );\n    }\n\n    const subscription = this._authService.subscribe(() => {\n      callback(this._facade);\n    });\n    return subscription;\n  }\n\n  /** @deprecated For internal use only */\n  public send(event: Event<AuthEvent>) {\n    this.authService.send(event);\n  }\n\n  private async getInitialAuthStatus(): Promise<void> {\n    try {\n      await Auth.currentAuthenticatedUser();\n      this._authStatus = 'authenticated';\n    } catch (e) {\n      this._authStatus = 'unauthenticated';\n    }\n  }\n\n  private setupHubListener(): void {\n    this._hubSubject = new Subject<void>();\n\n    const onSignIn = () => {\n      this._authStatus = 'authenticated';\n    };\n    const onSignOut = () => {\n      this._authStatus = 'unauthenticated';\n    };\n\n    this._unsubscribeHub = listenToAuthHub(\n      this._authService,\n      async (data, service) => {\n        await defaultAuthHubHandler(data, service, { onSignIn, onSignOut });\n        this._hubSubject.next();\n      }\n    );\n  }\n\n  private setupMachineSubscription(): void {\n    this._machineSubscription = this._authService.subscribe(\n      (state: unknown) => {\n        const newState = state as AuthMachineState;\n        this._authState = newState;\n        this._facade = getServiceFacade({\n          send: this._authService.send,\n          state: newState,\n        });\n      }\n    );\n  }\n}\n"]}
@@ -1,2 +1,2 @@
1
- export const VERSION = '3.2.16';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL3VpLWFuZ3VsYXIvc3JjL3ZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFHLFFBQVEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBWRVJTSU9OID0gJzMuMi4xNic7XG4iXX0=
1
+ export const VERSION = '3.2.17';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL3VpLWFuZ3VsYXIvc3JjL3ZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFHLFFBQVEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBWRVJTSU9OID0gJzMuMi4xNyc7XG4iXX0=
@@ -2,15 +2,16 @@ import * as i0 from '@angular/core';
2
2
  import { Directive, Input, Injectable, Component, HostBinding, EventEmitter, ContentChildren, Output, ViewEncapsulation, NgModule } from '@angular/core';
3
3
  import * as i6 from '@angular/common';
4
4
  import { CommonModule } from '@angular/common';
5
- import { __awaiter } from 'tslib';
6
- import { createAuthenticatorMachine, getServiceFacade, translate, authenticatorTextUtil, FederatedIdentityProviders, countryDialCodes, ComponentClassName, getErrors, getSortedFormFields, getFormDataFromEvent, getActorContext, getTotpCodeURL, defaultFormFieldOptions, getActorState, configureComponent, listenToAuthHub, defaultAuthHubHandler } from '@aws-amplify/ui';
5
+ import { createAuthenticatorMachine, translate, listenToAuthHub, defaultAuthHubHandler, getServiceFacade, authenticatorTextUtil, FederatedIdentityProviders, countryDialCodes, ComponentClassName, getErrors, getSortedFormFields, getFormDataFromEvent, getActorContext, getTotpCodeURL, defaultFormFieldOptions, getActorState, configureComponent } from '@aws-amplify/ui';
7
6
  export { translations } from '@aws-amplify/ui';
8
- import { Logger } from '@aws-amplify/core';
7
+ import { __awaiter } from 'tslib';
8
+ import { Subject } from 'rxjs';
9
9
  import { interpret } from 'xstate';
10
+ import { Auth, Logger as Logger$1 } from 'aws-amplify';
11
+ import { Logger } from '@aws-amplify/core';
10
12
  import { nanoid } from 'nanoid';
11
13
  import classnames from 'classnames';
12
14
  import QRCode from 'qrcode';
13
- import { Logger as Logger$1 } from 'aws-amplify';
14
15
 
15
16
  class AmplifySlotDirective {
16
17
  constructor(template) {
@@ -54,7 +55,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
54
55
  }]
55
56
  }] });
56
57
 
57
- const VERSION = '3.2.16';
58
+ const VERSION = '3.2.17';
58
59
 
59
60
  const logger$1 = new Logger('state-machine');
60
61
  /**
@@ -62,21 +63,18 @@ const logger$1 = new Logger('state-machine');
62
63
  */
63
64
  class AuthenticatorService {
64
65
  constructor() {
66
+ this._authStatus = 'configuring';
65
67
  const machine = createAuthenticatorMachine();
66
- const authService = interpret(machine).start();
67
- this._machineSubscription = authService.subscribe((state) => {
68
- const newState = state;
69
- this._authState = newState;
70
- this._facade = getServiceFacade({
71
- send: authService.send,
72
- state: newState,
73
- });
74
- });
75
- this._authService = authService;
68
+ this._authService = interpret(machine).start();
69
+ this.setupMachineSubscription();
70
+ this.setupHubListener();
71
+ this.getInitialAuthStatus();
76
72
  }
77
73
  ngOnDestroy() {
78
74
  if (this._machineSubscription)
79
75
  this._machineSubscription.unsubscribe();
76
+ if (this._unsubscribeHub)
77
+ this._unsubscribeHub();
80
78
  }
81
79
  /**
82
80
  * Context facades
@@ -98,8 +96,7 @@ class AuthenticatorService {
98
96
  return (_a = this._facade) === null || _a === void 0 ? void 0 : _a.route;
99
97
  }
100
98
  get authStatus() {
101
- var _a;
102
- return (_a = this._facade) === null || _a === void 0 ? void 0 : _a.authStatus;
99
+ return this._authStatus;
103
100
  }
104
101
  get user() {
105
102
  var _a;
@@ -175,6 +172,10 @@ class AuthenticatorService {
175
172
  get slotContext() {
176
173
  return Object.assign(Object.assign({}, this._facade), { $implicit: this._facade });
177
174
  }
175
+ /** @deprecated For internal use only */
176
+ get hubSubject() {
177
+ return this._hubSubject;
178
+ }
178
179
  subscribe(callback) {
179
180
  if (!this._authService) {
180
181
  logger$1.error('Subscription attempted before machine was created. This is likely a bug on the library, please consider filing a bug.');
@@ -188,6 +189,40 @@ class AuthenticatorService {
188
189
  send(event) {
189
190
  this.authService.send(event);
190
191
  }
192
+ getInitialAuthStatus() {
193
+ return __awaiter(this, void 0, void 0, function* () {
194
+ try {
195
+ yield Auth.currentAuthenticatedUser();
196
+ this._authStatus = 'authenticated';
197
+ }
198
+ catch (e) {
199
+ this._authStatus = 'unauthenticated';
200
+ }
201
+ });
202
+ }
203
+ setupHubListener() {
204
+ this._hubSubject = new Subject();
205
+ const onSignIn = () => {
206
+ this._authStatus = 'authenticated';
207
+ };
208
+ const onSignOut = () => {
209
+ this._authStatus = 'unauthenticated';
210
+ };
211
+ this._unsubscribeHub = listenToAuthHub(this._authService, (data, service) => __awaiter(this, void 0, void 0, function* () {
212
+ yield defaultAuthHubHandler(data, service, { onSignIn, onSignOut });
213
+ this._hubSubject.next();
214
+ }));
215
+ }
216
+ setupMachineSubscription() {
217
+ this._machineSubscription = this._authService.subscribe((state) => {
218
+ const newState = state;
219
+ this._authState = newState;
220
+ this._facade = getServiceFacade({
221
+ send: this._authService.send,
222
+ state: newState,
223
+ });
224
+ });
225
+ }
191
226
  }
192
227
  AuthenticatorService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: AuthenticatorService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
193
228
  AuthenticatorService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: AuthenticatorService, providedIn: 'root' });
@@ -1210,10 +1245,9 @@ class AuthenticatorComponent {
1210
1245
  packageName: '@aws-amplify/ui-angular',
1211
1246
  version: VERSION,
1212
1247
  });
1213
- const { authService, initializeMachine } = this.authenticator;
1214
- this.unsubscribeHub = listenToAuthHub(authService, (data, service) => __awaiter(this, void 0, void 0, function* () {
1215
- yield defaultAuthHubHandler(data, service);
1216
- /**
1248
+ const { initializeMachine } = this.authenticator;
1249
+ this.authenticator.hubSubject.subscribe(() => {
1250
+ /*
1217
1251
  * Hub events aren't properly caught by Angular, because they are
1218
1252
  * synchronous events. Angular tracks async network events and
1219
1253
  * html events, but not synchronous events like hub.
@@ -1221,7 +1255,7 @@ class AuthenticatorComponent {
1221
1255
  * On any notable hub events, we run change detection manually.
1222
1256
  */
1223
1257
  this.changeDetector.detectChanges();
1224
- /**
1258
+ /*
1225
1259
  * Hub events that we handle can lead to multiple state changes:
1226
1260
  * e.g. `authenticated` -> `signOut` -> initialState.
1227
1261
  *
@@ -1230,7 +1264,7 @@ class AuthenticatorComponent {
1230
1264
  * to true to until we reach initial state.
1231
1265
  */
1232
1266
  this.isHandlingHubEvent = true;
1233
- }));
1267
+ });
1234
1268
  /**
1235
1269
  * Subscribes to state machine changes and sends INIT event
1236
1270
  * once machine reaches 'setup' state.
@@ -1273,8 +1307,6 @@ class AuthenticatorComponent {
1273
1307
  ngOnDestroy() {
1274
1308
  if (this.unsubscribeMachine)
1275
1309
  this.unsubscribeMachine();
1276
- if (this.unsubscribeHub)
1277
- this.unsubscribeHub();
1278
1310
  }
1279
1311
  /**
1280
1312
  * Class Functions