@aws-amplify/ui-angular 3.0.0 → 3.1.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 +24 -21
- package/bundles/aws-amplify-ui-angular.umd.js.map +1 -1
- package/esm2015/lib/common/types/auth-types.js +1 -1
- package/esm2015/lib/services/authenticator.service.js +25 -23
- package/fesm2015/aws-amplify-ui-angular.js +24 -22
- package/fesm2015/aws-amplify-ui-angular.js.map +1 -1
- package/lib/common/types/auth-types.d.ts +2 -2
- package/lib/components/authenticator/components/authenticator/authenticator.component.d.ts +1 -23
- package/lib/components/authenticator/components/confirm-reset-password/amplify-confirm-reset-password.component.d.ts +1 -23
- package/lib/components/authenticator/components/confirm-sign-in/confirm-sign-in.component.d.ts +1 -23
- package/lib/components/authenticator/components/confirm-sign-up/confirm-sign-up.component.d.ts +1 -23
- package/lib/components/authenticator/components/confirm-verify-user/amplify-confirm-verify-user.component.d.ts +1 -23
- package/lib/components/authenticator/components/force-new-password/force-new-password.component.d.ts +1 -23
- package/lib/components/authenticator/components/reset-password/reset-password.component.d.ts +1 -23
- package/lib/components/authenticator/components/setup-totp/setup-totp.component.d.ts +1 -23
- package/lib/components/authenticator/components/sign-in/sign-in.component.d.ts +1 -23
- package/lib/components/authenticator/components/sign-up/sign-up.component.d.ts +1 -23
- package/lib/components/authenticator/components/verify-user/verify-user.component.d.ts +1 -23
- package/lib/services/authenticator.service.d.ts +1 -25
- package/package.json +2 -2
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC10eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWFuZ3VsYXIvc3JjL2xpYi9jb21tb24vdHlwZXMvYXV0aC10eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgRGVmYXVsdEZvcm1GaWVsZE9wdGlvbnMsXG4gIEF1dGhlbnRpY2F0b3JTZXJ2aWNlRmFjYWRlLFxufSBmcm9tICdAYXdzLWFtcGxpZnkvdWknO1xuXG4vLyBtYXBzIGF1dGggYXR0cmlidXRlIHRvIGl0cyByZXBzZWN0aXZlIGxhYmVscyBhbmQgcGxhY2Vob2xkZXJcbmV4cG9ydCB0eXBlIEF0dHJpYnV0ZUluZm9Qcm92aWRlciA9ICgpID0+IERlZmF1bHRGb3JtRmllbGRPcHRpb25zO1xuXG5leHBvcnQgdHlwZSBBdXRoU3Vic2NyaXB0aW9uQ2FsbGJhY2sgPSAoXG4gIHN0YXRlOiBBdXRoZW50aWNhdG9yU2VydmljZUZhY2FkZVxuKSA9PiB2b2lkO1xuIl19
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Injectable } from '@angular/core';
|
|
2
2
|
import { Logger } from '@aws-amplify/core';
|
|
3
|
-
import { createAuthenticatorMachine,
|
|
3
|
+
import { createAuthenticatorMachine, getServiceFacade, } from '@aws-amplify/ui';
|
|
4
4
|
import { interpret } from 'xstate';
|
|
5
5
|
import { translate } from '@aws-amplify/ui';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
@@ -13,10 +13,13 @@ export class AuthenticatorService {
|
|
|
13
13
|
const machine = createAuthenticatorMachine();
|
|
14
14
|
const authService = interpret(machine).start();
|
|
15
15
|
this._machineSubscription = authService.subscribe((state) => {
|
|
16
|
-
|
|
17
|
-
this.
|
|
16
|
+
const newState = state;
|
|
17
|
+
this._authState = newState;
|
|
18
|
+
this._facade = getServiceFacade({
|
|
19
|
+
send: authService.send,
|
|
20
|
+
state: newState,
|
|
21
|
+
});
|
|
18
22
|
});
|
|
19
|
-
this._sendEventAliases = getSendEventAliases(authService.send);
|
|
20
23
|
this._authService = authService;
|
|
21
24
|
}
|
|
22
25
|
ngOnDestroy() {
|
|
@@ -62,40 +65,40 @@ export class AuthenticatorService {
|
|
|
62
65
|
* Service facades
|
|
63
66
|
*/
|
|
64
67
|
get initializeMachine() {
|
|
65
|
-
return this.
|
|
68
|
+
return this._facade.initializeMachine;
|
|
66
69
|
}
|
|
67
70
|
get updateForm() {
|
|
68
|
-
return this.
|
|
71
|
+
return this._facade.updateForm;
|
|
69
72
|
}
|
|
70
73
|
get updateBlur() {
|
|
71
|
-
return this.
|
|
74
|
+
return this._facade.updateBlur;
|
|
72
75
|
}
|
|
73
76
|
get resendCode() {
|
|
74
|
-
return this.
|
|
77
|
+
return this._facade.resendCode;
|
|
75
78
|
}
|
|
76
79
|
get signOut() {
|
|
77
|
-
return this.
|
|
80
|
+
return this._facade.signOut;
|
|
78
81
|
}
|
|
79
82
|
get submitForm() {
|
|
80
|
-
return this.
|
|
83
|
+
return this._facade.submitForm;
|
|
81
84
|
}
|
|
82
85
|
/**
|
|
83
86
|
* Transition facades
|
|
84
87
|
*/
|
|
85
88
|
get toFederatedSignIn() {
|
|
86
|
-
return this.
|
|
89
|
+
return this._facade.toFederatedSignIn;
|
|
87
90
|
}
|
|
88
91
|
get toResetPassword() {
|
|
89
|
-
return this.
|
|
92
|
+
return this._facade.toResetPassword;
|
|
90
93
|
}
|
|
91
94
|
get toSignIn() {
|
|
92
|
-
return this.
|
|
95
|
+
return this._facade.toSignIn;
|
|
93
96
|
}
|
|
94
97
|
get toSignUp() {
|
|
95
|
-
return this.
|
|
98
|
+
return this._facade.toSignUp;
|
|
96
99
|
}
|
|
97
100
|
get skipVerification() {
|
|
98
|
-
return this.
|
|
101
|
+
return this._facade.skipVerification;
|
|
99
102
|
}
|
|
100
103
|
/**
|
|
101
104
|
* Internal utility functions
|
|
@@ -114,17 +117,16 @@ export class AuthenticatorService {
|
|
|
114
117
|
}
|
|
115
118
|
/** @deprecated For internal use only */
|
|
116
119
|
get slotContext() {
|
|
117
|
-
|
|
118
|
-
return Object.assign(Object.assign({}, slotContext), { $implicit: Object.assign({}, slotContext) });
|
|
120
|
+
return Object.assign(Object.assign({}, this._facade), { $implicit: this._facade });
|
|
119
121
|
}
|
|
120
|
-
/** @deprecated For internal use only */
|
|
121
122
|
subscribe(callback) {
|
|
122
|
-
if (this._authService) {
|
|
123
|
-
return this._authService.subscribe(callback);
|
|
124
|
-
}
|
|
125
|
-
else {
|
|
123
|
+
if (!this._authService) {
|
|
126
124
|
logger.error('Subscription attempted before machine was created. This is likely a bug on the library, please consider filing a bug.');
|
|
127
125
|
}
|
|
126
|
+
const subscription = this._authService.subscribe(() => {
|
|
127
|
+
callback(this._facade);
|
|
128
|
+
});
|
|
129
|
+
return subscription;
|
|
128
130
|
}
|
|
129
131
|
/** @deprecated For internal use only */
|
|
130
132
|
send(event) {
|
|
@@ -139,4 +141,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
139
141
|
providedIn: 'root', // ensure we have a singleton service
|
|
140
142
|
}]
|
|
141
143
|
}], ctorParameters: function () { return []; } });
|
|
142
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"authenticator.service.js","sourceRoot":"","sources":["../../../../../projects/ui-angular/src/lib/services/authenticator.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAa,MAAM,eAAe,CAAC;AACtD,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAC3C,OAAO,EAKL,0BAA0B,EAC1B,mBAAmB,EACnB,uBAAuB,GACxB,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAS,SAAS,EAAgB,MAAM,QAAQ,CAAC;AAExD,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;;AAE5C,MAAM,MAAM,GAAG,IAAI,MAAM,CAAC,eAAe,CAAC,CAAC;AAE3C;;GAEG;AAIH,MAAM,OAAO,oBAAoB;IAO/B;QACE,MAAM,OAAO,GAAG,0BAA0B,EAAE,CAAC;QAE7C,MAAM,WAAW,GAAG,SAAS,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,CAAC;QAE/C,IAAI,CAAC,oBAAoB,GAAG,WAAW,CAAC,SAAS,CAAC,CAAC,KAAc,EAAE,EAAE;YACnE,IAAI,CAAC,UAAU,GAAG,KAAyB,CAAC;YAC5C,IAAI,CAAC,OAAO,GAAG,uBAAuB,CAAC,KAAyB,CAAC,CAAC;QACpE,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,iBAAiB,GAAG,mBAAmB,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAC/D,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC;IAClC,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,oBAAoB;YAAE,IAAI,CAAC,oBAAoB,CAAC,WAAW,EAAE,CAAC;IACzE,CAAC;IAED;;OAEG;IAEH,IAAW,KAAK;;QACd,OAAO,SAAS,CAAC,MAAA,IAAI,CAAC,OAAO,0CAAE,KAAK,CAAC,CAAC;IACxC,CAAC;IAED,IAAW,mBAAmB;;QAC5B,OAAO,MAAA,IAAI,CAAC,OAAO,0CAAE,mBAAmB,CAAC;IAC3C,CAAC;IAED,IAAW,SAAS;;QAClB,OAAO,MAAA,IAAI,CAAC,OAAO,0CAAE,SAAS,CAAC;IACjC,CAAC;IAED,IAAW,KAAK;;QACd,OAAO,MAAA,IAAI,CAAC,OAAO,0CAAE,KAAK,CAAC;IAC7B,CAAC;IAED,IAAW,UAAU;;QACnB,OAAO,MAAA,IAAI,CAAC,OAAO,0CAAE,UAAU,CAAC;IAClC,CAAC;IAED,IAAW,IAAI;;QACb,OAAO,MAAA,IAAI,CAAC,OAAO,0CAAE,IAAI,CAAC;IAC5B,CAAC;IAED,IAAW,gBAAgB;;QACzB,OAAO,MAAA,IAAI,CAAC,OAAO,0CAAE,gBAAgB,CAAC;IACxC,CAAC;IAED,IAAW,mBAAmB;;QAC5B,OAAO,MAAA,IAAI,CAAC,OAAO,0CAAE,mBAAmB,CAAC;IAC3C,CAAC;IAED;;OAEG;IAEH,IAAW,iBAAiB;QAC1B,OAAO,IAAI,CAAC,iBAAiB,CAAC,iBAAiB,CAAC;IAClD,CAAC;IAED,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC;IAC3C,CAAC;IAED,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC;IAC3C,CAAC;IAED,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC;IAC3C,CAAC;IAED,IAAW,OAAO;QAChB,OAAO,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC;IACxC,CAAC;IAED,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC;IAC3C,CAAC;IAED;;OAEG;IAEH,IAAW,iBAAiB;QAC1B,OAAO,IAAI,CAAC,iBAAiB,CAAC,iBAAiB,CAAC;IAClD,CAAC;IAED,IAAW,eAAe;QACxB,OAAO,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAAC;IAChD,CAAC;IAED,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC;IACzC,CAAC;IAED,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC;IACzC,CAAC;IAED,IAAW,gBAAgB;QACzB,OAAO,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,CAAC;IACjD,CAAC;IAED;;OAEG;IAEH,wCAAwC;IACxC,IAAW,SAAS;QAClB,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED,wCAAwC;IACxC,IAAW,WAAW;QACpB,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAED,wCAAwC;IACxC,IAAW,OAAO;QAChB,OAAO,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC;IACjC,CAAC;IAED,wCAAwC;IACxC,IAAW,WAAW;QACpB,MAAM,WAAW,mCACZ,IAAI,CAAC,OAAO,GACZ,IAAI,CAAC,iBAAiB,CAC1B,CAAC;QAEF,uCACK,WAAW,KACd,SAAS,oBAAO,WAAW,KAC3B;IACJ,CAAC;IAED,wCAAwC;IACjC,SAAS,CAAC,QAAkC;QACjD,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,OAAO,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;SAC9C;aAAM;YACL,MAAM,CAAC,KAAK,CACV,uHAAuH,CACxH,CAAC;SACH;IACH,CAAC;IAED,wCAAwC;IACjC,IAAI,CAAC,KAAuB;QACjC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;;kHA/JU,oBAAoB;sHAApB,oBAAoB,cAFnB,MAAM;4FAEP,oBAAoB;kBAHhC,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM,EAAE,qCAAqC;iBAC1D","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  getSendEventAliases,\n  getServiceContextFacade,\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 _sendEventAliases: ReturnType<typeof getSendEventAliases>;\n  private _machineSubscription: Subscription;\n  private _facade: ReturnType<typeof getServiceContextFacade>;\n\n  constructor() {\n    const machine = createAuthenticatorMachine();\n\n    const authService = interpret(machine).start();\n\n    this._machineSubscription = authService.subscribe((state: unknown) => {\n      this._authState = state as AuthMachineState;\n      this._facade = getServiceContextFacade(state as AuthMachineState);\n    });\n\n    this._sendEventAliases = getSendEventAliases(authService.send);\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  /**\n   * Service facades\n   */\n\n  public get initializeMachine() {\n    return this._sendEventAliases.initializeMachine;\n  }\n\n  public get updateForm() {\n    return this._sendEventAliases.updateForm;\n  }\n\n  public get updateBlur() {\n    return this._sendEventAliases.updateBlur;\n  }\n\n  public get resendCode() {\n    return this._sendEventAliases.resendCode;\n  }\n\n  public get signOut() {\n    return this._sendEventAliases.signOut;\n  }\n\n  public get submitForm() {\n    return this._sendEventAliases.submitForm;\n  }\n\n  /**\n   * Transition facades\n   */\n\n  public get toFederatedSignIn() {\n    return this._sendEventAliases.toFederatedSignIn;\n  }\n\n  public get toResetPassword() {\n    return this._sendEventAliases.toResetPassword;\n  }\n\n  public get toSignIn() {\n    return this._sendEventAliases.toSignIn;\n  }\n\n  public get toSignUp() {\n    return this._sendEventAliases.toSignUp;\n  }\n\n  public get skipVerification() {\n    return this._sendEventAliases.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    const slotContext = {\n      ...this._facade,\n      ...this._sendEventAliases,\n    };\n\n    return {\n      ...slotContext,\n      $implicit: { ...slotContext },\n    };\n  }\n\n  /** @deprecated For internal use only */\n  public subscribe(callback: AuthSubscriptionCallback) {\n    if (this._authService) {\n      return this._authService.subscribe(callback);\n    } else {\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\n  /** @deprecated For internal use only */\n  public send(event: Event<AuthEvent>) {\n    this.authService.send(event);\n  }\n}\n"]}
|
|
144
|
+
//# 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  /**\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"]}
|
|
@@ -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,
|
|
6
|
+
import { createAuthenticatorMachine, getServiceFacade, translate, authenticatorTextUtil, FederatedIdentityProviders, countryDialCodes, getErrors, getSortedFormFields, getFormDataFromEvent, getActorContext, getTotpCodeURL, defaultFormFieldOptions, getActorState, 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';
|
|
@@ -62,10 +62,13 @@ class AuthenticatorService {
|
|
|
62
62
|
const machine = createAuthenticatorMachine();
|
|
63
63
|
const authService = interpret(machine).start();
|
|
64
64
|
this._machineSubscription = authService.subscribe((state) => {
|
|
65
|
-
|
|
66
|
-
this.
|
|
65
|
+
const newState = state;
|
|
66
|
+
this._authState = newState;
|
|
67
|
+
this._facade = getServiceFacade({
|
|
68
|
+
send: authService.send,
|
|
69
|
+
state: newState,
|
|
70
|
+
});
|
|
67
71
|
});
|
|
68
|
-
this._sendEventAliases = getSendEventAliases(authService.send);
|
|
69
72
|
this._authService = authService;
|
|
70
73
|
}
|
|
71
74
|
ngOnDestroy() {
|
|
@@ -111,40 +114,40 @@ class AuthenticatorService {
|
|
|
111
114
|
* Service facades
|
|
112
115
|
*/
|
|
113
116
|
get initializeMachine() {
|
|
114
|
-
return this.
|
|
117
|
+
return this._facade.initializeMachine;
|
|
115
118
|
}
|
|
116
119
|
get updateForm() {
|
|
117
|
-
return this.
|
|
120
|
+
return this._facade.updateForm;
|
|
118
121
|
}
|
|
119
122
|
get updateBlur() {
|
|
120
|
-
return this.
|
|
123
|
+
return this._facade.updateBlur;
|
|
121
124
|
}
|
|
122
125
|
get resendCode() {
|
|
123
|
-
return this.
|
|
126
|
+
return this._facade.resendCode;
|
|
124
127
|
}
|
|
125
128
|
get signOut() {
|
|
126
|
-
return this.
|
|
129
|
+
return this._facade.signOut;
|
|
127
130
|
}
|
|
128
131
|
get submitForm() {
|
|
129
|
-
return this.
|
|
132
|
+
return this._facade.submitForm;
|
|
130
133
|
}
|
|
131
134
|
/**
|
|
132
135
|
* Transition facades
|
|
133
136
|
*/
|
|
134
137
|
get toFederatedSignIn() {
|
|
135
|
-
return this.
|
|
138
|
+
return this._facade.toFederatedSignIn;
|
|
136
139
|
}
|
|
137
140
|
get toResetPassword() {
|
|
138
|
-
return this.
|
|
141
|
+
return this._facade.toResetPassword;
|
|
139
142
|
}
|
|
140
143
|
get toSignIn() {
|
|
141
|
-
return this.
|
|
144
|
+
return this._facade.toSignIn;
|
|
142
145
|
}
|
|
143
146
|
get toSignUp() {
|
|
144
|
-
return this.
|
|
147
|
+
return this._facade.toSignUp;
|
|
145
148
|
}
|
|
146
149
|
get skipVerification() {
|
|
147
|
-
return this.
|
|
150
|
+
return this._facade.skipVerification;
|
|
148
151
|
}
|
|
149
152
|
/**
|
|
150
153
|
* Internal utility functions
|
|
@@ -163,17 +166,16 @@ class AuthenticatorService {
|
|
|
163
166
|
}
|
|
164
167
|
/** @deprecated For internal use only */
|
|
165
168
|
get slotContext() {
|
|
166
|
-
|
|
167
|
-
return Object.assign(Object.assign({}, slotContext), { $implicit: Object.assign({}, slotContext) });
|
|
169
|
+
return Object.assign(Object.assign({}, this._facade), { $implicit: this._facade });
|
|
168
170
|
}
|
|
169
|
-
/** @deprecated For internal use only */
|
|
170
171
|
subscribe(callback) {
|
|
171
|
-
if (this._authService) {
|
|
172
|
-
return this._authService.subscribe(callback);
|
|
173
|
-
}
|
|
174
|
-
else {
|
|
172
|
+
if (!this._authService) {
|
|
175
173
|
logger$1.error('Subscription attempted before machine was created. This is likely a bug on the library, please consider filing a bug.');
|
|
176
174
|
}
|
|
175
|
+
const subscription = this._authService.subscribe(() => {
|
|
176
|
+
callback(this._facade);
|
|
177
|
+
});
|
|
178
|
+
return subscription;
|
|
177
179
|
}
|
|
178
180
|
/** @deprecated For internal use only */
|
|
179
181
|
send(event) {
|