@aws-amplify/ui-angular 3.2.15 → 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.
- package/bundles/aws-amplify-ui-angular.umd.js +147 -101
- package/bundles/aws-amplify-ui-angular.umd.js.map +1 -1
- package/esm2015/lib/components/authenticator/components/authenticator/authenticator.component.js +7 -11
- package/esm2015/lib/services/authenticator.service.js +52 -15
- package/esm2015/version.js +2 -2
- package/fesm2015/aws-amplify-ui-angular.js +57 -25
- package/fesm2015/aws-amplify-ui-angular.js.map +1 -1
- package/lib/components/authenticator/components/authenticator/authenticator.component.d.ts +1 -2
- package/lib/components/authenticator/components/confirm-reset-password/amplify-confirm-reset-password.component.d.ts +1 -1
- package/lib/components/authenticator/components/confirm-sign-in/confirm-sign-in.component.d.ts +1 -1
- package/lib/components/authenticator/components/confirm-sign-up/confirm-sign-up.component.d.ts +1 -1
- package/lib/components/authenticator/components/confirm-verify-user/amplify-confirm-verify-user.component.d.ts +1 -1
- package/lib/components/authenticator/components/force-new-password/force-new-password.component.d.ts +1 -1
- package/lib/components/authenticator/components/reset-password/reset-password.component.d.ts +1 -1
- package/lib/components/authenticator/components/setup-totp/setup-totp.component.d.ts +1 -1
- package/lib/components/authenticator/components/sign-in/sign-in.component.d.ts +1 -1
- package/lib/components/authenticator/components/sign-up/sign-up.component.d.ts +1 -1
- package/lib/components/authenticator/components/verify-user/verify-user.component.d.ts +1 -1
- package/lib/services/authenticator.service.d.ts +12 -3
- package/package.json +2 -2
- package/version.d.ts +1 -1
package/esm2015/lib/components/authenticator/components/authenticator/authenticator.component.js
CHANGED
|
@@ -1,6 +1,5 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
1
|
import { Component, ContentChildren, Input, ViewEncapsulation, } from '@angular/core';
|
|
3
|
-
import { authenticatorTextUtil, configureComponent,
|
|
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 {
|
|
44
|
-
this.
|
|
45
|
-
|
|
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 {
|
|
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
|
-
|
|
15
|
-
this.
|
|
16
|
-
|
|
17
|
-
|
|
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
|
-
|
|
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"]}
|
package/esm2015/version.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export const VERSION = '3.2.
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
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 {
|
|
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 {
|
|
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.
|
|
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
|
-
|
|
67
|
-
this.
|
|
68
|
-
|
|
69
|
-
|
|
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
|
-
|
|
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 {
|
|
1214
|
-
this.
|
|
1215
|
-
|
|
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
|