@annalib/anna-cognito-lib 0.2.4 → 0.2.5

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.
Files changed (81) hide show
  1. package/annalib-anna-cognito-lib.d.ts +5 -0
  2. package/esm2020/annalib-anna-cognito-lib.mjs +5 -0
  3. package/esm2020/lib/anna-cognito-lib.module.mjs +74 -0
  4. package/esm2020/lib/components/forgot-password/forgot-password.component.mjs +69 -0
  5. package/esm2020/lib/components/login/login.component.mjs +45 -0
  6. package/esm2020/lib/components/password-matching/password-matching.component.mjs +90 -0
  7. package/esm2020/lib/components/set-new-password/set-new-password.component.mjs +55 -0
  8. package/esm2020/lib/components/verify-and-set-new-password/verify-and-set-new-password.component.mjs +66 -0
  9. package/esm2020/lib/config/acl-service.token.mjs +4 -0
  10. package/esm2020/lib/config/auth-service.token.mjs +4 -0
  11. package/esm2020/lib/config/library.config.mjs +6 -0
  12. package/esm2020/lib/constants/loginConstant.mjs +46 -0
  13. package/esm2020/lib/directives/spinner-button/index.mjs +2 -0
  14. package/esm2020/lib/directives/spinner-button/spinner-button.directive.mjs +42 -0
  15. package/esm2020/lib/models/auth.model.mjs +18 -0
  16. package/esm2020/lib/services/acl.service.mjs +30 -0
  17. package/esm2020/lib/services/auth.service.mjs +219 -0
  18. package/esm2020/public-api.mjs +21 -0
  19. package/fesm2015/annalib-anna-cognito-lib.mjs +705 -0
  20. package/fesm2015/annalib-anna-cognito-lib.mjs.map +1 -0
  21. package/fesm2020/annalib-anna-cognito-lib.mjs +699 -0
  22. package/fesm2020/annalib-anna-cognito-lib.mjs.map +1 -0
  23. package/lib/anna-cognito-lib.module.d.ts +18 -0
  24. package/lib/components/forgot-password/forgot-password.component.d.ts +31 -0
  25. package/lib/components/login/login.component.d.ts +21 -0
  26. package/lib/components/password-matching/password-matching.component.d.ts +22 -0
  27. package/lib/components/set-new-password/set-new-password.component.d.ts +26 -0
  28. package/lib/components/verify-and-set-new-password/verify-and-set-new-password.component.d.ts +30 -0
  29. package/lib/config/acl-service.token.d.ts +19 -0
  30. package/lib/config/auth-service.token.d.ts +11 -0
  31. package/lib/config/library.config.d.ts +7 -0
  32. package/lib/constants/loginConstant.d.ts +40 -0
  33. package/{src/lib/directives/spinner-button/index.ts → lib/directives/spinner-button/index.d.ts} +0 -0
  34. package/lib/directives/spinner-button/spinner-button.directive.d.ts +15 -0
  35. package/lib/models/auth.model.d.ts +16 -0
  36. package/lib/services/acl.service.d.ts +12 -0
  37. package/lib/services/auth.service.d.ts +53 -0
  38. package/package.json +37 -14
  39. package/{src/public-api.ts → public-api.d.ts} +0 -14
  40. package/.browserslistrc +0 -16
  41. package/karma.conf.js +0 -44
  42. package/ng-package.json +0 -7
  43. package/src/assets/.gitkeep +0 -0
  44. package/src/assets/images/Anna-Logo.png +0 -0
  45. package/src/lib/anna-cognito-lib.module.ts +0 -51
  46. package/src/lib/components/forgot-password/forgot-password.component.html +0 -44
  47. package/src/lib/components/forgot-password/forgot-password.component.scss +0 -22
  48. package/src/lib/components/forgot-password/forgot-password.component.spec.ts +0 -25
  49. package/src/lib/components/forgot-password/forgot-password.component.ts +0 -75
  50. package/src/lib/components/login/login.component.html +0 -45
  51. package/src/lib/components/login/login.component.scss +0 -10
  52. package/src/lib/components/login/login.component.spec.ts +0 -25
  53. package/src/lib/components/login/login.component.ts +0 -47
  54. package/src/lib/components/password-matching/password-matching.component.html +0 -84
  55. package/src/lib/components/password-matching/password-matching.component.scss +0 -83
  56. package/src/lib/components/password-matching/password-matching.component.spec.ts +0 -25
  57. package/src/lib/components/password-matching/password-matching.component.ts +0 -92
  58. package/src/lib/components/set-new-password/set-new-password.component.html +0 -31
  59. package/src/lib/components/set-new-password/set-new-password.component.scss +0 -1
  60. package/src/lib/components/set-new-password/set-new-password.component.spec.ts +0 -25
  61. package/src/lib/components/set-new-password/set-new-password.component.ts +0 -54
  62. package/src/lib/components/verify-and-set-new-password/verify-and-set-new-password.component.html +0 -54
  63. package/src/lib/components/verify-and-set-new-password/verify-and-set-new-password.component.scss +0 -40
  64. package/src/lib/components/verify-and-set-new-password/verify-and-set-new-password.component.spec.ts +0 -25
  65. package/src/lib/components/verify-and-set-new-password/verify-and-set-new-password.component.ts +0 -70
  66. package/src/lib/config/acl-service.token.ts +0 -22
  67. package/src/lib/config/auth-service.token.ts +0 -15
  68. package/src/lib/config/library.config.ts +0 -8
  69. package/src/lib/constants/loginConstant.ts +0 -50
  70. package/src/lib/directives/spinner-button/spinner-button.directive.spec.ts +0 -40
  71. package/src/lib/directives/spinner-button/spinner-button.directive.ts +0 -36
  72. package/src/lib/models/auth.model.ts +0 -24
  73. package/src/lib/scss/_colors.scss +0 -107
  74. package/src/lib/scss/_fonts.scss +0 -86
  75. package/src/lib/scss/_loginTemplate.scss +0 -164
  76. package/src/lib/services/acl.service.ts +0 -24
  77. package/src/lib/services/auth.service.ts +0 -243
  78. package/src/test.ts +0 -27
  79. package/tsconfig.lib.json +0 -18
  80. package/tsconfig.lib.prod.json +0 -10
  81. package/tsconfig.spec.json +0 -17
