@aws-amplify/ui-angular 3.1.3 → 3.2.0
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 +6 -0
- package/bundles/aws-amplify-ui-angular.umd.js.map +1 -1
- package/esm2015/lib/components/authenticator/components/authenticator/authenticator.component.js +7 -2
- package/esm2015/version.js +2 -0
- package/fesm2015/aws-amplify-ui-angular.js +7 -1
- package/fesm2015/aws-amplify-ui-angular.js.map +1 -1
- package/package.json +2 -2
- package/version.d.ts +1 -0
package/esm2015/lib/components/authenticator/components/authenticator/authenticator.component.js
CHANGED
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import { __awaiter } from "tslib";
|
|
2
2
|
import { Component, ContentChildren, Input, ViewEncapsulation, } from '@angular/core';
|
|
3
|
-
import { defaultAuthHubHandler, listenToAuthHub,
|
|
3
|
+
import { authenticatorTextUtil, configureComponent, defaultAuthHubHandler, listenToAuthHub, } from '@aws-amplify/ui';
|
|
4
4
|
import { AmplifySlotDirective } from '../../../../utilities/amplify-slot/amplify-slot.directive';
|
|
5
5
|
import { CustomComponentsService } from '../../../../services/custom-components.service';
|
|
6
|
+
import { VERSION } from '../../../../../version';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
import * as i1 from "../../../../services/authenticator.service";
|
|
8
9
|
import * as i2 from "../../../../services/custom-components.service";
|
|
@@ -35,6 +36,10 @@ export class AuthenticatorComponent {
|
|
|
35
36
|
}
|
|
36
37
|
ngOnInit() {
|
|
37
38
|
const { initialState, loginMechanisms, services, signUpAttributes, socialProviders, formFields, } = this;
|
|
39
|
+
configureComponent({
|
|
40
|
+
packageName: '@aws-amplify/ui-angular',
|
|
41
|
+
version: VERSION,
|
|
42
|
+
});
|
|
38
43
|
const { authService, initializeMachine } = this.authenticator;
|
|
39
44
|
this.unsubscribeHub = listenToAuthHub(authService, (data, service) => __awaiter(this, void 0, void 0, function* () {
|
|
40
45
|
yield defaultAuthHubHandler(data, service);
|
|
@@ -177,4 +182,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
177
182
|
type: ContentChildren,
|
|
178
183
|
args: [AmplifySlotDirective]
|
|
179
184
|
}] } });
|
|
180
|
-
//# 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  defaultAuthHubHandler,\n  listenToAuthHub,\n  SocialProvider,\n  authenticatorTextUtil,\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';\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    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"]}
|
|
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"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export const VERSION = '3.2.0';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL3VpLWFuZ3VsYXIvc3JjL3ZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFHLE9BQU8sQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBWRVJTSU9OID0gJzMuMi4wJztcbiJdfQ==
|
|
@@ -3,7 +3,7 @@ import { Directive, Input, Injectable, Component, HostBinding, EventEmitter, Con
|
|
|
3
3
|
import * as i6 from '@angular/common';
|
|
4
4
|
import { CommonModule } from '@angular/common';
|
|
5
5
|
import { __awaiter } from 'tslib';
|
|
6
|
-
import { createAuthenticatorMachine, getServiceFacade, translate, authenticatorTextUtil, FederatedIdentityProviders, countryDialCodes, getErrors, getSortedFormFields, getFormDataFromEvent, getActorContext, getTotpCodeURL, defaultFormFieldOptions, getActorState, listenToAuthHub, defaultAuthHubHandler } from '@aws-amplify/ui';
|
|
6
|
+
import { createAuthenticatorMachine, getServiceFacade, translate, authenticatorTextUtil, FederatedIdentityProviders, countryDialCodes, getErrors, getSortedFormFields, getFormDataFromEvent, getActorContext, getTotpCodeURL, defaultFormFieldOptions, getActorState, configureComponent, listenToAuthHub, defaultAuthHubHandler } from '@aws-amplify/ui';
|
|
7
7
|
export { translations } from '@aws-amplify/ui';
|
|
8
8
|
import { Logger } from '@aws-amplify/core';
|
|
9
9
|
import { interpret } from 'xstate';
|
|
@@ -53,6 +53,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
53
53
|
}]
|
|
54
54
|
}] });
|
|
55
55
|
|
|
56
|
+
const VERSION = '3.2.0';
|
|
57
|
+
|
|
56
58
|
const logger$1 = new Logger('state-machine');
|
|
57
59
|
/**
|
|
58
60
|
* AuthenticatorService provides access to the authenticator state and context.
|
|
@@ -1197,6 +1199,10 @@ class AuthenticatorComponent {
|
|
|
1197
1199
|
}
|
|
1198
1200
|
ngOnInit() {
|
|
1199
1201
|
const { initialState, loginMechanisms, services, signUpAttributes, socialProviders, formFields, } = this;
|
|
1202
|
+
configureComponent({
|
|
1203
|
+
packageName: '@aws-amplify/ui-angular',
|
|
1204
|
+
version: VERSION,
|
|
1205
|
+
});
|
|
1200
1206
|
const { authService, initializeMachine } = this.authenticator;
|
|
1201
1207
|
this.unsubscribeHub = listenToAuthHub(authService, (data, service) => __awaiter(this, void 0, void 0, function* () {
|
|
1202
1208
|
yield defaultAuthHubHandler(data, service);
|