@@ -0,0 +1,699 @@
1
+ import * as i0 from '@angular/core';
2
+ import { InjectionToken, Injectable, Inject, Directive, Input, Component, EventEmitter, Output, NgModule } from '@angular/core';
3
+ import * as i2 from '@angular/forms';
4
+ import { Validators, FormBuilder, FormsModule, ReactiveFormsModule } from '@angular/forms';
5
+ import * as i3 from '@angular/router';
6
+ import { RouterModule } from '@angular/router';
7
+ import { CognitoUserPool, CognitoUser, AuthenticationDetails } from 'amazon-cognito-identity-js';
8
+ import * as i4 from '@angular/common';
9
+ import { CommonModule } from '@angular/common';
10
+ import { debounceTime } from 'rxjs/operators';
11
+ import * as i3$1 from 'ngx-toastr';
12
+
13
+ class LoginConstant {
14
+ }
15
+ // Login page
16
+ LoginConstant.enterEmail = "Enter your username";
17
+ LoginConstant.password = "Password";
18
+ LoginConstant.confirmPassword = "Confirm Password";
19
+ LoginConstant.login = "Login";
20
+ LoginConstant.otp = "OTP";
21
+ LoginConstant.forgotPassword = "Forgot " + LoginConstant.password.toLowerCase() + "?";
22
+ // set new password
23
+ LoginConstant.setNewPasswordHeading = "Set new " + LoginConstant.password.toLowerCase();
24
+ LoginConstant.setNewPasswordButton = "Set and " + LoginConstant.login.toLowerCase() + " again";
25
+ LoginConstant.passwordMustContain = "The password must contain:";
26
+ LoginConstant.minimumCharacter = "Minimum 8 characters";
27
+ LoginConstant.oneUppercase = "1 Uppercase";
28
+ LoginConstant.oneLowercase = "1 Lowercase";
29
+ LoginConstant.oneNumber = "1 Numerical";
30
+ LoginConstant.specialCharacter = "1 Special character";
31
+ LoginConstant.passwordNotMatching = "The passwords do not match. Please try again.";
32
+ LoginConstant.userNamePasswordIncorrect = "Incorrect username or password";
33
+ LoginConstant.userNotFound = "No registered user found";
34
+ LoginConstant.loginAgain = LoginConstant.login + " again";
35
+ // verify OTP & set new password
36
+ LoginConstant.verifyAndSetNewPasswordheading = "Enter " + LoginConstant.otp + " & set new password";
37
+ LoginConstant.verifyAndSetNewPasswordMessage = "An " + LoginConstant.otp + " has been succesfully emailed to ";
38
+ LoginConstant.pleaseEnterItBelow = ". Please enter it below.";
39
+ LoginConstant.regenerateOtp = "Regenerate " + LoginConstant.otp;
40
+ LoginConstant.enterOtp = "Enter " + LoginConstant.otp;
41
+ LoginConstant.submit = "Submit";
42
+ LoginConstant.attempt = "Attempt";
43
+ LoginConstant.attemptLimitExceeded = "You have exceeded the maximum number of allowed attempts. Please try again after 15 minutes.";
44
+ LoginConstant.attemptMessage = " of 5. The OTP entered is incorrect. Please try again with the right one.";
45
+ LoginConstant.sessionExpired = "The session has expired. Please try again.";
46
+ // forgot password
47
+ LoginConstant.forgotPasswordHeading = "Forgot your password?";
48
+ LoginConstant.forgotPasswordMessage = "Please enter your username.";
49
+ LoginConstant.forgotPasswordButton = "Get " + LoginConstant.otp;
50
+ LoginConstant.apiFailErrorMessage = "Unable to connect to server right now. Please try after some time.";
51
+ //url
52
+ LoginConstant.setNewPasswordUrl = "/set-new-password";
53
+ LoginConstant.forgortPasswordPageUrl = "/forgot-password";
54
+ LoginConstant.verifyAndSetNewPasswordUrl = "/verify-and-set-new-password";
55
+ LoginConstant.loginPageUrl = "/login";
56
+ LoginConstant.homePageUrl = "/home";
57
+ LoginConstant.stationSettingUrl = "/station-settings";
58
+
59
+ class AuthenticationData {
60
+ constructor(Username, Password) {
61
+ this.Username = Username;
62
+ this.Password = Password;
63
+ }
64
+ }
65
+ class UserPoolInformation {
66
+ constructor(UserPoolId, ClientId) {
67
+ this.UserPoolId = UserPoolId;
68
+ this.ClientId = ClientId;
69
+ }
70
+ }
71
+ class UsernameInfo {
72
+ constructor(object) {
73
+ this.isUsernameAvailable = object.isUsernameAvailable;
74
+ }
75
+ }
76
+
77
+ /** Token to inject the acl service */
78
+ const ACL_SERVICE_TOKEN = new InjectionToken('ACL service token');
79
+
80
+ class AnnaLibAclService {
81
+ constructor(consumingProjectAclService) {
82
+ this.consumingProjectAclService = consumingProjectAclService;
83
+ }
84
+ isUserAuthorisedToAccessPage(url) {
85
+ let privilegeName = this.consumingProjectAclService.urlToCognitoPrivilegeMap[url];
86
+ return this.userGroupsInCognitoJWT.includes(privilegeName);
87
+ }
88
+ isUserAuthorisedToAccessElement(privilege) {
89
+ return this.userGroupsInCognitoJWT.includes(privilege);
90
+ }
91
+ isUserAuthoriseToAcessManageUser() {
92
+ return this.consumingProjectAclService.isUserAuthoriseToAcessManageUser();
93
+ }
94
+ }
95
+ AnnaLibAclService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: AnnaLibAclService, deps: [{ token: ACL_SERVICE_TOKEN }], target: i0.ɵɵFactoryTarget.Injectable });
96
+ AnnaLibAclService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: AnnaLibAclService, providedIn: "root" });
97
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: AnnaLibAclService, decorators: [{
98
+ type: Injectable,
99
+ args: [{
100
+ providedIn: "root",
101
+ }]
102
+ }], ctorParameters: function () { return [{ type: undefined, decorators: [{
103
+ type: Inject,
104
+ args: [ACL_SERVICE_TOKEN]
105
+ }] }]; } });
106
+
107
+ class LibraryConfig {
108
+ constructor() {
109
+ this.loginPageLogoImgUrl = '';
110
+ }
111
+ }
112
+
113
+ /** Token to inject the auth service */
114
+ const AUTH_SERVICE_TOKEN = new InjectionToken('Auth service token');
115
+
116
+ // Angular import statements
117
+ class AnnaLibAuthService {
118
+ constructor(router, aclService, libraryConfig, consumingProjectAuthService) {
119
+ this.router = router;
120
+ this.aclService = aclService;
121
+ this.libraryConfig = libraryConfig;
122
+ this.consumingProjectAuthService = consumingProjectAuthService;
123
+ this.noOfAttempts = 0;
124
+ this.sessionLocked = false;
125
+ if (!consumingProjectAuthService) {
126
+ throw new Error('You must provide a authService');
127
+ }
128
+ }
129
+ ngOnInit() { }
130
+ /***
131
+ 1. takes user pool data (userPool ID and client ID)
132
+ 2. if current user is null then it means user already logged out then simply return Promise<false>
133
+ 3. if current user present check if token is valid for it.
134
+ */
135
+ isUserLoggedIn() {
136
+ let currentUser = this.getCurrentUserDetails();
137
+ if (currentUser) {
138
+ return new Promise((resolve, reject) => {
139
+ currentUser && currentUser.getSession((error, token) => {
140
+ if (token) {
141
+ this.getAllCognitoTokenAndGroups(token);
142
+ resolve(true);
143
+ }
144
+ else {
145
+ this.sessionTimeout();
146
+ resolve(false);
147
+ }
148
+ });
149
+ });
150
+ }
151
+ else {
152
+ return new Promise((resolve) => {
153
+ clearInterval(this.accessTokenTimerId);
154
+ resolve(false);
155
+ });
156
+ }
157
+ }
158
+ sessionTimeout() {
159
+ localStorage.clear();
160
+ clearInterval(this.accessTokenTimerId);
161
+ this.router.navigate([LoginConstant.loginPageUrl]);
162
+ }
163
+ refreshAccessToken() {
164
+ let currentUser = this.getCurrentUserDetails();
165
+ let accessTokenExpiration = localStorage.getItem("accessTokenExpiration");
166
+ let expTime = accessTokenExpiration ? parseInt(accessTokenExpiration) : 0;
167
+ this.accessTokenTimerId = setInterval(() => {
168
+ let counter = 1000;
169
+ let delayFunction = setTimeout(() => {
170
+ currentUser && currentUser.getSession((error, token) => {
171
+ if (token) {
172
+ this.getAllCognitoTokenAndGroups(token);
173
+ let newExpTime = this.computeTokenExpiration(this.IdToken);
174
+ if (newExpTime <= 0) {
175
+ newExpTime = 1000;
176
+ counter = 0;
177
+ if (delayFunction) {
178
+ clearInterval(delayFunction);
179
+ }
180
+ }
181
+ expTime = newExpTime;
182
+ localStorage.setItem("accessTokenExpiration", newExpTime.toString());
183
+ clearInterval(this.accessTokenTimerId);
184
+ this.refreshAccessToken();
185
+ }
186
+ else if (error.code === "NotAuthorizedException") {
187
+ this.sessionTimeout();
188
+ }
189
+ });
190
+ }, counter);
191
+ }, expTime);
192
+ }
193
+ computeTokenExpiration(token) {
194
+ let currentTime = Math.floor(Date.now() / 1000);
195
+ let tokenTime = token.payload.exp;
196
+ let expTime = (tokenTime - currentTime) * 1000;
197
+ return expTime;
198
+ }
199
+ getCurrentUserDetails() {
200
+ let poolData = new UserPoolInformation(this.libraryConfig.cognito.userPoolId, this.libraryConfig.cognito.clientId);
201
+ let userPool = new CognitoUserPool(poolData);
202
+ return userPool.getCurrentUser();
203
+ }
204
+ getCognitoUserDetails(email) {
205
+ this.poolData = new UserPoolInformation(this.libraryConfig.cognito.userPoolId, this.libraryConfig.cognito.clientId);
206
+ this.userPool = new CognitoUserPool(this.poolData);
207
+ let userData = {
208
+ Username: email,
209
+ Pool: this.userPool,
210
+ };
211
+ let cognitoUser = new CognitoUser(userData);
212
+ return cognitoUser;
213
+ }
214
+ authenticate(email, password) {
215
+ this.loginErrorMessage = null;
216
+ let authData = new AuthenticationData(email, password);
217
+ this.authenticationDetails = new AuthenticationDetails(authData);
218
+ this.cognitoUser = this.getCognitoUserDetails(email);
219
+ this.CognitoAuthentication(this.authenticationDetails);
220
+ }
221
+ CognitoAuthentication(authenticationDetails) {
222
+ this.cognitoUser.authenticateUser(authenticationDetails, {
223
+ onSuccess: async (result) => {
224
+ this.getAllCognitoTokenAndGroups(result);
225
+ await this.consumingProjectAuthService.onSuccessfulAuthenticatingUser(result);
226
+ },
227
+ onFailure: (err) => {
228
+ this.consumingProjectAuthService.isLoggingIn = false;
229
+ if (err.message === "Password attempts exceeded") {
230
+ this.loginErrorMessage = LoginConstant.attemptLimitExceeded;
231
+ }
232
+ else {
233
+ this.loginErrorMessage = LoginConstant.userNamePasswordIncorrect;
234
+ }
235
+ },
236
+ newPasswordRequired: (data) => {
237
+ this.consumingProjectAuthService.isLoggingIn = false;
238
+ this.userAttribute = data;
239
+ this.router.navigate([LoginConstant.setNewPasswordUrl]);
240
+ },
241
+ });
242
+ }
243
+ setNewPassword(newPassword) {
244
+ delete this.userAttribute.email;
245
+ delete this.userAttribute.email_verified;
246
+ delete this.userAttribute.phone_number_verified;
247
+ this.cognitoUser.completeNewPasswordChallenge(newPassword, this.userAttribute, {
248
+ onSuccess: (result) => {
249
+ this.router.navigate([LoginConstant.loginPageUrl]);
250
+ },
251
+ onFailure: (error) => {
252
+ this.setNewPasswordErrorMessage = LoginConstant.sessionExpired;
253
+ this.setNewPasswordButtonMessage = LoginConstant.loginAgain;
254
+ },
255
+ });
256
+ }
257
+ onForgotPasswordGenerateOTP(email) {
258
+ this.userName = email;
259
+ this.cognitoUser = this.getCognitoUserDetails(email);
260
+ this.cognitoUser.forgotPassword({
261
+ onSuccess: (result) => {
262
+ this.verifyAndSetNewPasswordMessage =
263
+ LoginConstant.verifyAndSetNewPasswordMessage +
264
+ result.CodeDeliveryDetails.Destination +
265
+ LoginConstant.pleaseEnterItBelow;
266
+ this.router.navigate([LoginConstant.verifyAndSetNewPasswordUrl]);
267
+ },
268
+ onFailure: (err) => { },
269
+ });
270
+ }
271
+ verifyCode(verificationCode, newPassword) {
272
+ this.cognitoUser.confirmPassword(verificationCode, newPassword, {
273
+ onFailure: (error) => {
274
+ this.noOfAttempts = this.noOfAttempts + 1;
275
+ this.verifyAndSetNewPasswordErrorMessage = this.forgotPasswordError(error, this.noOfAttempts);
276
+ },
277
+ onSuccess: () => {
278
+ this.router.navigate([LoginConstant.loginPageUrl]);
279
+ },
280
+ });
281
+ }
282
+ forgotPasswordError(err, noOfAttempts) {
283
+ let errorMessage;
284
+ switch (err.code) {
285
+ case "LimitExceededException":
286
+ this.sessionLocked = true;
287
+ errorMessage = LoginConstant.attemptLimitExceeded;
288
+ break;
289
+ case "ExpiredCodeException":
290
+ errorMessage = LoginConstant.sessionExpired;
291
+ this.verifyAndSetNewPasswordButton = LoginConstant.regenerateOtp;
292
+ break;
293
+ default:
294
+ errorMessage = LoginConstant.attempt + " " + noOfAttempts + LoginConstant.attemptMessage;
295
+ }
296
+ return errorMessage;
297
+ }
298
+ getAllCognitoTokenAndGroups(token) {
299
+ this.accessToken = token.getAccessToken().getJwtToken();
300
+ this.IdToken = token.getIdToken();
301
+ if ("cognito:groups" in token.getAccessToken().payload) {
302
+ this.aclService.userGroupsInCognitoJWT = token.getAccessToken().payload["cognito:groups"];
303
+ }
304
+ else {
305
+ this.aclService.userGroupsInCognitoJWT = [];
306
+ }
307
+ }
308
+ }
309
+ AnnaLibAuthService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: AnnaLibAuthService, deps: [{ token: i3.Router }, { token: AnnaLibAclService }, { token: LibraryConfig }, { token: AUTH_SERVICE_TOKEN }], target: i0.ɵɵFactoryTarget.Injectable });
310
+ AnnaLibAuthService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: AnnaLibAuthService, providedIn: "root" });
311
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: AnnaLibAuthService, decorators: [{
312
+ type: Injectable,
313
+ args: [{
314
+ providedIn: "root",
315
+ }]
316
+ }], ctorParameters: function () { return [{ type: i3.Router }, { type: AnnaLibAclService }, { type: LibraryConfig }, { type: undefined, decorators: [{
317
+ type: Inject,
318
+ args: [AUTH_SERVICE_TOKEN]
319
+ }] }]; } });
320
+
321
+ class SpinnerButtonDirective {
322
+ constructor(el, renderer) {
323
+ this.el = el;
324
+ this.renderer = renderer;
325
+ this.button = this.el.nativeElement;
326
+ this.child = document.createElement("div");
327
+ }
328
+ ngOnInit() { }
329
+ ngOnChanges(changes) {
330
+ if (changes['spinnerButtonText'] && changes['spinnerButtonText'].currentValue) {
331
+ this.button.innerHTML = this.spinnerButtonText;
332
+ }
333
+ if (changes['loading'] && changes['loading'].currentValue) {
334
+ this.button.innerHTML = "";
335
+ this.button.setAttribute("disabled", "true");
336
+ this.child.classList.add("spinner-for-button-directive");
337
+ this.renderer.appendChild(this.button, this.child);
338
+ }
339
+ else {
340
+ this.child.classList.remove("spinner-for-button-directive");
341
+ this.button.removeAttribute("disabled");
342
+ this.button.innerHTML = this.spinnerButtonText;
343
+ }
344
+ }
345
+ }
346
+ SpinnerButtonDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SpinnerButtonDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
347
+ SpinnerButtonDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.7", type: SpinnerButtonDirective, selector: "[anna-cognito-lib-SpinnerButton]", inputs: { loading: ["anna-cognito-lib-SpinnerButton", "loading"], spinnerButtonText: "spinnerButtonText" }, usesOnChanges: true, ngImport: i0 });
348
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SpinnerButtonDirective, decorators: [{
349
+ type: Directive,
350
+ args: [{
351
+ selector: "[anna-cognito-lib-SpinnerButton]",
352
+ }]
353
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { loading: [{
354
+ type: Input,
355
+ args: ["anna-cognito-lib-SpinnerButton"]
356
+ }], spinnerButtonText: [{
357
+ type: Input,
358
+ args: ["spinnerButtonText"]
359
+ }] } });
360
+
361
+ // Angular import statements
362
+ class LoginComponent {
363
+ constructor(authService, fb, libraryConfig) {
364
+ this.authService = authService;
365
+ this.fb = fb;
366
+ this.libraryConfig = libraryConfig;
367
+ this.annaLogoUrl = "assets/images/Anna-Logo-for-footer-min.png";
368
+ }
369
+ ngOnInit() {
370
+ this.constants = LoginConstant;
371
+ this.onIntialiseForm();
372
+ }
373
+ onIntialiseForm() {
374
+ this.loginForm = this.fb.group({
375
+ username: [null],
376
+ password: [null],
377
+ });
378
+ }
379
+ OnLogin() {
380
+ this.authService.consumingProjectAuthService.isLoggingIn = true;
381
+ const username = this.loginForm.controls['username'].value;
382
+ const password = this.loginForm.controls['password'].value;
383
+ this.authService.authenticate(username, password);
384
+ }
385
+ }
386
+ LoginComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: LoginComponent, deps: [{ token: AnnaLibAuthService }, { token: i2.FormBuilder }, { token: LibraryConfig }], target: i0.ɵɵFactoryTarget.Component });
387
+ LoginComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: LoginComponent, selector: "anna-cognito-lib-login", ngImport: i0, template: "<div class=\"main\">\r\n <!-- Load login page when all constant variable are intiated otherwise it will show a glitch. that's why ngIf check of constants.forgotPassword -->\r\n <section *ngIf=\"constants.forgotPassword\">\r\n <header>\r\n <img [src]=\"libraryConfig.loginPageLogoImgUrl\" loading=\"eager\" alt=\"Anna Logo\" />\r\n </header>\r\n <article>\r\n <form [formGroup]=\"loginForm\" (ngSubmit)=\"OnLogin()\">\r\n <div id=\"alert-div\" *ngIf=\"authService.loginErrorMessage\">\r\n <span class=\"material-icons\">report</span>\r\n <p>{{ authService.loginErrorMessage }}</p>\r\n </div>\r\n\r\n <input\r\n type=\"text\"\r\n tabindex=\"1\"\r\n formControlName=\"username\"\r\n [ngClass]=\"{ 'input-invalid': authService.loginErrorMessage }\"\r\n [placeholder]=\"constants.enterEmail\"\r\n autocomplete=\"username\"\r\n autofocus\r\n />\r\n\r\n <input\r\n type=\"password\"\r\n tabindex=\"2\"\r\n formControlName=\"password\"\r\n [ngClass]=\"{ 'input-invalid': authService.loginErrorMessage }\"\r\n [placeholder]=\"constants.password\"\r\n autocomplete=\"current-password\"\r\n autofocus\r\n />\r\n\r\n <a tabindex=\"4\" [routerLink]=\"constants.forgortPasswordPageUrl\">{{ constants.forgotPassword }}</a>\r\n <button\r\n tabindex=\"3\"\r\n class=\"login-btn\"\r\n [anna-cognito-lib-SpinnerButton]=\"authService.consumingProjectAuthService.isLoggingIn\"\r\n [spinnerButtonText]=\"constants.login\"\r\n ></button>\r\n </form>\r\n </article>\r\n <footer>Powered by <span>SureWaves</span></footer>\r\n </section>\r\n</div>\r\n", styles: ["@keyframes show{0%{opacity:0}50%{opacity:.5}to{opacity:1}}html{overflow-y:scroll}.main{background-color:#fff;background-size:cover;font-family:Roboto;height:100vh}section{top:45%;left:50%;position:absolute;transform:translate(-50%,-50%);width:20.875rem;animation:show .5s 1;-moz-animation:show .5s 1}.container{width:100%;height:100%;overflow:auto}header{height:auto;width:100%;text-align:center}article{margin-top:.9375rem;margin-bottom:.9375rem;border:1px solid #979797;background-color:#f4f4f4;padding:2rem 1.375rem;border-radius:.375rem;box-shadow:0 .125rem .4375rem #0000001a}article #heading{color:#212121;text-align:center;margin-bottom:1.5rem;font-family:Roboto;font-size:1.125rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}#alert-div{padding:.25rem 0 0;margin-bottom:.75rem;border-radius:.25rem;border:solid 1px #f9b3ae;background-color:#fde4e3}#alert-div .material-icons{color:#f44336;font-size:1rem;margin-left:.5rem}#alert-div p{margin:-1.5625rem 0 0 1.8rem;padding:.3125rem 0;color:#4a4a4a;font-family:Roboto;font-size:.75rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}footer{align-items:baseline;color:#6e6e6e;opacity:.9;display:flex;font-family:Ubuntu;font-size:1rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;justify-content:center}footer span{font-size:1.3125rem;font-weight:700;margin-left:.25rem}input[type=password],input[type=text],input[type=number]{width:100%;height:30px;padding:.75rem 1rem;border:1px solid #979797;margin-bottom:.625rem;border-radius:.375rem}.login-btn{width:100%;height:2.5rem;border:0;color:#fff;background-color:#268bff;border-radius:.375rem;font-size:1rem;margin-top:.9375rem}.login-btn:hover{background-color:#4099ff;cursor:pointer}.login-btn:disabled{background-color:#ccc;color:#fff;cursor:not-allowed}.input-invalid{border:1px solid #fe3824!important}input[type=password].ng-dirty.ng-invalid,input[type=text].ng-dirty.ng-invalid{border:1px solid #fe3824}input[type=submit]:focus,input[type=password]:focus,input[type=text]:focus,input[type=checkbox]:focus,button:focus{outline:none}input::placeholder{color:#a4a4a4}a{float:right;color:#268bff;font-family:Roboto;font-size:.875rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;text-decoration:underline}a:hover{cursor:pointer}\n"], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i3.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo", "routerLink"] }, { type: SpinnerButtonDirective, selector: "[anna-cognito-lib-SpinnerButton]", inputs: ["anna-cognito-lib-SpinnerButton", "spinnerButtonText"] }] });
388
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: LoginComponent, decorators: [{
389
+ type: Component,
390
+ args: [{ selector: "anna-cognito-lib-login", template: "<div class=\"main\">\r\n <!-- Load login page when all constant variable are intiated otherwise it will show a glitch. that's why ngIf check of constants.forgotPassword -->\r\n <section *ngIf=\"constants.forgotPassword\">\r\n <header>\r\n <img [src]=\"libraryConfig.loginPageLogoImgUrl\" loading=\"eager\" alt=\"Anna Logo\" />\r\n </header>\r\n <article>\r\n <form [formGroup]=\"loginForm\" (ngSubmit)=\"OnLogin()\">\r\n <div id=\"alert-div\" *ngIf=\"authService.loginErrorMessage\">\r\n <span class=\"material-icons\">report</span>\r\n <p>{{ authService.loginErrorMessage }}</p>\r\n </div>\r\n\r\n <input\r\n type=\"text\"\r\n tabindex=\"1\"\r\n formControlName=\"username\"\r\n [ngClass]=\"{ 'input-invalid': authService.loginErrorMessage }\"\r\n [placeholder]=\"constants.enterEmail\"\r\n autocomplete=\"username\"\r\n autofocus\r\n />\r\n\r\n <input\r\n type=\"password\"\r\n tabindex=\"2\"\r\n formControlName=\"password\"\r\n [ngClass]=\"{ 'input-invalid': authService.loginErrorMessage }\"\r\n [placeholder]=\"constants.password\"\r\n autocomplete=\"current-password\"\r\n autofocus\r\n />\r\n\r\n <a tabindex=\"4\" [routerLink]=\"constants.forgortPasswordPageUrl\">{{ constants.forgotPassword }}</a>\r\n <button\r\n tabindex=\"3\"\r\n class=\"login-btn\"\r\n [anna-cognito-lib-SpinnerButton]=\"authService.consumingProjectAuthService.isLoggingIn\"\r\n [spinnerButtonText]=\"constants.login\"\r\n ></button>\r\n </form>\r\n </article>\r\n <footer>Powered by <span>SureWaves</span></footer>\r\n </section>\r\n</div>\r\n", styles: ["@keyframes show{0%{opacity:0}50%{opacity:.5}to{opacity:1}}html{overflow-y:scroll}.main{background-color:#fff;background-size:cover;font-family:Roboto;height:100vh}section{top:45%;left:50%;position:absolute;transform:translate(-50%,-50%);width:20.875rem;animation:show .5s 1;-moz-animation:show .5s 1}.container{width:100%;height:100%;overflow:auto}header{height:auto;width:100%;text-align:center}article{margin-top:.9375rem;margin-bottom:.9375rem;border:1px solid #979797;background-color:#f4f4f4;padding:2rem 1.375rem;border-radius:.375rem;box-shadow:0 .125rem .4375rem #0000001a}article #heading{color:#212121;text-align:center;margin-bottom:1.5rem;font-family:Roboto;font-size:1.125rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}#alert-div{padding:.25rem 0 0;margin-bottom:.75rem;border-radius:.25rem;border:solid 1px #f9b3ae;background-color:#fde4e3}#alert-div .material-icons{color:#f44336;font-size:1rem;margin-left:.5rem}#alert-div p{margin:-1.5625rem 0 0 1.8rem;padding:.3125rem 0;color:#4a4a4a;font-family:Roboto;font-size:.75rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}footer{align-items:baseline;color:#6e6e6e;opacity:.9;display:flex;font-family:Ubuntu;font-size:1rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;justify-content:center}footer span{font-size:1.3125rem;font-weight:700;margin-left:.25rem}input[type=password],input[type=text],input[type=number]{width:100%;height:30px;padding:.75rem 1rem;border:1px solid #979797;margin-bottom:.625rem;border-radius:.375rem}.login-btn{width:100%;height:2.5rem;border:0;color:#fff;background-color:#268bff;border-radius:.375rem;font-size:1rem;margin-top:.9375rem}.login-btn:hover{background-color:#4099ff;cursor:pointer}.login-btn:disabled{background-color:#ccc;color:#fff;cursor:not-allowed}.input-invalid{border:1px solid #fe3824!important}input[type=password].ng-dirty.ng-invalid,input[type=text].ng-dirty.ng-invalid{border:1px solid #fe3824}input[type=submit]:focus,input[type=password]:focus,input[type=text]:focus,input[type=checkbox]:focus,button:focus{outline:none}input::placeholder{color:#a4a4a4}a{float:right;color:#268bff;font-family:Roboto;font-size:.875rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;text-decoration:underline}a:hover{cursor:pointer}\n"] }]
391
+ }], ctorParameters: function () { return [{ type: AnnaLibAuthService }, { type: i2.FormBuilder }, { type: LibraryConfig }]; } });
392
+
393
+ // Angular import statements
394
+ class PasswordMatchingComponent {
395
+ constructor(fb) {
396
+ this.fb = fb;
397
+ this.passwordChange = new EventEmitter();
398
+ this.confirmPasswordChange = new EventEmitter();
399
+ }
400
+ ngOnInit() {
401
+ this.constants = LoginConstant;
402
+ this.createGroup();
403
+ this.formValueChanged();
404
+ }
405
+ formValueChanged() {
406
+ const password = this.passwordForm.get("password");
407
+ const confirmPassword = this.passwordForm.get("confirmPassword");
408
+ password && password.valueChanges.subscribe(() => {
409
+ password && password.setValidators([
410
+ Validators.required,
411
+ this.regexValidator(new RegExp(".{8,}"), { minLength: true }),
412
+ this.regexValidator(new RegExp("[a-z]"), { lowercase: true }),
413
+ this.regexValidator(new RegExp("[A-Z]"), { uppercase: true }),
414
+ this.regexValidator(new RegExp("[0-9]"), { number: true }),
415
+ this.regexValidator(new RegExp("[^a-zA-Z0-9]"), { specialCharacter: true }),
416
+ ]);
417
+ password.updateValueAndValidity({ emitEvent: false });
418
+ this.onPasswordChange();
419
+ });
420
+ if (confirmPassword) {
421
+ confirmPassword.valueChanges.pipe(debounceTime(300)).subscribe(() => {
422
+ confirmPassword.setValidators([Validators.required]);
423
+ confirmPassword.updateValueAndValidity({ emitEvent: false });
424
+ this.onConfirmPasswordChange();
425
+ });
426
+ }
427
+ }
428
+ onPasswordChange() {
429
+ let result = {
430
+ value: this.passwordForm.value.password,
431
+ status: this.passwordForm.controls['password'].status,
432
+ };
433
+ this.passwordChange.emit(result);
434
+ }
435
+ onConfirmPasswordChange() {
436
+ let result = {
437
+ value: this.passwordForm.value.confirmPassword,
438
+ status: this.passwordForm.controls['confirmPassword'].status,
439
+ };
440
+ this.confirmPasswordChange.emit(result);
441
+ }
442
+ createGroup() {
443
+ this.passwordForm = this.fb.group({
444
+ password: [null],
445
+ confirmPassword: [null],
446
+ });
447
+ return this.passwordForm;
448
+ }
449
+ // TODO: check the return again
450
+ regexValidator(regex, error) {
451
+ return (control) => {
452
+ const valid = regex.test(control.value);
453
+ return (valid ? null : error);
454
+ };
455
+ }
456
+ }
457
+ PasswordMatchingComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: PasswordMatchingComponent, deps: [{ token: FormBuilder }], target: i0.ɵɵFactoryTarget.Component });
458
+ PasswordMatchingComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: PasswordMatchingComponent, selector: "anna-cognito-lib-password-matching", inputs: { passwordNotMatching: "passwordNotMatching" }, outputs: { passwordChange: "passwordChange", confirmPasswordChange: "confirmPasswordChange" }, ngImport: i0, template: "<form [formGroup]=\"passwordForm\">\r\n <div id=\"alert-div\" *ngIf=\"passwordNotMatching\">\r\n <div id=\"icon-div\">\r\n <span class=\"material-icons\">report</span>\r\n </div>\r\n <p>{{ constants.passwordNotMatching }}</p>\r\n </div>\r\n <div class=\"password-policies\">\r\n <ng-container *ngIf=\"!passwordForm.get('password')?.dirty\">\r\n <p>\r\n <b>{{ constants.passwordMustContain }} </b>\r\n </p>\r\n <p>{{ constants.minimumCharacter }}</p>\r\n <p>{{ constants.oneUppercase }}</p>\r\n <p>{{ constants.oneLowercase }}</p>\r\n <p>{{ constants.oneNumber }}</p>\r\n <p>{{ constants.specialCharacter }}</p>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"passwordForm.get('password')?.dirty\">\r\n <p>\r\n <b>{{ constants.passwordMustContain }}</b>\r\n </p>\r\n\r\n <div [ngClass]=\"passwordForm.get('password')?.hasError('minLength') ? 'error-color' : 'success-color'\">\r\n <div id=\"icon-div-msg\">\r\n <span class=\"material-icons\" *ngIf=\"passwordForm.get('password')?.hasError('minLength')\"> cancel </span>\r\n <span class=\"material-icons\" *ngIf=\"!passwordForm.get('password')?.hasError('minLength')\"> check_circle </span>\r\n </div>\r\n <span class=\"span-text\">{{ constants.minimumCharacter }}</span>\r\n </div>\r\n\r\n <div [ngClass]=\"passwordForm.get('password')?.hasError('uppercase') ? 'error-color' : 'success-color'\">\r\n <div id=\"icon-div-msg\">\r\n <span class=\"material-icons\" *ngIf=\"passwordForm.get('password')?.hasError('uppercase')\"> cancel </span>\r\n <span class=\"material-icons\" *ngIf=\"!passwordForm.get('password')?.hasError('uppercase')\"> check_circle </span>\r\n </div>\r\n <span class=\"span-text\">{{ constants.oneUppercase }}</span>\r\n </div>\r\n\r\n <div [ngClass]=\"passwordForm.get('password')?.hasError('lowercase') ? 'error-color' : 'success-color'\">\r\n <div id=\"icon-div-msg\">\r\n <span class=\"material-icons\" *ngIf=\"passwordForm.get('password')?.hasError('lowercase')\"> cancel </span>\r\n <span class=\"material-icons\" *ngIf=\"!passwordForm.get('password')?.hasError('lowercase')\"> check_circle </span>\r\n </div>\r\n <span class=\"span-text\">{{ constants.oneLowercase }}</span>\r\n </div>\r\n\r\n <div [ngClass]=\"passwordForm.get('password')?.hasError('number') ? 'error-color' : 'success-color'\">\r\n <div id=\"icon-div-msg\">\r\n <span class=\"material-icons\" *ngIf=\"passwordForm.get('password')?.hasError('number')\"> cancel </span>\r\n <span class=\"material-icons\" *ngIf=\"!passwordForm.get('password')?.hasError('number')\"> check_circle </span>\r\n </div>\r\n <span class=\"span-text\">{{ constants.oneNumber }}</span>\r\n </div>\r\n\r\n <div [ngClass]=\"passwordForm.get('password')?.hasError('specialCharacter') ? 'error-color' : 'success-color'\">\r\n <div id=\"icon-div-msg\">\r\n <span class=\"material-icons\" *ngIf=\"passwordForm.get('password')?.hasError('specialCharacter')\"> cancel </span>\r\n <span class=\"material-icons\" *ngIf=\"!passwordForm.get('password')?.hasError('specialCharacter')\">\r\n check_circle\r\n </span>\r\n </div>\r\n <span class=\"span-text\">{{ constants.specialCharacter }}</span>\r\n </div>\r\n </ng-container>\r\n </div>\r\n\r\n <input\r\n type=\"password\"\r\n tabindex=\"2\"\r\n formControlName=\"password\"\r\n [placeholder]=\"constants.password\"\r\n [ngClass]=\"{ 'input-invalid': passwordNotMatching }\"\r\n />\r\n\r\n <input\r\n type=\"password\"\r\n tabindex=\"3\"\r\n formControlName=\"confirmPassword\"\r\n [placeholder]=\"constants.confirmPassword\"\r\n [ngClass]=\"{ 'input-invalid': passwordNotMatching }\"\r\n />\r\n</form>\r\n", styles: ["input[type=password],input[type=text]{width:100%;height:30px;padding:10px 16px;border:1px solid #979797;margin-bottom:.625rem;border-radius:.375rem}input[type=password].ng-dirty.ng-invalid,.input-invalid{border:1px solid #fe3824!important}input[type=password]:focus:focus{outline:none;box-shadow:none}input[type=password]:focus::placeholder{color:#a4a4a4}.password-policies{margin-bottom:1rem}.password-policies p{color:#4a4a4a;font-family:Roboto;font-size:1rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:1.31;letter-spacing:normal;margin-bottom:0}.span-text{vertical-align:top;font-family:Roboto;font-size:1rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:1.31;letter-spacing:normal}#icon-div-msg{display:inline;margin-right:.3125rem}#icon-div-msg .material-icons{margin-top:1px;font-size:16px}#alert-div{padding:4px 0 0;margin-bottom:.75rem;border-radius:.25rem;border:solid 1px #f9b3ae;background-color:#fde4e3}#alert-div #icon-div{width:18px;margin-top:-5px;display:inline-block}#alert-div #icon-div .material-icons{color:#f44336;font-size:1.125rem;margin-left:.5rem}#alert-div p{display:inline;vertical-align:top;margin-left:.5rem;color:#4a4a4a;font-family:Roboto;font-size:.7188rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}.error-color{color:#fe3824}.success-color{color:#43a047}\n"], directives: [{ type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }] });
459
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: PasswordMatchingComponent, decorators: [{
460
+ type: Component,
461
+ args: [{ selector: 'anna-cognito-lib-password-matching', template: "<form [formGroup]=\"passwordForm\">\r\n <div id=\"alert-div\" *ngIf=\"passwordNotMatching\">\r\n <div id=\"icon-div\">\r\n <span class=\"material-icons\">report</span>\r\n </div>\r\n <p>{{ constants.passwordNotMatching }}</p>\r\n </div>\r\n <div class=\"password-policies\">\r\n <ng-container *ngIf=\"!passwordForm.get('password')?.dirty\">\r\n <p>\r\n <b>{{ constants.passwordMustContain }} </b>\r\n </p>\r\n <p>{{ constants.minimumCharacter }}</p>\r\n <p>{{ constants.oneUppercase }}</p>\r\n <p>{{ constants.oneLowercase }}</p>\r\n <p>{{ constants.oneNumber }}</p>\r\n <p>{{ constants.specialCharacter }}</p>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"passwordForm.get('password')?.dirty\">\r\n <p>\r\n <b>{{ constants.passwordMustContain }}</b>\r\n </p>\r\n\r\n <div [ngClass]=\"passwordForm.get('password')?.hasError('minLength') ? 'error-color' : 'success-color'\">\r\n <div id=\"icon-div-msg\">\r\n <span class=\"material-icons\" *ngIf=\"passwordForm.get('password')?.hasError('minLength')\"> cancel </span>\r\n <span class=\"material-icons\" *ngIf=\"!passwordForm.get('password')?.hasError('minLength')\"> check_circle </span>\r\n </div>\r\n <span class=\"span-text\">{{ constants.minimumCharacter }}</span>\r\n </div>\r\n\r\n <div [ngClass]=\"passwordForm.get('password')?.hasError('uppercase') ? 'error-color' : 'success-color'\">\r\n <div id=\"icon-div-msg\">\r\n <span class=\"material-icons\" *ngIf=\"passwordForm.get('password')?.hasError('uppercase')\"> cancel </span>\r\n <span class=\"material-icons\" *ngIf=\"!passwordForm.get('password')?.hasError('uppercase')\"> check_circle </span>\r\n </div>\r\n <span class=\"span-text\">{{ constants.oneUppercase }}</span>\r\n </div>\r\n\r\n <div [ngClass]=\"passwordForm.get('password')?.hasError('lowercase') ? 'error-color' : 'success-color'\">\r\n <div id=\"icon-div-msg\">\r\n <span class=\"material-icons\" *ngIf=\"passwordForm.get('password')?.hasError('lowercase')\"> cancel </span>\r\n <span class=\"material-icons\" *ngIf=\"!passwordForm.get('password')?.hasError('lowercase')\"> check_circle </span>\r\n </div>\r\n <span class=\"span-text\">{{ constants.oneLowercase }}</span>\r\n </div>\r\n\r\n <div [ngClass]=\"passwordForm.get('password')?.hasError('number') ? 'error-color' : 'success-color'\">\r\n <div id=\"icon-div-msg\">\r\n <span class=\"material-icons\" *ngIf=\"passwordForm.get('password')?.hasError('number')\"> cancel </span>\r\n <span class=\"material-icons\" *ngIf=\"!passwordForm.get('password')?.hasError('number')\"> check_circle </span>\r\n </div>\r\n <span class=\"span-text\">{{ constants.oneNumber }}</span>\r\n </div>\r\n\r\n <div [ngClass]=\"passwordForm.get('password')?.hasError('specialCharacter') ? 'error-color' : 'success-color'\">\r\n <div id=\"icon-div-msg\">\r\n <span class=\"material-icons\" *ngIf=\"passwordForm.get('password')?.hasError('specialCharacter')\"> cancel </span>\r\n <span class=\"material-icons\" *ngIf=\"!passwordForm.get('password')?.hasError('specialCharacter')\">\r\n check_circle\r\n </span>\r\n </div>\r\n <span class=\"span-text\">{{ constants.specialCharacter }}</span>\r\n </div>\r\n </ng-container>\r\n </div>\r\n\r\n <input\r\n type=\"password\"\r\n tabindex=\"2\"\r\n formControlName=\"password\"\r\n [placeholder]=\"constants.password\"\r\n [ngClass]=\"{ 'input-invalid': passwordNotMatching }\"\r\n />\r\n\r\n <input\r\n type=\"password\"\r\n tabindex=\"3\"\r\n formControlName=\"confirmPassword\"\r\n [placeholder]=\"constants.confirmPassword\"\r\n [ngClass]=\"{ 'input-invalid': passwordNotMatching }\"\r\n />\r\n</form>\r\n", styles: ["input[type=password],input[type=text]{width:100%;height:30px;padding:10px 16px;border:1px solid #979797;margin-bottom:.625rem;border-radius:.375rem}input[type=password].ng-dirty.ng-invalid,.input-invalid{border:1px solid #fe3824!important}input[type=password]:focus:focus{outline:none;box-shadow:none}input[type=password]:focus::placeholder{color:#a4a4a4}.password-policies{margin-bottom:1rem}.password-policies p{color:#4a4a4a;font-family:Roboto;font-size:1rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:1.31;letter-spacing:normal;margin-bottom:0}.span-text{vertical-align:top;font-family:Roboto;font-size:1rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:1.31;letter-spacing:normal}#icon-div-msg{display:inline;margin-right:.3125rem}#icon-div-msg .material-icons{margin-top:1px;font-size:16px}#alert-div{padding:4px 0 0;margin-bottom:.75rem;border-radius:.25rem;border:solid 1px #f9b3ae;background-color:#fde4e3}#alert-div #icon-div{width:18px;margin-top:-5px;display:inline-block}#alert-div #icon-div .material-icons{color:#f44336;font-size:1.125rem;margin-left:.5rem}#alert-div p{display:inline;vertical-align:top;margin-left:.5rem;color:#4a4a4a;font-family:Roboto;font-size:.7188rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}.error-color{color:#fe3824}.success-color{color:#43a047}\n"] }]
462
+ }], ctorParameters: function () { return [{ type: i2.FormBuilder, decorators: [{
463
+ type: Inject,
464
+ args: [FormBuilder]
465
+ }] }]; }, propDecorators: { passwordChange: [{
466
+ type: Output
467
+ }], confirmPasswordChange: [{
468
+ type: Output
469
+ }], passwordNotMatching: [{
470
+ type: Input
471
+ }] } });
472
+
473
+ // Angular import statements
474
+ class SetNewPasswordComponent {
475
+ constructor(authService, router) {
476
+ this.authService = authService;
477
+ this.router = router;
478
+ this.passwordNotMatching = false;
479
+ this.password = { value: null, status: null };
480
+ this.confirmPassword = { value: null, status: null };
481
+ }
482
+ ngOnInit() {
483
+ this.constants = LoginConstant;
484
+ this.authService.setNewPasswordButtonMessage = LoginConstant.setNewPasswordButton;
485
+ }
486
+ isFormValid() {
487
+ return this.password.status === "VALID" && this.confirmPassword.status === "VALID";
488
+ }
489
+ onPasswordChange($event) {
490
+ this.password = $event;
491
+ }
492
+ onConfirmPasswordChange($event) {
493
+ this.confirmPassword = $event;
494
+ }
495
+ onSettingNewPassword() {
496
+ if (this.password.value != this.confirmPassword.value) {
497
+ this.passwordNotMatching = true;
498
+ }
499
+ else {
500
+ this.passwordNotMatching = false;
501
+ if (this.authService.setNewPasswordButtonMessage === LoginConstant.loginAgain) {
502
+ this.router.navigate([LoginConstant.loginPageUrl]);
503
+ }
504
+ else {
505
+ this.authService.setNewPassword(this.password.value);
506
+ }
507
+ }
508
+ }
509
+ }
510
+ SetNewPasswordComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SetNewPasswordComponent, deps: [{ token: AnnaLibAuthService }, { token: i3.Router }], target: i0.ɵɵFactoryTarget.Component });
511
+ SetNewPasswordComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: SetNewPasswordComponent, selector: "anna-cognito-lib-set-new-password", ngImport: i0, template: "<div class=\"main\">\r\n <section>\r\n <header>\r\n <img src=\"assets/images/Anna-Logo-for-footer-min.png\" alt=\"Anna Logo\" />\r\n </header>\r\n <article>\r\n <form>\r\n <div id=\"heading\">\r\n {{ constants.setNewPasswordHeading }}\r\n </div>\r\n\r\n <div id=\"alert-div\" *ngIf=\"authService.setNewPasswordErrorMessage\">\r\n <span class=\"material-icons\">report</span>\r\n <p>{{ authService.setNewPasswordErrorMessage }}</p>\r\n </div>\r\n <anna-cognito-lib-password-matching\r\n (passwordChange)=\"onPasswordChange($event)\"\r\n (confirmPasswordChange)=\"onConfirmPasswordChange($event)\"\r\n [passwordNotMatching]=\"passwordNotMatching\"\r\n >\r\n </anna-cognito-lib-password-matching>\r\n <button tabindex=\"3\" class=\"login-btn\" [disabled]=\"!isFormValid()\" (click)=\"onSettingNewPassword()\">\r\n {{ authService.setNewPasswordButtonMessage }}\r\n </button>\r\n </form>\r\n </article>\r\n <footer>\r\n Powered by <span> <strong> SureWaves</strong></span>\r\n </footer>\r\n </section>\r\n</div>\r\n", styles: ["@keyframes show{0%{opacity:0}50%{opacity:.5}to{opacity:1}}html{overflow-y:scroll}.main{background-color:#fff;background-size:cover;font-family:Roboto;height:100vh}section{top:45%;left:50%;position:absolute;transform:translate(-50%,-50%);width:20.875rem;animation:show .5s 1;-moz-animation:show .5s 1}.container{width:100%;height:100%;overflow:auto}header{height:auto;width:100%;text-align:center}article{margin-top:.9375rem;margin-bottom:.9375rem;border:1px solid #979797;background-color:#f4f4f4;padding:2rem 1.375rem;border-radius:.375rem;box-shadow:0 .125rem .4375rem #0000001a}article #heading{color:#212121;text-align:center;margin-bottom:1.5rem;font-family:Roboto;font-size:1.125rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}#alert-div{padding:.25rem 0 0;margin-bottom:.75rem;border-radius:.25rem;border:solid 1px #f9b3ae;background-color:#fde4e3}#alert-div .material-icons{color:#f44336;font-size:1rem;margin-left:.5rem}#alert-div p{margin:-1.5625rem 0 0 1.8rem;padding:.3125rem 0;color:#4a4a4a;font-family:Roboto;font-size:.75rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}footer{align-items:baseline;color:#6e6e6e;opacity:.9;display:flex;font-family:Ubuntu;font-size:1rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;justify-content:center}footer span{font-size:1.3125rem;font-weight:700;margin-left:.25rem}input[type=password],input[type=text],input[type=number]{width:100%;height:30px;padding:.75rem 1rem;border:1px solid #979797;margin-bottom:.625rem;border-radius:.375rem}.login-btn{width:100%;height:2.5rem;border:0;color:#fff;background-color:#268bff;border-radius:.375rem;font-size:1rem;margin-top:.9375rem}.login-btn:hover{background-color:#4099ff;cursor:pointer}.login-btn:disabled{background-color:#ccc;color:#fff;cursor:not-allowed}.input-invalid{border:1px solid #fe3824!important}input[type=password].ng-dirty.ng-invalid,input[type=text].ng-dirty.ng-invalid{border:1px solid #fe3824}input[type=submit]:focus,input[type=password]:focus,input[type=text]:focus,input[type=checkbox]:focus,button:focus{outline:none}input::placeholder{color:#a4a4a4}\n"], components: [{ type: PasswordMatchingComponent, selector: "anna-cognito-lib-password-matching", inputs: ["passwordNotMatching"], outputs: ["passwordChange", "confirmPasswordChange"] }], directives: [{ type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i2.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
512
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SetNewPasswordComponent, decorators: [{
513
+ type: Component,
514
+ args: [{ selector: 'anna-cognito-lib-set-new-password', template: "<div class=\"main\">\r\n <section>\r\n <header>\r\n <img src=\"assets/images/Anna-Logo-for-footer-min.png\" alt=\"Anna Logo\" />\r\n </header>\r\n <article>\r\n <form>\r\n <div id=\"heading\">\r\n {{ constants.setNewPasswordHeading }}\r\n </div>\r\n\r\n <div id=\"alert-div\" *ngIf=\"authService.setNewPasswordErrorMessage\">\r\n <span class=\"material-icons\">report</span>\r\n <p>{{ authService.setNewPasswordErrorMessage }}</p>\r\n </div>\r\n <anna-cognito-lib-password-matching\r\n (passwordChange)=\"onPasswordChange($event)\"\r\n (confirmPasswordChange)=\"onConfirmPasswordChange($event)\"\r\n [passwordNotMatching]=\"passwordNotMatching\"\r\n >\r\n </anna-cognito-lib-password-matching>\r\n <button tabindex=\"3\" class=\"login-btn\" [disabled]=\"!isFormValid()\" (click)=\"onSettingNewPassword()\">\r\n {{ authService.setNewPasswordButtonMessage }}\r\n </button>\r\n </form>\r\n </article>\r\n <footer>\r\n Powered by <span> <strong> SureWaves</strong></span>\r\n </footer>\r\n </section>\r\n</div>\r\n", styles: ["@keyframes show{0%{opacity:0}50%{opacity:.5}to{opacity:1}}html{overflow-y:scroll}.main{background-color:#fff;background-size:cover;font-family:Roboto;height:100vh}section{top:45%;left:50%;position:absolute;transform:translate(-50%,-50%);width:20.875rem;animation:show .5s 1;-moz-animation:show .5s 1}.container{width:100%;height:100%;overflow:auto}header{height:auto;width:100%;text-align:center}article{margin-top:.9375rem;margin-bottom:.9375rem;border:1px solid #979797;background-color:#f4f4f4;padding:2rem 1.375rem;border-radius:.375rem;box-shadow:0 .125rem .4375rem #0000001a}article #heading{color:#212121;text-align:center;margin-bottom:1.5rem;font-family:Roboto;font-size:1.125rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}#alert-div{padding:.25rem 0 0;margin-bottom:.75rem;border-radius:.25rem;border:solid 1px #f9b3ae;background-color:#fde4e3}#alert-div .material-icons{color:#f44336;font-size:1rem;margin-left:.5rem}#alert-div p{margin:-1.5625rem 0 0 1.8rem;padding:.3125rem 0;color:#4a4a4a;font-family:Roboto;font-size:.75rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}footer{align-items:baseline;color:#6e6e6e;opacity:.9;display:flex;font-family:Ubuntu;font-size:1rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;justify-content:center}footer span{font-size:1.3125rem;font-weight:700;margin-left:.25rem}input[type=password],input[type=text],input[type=number]{width:100%;height:30px;padding:.75rem 1rem;border:1px solid #979797;margin-bottom:.625rem;border-radius:.375rem}.login-btn{width:100%;height:2.5rem;border:0;color:#fff;background-color:#268bff;border-radius:.375rem;font-size:1rem;margin-top:.9375rem}.login-btn:hover{background-color:#4099ff;cursor:pointer}.login-btn:disabled{background-color:#ccc;color:#fff;cursor:not-allowed}.input-invalid{border:1px solid #fe3824!important}input[type=password].ng-dirty.ng-invalid,input[type=text].ng-dirty.ng-invalid{border:1px solid #fe3824}input[type=submit]:focus,input[type=password]:focus,input[type=text]:focus,input[type=checkbox]:focus,button:focus{outline:none}input::placeholder{color:#a4a4a4}\n"] }]
515
+ }], ctorParameters: function () { return [{ type: AnnaLibAuthService }, { type: i3.Router }]; } });
516
+
517
+ // Angular import statements
518
+ class ForgotPasswordComponent {
519
+ constructor(authService, fb, toastr) {
520
+ this.authService = authService;
521
+ this.fb = fb;
522
+ this.toastr = toastr;
523
+ this.passwordNotMatching = false;
524
+ this.password = { value: null, status: null };
525
+ this.confirmPassword = { value: null, status: null };
526
+ }
527
+ ngOnInit() {
528
+ this.constants = LoginConstant;
529
+ this.onIntialiseForm();
530
+ if (this.authService.userName) {
531
+ this.onUpdateForm();
532
+ }
533
+ }
534
+ onIntialiseForm() {
535
+ this.verifyRegisteredEmail = this.fb.group({
536
+ email: [null, [Validators.required]],
537
+ });
538
+ }
539
+ onUpdateForm() {
540
+ this.verifyRegisteredEmail.patchValue({
541
+ email: this.authService.userName,
542
+ });
543
+ }
544
+ isFormValid() {
545
+ return this.verifyRegisteredEmail.valid;
546
+ }
547
+ onVerifyRegisteredEmail() {
548
+ let username = this.verifyRegisteredEmail.controls['email'].value;
549
+ this.authService.consumingProjectAuthService.isUsernameAvailable(username)
550
+ .subscribe({
551
+ next: (response) => {
552
+ let res = new UsernameInfo(response);
553
+ if (!res.isUsernameAvailable) {
554
+ this.authService.onForgotPasswordGenerateOTP(username);
555
+ }
556
+ else {
557
+ this.errorMessage = this.constants.userNotFound;
558
+ }
559
+ },
560
+ error: any => {
561
+ this.toastr.error(LoginConstant.apiFailErrorMessage);
562
+ }
563
+ });
564
+ }
565
+ }
566
+ ForgotPasswordComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: ForgotPasswordComponent, deps: [{ token: AnnaLibAuthService }, { token: i2.FormBuilder }, { token: i3$1.ToastrService }], target: i0.ɵɵFactoryTarget.Component });
567
+ ForgotPasswordComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: ForgotPasswordComponent, selector: "anna-cognito-lib-forgot-password", ngImport: i0, template: "<div class=\"main\">\r\n <section>\r\n <header>\r\n <img src=\"assets/images/Anna-Logo-for-footer-min.png\" alt=\"Anna Logo\" />\r\n </header>\r\n <article>\r\n <form [formGroup]=\"verifyRegisteredEmail\">\r\n <div id=\"heading\">\r\n {{ constants.forgotPasswordHeading }}\r\n </div>\r\n <p>\r\n {{ constants.forgotPasswordMessage }}\r\n </p>\r\n <div id=\"alert-div\" *ngIf=\"errorMessage\">\r\n <span class=\"material-icons\">report</span>\r\n <p id=\"alert-msg\">{{ errorMessage }}</p>\r\n </div>\r\n\r\n <input\r\n type=\"text\"\r\n tabindex=\"1\"\r\n formControlName=\"email\"\r\n [placeholder]=\"constants.enterEmail\"\r\n [ngClass]=\"{\r\n 'input-invalid': verifyRegisteredEmail.get('email')?.dirty && verifyRegisteredEmail.get('email')?.errors\r\n }\"\r\n />\r\n\r\n <button\r\n tabindex=\"2\"\r\n type=\"submit\"\r\n class=\"login-btn\"\r\n [disabled]=\"!isFormValid()\"\r\n (click)=\"onVerifyRegisteredEmail()\"\r\n >\r\n {{ constants.forgotPasswordButton }}\r\n </button>\r\n </form>\r\n </article>\r\n <footer>\r\n Powered by <span> <strong> SureWaves</strong></span>\r\n </footer>\r\n </section>\r\n</div>\r\n", styles: ["@keyframes show{0%{opacity:0}50%{opacity:.5}to{opacity:1}}html{overflow-y:scroll}.main{background-color:#fff;background-size:cover;font-family:Roboto;height:100vh}section{top:45%;left:50%;position:absolute;transform:translate(-50%,-50%);width:20.875rem;animation:show .5s 1;-moz-animation:show .5s 1}.container{width:100%;height:100%;overflow:auto}header{height:auto;width:100%;text-align:center}article{margin-top:.9375rem;margin-bottom:.9375rem;border:1px solid #979797;background-color:#f4f4f4;padding:2rem 1.375rem;border-radius:.375rem;box-shadow:0 .125rem .4375rem #0000001a}article #heading{color:#212121;text-align:center;margin-bottom:1.5rem;font-family:Roboto;font-size:1.125rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}#alert-div{padding:.25rem 0 0;margin-bottom:.75rem;border-radius:.25rem;border:solid 1px #f9b3ae;background-color:#fde4e3}#alert-div .material-icons{color:#f44336;font-size:1rem;margin-left:.5rem}#alert-div p{margin:-1.5625rem 0 0 1.8rem;padding:.3125rem 0;color:#4a4a4a;font-family:Roboto;font-size:.75rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}footer{align-items:baseline;color:#6e6e6e;opacity:.9;display:flex;font-family:Ubuntu;font-size:1rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;justify-content:center}footer span{font-size:1.3125rem;font-weight:700;margin-left:.25rem}input[type=password],input[type=text],input[type=number]{width:100%;height:30px;padding:.75rem 1rem;border:1px solid #979797;margin-bottom:.625rem;border-radius:.375rem}.login-btn{width:100%;height:2.5rem;border:0;color:#fff;background-color:#268bff;border-radius:.375rem;font-size:1rem;margin-top:.9375rem}.login-btn:hover{background-color:#4099ff;cursor:pointer}.login-btn:disabled{background-color:#ccc;color:#fff;cursor:not-allowed}.input-invalid{border:1px solid #fe3824!important}input[type=password].ng-dirty.ng-invalid,input[type=text].ng-dirty.ng-invalid{border:1px solid #fe3824}input[type=submit]:focus,input[type=password]:focus,input[type=text]:focus,input[type=checkbox]:focus,button:focus{outline:none}input::placeholder{color:#a4a4a4}p{color:#4a4a4a;font-family:Roboto;font-size:1rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}input[type=text]{margin-bottom:16px}input[type=text]:focus{box-shadow:none}.back-btn{font-size:27px;position:relative;color:#268bff;float:left;top:-30px;left:-15px;font-weight:400!important}\n"], directives: [{ type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] });
568
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: ForgotPasswordComponent, decorators: [{
569
+ type: Component,
570
+ args: [{ selector: 'anna-cognito-lib-forgot-password', template: "<div class=\"main\">\r\n <section>\r\n <header>\r\n <img src=\"assets/images/Anna-Logo-for-footer-min.png\" alt=\"Anna Logo\" />\r\n </header>\r\n <article>\r\n <form [formGroup]=\"verifyRegisteredEmail\">\r\n <div id=\"heading\">\r\n {{ constants.forgotPasswordHeading }}\r\n </div>\r\n <p>\r\n {{ constants.forgotPasswordMessage }}\r\n </p>\r\n <div id=\"alert-div\" *ngIf=\"errorMessage\">\r\n <span class=\"material-icons\">report</span>\r\n <p id=\"alert-msg\">{{ errorMessage }}</p>\r\n </div>\r\n\r\n <input\r\n type=\"text\"\r\n tabindex=\"1\"\r\n formControlName=\"email\"\r\n [placeholder]=\"constants.enterEmail\"\r\n [ngClass]=\"{\r\n 'input-invalid': verifyRegisteredEmail.get('email')?.dirty && verifyRegisteredEmail.get('email')?.errors\r\n }\"\r\n />\r\n\r\n <button\r\n tabindex=\"2\"\r\n type=\"submit\"\r\n class=\"login-btn\"\r\n [disabled]=\"!isFormValid()\"\r\n (click)=\"onVerifyRegisteredEmail()\"\r\n >\r\n {{ constants.forgotPasswordButton }}\r\n </button>\r\n </form>\r\n </article>\r\n <footer>\r\n Powered by <span> <strong> SureWaves</strong></span>\r\n </footer>\r\n </section>\r\n</div>\r\n", styles: ["@keyframes show{0%{opacity:0}50%{opacity:.5}to{opacity:1}}html{overflow-y:scroll}.main{background-color:#fff;background-size:cover;font-family:Roboto;height:100vh}section{top:45%;left:50%;position:absolute;transform:translate(-50%,-50%);width:20.875rem;animation:show .5s 1;-moz-animation:show .5s 1}.container{width:100%;height:100%;overflow:auto}header{height:auto;width:100%;text-align:center}article{margin-top:.9375rem;margin-bottom:.9375rem;border:1px solid #979797;background-color:#f4f4f4;padding:2rem 1.375rem;border-radius:.375rem;box-shadow:0 .125rem .4375rem #0000001a}article #heading{color:#212121;text-align:center;margin-bottom:1.5rem;font-family:Roboto;font-size:1.125rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}#alert-div{padding:.25rem 0 0;margin-bottom:.75rem;border-radius:.25rem;border:solid 1px #f9b3ae;background-color:#fde4e3}#alert-div .material-icons{color:#f44336;font-size:1rem;margin-left:.5rem}#alert-div p{margin:-1.5625rem 0 0 1.8rem;padding:.3125rem 0;color:#4a4a4a;font-family:Roboto;font-size:.75rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}footer{align-items:baseline;color:#6e6e6e;opacity:.9;display:flex;font-family:Ubuntu;font-size:1rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;justify-content:center}footer span{font-size:1.3125rem;font-weight:700;margin-left:.25rem}input[type=password],input[type=text],input[type=number]{width:100%;height:30px;padding:.75rem 1rem;border:1px solid #979797;margin-bottom:.625rem;border-radius:.375rem}.login-btn{width:100%;height:2.5rem;border:0;color:#fff;background-color:#268bff;border-radius:.375rem;font-size:1rem;margin-top:.9375rem}.login-btn:hover{background-color:#4099ff;cursor:pointer}.login-btn:disabled{background-color:#ccc;color:#fff;cursor:not-allowed}.input-invalid{border:1px solid #fe3824!important}input[type=password].ng-dirty.ng-invalid,input[type=text].ng-dirty.ng-invalid{border:1px solid #fe3824}input[type=submit]:focus,input[type=password]:focus,input[type=text]:focus,input[type=checkbox]:focus,button:focus{outline:none}input::placeholder{color:#a4a4a4}p{color:#4a4a4a;font-family:Roboto;font-size:1rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}input[type=text]{margin-bottom:16px}input[type=text]:focus{box-shadow:none}.back-btn{font-size:27px;position:relative;color:#268bff;float:left;top:-30px;left:-15px;font-weight:400!important}\n"] }]
571
+ }], ctorParameters: function () { return [{ type: AnnaLibAuthService }, { type: i2.FormBuilder }, { type: i3$1.ToastrService }]; } });
572
+
573
+ class VerifyAndSetNewPasswordComponent {
574
+ constructor(authService, fb, router) {
575
+ this.authService = authService;
576
+ this.fb = fb;
577
+ this.router = router;
578
+ this.passwordNotMatching = false;
579
+ this.password = { value: null, status: null };
580
+ this.confirmPassword = { value: null, status: null };
581
+ }
582
+ ngOnInit() {
583
+ this.constants = LoginConstant;
584
+ this.authService.verifyAndSetNewPasswordButton = LoginConstant.setNewPasswordButton;
585
+ this.onIntialiseForm();
586
+ }
587
+ onIntialiseForm() {
588
+ this.verifyOtpForm = this.fb.group({
589
+ otp: [null, [Validators.required]],
590
+ });
591
+ }
592
+ isFormValid() {
593
+ if (this.password.status === "VALID" &&
594
+ this.confirmPassword.status === "VALID" &&
595
+ this.verifyOtpForm.controls['otp'].valid) {
596
+ return true;
597
+ }
598
+ return false;
599
+ }
600
+ onPasswordChange($event) {
601
+ this.password = $event;
602
+ }
603
+ onConfirmPasswordChange($event) {
604
+ this.confirmPassword = $event;
605
+ }
606
+ onVerifyOtpSettingNewPassword() {
607
+ if (this.password.value != this.confirmPassword.value) {
608
+ this.passwordNotMatching = true;
609
+ }
610
+ else {
611
+ this.passwordNotMatching = false;
612
+ if (this.authService.verifyAndSetNewPasswordButton === LoginConstant.regenerateOtp) {
613
+ this.router.navigate([LoginConstant.forgortPasswordPageUrl]);
614
+ }
615
+ else {
616
+ this.password.value && this.authService.verifyCode(this.verifyOtpForm.controls['otp'].value, this.password.value);
617
+ }
618
+ }
619
+ }
620
+ }
621
+ VerifyAndSetNewPasswordComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: VerifyAndSetNewPasswordComponent, deps: [{ token: AnnaLibAuthService }, { token: i2.FormBuilder }, { token: i3.Router }], target: i0.ɵɵFactoryTarget.Component });
622
+ VerifyAndSetNewPasswordComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: VerifyAndSetNewPasswordComponent, selector: "anna-cognito-lib-verify-and-set-new-password", ngImport: i0, template: "<div class=\"main\" [ngClass]=\"{ 'main-height': authService.verifyAndSetNewPasswordErrorMessage }\">\r\n <section>\r\n <header>\r\n <img src=\"assets/images/Anna-Logo-for-footer-min.png\" alt=\"Anna Logo\" />\r\n </header>\r\n <article>\r\n <span class=\"back-btn\" [routerLink]=\"constants.forgortPasswordPageUrl\">\r\n <i class=\"mdi mdi-arrow-left\"></i>\r\n </span>\r\n\r\n <form [formGroup]=\"verifyOtpForm\">\r\n <div class=\"pull-left\" id=\"heading\">\r\n {{ constants.verifyAndSetNewPasswordheading }}\r\n </div>\r\n <p>{{ authService.verifyAndSetNewPasswordMessage }}</p>\r\n\r\n <div id=\"alert-div\" *ngIf=\"authService.verifyAndSetNewPasswordErrorMessage\">\r\n <div id=\"icon-div\">\r\n <span class=\"material-icons\">report</span>\r\n </div>\r\n <p id=\"display-block-msg\">{{ authService.verifyAndSetNewPasswordErrorMessage }}</p>\r\n </div>\r\n\r\n <input\r\n type=\"text\"\r\n tabindex=\"1\"\r\n formControlName=\"otp\"\r\n [placeholder]=\"constants.enterOtp\"\r\n autocomplete=\"new-field-name\"\r\n [ngClass]=\"{ 'input-invalid': authService.verifyAndSetNewPasswordErrorMessage }\"\r\n />\r\n\r\n <anna-cognito-lib-password-matching\r\n (passwordChange)=\"onPasswordChange($event)\"\r\n (confirmPasswordChange)=\"onConfirmPasswordChange($event)\"\r\n [passwordNotMatching]=\"passwordNotMatching\"\r\n >\r\n </anna-cognito-lib-password-matching>\r\n <button\r\n tabindex=\"4\"\r\n type=\"submit\"\r\n class=\"login-btn\"\r\n [disabled]=\"authService.sessionLocked || !isFormValid()\"\r\n (click)=\"onVerifyOtpSettingNewPassword()\"\r\n >\r\n {{ authService.verifyAndSetNewPasswordButton }}\r\n </button>\r\n </form>\r\n </article>\r\n <footer>\r\n Powered by <span> <strong>SureWaves</strong> </span>\r\n </footer>\r\n </section>\r\n</div>\r\n", styles: ["@keyframes show{0%{opacity:0}50%{opacity:.5}to{opacity:1}}html{overflow-y:scroll}.main{background-color:#fff;background-size:cover;font-family:Roboto;height:100vh}section{top:45%;left:50%;position:absolute;transform:translate(-50%,-50%);width:20.875rem;animation:show .5s 1;-moz-animation:show .5s 1}.container{width:100%;height:100%;overflow:auto}header{height:auto;width:100%;text-align:center}article{margin-top:.9375rem;margin-bottom:.9375rem;border:1px solid #979797;background-color:#f4f4f4;padding:2rem 1.375rem;border-radius:.375rem;box-shadow:0 .125rem .4375rem #0000001a}article #heading{color:#212121;text-align:center;margin-bottom:1.5rem;font-family:Roboto;font-size:1.125rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}#alert-div{padding:.25rem 0 0;margin-bottom:.75rem;border-radius:.25rem;border:solid 1px #f9b3ae;background-color:#fde4e3}#alert-div .material-icons{color:#f44336;font-size:1rem;margin-left:.5rem}#alert-div p{margin:-1.5625rem 0 0 1.8rem;padding:.3125rem 0;color:#4a4a4a;font-family:Roboto;font-size:.75rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}footer{align-items:baseline;color:#6e6e6e;opacity:.9;display:flex;font-family:Ubuntu;font-size:1rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;justify-content:center}footer span{font-size:1.3125rem;font-weight:700;margin-left:.25rem}input[type=password],input[type=text],input[type=number]{width:100%;height:30px;padding:.75rem 1rem;border:1px solid #979797;margin-bottom:.625rem;border-radius:.375rem}.login-btn{width:100%;height:2.5rem;border:0;color:#fff;background-color:#268bff;border-radius:.375rem;font-size:1rem;margin-top:.9375rem}.login-btn:hover{background-color:#4099ff;cursor:pointer}.login-btn:disabled{background-color:#ccc;color:#fff;cursor:not-allowed}.input-invalid{border:1px solid #fe3824!important}input[type=password].ng-dirty.ng-invalid,input[type=text].ng-dirty.ng-invalid{border:1px solid #fe3824}input[type=submit]:focus,input[type=password]:focus,input[type=text]:focus,input[type=checkbox]:focus,button:focus{outline:none}input::placeholder{color:#a4a4a4}.main-height{height:105vh}section{top:52%}p{color:#4a4a4a;font-family:Roboto;font-size:1rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}input[type=text]{margin-bottom:24px}input[type=text]:focus{box-shadow:none}.back-btn{width:27px;height:27px;top:-27px;left:-15px;cursor:pointer;position:relative;color:#268bff;float:left;border-radius:50%;border:1px solid #268bff;background-color:#f4f4f4}.back-btn i{position:absolute;top:.1875rem;left:.25rem}\n"], components: [{ type: PasswordMatchingComponent, selector: "anna-cognito-lib-password-matching", inputs: ["passwordNotMatching"], outputs: ["passwordChange", "confirmPasswordChange"] }], directives: [{ type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i3.RouterLink, selector: ":not(a):not(area)[routerLink]", inputs: ["queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo", "routerLink"] }, { type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }] });
623
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: VerifyAndSetNewPasswordComponent, decorators: [{
624
+ type: Component,
625
+ args: [{ selector: 'anna-cognito-lib-verify-and-set-new-password', template: "<div class=\"main\" [ngClass]=\"{ 'main-height': authService.verifyAndSetNewPasswordErrorMessage }\">\r\n <section>\r\n <header>\r\n <img src=\"assets/images/Anna-Logo-for-footer-min.png\" alt=\"Anna Logo\" />\r\n </header>\r\n <article>\r\n <span class=\"back-btn\" [routerLink]=\"constants.forgortPasswordPageUrl\">\r\n <i class=\"mdi mdi-arrow-left\"></i>\r\n </span>\r\n\r\n <form [formGroup]=\"verifyOtpForm\">\r\n <div class=\"pull-left\" id=\"heading\">\r\n {{ constants.verifyAndSetNewPasswordheading }}\r\n </div>\r\n <p>{{ authService.verifyAndSetNewPasswordMessage }}</p>\r\n\r\n <div id=\"alert-div\" *ngIf=\"authService.verifyAndSetNewPasswordErrorMessage\">\r\n <div id=\"icon-div\">\r\n <span class=\"material-icons\">report</span>\r\n </div>\r\n <p id=\"display-block-msg\">{{ authService.verifyAndSetNewPasswordErrorMessage }}</p>\r\n </div>\r\n\r\n <input\r\n type=\"text\"\r\n tabindex=\"1\"\r\n formControlName=\"otp\"\r\n [placeholder]=\"constants.enterOtp\"\r\n autocomplete=\"new-field-name\"\r\n [ngClass]=\"{ 'input-invalid': authService.verifyAndSetNewPasswordErrorMessage }\"\r\n />\r\n\r\n <anna-cognito-lib-password-matching\r\n (passwordChange)=\"onPasswordChange($event)\"\r\n (confirmPasswordChange)=\"onConfirmPasswordChange($event)\"\r\n [passwordNotMatching]=\"passwordNotMatching\"\r\n >\r\n </anna-cognito-lib-password-matching>\r\n <button\r\n tabindex=\"4\"\r\n type=\"submit\"\r\n class=\"login-btn\"\r\n [disabled]=\"authService.sessionLocked || !isFormValid()\"\r\n (click)=\"onVerifyOtpSettingNewPassword()\"\r\n >\r\n {{ authService.verifyAndSetNewPasswordButton }}\r\n </button>\r\n </form>\r\n </article>\r\n <footer>\r\n Powered by <span> <strong>SureWaves</strong> </span>\r\n </footer>\r\n </section>\r\n</div>\r\n", styles: ["@keyframes show{0%{opacity:0}50%{opacity:.5}to{opacity:1}}html{overflow-y:scroll}.main{background-color:#fff;background-size:cover;font-family:Roboto;height:100vh}section{top:45%;left:50%;position:absolute;transform:translate(-50%,-50%);width:20.875rem;animation:show .5s 1;-moz-animation:show .5s 1}.container{width:100%;height:100%;overflow:auto}header{height:auto;width:100%;text-align:center}article{margin-top:.9375rem;margin-bottom:.9375rem;border:1px solid #979797;background-color:#f4f4f4;padding:2rem 1.375rem;border-radius:.375rem;box-shadow:0 .125rem .4375rem #0000001a}article #heading{color:#212121;text-align:center;margin-bottom:1.5rem;font-family:Roboto;font-size:1.125rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}#alert-div{padding:.25rem 0 0;margin-bottom:.75rem;border-radius:.25rem;border:solid 1px #f9b3ae;background-color:#fde4e3}#alert-div .material-icons{color:#f44336;font-size:1rem;margin-left:.5rem}#alert-div p{margin:-1.5625rem 0 0 1.8rem;padding:.3125rem 0;color:#4a4a4a;font-family:Roboto;font-size:.75rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}footer{align-items:baseline;color:#6e6e6e;opacity:.9;display:flex;font-family:Ubuntu;font-size:1rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;justify-content:center}footer span{font-size:1.3125rem;font-weight:700;margin-left:.25rem}input[type=password],input[type=text],input[type=number]{width:100%;height:30px;padding:.75rem 1rem;border:1px solid #979797;margin-bottom:.625rem;border-radius:.375rem}.login-btn{width:100%;height:2.5rem;border:0;color:#fff;background-color:#268bff;border-radius:.375rem;font-size:1rem;margin-top:.9375rem}.login-btn:hover{background-color:#4099ff;cursor:pointer}.login-btn:disabled{background-color:#ccc;color:#fff;cursor:not-allowed}.input-invalid{border:1px solid #fe3824!important}input[type=password].ng-dirty.ng-invalid,input[type=text].ng-dirty.ng-invalid{border:1px solid #fe3824}input[type=submit]:focus,input[type=password]:focus,input[type=text]:focus,input[type=checkbox]:focus,button:focus{outline:none}input::placeholder{color:#a4a4a4}.main-height{height:105vh}section{top:52%}p{color:#4a4a4a;font-family:Roboto;font-size:1rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}input[type=text]{margin-bottom:24px}input[type=text]:focus{box-shadow:none}.back-btn{width:27px;height:27px;top:-27px;left:-15px;cursor:pointer;position:relative;color:#268bff;float:left;border-radius:50%;border:1px solid #268bff;background-color:#f4f4f4}.back-btn i{position:absolute;top:.1875rem;left:.25rem}\n"] }]
626
+ }], ctorParameters: function () { return [{ type: AnnaLibAuthService }, { type: i2.FormBuilder }, { type: i3.Router }]; } });
627
+
628
+ class AnnaCognitoLibModule {
629
+ static forRoot(configuration) {
630
+ return {
631
+ ngModule: AnnaCognitoLibModule,
632
+ providers: [
633
+ {
634
+ provide: LibraryConfig,
635
+ useValue: configuration
636
+ }
637
+ ]
638
+ };
639
+ }
640
+ }
641
+ AnnaCognitoLibModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: AnnaCognitoLibModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
642
+ AnnaCognitoLibModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: AnnaCognitoLibModule, declarations: [LoginComponent,
643
+ SetNewPasswordComponent,
644
+ PasswordMatchingComponent,
645
+ ForgotPasswordComponent,
646
+ VerifyAndSetNewPasswordComponent,
647
+ SpinnerButtonDirective], imports: [FormsModule,
648
+ ReactiveFormsModule,
649
+ RouterModule,
650
+ CommonModule], exports: [LoginComponent,
651
+ SetNewPasswordComponent,
652
+ PasswordMatchingComponent,
653
+ ForgotPasswordComponent,
654
+ VerifyAndSetNewPasswordComponent,
655
+ SpinnerButtonDirective] });
656
+ AnnaCognitoLibModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: AnnaCognitoLibModule, imports: [[
657
+ FormsModule,
658
+ ReactiveFormsModule,
659
+ RouterModule,
660
+ CommonModule
661
+ ]] });
662
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: AnnaCognitoLibModule, decorators: [{
663
+ type: NgModule,
664
+ args: [{
665
+ declarations: [
666
+ LoginComponent,
667
+ SetNewPasswordComponent,
668
+ PasswordMatchingComponent,
669
+ ForgotPasswordComponent,
670
+ VerifyAndSetNewPasswordComponent,
671
+ SpinnerButtonDirective,
672
+ ],
673
+ imports: [
674
+ FormsModule,
675
+ ReactiveFormsModule,
676
+ RouterModule,
677
+ CommonModule
678
+ ],
679
+ exports: [
680
+ LoginComponent,
681
+ SetNewPasswordComponent,
682
+ PasswordMatchingComponent,
683
+ ForgotPasswordComponent,
684
+ VerifyAndSetNewPasswordComponent,
685
+ SpinnerButtonDirective
686
+ ]
687
+ }]
688
+ }] });
689
+
690
+ /*
691
+ * Public API Surface of anna-cognito-lib
692
+ */
693
+
694
+ /**
695
+ * Generated bundle index. Do not edit.
696
+ */
697
+
698
+ export { ACL_SERVICE_TOKEN, AUTH_SERVICE_TOKEN, AnnaCognitoLibModule, AnnaLibAclService, AnnaLibAuthService, ForgotPasswordComponent, LibraryConfig, LoginComponent, LoginConstant, PasswordMatchingComponent, SetNewPasswordComponent, SpinnerButtonDirective, VerifyAndSetNewPasswordComponent };
699
+ //# sourceMappingURL=annalib-anna-cognito-lib.mjs.map