@annalib/anna-cognito-lib 2.3.20 → 2.3.22

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 (47) hide show
  1. package/esm2022/lib/components/anna-login/anna-login.component.mjs +16 -16
  2. package/esm2022/lib/components/cognito-and-sso-login-container/cognito-and-sso-login-container.component.mjs +7 -7
  3. package/esm2022/lib/components/forgot-password/forgot-password.component.mjs +19 -19
  4. package/esm2022/lib/components/password-matching/password-matching.component.mjs +17 -17
  5. package/esm2022/lib/components/powered-by-logo-template/powered-by-logo-template.component.mjs +4 -4
  6. package/esm2022/lib/components/set-new-password/set-new-password.component.mjs +14 -14
  7. package/esm2022/lib/components/sso-login/sso-login.component.mjs +10 -10
  8. package/esm2022/lib/components/surewaves-year-logo/surewaves-year-logo.component.mjs +3 -3
  9. package/esm2022/lib/components/verify-and-set-new-password/verify-and-set-new-password.component.mjs +18 -18
  10. package/esm2022/lib/components/version-and-term-policy/version-and-term-policy.component.mjs +4 -4
  11. package/esm2022/lib/config/acl-service.token.mjs +1 -1
  12. package/esm2022/lib/config/auth-service.token.mjs +3 -3
  13. package/esm2022/lib/config/config-service.token.mjs +3 -3
  14. package/esm2022/lib/config/sso-login-service.token.mjs +3 -3
  15. package/esm2022/lib/constants/loginConstant.mjs +48 -48
  16. package/esm2022/lib/directives/spinner-button/index.mjs +2 -2
  17. package/esm2022/lib/directives/spinner-button/spinner-button.directive.mjs +13 -13
  18. package/esm2022/lib/models/auth.model.mjs +2 -2
  19. package/esm2022/lib/services/acl.service.mjs +5 -5
  20. package/esm2022/lib/services/auth.service.mjs +29 -29
  21. package/esm2022/lib/services/config.service.mjs +5 -5
  22. package/esm2022/lib/services/sso-login.service.mjs +5 -5
  23. package/esm2022/public-api.mjs +21 -21
  24. package/fesm2022/annalib-anna-cognito-lib.mjs +114 -114
  25. package/fesm2022/annalib-anna-cognito-lib.mjs.map +1 -1
  26. package/lib/components/anna-login/anna-login.component.d.ts +5 -5
  27. package/lib/components/cognito-and-sso-login-container/cognito-and-sso-login-container.component.d.ts +2 -2
  28. package/lib/components/forgot-password/forgot-password.component.d.ts +9 -9
  29. package/lib/components/password-matching/password-matching.component.d.ts +4 -4
  30. package/lib/components/powered-by-logo-template/powered-by-logo-template.component.d.ts +1 -1
  31. package/lib/components/set-new-password/set-new-password.component.d.ts +5 -5
  32. package/lib/components/sso-login/sso-login.component.d.ts +3 -3
  33. package/lib/components/surewaves-year-logo/surewaves-year-logo.component.d.ts +1 -1
  34. package/lib/components/verify-and-set-new-password/verify-and-set-new-password.component.d.ts +6 -6
  35. package/lib/components/version-and-term-policy/version-and-term-policy.component.d.ts +2 -2
  36. package/lib/config/acl-service.token.d.ts +2 -2
  37. package/lib/config/auth-service.token.d.ts +4 -4
  38. package/lib/config/config-service.token.d.ts +1 -1
  39. package/lib/config/sso-login-service.token.d.ts +2 -2
  40. package/lib/directives/spinner-button/index.d.ts +1 -1
  41. package/lib/directives/spinner-button/spinner-button.directive.d.ts +1 -1
  42. package/lib/services/acl.service.d.ts +1 -1
  43. package/lib/services/auth.service.d.ts +7 -7
  44. package/lib/services/config.service.d.ts +1 -1
  45. package/lib/services/sso-login.service.d.ts +1 -1
  46. package/package.json +1 -1
  47. package/public-api.d.ts +20 -20
@@ -1,17 +1,17 @@
1
1
  // Angular import statements
2
- import { Component, Inject } from "@angular/core";
3
- import { FormBuilder, FormsModule, ReactiveFormsModule } from "@angular/forms";
2
+ import { Component, Inject } from '@angular/core';
3
+ import { FormBuilder, FormsModule, ReactiveFormsModule } from '@angular/forms';
4
4
  // User defined import statements
5
- import { LoginConstant } from "../../constants/loginConstant";
6
- import { AnnaLibAuthService } from "../../services/auth.service";
7
- import { CONFIG_SERVICE_TOKEN } from "../../config/config-service.token";
8
- import { SSO_LOGIN_SERVICE_TOKEN } from "../../config/sso-login-service.token";
9
- import { VersionAndTermPolicyComponent } from "../version-and-term-policy/version-and-term-policy.component";
10
- import { SurewavesYearLogoComponent } from "../surewaves-year-logo/surewaves-year-logo.component";
11
- import { PoweredByLogoTemplateComponent } from "../powered-by-logo-template/powered-by-logo-template.component";
12
- import { SpinnerButtonDirective } from "../../directives/spinner-button/spinner-button.directive";
13
- import { RouterLink } from "@angular/router";
14
- import { NgIf, NgOptimizedImage, NgClass } from "@angular/common";
5
+ import { LoginConstant } from '../../constants/loginConstant';
6
+ import { AnnaLibAuthService } from '../../services/auth.service';
7
+ import { CONFIG_SERVICE_TOKEN } from '../../config/config-service.token';
8
+ import { SSO_LOGIN_SERVICE_TOKEN } from '../../config/sso-login-service.token';
9
+ import { VersionAndTermPolicyComponent } from '../version-and-term-policy/version-and-term-policy.component';
10
+ import { SurewavesYearLogoComponent } from '../surewaves-year-logo/surewaves-year-logo.component';
11
+ import { PoweredByLogoTemplateComponent } from '../powered-by-logo-template/powered-by-logo-template.component';
12
+ import { SpinnerButtonDirective } from '../../directives/spinner-button/spinner-button.directive';
13
+ import { RouterLink } from '@angular/router';
14
+ import { NgIf, NgOptimizedImage, NgClass } from '@angular/common';
15
15
  import * as i0 from "@angular/core";
16
16
  import * as i1 from "../../services/auth.service";
17
17
  import * as i2 from "@angular/forms";
@@ -36,8 +36,8 @@ export class AnnaLoginComponent {
36
36
  }
37
37
  OnLogin() {
38
38
  this.authService.consumingProjectAuthService.isLoggingIn = true;
39
- const username = this.loginForm.controls["username"].value;
40
- const password = this.loginForm.controls["password"].value;
39
+ const username = this.loginForm.controls['username'].value;
40
+ const password = this.loginForm.controls['password'].value;
41
41
  this.authService.handleSignIn({ username, password });
42
42
  }
43
43
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AnnaLoginComponent, deps: [{ token: i1.AnnaLibAuthService }, { token: i2.FormBuilder }, { token: CONFIG_SERVICE_TOKEN }, { token: SSO_LOGIN_SERVICE_TOKEN }], target: i0.ɵɵFactoryTarget.Component }); }
@@ -45,7 +45,7 @@ export class AnnaLoginComponent {
45
45
  }
46
46
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AnnaLoginComponent, decorators: [{
47
47
  type: Component,
48
- args: [{ selector: "anna-cognito-lib-anna-login", standalone: true, imports: [
48
+ args: [{ selector: 'anna-cognito-lib-anna-login', standalone: true, imports: [
49
49
  NgIf,
50
50
  NgOptimizedImage,
51
51
  FormsModule,
@@ -64,4 +64,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
64
64
  type: Inject,
65
65
  args: [SSO_LOGIN_SERVICE_TOKEN]
66
66
  }] }]; } });
67
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"anna-login.component.js","sourceRoot":"","sources":["../../../../../../projects/anna-cognito-lib/src/lib/components/anna-login/anna-login.component.ts","../../../../../../projects/anna-cognito-lib/src/lib/components/anna-login/anna-login.component.html"],"names":[],"mappings":"AAAA,4BAA4B;AAC5B,OAAO,EAAE,SAAS,EAAE,MAAM,EAAU,MAAM,eAAe,CAAC;AAC1D,OAAO,EAAE,WAAW,EAAa,WAAW,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAE1F,iCAAiC;AACjC,OAAO,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAC;AAC9D,OAAO,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AACjE,OAAO,EAAE,oBAAoB,EAAkB,MAAM,mCAAmC,CAAC;AACzF,OAAO,EAAoB,uBAAuB,EAAE,MAAM,sCAAsC,CAAC;AACjG,OAAO,EAAE,6BAA6B,EAAE,MAAM,8DAA8D,CAAC;AAC7G,OAAO,EAAE,0BAA0B,EAAE,MAAM,sDAAsD,CAAC;AAClG,OAAO,EAAE,8BAA8B,EAAE,MAAM,gEAAgE,CAAC;AAChH,OAAO,EAAE,sBAAsB,EAAE,MAAM,0DAA0D,CAAC;AAClG,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAE,IAAI,EAAE,gBAAgB,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;;;;AAoBlE,MAAM,OAAO,kBAAkB;IAI3B,YACW,WAA+B,EAC9B,EAAe,EACc,6BAA6C,EAC1C,+BAAiD;QAHlF,gBAAW,GAAX,WAAW,CAAoB;QAC9B,OAAE,GAAF,EAAE,CAAa;QACc,kCAA6B,GAA7B,6BAA6B,CAAgB;QAC1C,oCAA+B,GAA/B,+BAA+B,CAAkB;IAC1F,CAAC;IAEJ,QAAQ;QACJ,IAAI,CAAC,WAAW,CAAC,2BAA2B,CAAC,WAAW,GAAG,KAAK,CAAC;QACjE,IAAI,CAAC,+BAA+B,CAAC,cAAc,GAAG,KAAK,CAAC;QAC5D,IAAI,CAAC,SAAS,GAAG,aAAa,CAAC;QAC/B,IAAI,CAAC,eAAe,EAAE,CAAC;IAC3B,CAAC;IAED,eAAe;QACX,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC;YAC3B,QAAQ,EAAE,CAAC,IAAI,CAAC;YAChB,QAAQ,EAAE,CAAC,IAAI,CAAC;SACnB,CAAC,CAAC;IACP,CAAC;IAED,OAAO;QACH,IAAI,CAAC,WAAW,CAAC,2BAA2B,CAAC,WAAW,GAAG,IAAI,CAAC;QAChE,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,KAAK,CAAC;QAC3D,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,KAAK,CAAC;QAC3D,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC;IAC1D,CAAC;+GA9BQ,kBAAkB,+EAOf,oBAAoB,aACpB,uBAAuB;mGAR1B,kBAAkB,uFClC/B,86FAwEA,+lGDlDQ,IAAI,6FACJ,gBAAgB,2MAChB,WAAW,2pBACX,mBAAmB,gVACnB,OAAO,oFACP,UAAU,4NACV,sBAAsB,8IACtB,8BAA8B,sFAC9B,0BAA0B,iFAC1B,6BAA6B;;4FAGxB,kBAAkB;kBAlB9B,SAAS;+BACI,6BAA6B,cAG3B,IAAI,WACP;wBACL,IAAI;wBACJ,gBAAgB;wBAChB,WAAW;wBACX,mBAAmB;wBACnB,OAAO;wBACP,UAAU;wBACV,sBAAsB;wBACtB,8BAA8B;wBAC9B,0BAA0B;wBAC1B,6BAA6B;qBAChC;;0BASI,MAAM;2BAAC,oBAAoB;;0BAC3B,MAAM;2BAAC,uBAAuB","sourcesContent":["// Angular import statements\r\nimport { Component, Inject, OnInit } from \"@angular/core\";\r\nimport { FormBuilder, FormGroup, FormsModule, ReactiveFormsModule } from \"@angular/forms\";\r\n\r\n// User defined import statements\r\nimport { LoginConstant } from \"../../constants/loginConstant\";\r\nimport { AnnaLibAuthService } from \"../../services/auth.service\";\r\nimport { CONFIG_SERVICE_TOKEN, IConfigService } from \"../../config/config-service.token\";\r\nimport { ISSOLoginService, SSO_LOGIN_SERVICE_TOKEN } from \"../../config/sso-login-service.token\";\r\nimport { VersionAndTermPolicyComponent } from \"../version-and-term-policy/version-and-term-policy.component\";\r\nimport { SurewavesYearLogoComponent } from \"../surewaves-year-logo/surewaves-year-logo.component\";\r\nimport { PoweredByLogoTemplateComponent } from \"../powered-by-logo-template/powered-by-logo-template.component\";\r\nimport { SpinnerButtonDirective } from \"../../directives/spinner-button/spinner-button.directive\";\r\nimport { RouterLink } from \"@angular/router\";\r\nimport { NgIf, NgOptimizedImage, NgClass } from \"@angular/common\";\r\n\r\n@Component({\r\n    selector: \"anna-cognito-lib-anna-login\",\r\n    templateUrl: \"./anna-login.component.html\",\r\n    styleUrls: [\"./anna-login.component.scss\"],\r\n    standalone: true,\r\n    imports: [\r\n        NgIf,\r\n        NgOptimizedImage,\r\n        FormsModule,\r\n        ReactiveFormsModule,\r\n        NgClass,\r\n        RouterLink,\r\n        SpinnerButtonDirective,\r\n        PoweredByLogoTemplateComponent,\r\n        SurewavesYearLogoComponent,\r\n        VersionAndTermPolicyComponent,\r\n    ],\r\n})\r\nexport class AnnaLoginComponent {\r\n    loginForm: FormGroup;\r\n    constants: typeof LoginConstant;\r\n\r\n    constructor(\r\n        public authService: AnnaLibAuthService,\r\n        private fb: FormBuilder,\r\n        @Inject(CONFIG_SERVICE_TOKEN) public consumingProjectConfigService: IConfigService,\r\n        @Inject(SSO_LOGIN_SERVICE_TOKEN) public consumingProjectSSOLoginService: ISSOLoginService,\r\n    ) {}\r\n\r\n    ngOnInit() {\r\n        this.authService.consumingProjectAuthService.isLoggingIn = false;\r\n        this.consumingProjectSSOLoginService.loggedInViaSso = false;\r\n        this.constants = LoginConstant;\r\n        this.onIntialiseForm();\r\n    }\r\n\r\n    onIntialiseForm() {\r\n        this.loginForm = this.fb.group({\r\n            username: [null],\r\n            password: [null],\r\n        });\r\n    }\r\n\r\n    OnLogin() {\r\n        this.authService.consumingProjectAuthService.isLoggingIn = true;\r\n        const username = this.loginForm.controls[\"username\"].value;\r\n        const password = this.loginForm.controls[\"password\"].value;\r\n        this.authService.handleSignIn({ username, password });\r\n    }\r\n}\r\n","<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\r\n                [ngSrc]=\"consumingProjectConfigService.appGenericConfig.loginPageLogoImgUrl\"\r\n                width=\"145\"\r\n                height=\"50\"\r\n                alt=\"Anna Logo\"\r\n                priority\r\n            />\r\n        </header>\r\n        <article>\r\n            <form\r\n                [formGroup]=\"loginForm\"\r\n                (ngSubmit)=\"OnLogin()\"\r\n            >\r\n                <div\r\n                    id=\"alert-div\"\r\n                    *ngIf=\"authService.loginErrorMessage\"\r\n                >\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]=\"\r\n                        consumingProjectSSOLoginService?.isSsoIntegrated\r\n                            ? constants.enterUserCode\r\n                            : constants.enterEmail\r\n                    \"\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\r\n                    tabindex=\"4\"\r\n                    [routerLink]=\"constants.forgortPasswordPageUrl\"\r\n                    >{{ constants.forgotPassword }}</a\r\n                >\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>\r\n            <anna-cognito-lib-powered-by-logo-template> </anna-cognito-lib-powered-by-logo-template>\r\n        </footer>\r\n    </section>\r\n</div>\r\n\r\n<div class=\"page-footer\">\r\n    <anna-cognito-lib-surewaves-year-logo></anna-cognito-lib-surewaves-year-logo>\r\n    <anna-cognito-lib-version-and-term-policy></anna-cognito-lib-version-and-term-policy>\r\n</div>\r\n"]}
67
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"anna-login.component.js","sourceRoot":"","sources":["../../../../../../projects/anna-cognito-lib/src/lib/components/anna-login/anna-login.component.ts","../../../../../../projects/anna-cognito-lib/src/lib/components/anna-login/anna-login.component.html"],"names":[],"mappings":"AAAA,4BAA4B;AAC5B,OAAO,EAAE,SAAS,EAAE,MAAM,EAAU,MAAM,eAAe,CAAC;AAC1D,OAAO,EAAE,WAAW,EAAa,WAAW,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAE1F,iCAAiC;AACjC,OAAO,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAC;AAC9D,OAAO,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AACjE,OAAO,EAAE,oBAAoB,EAAkB,MAAM,mCAAmC,CAAC;AACzF,OAAO,EAAoB,uBAAuB,EAAE,MAAM,sCAAsC,CAAC;AACjG,OAAO,EAAE,6BAA6B,EAAE,MAAM,8DAA8D,CAAC;AAC7G,OAAO,EAAE,0BAA0B,EAAE,MAAM,sDAAsD,CAAC;AAClG,OAAO,EAAE,8BAA8B,EAAE,MAAM,gEAAgE,CAAC;AAChH,OAAO,EAAE,sBAAsB,EAAE,MAAM,0DAA0D,CAAC;AAClG,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAE,IAAI,EAAE,gBAAgB,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;;;;AAoBlE,MAAM,OAAO,kBAAkB;IAI3B,YACW,WAA+B,EAC9B,EAAe,EACc,6BAA6C,EAC1C,+BAAiD;QAHlF,gBAAW,GAAX,WAAW,CAAoB;QAC9B,OAAE,GAAF,EAAE,CAAa;QACc,kCAA6B,GAA7B,6BAA6B,CAAgB;QAC1C,oCAA+B,GAA/B,+BAA+B,CAAkB;IAC1F,CAAC;IAEJ,QAAQ;QACJ,IAAI,CAAC,WAAW,CAAC,2BAA2B,CAAC,WAAW,GAAG,KAAK,CAAC;QACjE,IAAI,CAAC,+BAA+B,CAAC,cAAc,GAAG,KAAK,CAAC;QAC5D,IAAI,CAAC,SAAS,GAAG,aAAa,CAAC;QAC/B,IAAI,CAAC,eAAe,EAAE,CAAC;IAC3B,CAAC;IAED,eAAe;QACX,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC;YAC3B,QAAQ,EAAE,CAAC,IAAI,CAAC;YAChB,QAAQ,EAAE,CAAC,IAAI,CAAC;SACnB,CAAC,CAAC;IACP,CAAC;IAED,OAAO;QACH,IAAI,CAAC,WAAW,CAAC,2BAA2B,CAAC,WAAW,GAAG,IAAI,CAAC;QAChE,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,KAAK,CAAC;QAC3D,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,KAAK,CAAC;QAC3D,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC;IAC1D,CAAC;+GA9BQ,kBAAkB,+EAOf,oBAAoB,aACpB,uBAAuB;mGAR1B,kBAAkB,uFClC/B,86FAwEA,+lGDlDQ,IAAI,6FACJ,gBAAgB,2MAChB,WAAW,2pBACX,mBAAmB,gVACnB,OAAO,oFACP,UAAU,4NACV,sBAAsB,8IACtB,8BAA8B,sFAC9B,0BAA0B,iFAC1B,6BAA6B;;4FAGxB,kBAAkB;kBAlB9B,SAAS;+BACI,6BAA6B,cAG3B,IAAI,WACP;wBACL,IAAI;wBACJ,gBAAgB;wBAChB,WAAW;wBACX,mBAAmB;wBACnB,OAAO;wBACP,UAAU;wBACV,sBAAsB;wBACtB,8BAA8B;wBAC9B,0BAA0B;wBAC1B,6BAA6B;qBAChC;;0BASI,MAAM;2BAAC,oBAAoB;;0BAC3B,MAAM;2BAAC,uBAAuB","sourcesContent":["// Angular import statements\r\nimport { Component, Inject, OnInit } from '@angular/core';\r\nimport { FormBuilder, FormGroup, FormsModule, ReactiveFormsModule } from '@angular/forms';\r\n\r\n// User defined import statements\r\nimport { LoginConstant } from '../../constants/loginConstant';\r\nimport { AnnaLibAuthService } from '../../services/auth.service';\r\nimport { CONFIG_SERVICE_TOKEN, IConfigService } from '../../config/config-service.token';\r\nimport { ISSOLoginService, SSO_LOGIN_SERVICE_TOKEN } from '../../config/sso-login-service.token';\r\nimport { VersionAndTermPolicyComponent } from '../version-and-term-policy/version-and-term-policy.component';\r\nimport { SurewavesYearLogoComponent } from '../surewaves-year-logo/surewaves-year-logo.component';\r\nimport { PoweredByLogoTemplateComponent } from '../powered-by-logo-template/powered-by-logo-template.component';\r\nimport { SpinnerButtonDirective } from '../../directives/spinner-button/spinner-button.directive';\r\nimport { RouterLink } from '@angular/router';\r\nimport { NgIf, NgOptimizedImage, NgClass } from '@angular/common';\r\n\r\n@Component({\r\n    selector: 'anna-cognito-lib-anna-login',\r\n    templateUrl: './anna-login.component.html',\r\n    styleUrls: ['./anna-login.component.scss'],\r\n    standalone: true,\r\n    imports: [\r\n        NgIf,\r\n        NgOptimizedImage,\r\n        FormsModule,\r\n        ReactiveFormsModule,\r\n        NgClass,\r\n        RouterLink,\r\n        SpinnerButtonDirective,\r\n        PoweredByLogoTemplateComponent,\r\n        SurewavesYearLogoComponent,\r\n        VersionAndTermPolicyComponent,\r\n    ],\r\n})\r\nexport class AnnaLoginComponent {\r\n    loginForm: FormGroup;\r\n    constants: typeof LoginConstant;\r\n\r\n    constructor(\r\n        public authService: AnnaLibAuthService,\r\n        private fb: FormBuilder,\r\n        @Inject(CONFIG_SERVICE_TOKEN) public consumingProjectConfigService: IConfigService,\r\n        @Inject(SSO_LOGIN_SERVICE_TOKEN) public consumingProjectSSOLoginService: ISSOLoginService,\r\n    ) {}\r\n\r\n    ngOnInit() {\r\n        this.authService.consumingProjectAuthService.isLoggingIn = false;\r\n        this.consumingProjectSSOLoginService.loggedInViaSso = false;\r\n        this.constants = LoginConstant;\r\n        this.onIntialiseForm();\r\n    }\r\n\r\n    onIntialiseForm() {\r\n        this.loginForm = this.fb.group({\r\n            username: [null],\r\n            password: [null],\r\n        });\r\n    }\r\n\r\n    OnLogin() {\r\n        this.authService.consumingProjectAuthService.isLoggingIn = true;\r\n        const username = this.loginForm.controls['username'].value;\r\n        const password = this.loginForm.controls['password'].value;\r\n        this.authService.handleSignIn({ username, password });\r\n    }\r\n}\r\n","<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\r\n                [ngSrc]=\"consumingProjectConfigService.appGenericConfig.loginPageLogoImgUrl\"\r\n                width=\"145\"\r\n                height=\"50\"\r\n                alt=\"Anna Logo\"\r\n                priority\r\n            />\r\n        </header>\r\n        <article>\r\n            <form\r\n                [formGroup]=\"loginForm\"\r\n                (ngSubmit)=\"OnLogin()\"\r\n            >\r\n                <div\r\n                    id=\"alert-div\"\r\n                    *ngIf=\"authService.loginErrorMessage\"\r\n                >\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]=\"\r\n                        consumingProjectSSOLoginService?.isSsoIntegrated\r\n                            ? constants.enterUserCode\r\n                            : constants.enterEmail\r\n                    \"\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\r\n                    tabindex=\"4\"\r\n                    [routerLink]=\"constants.forgortPasswordPageUrl\"\r\n                    >{{ constants.forgotPassword }}</a\r\n                >\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>\r\n            <anna-cognito-lib-powered-by-logo-template> </anna-cognito-lib-powered-by-logo-template>\r\n        </footer>\r\n    </section>\r\n</div>\r\n\r\n<div class=\"page-footer\">\r\n    <anna-cognito-lib-surewaves-year-logo></anna-cognito-lib-surewaves-year-logo>\r\n    <anna-cognito-lib-version-and-term-policy></anna-cognito-lib-version-and-term-policy>\r\n</div>\r\n"]}
@@ -1,8 +1,8 @@
1
- import { Component, Inject } from "@angular/core";
2
- import { SSO_LOGIN_SERVICE_TOKEN } from "../../config/sso-login-service.token";
3
- import { SsoLoginComponent } from "../sso-login/sso-login.component";
4
- import { AnnaLoginComponent } from "../anna-login/anna-login.component";
5
- import { NgIf } from "@angular/common";
1
+ import { Component, Inject } from '@angular/core';
2
+ import { SSO_LOGIN_SERVICE_TOKEN } from '../../config/sso-login-service.token';
3
+ import { SsoLoginComponent } from '../sso-login/sso-login.component';
4
+ import { AnnaLoginComponent } from '../anna-login/anna-login.component';
5
+ import { NgIf } from '@angular/common';
6
6
  import * as i0 from "@angular/core";
7
7
  export class CognitoAndSSOLoginContainerComponent {
8
8
  constructor(consumingProjectSSOLoginService) {
@@ -14,9 +14,9 @@ export class CognitoAndSSOLoginContainerComponent {
14
14
  }
15
15
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CognitoAndSSOLoginContainerComponent, decorators: [{
16
16
  type: Component,
17
- args: [{ selector: "anna-cognito-lib-cognito-and-sso-login-container", standalone: true, imports: [NgIf, AnnaLoginComponent, SsoLoginComponent], template: "<anna-cognito-lib-anna-login *ngIf=\"!consumingProjectSSOLoginService?.isSsoIntegrated\"></anna-cognito-lib-anna-login>\r\n<anna-cognito-lib-sso-login *ngIf=\"consumingProjectSSOLoginService?.isSsoIntegrated\"></anna-cognito-lib-sso-login>\r\n" }]
17
+ args: [{ selector: 'anna-cognito-lib-cognito-and-sso-login-container', standalone: true, imports: [NgIf, AnnaLoginComponent, SsoLoginComponent], template: "<anna-cognito-lib-anna-login *ngIf=\"!consumingProjectSSOLoginService?.isSsoIntegrated\"></anna-cognito-lib-anna-login>\r\n<anna-cognito-lib-sso-login *ngIf=\"consumingProjectSSOLoginService?.isSsoIntegrated\"></anna-cognito-lib-sso-login>\r\n" }]
18
18
  }], ctorParameters: function () { return [{ type: undefined, decorators: [{
19
19
  type: Inject,
20
20
  args: [SSO_LOGIN_SERVICE_TOKEN]
21
21
  }] }]; } });
22
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29nbml0by1hbmQtc3NvLWxvZ2luLWNvbnRhaW5lci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbm5hLWNvZ25pdG8tbGliL3NyYy9saWIvY29tcG9uZW50cy9jb2duaXRvLWFuZC1zc28tbG9naW4tY29udGFpbmVyL2NvZ25pdG8tYW5kLXNzby1sb2dpbi1jb250YWluZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5uYS1jb2duaXRvLWxpYi9zcmMvbGliL2NvbXBvbmVudHMvY29nbml0by1hbmQtc3NvLWxvZ2luLWNvbnRhaW5lci9jb2duaXRvLWFuZC1zc28tbG9naW4tY29udGFpbmVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQzFELE9BQU8sRUFBb0IsdUJBQXVCLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUNqRyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUNyRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUN4RSxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0saUJBQWlCLENBQUM7O0FBU3ZDLE1BQU0sT0FBTyxvQ0FBb0M7SUFDN0MsWUFBb0QsK0JBQWlEO1FBQWpELG9DQUErQixHQUEvQiwrQkFBK0IsQ0FBa0I7SUFBRyxDQUFDO0lBRXpHLFFBQVEsS0FBSSxDQUFDOytHQUhKLG9DQUFvQyxrQkFDekIsdUJBQXVCO21HQURsQyxvQ0FBb0MsNEdDYmpELHFQQUVBLDBERFNjLElBQUksNkZBQUUsa0JBQWtCLHdFQUFFLGlCQUFpQjs7NEZBRTVDLG9DQUFvQztrQkFQaEQsU0FBUzsrQkFDSSxrREFBa0QsY0FHaEQsSUFBSSxXQUNQLENBQUMsSUFBSSxFQUFFLGtCQUFrQixFQUFFLGlCQUFpQixDQUFDOzswQkFHekMsTUFBTTsyQkFBQyx1QkFBdUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEluamVjdCwgT25Jbml0IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgSVNTT0xvZ2luU2VydmljZSwgU1NPX0xPR0lOX1NFUlZJQ0VfVE9LRU4gfSBmcm9tIFwiLi4vLi4vY29uZmlnL3Nzby1sb2dpbi1zZXJ2aWNlLnRva2VuXCI7XHJcbmltcG9ydCB7IFNzb0xvZ2luQ29tcG9uZW50IH0gZnJvbSBcIi4uL3Nzby1sb2dpbi9zc28tbG9naW4uY29tcG9uZW50XCI7XHJcbmltcG9ydCB7IEFubmFMb2dpbkNvbXBvbmVudCB9IGZyb20gXCIuLi9hbm5hLWxvZ2luL2FubmEtbG9naW4uY29tcG9uZW50XCI7XHJcbmltcG9ydCB7IE5nSWYgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiBcImFubmEtY29nbml0by1saWItY29nbml0by1hbmQtc3NvLWxvZ2luLWNvbnRhaW5lclwiLFxyXG4gICAgdGVtcGxhdGVVcmw6IFwiLi9jb2duaXRvLWFuZC1zc28tbG9naW4tY29udGFpbmVyLmNvbXBvbmVudC5odG1sXCIsXHJcbiAgICBzdHlsZVVybHM6IFtcIi4vY29nbml0by1hbmQtc3NvLWxvZ2luLWNvbnRhaW5lci5jb21wb25lbnQuc2Nzc1wiXSxcclxuICAgIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgICBpbXBvcnRzOiBbTmdJZiwgQW5uYUxvZ2luQ29tcG9uZW50LCBTc29Mb2dpbkNvbXBvbmVudF0sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDb2duaXRvQW5kU1NPTG9naW5Db250YWluZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG4gICAgY29uc3RydWN0b3IoQEluamVjdChTU09fTE9HSU5fU0VSVklDRV9UT0tFTikgcHVibGljIGNvbnN1bWluZ1Byb2plY3RTU09Mb2dpblNlcnZpY2U6IElTU09Mb2dpblNlcnZpY2UpIHt9XHJcblxyXG4gICAgbmdPbkluaXQoKSB7fVxyXG59XHJcbiIsIjxhbm5hLWNvZ25pdG8tbGliLWFubmEtbG9naW4gKm5nSWY9XCIhY29uc3VtaW5nUHJvamVjdFNTT0xvZ2luU2VydmljZT8uaXNTc29JbnRlZ3JhdGVkXCI+PC9hbm5hLWNvZ25pdG8tbGliLWFubmEtbG9naW4+XHJcbjxhbm5hLWNvZ25pdG8tbGliLXNzby1sb2dpbiAqbmdJZj1cImNvbnN1bWluZ1Byb2plY3RTU09Mb2dpblNlcnZpY2U/LmlzU3NvSW50ZWdyYXRlZFwiPjwvYW5uYS1jb2duaXRvLWxpYi1zc28tbG9naW4+XHJcbiJdfQ==
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29nbml0by1hbmQtc3NvLWxvZ2luLWNvbnRhaW5lci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbm5hLWNvZ25pdG8tbGliL3NyYy9saWIvY29tcG9uZW50cy9jb2duaXRvLWFuZC1zc28tbG9naW4tY29udGFpbmVyL2NvZ25pdG8tYW5kLXNzby1sb2dpbi1jb250YWluZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5uYS1jb2duaXRvLWxpYi9zcmMvbGliL2NvbXBvbmVudHMvY29nbml0by1hbmQtc3NvLWxvZ2luLWNvbnRhaW5lci9jb2duaXRvLWFuZC1zc28tbG9naW4tY29udGFpbmVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQzFELE9BQU8sRUFBb0IsdUJBQXVCLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUNqRyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUNyRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUN4RSxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0saUJBQWlCLENBQUM7O0FBU3ZDLE1BQU0sT0FBTyxvQ0FBb0M7SUFDN0MsWUFBb0QsK0JBQWlEO1FBQWpELG9DQUErQixHQUEvQiwrQkFBK0IsQ0FBa0I7SUFBRyxDQUFDO0lBRXpHLFFBQVEsS0FBSSxDQUFDOytHQUhKLG9DQUFvQyxrQkFDekIsdUJBQXVCO21HQURsQyxvQ0FBb0MsNEdDYmpELHFQQUVBLDBERFNjLElBQUksNkZBQUUsa0JBQWtCLHdFQUFFLGlCQUFpQjs7NEZBRTVDLG9DQUFvQztrQkFQaEQsU0FBUzsrQkFDSSxrREFBa0QsY0FHaEQsSUFBSSxXQUNQLENBQUMsSUFBSSxFQUFFLGtCQUFrQixFQUFFLGlCQUFpQixDQUFDOzswQkFHekMsTUFBTTsyQkFBQyx1QkFBdUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEluamVjdCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IElTU09Mb2dpblNlcnZpY2UsIFNTT19MT0dJTl9TRVJWSUNFX1RPS0VOIH0gZnJvbSAnLi4vLi4vY29uZmlnL3Nzby1sb2dpbi1zZXJ2aWNlLnRva2VuJztcclxuaW1wb3J0IHsgU3NvTG9naW5Db21wb25lbnQgfSBmcm9tICcuLi9zc28tbG9naW4vc3NvLWxvZ2luLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEFubmFMb2dpbkNvbXBvbmVudCB9IGZyb20gJy4uL2FubmEtbG9naW4vYW5uYS1sb2dpbi5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBOZ0lmIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICdhbm5hLWNvZ25pdG8tbGliLWNvZ25pdG8tYW5kLXNzby1sb2dpbi1jb250YWluZXInLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL2NvZ25pdG8tYW5kLXNzby1sb2dpbi1jb250YWluZXIuY29tcG9uZW50Lmh0bWwnLFxyXG4gICAgc3R5bGVVcmxzOiBbJy4vY29nbml0by1hbmQtc3NvLWxvZ2luLWNvbnRhaW5lci5jb21wb25lbnQuc2NzcyddLFxyXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICAgIGltcG9ydHM6IFtOZ0lmLCBBbm5hTG9naW5Db21wb25lbnQsIFNzb0xvZ2luQ29tcG9uZW50XSxcclxufSlcclxuZXhwb3J0IGNsYXNzIENvZ25pdG9BbmRTU09Mb2dpbkNvbnRhaW5lckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgICBjb25zdHJ1Y3RvcihASW5qZWN0KFNTT19MT0dJTl9TRVJWSUNFX1RPS0VOKSBwdWJsaWMgY29uc3VtaW5nUHJvamVjdFNTT0xvZ2luU2VydmljZTogSVNTT0xvZ2luU2VydmljZSkge31cclxuXHJcbiAgICBuZ09uSW5pdCgpIHt9XHJcbn1cclxuIiwiPGFubmEtY29nbml0by1saWItYW5uYS1sb2dpbiAqbmdJZj1cIiFjb25zdW1pbmdQcm9qZWN0U1NPTG9naW5TZXJ2aWNlPy5pc1Nzb0ludGVncmF0ZWRcIj48L2FubmEtY29nbml0by1saWItYW5uYS1sb2dpbj5cclxuPGFubmEtY29nbml0by1saWItc3NvLWxvZ2luICpuZ0lmPVwiY29uc3VtaW5nUHJvamVjdFNTT0xvZ2luU2VydmljZT8uaXNTc29JbnRlZ3JhdGVkXCI+PC9hbm5hLWNvZ25pdG8tbGliLXNzby1sb2dpbj5cclxuIl19
@@ -1,22 +1,22 @@
1
1
  // Angular import statements
2
- import { Component, Inject } from "@angular/core";
3
- import { FormBuilder, Validators, FormsModule, ReactiveFormsModule } from "@angular/forms";
2
+ import { Component, Inject } from '@angular/core';
3
+ import { FormBuilder, Validators, FormsModule, ReactiveFormsModule } from '@angular/forms';
4
4
  // Third party import statements
5
- import { ToastrService } from "ngx-toastr";
6
- import { forkJoin } from "rxjs";
5
+ import { ToastrService } from 'ngx-toastr';
6
+ import { forkJoin } from 'rxjs';
7
7
  // User defined import statements
8
- import { UsernameInfo, UserState } from "../../models/auth.model";
9
- import { AnnaLibAuthService } from "../../services/auth.service";
10
- import { LoginConstant } from "../../constants/loginConstant";
11
- import { Router } from "@angular/router";
12
- import { CONFIG_SERVICE_TOKEN } from "../../config/config-service.token";
13
- import { AUTH_SERVICE_TOKEN } from "../../config/auth-service.token";
14
- import { SSO_LOGIN_SERVICE_TOKEN } from "../../config/sso-login-service.token";
15
- import { VersionAndTermPolicyComponent } from "../version-and-term-policy/version-and-term-policy.component";
16
- import { SurewavesYearLogoComponent } from "../surewaves-year-logo/surewaves-year-logo.component";
17
- import { PoweredByLogoTemplateComponent } from "../powered-by-logo-template/powered-by-logo-template.component";
18
- import { SpinnerButtonDirective } from "../../directives/spinner-button/spinner-button.directive";
19
- import { NgIf, NgClass } from "@angular/common";
8
+ import { UsernameInfo, UserState } from '../../models/auth.model';
9
+ import { AnnaLibAuthService } from '../../services/auth.service';
10
+ import { LoginConstant } from '../../constants/loginConstant';
11
+ import { Router } from '@angular/router';
12
+ import { CONFIG_SERVICE_TOKEN } from '../../config/config-service.token';
13
+ import { AUTH_SERVICE_TOKEN } from '../../config/auth-service.token';
14
+ import { SSO_LOGIN_SERVICE_TOKEN } from '../../config/sso-login-service.token';
15
+ import { VersionAndTermPolicyComponent } from '../version-and-term-policy/version-and-term-policy.component';
16
+ import { SurewavesYearLogoComponent } from '../surewaves-year-logo/surewaves-year-logo.component';
17
+ import { PoweredByLogoTemplateComponent } from '../powered-by-logo-template/powered-by-logo-template.component';
18
+ import { SpinnerButtonDirective } from '../../directives/spinner-button/spinner-button.directive';
19
+ import { NgIf, NgClass } from '@angular/common';
20
20
  import * as i0 from "@angular/core";
21
21
  import * as i1 from "../../services/auth.service";
22
22
  import * as i2 from "@angular/forms";
@@ -71,7 +71,7 @@ export class ForgotPasswordComponent {
71
71
  this.isLoading = true;
72
72
  this.errorMessage = null;
73
73
  this.infoMessageToRedirectLogin = null;
74
- let username = this.verifyRegisteredEmail.controls["email"].value;
74
+ let username = this.verifyRegisteredEmail.controls['email'].value;
75
75
  let isUsernameAvailable = this.authService.consumingProjectAuthService.isUsernameAvailable(username);
76
76
  let isUsernameTempPasswordSet = this.authService.consumingProjectAuthService.getUserState(username);
77
77
  forkJoin([isUsernameAvailable, isUsernameTempPasswordSet]).subscribe({
@@ -110,7 +110,7 @@ export class ForgotPasswordComponent {
110
110
  }
111
111
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ForgotPasswordComponent, decorators: [{
112
112
  type: Component,
113
- args: [{ selector: "anna-cognito-lib-forgot-password", standalone: true, imports: [
113
+ args: [{ selector: 'anna-cognito-lib-forgot-password', standalone: true, imports: [
114
114
  FormsModule,
115
115
  ReactiveFormsModule,
116
116
  NgIf,
@@ -130,4 +130,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
130
130
  type: Inject,
131
131
  args: [SSO_LOGIN_SERVICE_TOKEN]
132
132
  }] }]; } });
133
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"forgot-password.component.js","sourceRoot":"","sources":["../../../../../../projects/anna-cognito-lib/src/lib/components/forgot-password/forgot-password.component.ts","../../../../../../projects/anna-cognito-lib/src/lib/components/forgot-password/forgot-password.component.html"],"names":[],"mappings":"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","sourcesContent":["// Angular import statements\r\nimport { Component, Inject, OnInit } from \"@angular/core\";\r\nimport { FormBuilder, FormGroup, Validators, FormsModule, ReactiveFormsModule } from \"@angular/forms\";\r\n\r\n// Third party import statements\r\nimport { ToastrService } from \"ngx-toastr\";\r\nimport { forkJoin, catchError, pipe, map } from \"rxjs\";\r\n\r\n// User defined import statements\r\nimport { UsernameInfo, UserState } from \"../../models/auth.model\";\r\nimport { AnnaLibAuthService } from \"../../services/auth.service\";\r\nimport { LoginConstant } from \"../../constants/loginConstant\";\r\nimport { Router } from \"@angular/router\";\r\nimport { CONFIG_SERVICE_TOKEN, IConfigService } from \"../../config/config-service.token\";\r\nimport { AUTH_SERVICE_TOKEN, IAuthService } from \"../../config/auth-service.token\";\r\nimport { ISSOLoginService, SSO_LOGIN_SERVICE_TOKEN } from \"../../config/sso-login-service.token\";\r\nimport { VersionAndTermPolicyComponent } from \"../version-and-term-policy/version-and-term-policy.component\";\r\nimport { SurewavesYearLogoComponent } from \"../surewaves-year-logo/surewaves-year-logo.component\";\r\nimport { PoweredByLogoTemplateComponent } from \"../powered-by-logo-template/powered-by-logo-template.component\";\r\nimport { SpinnerButtonDirective } from \"../../directives/spinner-button/spinner-button.directive\";\r\nimport { NgIf, NgClass } from \"@angular/common\";\r\n\r\ntype passwordType = { value: string; status: string };\r\n@Component({\r\n    selector: \"anna-cognito-lib-forgot-password\",\r\n    templateUrl: \"./forgot-password.component.html\",\r\n    styleUrls: [\"./forgot-password.component.scss\"],\r\n    standalone: true,\r\n    imports: [\r\n        FormsModule,\r\n        ReactiveFormsModule,\r\n        NgIf,\r\n        NgClass,\r\n        SpinnerButtonDirective,\r\n        PoweredByLogoTemplateComponent,\r\n        SurewavesYearLogoComponent,\r\n        VersionAndTermPolicyComponent,\r\n    ],\r\n})\r\nexport class ForgotPasswordComponent implements OnInit {\r\n    errorMessage: string;\r\n    verifyRegisteredEmail: FormGroup;\r\n    passwordNotMatching = false;\r\n    constants: typeof LoginConstant;\r\n    password: passwordType = { value: null, status: null };\r\n    confirmPassword: passwordType = { value: null, status: null };\r\n    infoMessageToRedirectLogin: string = null;\r\n    isLoading: boolean = false;\r\n\r\n    constructor(\r\n        private authService: AnnaLibAuthService,\r\n        private fb: FormBuilder,\r\n        private toastr: ToastrService,\r\n        private router: Router,\r\n        @Inject(CONFIG_SERVICE_TOKEN) public consumingProjectConfigService: IConfigService,\r\n        @Inject(AUTH_SERVICE_TOKEN) public consumingProjectAuthService: IAuthService,\r\n        @Inject(SSO_LOGIN_SERVICE_TOKEN) public consumingProjectSSOLoginService: ISSOLoginService,\r\n    ) {}\r\n\r\n    ngOnInit() {\r\n        this.infoMessageToRedirectLogin = null;\r\n        this.constants = LoginConstant;\r\n        this.onIntialiseForm();\r\n        if (this.consumingProjectAuthService.userName) {\r\n            this.onUpdateForm();\r\n        }\r\n        this.authService.forgotPasswordAndGlobalSignoutLoader = false;\r\n    }\r\n\r\n    onIntialiseForm() {\r\n        this.verifyRegisteredEmail = this.fb.group({\r\n            email: [null, [Validators.required]],\r\n        });\r\n    }\r\n\r\n    onUpdateForm() {\r\n        this.verifyRegisteredEmail.patchValue({\r\n            email: this.consumingProjectAuthService.userName,\r\n        });\r\n    }\r\n\r\n    isFormValid() {\r\n        return this.verifyRegisteredEmail.valid;\r\n    }\r\n\r\n    onLoginOrGetOtpButtonClick() {\r\n        if (this.infoMessageToRedirectLogin) {\r\n            this.router.navigate([LoginConstant.loginPageUrl]);\r\n        } else {\r\n            this.onVerifyRegisteredEmail();\r\n        }\r\n    }\r\n\r\n    onVerifyRegisteredEmail() {\r\n        this.isLoading = true;\r\n        this.errorMessage = null;\r\n        this.infoMessageToRedirectLogin = null;\r\n        let username = this.verifyRegisteredEmail.controls[\"email\"].value;\r\n\r\n        let isUsernameAvailable = this.authService.consumingProjectAuthService.isUsernameAvailable(username);\r\n        let isUsernameTempPasswordSet = this.authService.consumingProjectAuthService.getUserState(username);\r\n\r\n        forkJoin([isUsernameAvailable, isUsernameTempPasswordSet]).subscribe({\r\n            next: (result) => {\r\n                let isUsernameAvailable = new UsernameInfo(result[0]).isUsernameAvailable;\r\n                let isUserWithTempPassword = new UserState(result[1]).isUserWithTempPassword;\r\n                this.onGettingUserStatus(isUsernameAvailable, isUserWithTempPassword, username);\r\n                this.isLoading = false;\r\n            },\r\n            error: (error) => {\r\n                if (error.status == 400) {\r\n                    this.errorMessage = this.constants.userNotFound;\r\n                } else {\r\n                    this.toastr.error(LoginConstant.apiFailErrorMessage);\r\n                }\r\n                this.isLoading = false;\r\n            },\r\n        });\r\n    }\r\n\r\n    onGettingUserStatus(isUsernameAvailable: boolean, isUserWithTempPassword: boolean, username: string) {\r\n        if (!isUsernameAvailable) {\r\n            if (!isUserWithTempPassword) {\r\n                this.authService.onForgotPasswordGenerateOTP(username);\r\n            } else {\r\n                this.infoMessageToRedirectLogin = this.constants.firstTimeLoginUserTempPasswordMsg;\r\n            }\r\n        } else {\r\n            this.errorMessage = this.constants.userNotFound;\r\n        }\r\n    }\r\n}\r\n","<div class=\"main\">\r\n    <section>\r\n        <header>\r\n            <img\r\n                [src]=\"consumingProjectConfigService.appGenericConfig.loginPageLogoImgUrl\"\r\n                alt=\"Anna Logo\"\r\n            />\r\n        </header>\r\n        <article>\r\n            <form [formGroup]=\"verifyRegisteredEmail\">\r\n                <ng-container *ngIf=\"!infoMessageToRedirectLogin\">\r\n                    <div id=\"heading\">\r\n                        {{ constants.forgotPasswordHeading }}\r\n                    </div>\r\n                    <p>\r\n                        {{\r\n                            consumingProjectSSOLoginService?.isSsoIntegrated\r\n                                ? constants.PleaseEnterYourUsercodeMessage\r\n                                : constants.PleaseEnterYourUsernameMessage\r\n                        }}\r\n                    </p>\r\n                </ng-container>\r\n                <div\r\n                    id=\"alert-div\"\r\n                    *ngIf=\"errorMessage\"\r\n                >\r\n                    <span class=\"material-icons\">report</span>\r\n                    <p id=\"alert-msg\">{{ errorMessage }}</p>\r\n                </div>\r\n                <div\r\n                    id=\"info-div\"\r\n                    *ngIf=\"infoMessageToRedirectLogin\"\r\n                >\r\n                    <i class=\"mi mdi-info\"></i>\r\n                    <p>{{ infoMessageToRedirectLogin }}</p>\r\n                </div>\r\n\r\n                <input\r\n                    *ngIf=\"!infoMessageToRedirectLogin\"\r\n                    type=\"text\"\r\n                    tabindex=\"1\"\r\n                    formControlName=\"email\"\r\n                    [placeholder]=\"\r\n                        consumingProjectSSOLoginService?.isSsoIntegrated\r\n                            ? constants.enterUserCode\r\n                            : constants.enterEmail\r\n                    \"\r\n                    [ngClass]=\"{\r\n                        'input-invalid':\r\n                            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                    [anna-cognito-lib-SpinnerButton]=\"isLoading\"\r\n                    (click)=\"onLoginOrGetOtpButtonClick()\"\r\n                    [spinnerButtonText]=\"infoMessageToRedirectLogin ? constants.login : constants.forgotPasswordButton\"\r\n                ></button>\r\n            </form>\r\n        </article>\r\n        <footer>\r\n            <anna-cognito-lib-powered-by-logo-template> </anna-cognito-lib-powered-by-logo-template>\r\n        </footer>\r\n    </section>\r\n</div>\r\n\r\n<div class=\"page-footer\">\r\n    <anna-cognito-lib-surewaves-year-logo></anna-cognito-lib-surewaves-year-logo>\r\n    <anna-cognito-lib-version-and-term-policy></anna-cognito-lib-version-and-term-policy>\r\n</div>\r\n"]}
133
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"forgot-password.component.js","sourceRoot":"","sources":["../../../../../../projects/anna-cognito-lib/src/lib/components/forgot-password/forgot-password.component.ts","../../../../../../projects/anna-cognito-lib/src/lib/components/forgot-password/forgot-password.component.html"],"names":[],"mappings":"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","sourcesContent":["// Angular import statements\r\nimport { Component, Inject, OnInit } from '@angular/core';\r\nimport { FormBuilder, FormGroup, Validators, FormsModule, ReactiveFormsModule } from '@angular/forms';\r\n\r\n// Third party import statements\r\nimport { ToastrService } from 'ngx-toastr';\r\nimport { forkJoin, catchError, pipe, map } from 'rxjs';\r\n\r\n// User defined import statements\r\nimport { UsernameInfo, UserState } from '../../models/auth.model';\r\nimport { AnnaLibAuthService } from '../../services/auth.service';\r\nimport { LoginConstant } from '../../constants/loginConstant';\r\nimport { Router } from '@angular/router';\r\nimport { CONFIG_SERVICE_TOKEN, IConfigService } from '../../config/config-service.token';\r\nimport { AUTH_SERVICE_TOKEN, IAuthService } from '../../config/auth-service.token';\r\nimport { ISSOLoginService, SSO_LOGIN_SERVICE_TOKEN } from '../../config/sso-login-service.token';\r\nimport { VersionAndTermPolicyComponent } from '../version-and-term-policy/version-and-term-policy.component';\r\nimport { SurewavesYearLogoComponent } from '../surewaves-year-logo/surewaves-year-logo.component';\r\nimport { PoweredByLogoTemplateComponent } from '../powered-by-logo-template/powered-by-logo-template.component';\r\nimport { SpinnerButtonDirective } from '../../directives/spinner-button/spinner-button.directive';\r\nimport { NgIf, NgClass } from '@angular/common';\r\n\r\ntype passwordType = { value: string; status: string };\r\n@Component({\r\n    selector: 'anna-cognito-lib-forgot-password',\r\n    templateUrl: './forgot-password.component.html',\r\n    styleUrls: ['./forgot-password.component.scss'],\r\n    standalone: true,\r\n    imports: [\r\n        FormsModule,\r\n        ReactiveFormsModule,\r\n        NgIf,\r\n        NgClass,\r\n        SpinnerButtonDirective,\r\n        PoweredByLogoTemplateComponent,\r\n        SurewavesYearLogoComponent,\r\n        VersionAndTermPolicyComponent,\r\n    ],\r\n})\r\nexport class ForgotPasswordComponent implements OnInit {\r\n    errorMessage: string;\r\n    verifyRegisteredEmail: FormGroup;\r\n    passwordNotMatching = false;\r\n    constants: typeof LoginConstant;\r\n    password: passwordType = { value: null, status: null };\r\n    confirmPassword: passwordType = { value: null, status: null };\r\n    infoMessageToRedirectLogin: string = null;\r\n    isLoading: boolean = false;\r\n\r\n    constructor(\r\n        private authService: AnnaLibAuthService,\r\n        private fb: FormBuilder,\r\n        private toastr: ToastrService,\r\n        private router: Router,\r\n        @Inject(CONFIG_SERVICE_TOKEN) public consumingProjectConfigService: IConfigService,\r\n        @Inject(AUTH_SERVICE_TOKEN) public consumingProjectAuthService: IAuthService,\r\n        @Inject(SSO_LOGIN_SERVICE_TOKEN) public consumingProjectSSOLoginService: ISSOLoginService,\r\n    ) {}\r\n\r\n    ngOnInit() {\r\n        this.infoMessageToRedirectLogin = null;\r\n        this.constants = LoginConstant;\r\n        this.onIntialiseForm();\r\n        if (this.consumingProjectAuthService.userName) {\r\n            this.onUpdateForm();\r\n        }\r\n        this.authService.forgotPasswordAndGlobalSignoutLoader = false;\r\n    }\r\n\r\n    onIntialiseForm() {\r\n        this.verifyRegisteredEmail = this.fb.group({\r\n            email: [null, [Validators.required]],\r\n        });\r\n    }\r\n\r\n    onUpdateForm() {\r\n        this.verifyRegisteredEmail.patchValue({\r\n            email: this.consumingProjectAuthService.userName,\r\n        });\r\n    }\r\n\r\n    isFormValid() {\r\n        return this.verifyRegisteredEmail.valid;\r\n    }\r\n\r\n    onLoginOrGetOtpButtonClick() {\r\n        if (this.infoMessageToRedirectLogin) {\r\n            this.router.navigate([LoginConstant.loginPageUrl]);\r\n        } else {\r\n            this.onVerifyRegisteredEmail();\r\n        }\r\n    }\r\n\r\n    onVerifyRegisteredEmail() {\r\n        this.isLoading = true;\r\n        this.errorMessage = null;\r\n        this.infoMessageToRedirectLogin = null;\r\n        let username = this.verifyRegisteredEmail.controls['email'].value;\r\n\r\n        let isUsernameAvailable = this.authService.consumingProjectAuthService.isUsernameAvailable(username);\r\n        let isUsernameTempPasswordSet = this.authService.consumingProjectAuthService.getUserState(username);\r\n\r\n        forkJoin([isUsernameAvailable, isUsernameTempPasswordSet]).subscribe({\r\n            next: (result) => {\r\n                let isUsernameAvailable = new UsernameInfo(result[0]).isUsernameAvailable;\r\n                let isUserWithTempPassword = new UserState(result[1]).isUserWithTempPassword;\r\n                this.onGettingUserStatus(isUsernameAvailable, isUserWithTempPassword, username);\r\n                this.isLoading = false;\r\n            },\r\n            error: (error) => {\r\n                if (error.status == 400) {\r\n                    this.errorMessage = this.constants.userNotFound;\r\n                } else {\r\n                    this.toastr.error(LoginConstant.apiFailErrorMessage);\r\n                }\r\n                this.isLoading = false;\r\n            },\r\n        });\r\n    }\r\n\r\n    onGettingUserStatus(isUsernameAvailable: boolean, isUserWithTempPassword: boolean, username: string) {\r\n        if (!isUsernameAvailable) {\r\n            if (!isUserWithTempPassword) {\r\n                this.authService.onForgotPasswordGenerateOTP(username);\r\n            } else {\r\n                this.infoMessageToRedirectLogin = this.constants.firstTimeLoginUserTempPasswordMsg;\r\n            }\r\n        } else {\r\n            this.errorMessage = this.constants.userNotFound;\r\n        }\r\n    }\r\n}\r\n","<div class=\"main\">\r\n    <section>\r\n        <header>\r\n            <img\r\n                [src]=\"consumingProjectConfigService.appGenericConfig.loginPageLogoImgUrl\"\r\n                alt=\"Anna Logo\"\r\n            />\r\n        </header>\r\n        <article>\r\n            <form [formGroup]=\"verifyRegisteredEmail\">\r\n                <ng-container *ngIf=\"!infoMessageToRedirectLogin\">\r\n                    <div id=\"heading\">\r\n                        {{ constants.forgotPasswordHeading }}\r\n                    </div>\r\n                    <p>\r\n                        {{\r\n                            consumingProjectSSOLoginService?.isSsoIntegrated\r\n                                ? constants.PleaseEnterYourUsercodeMessage\r\n                                : constants.PleaseEnterYourUsernameMessage\r\n                        }}\r\n                    </p>\r\n                </ng-container>\r\n                <div\r\n                    id=\"alert-div\"\r\n                    *ngIf=\"errorMessage\"\r\n                >\r\n                    <span class=\"material-icons\">report</span>\r\n                    <p id=\"alert-msg\">{{ errorMessage }}</p>\r\n                </div>\r\n                <div\r\n                    id=\"info-div\"\r\n                    *ngIf=\"infoMessageToRedirectLogin\"\r\n                >\r\n                    <i class=\"mi mdi-info\"></i>\r\n                    <p>{{ infoMessageToRedirectLogin }}</p>\r\n                </div>\r\n\r\n                <input\r\n                    *ngIf=\"!infoMessageToRedirectLogin\"\r\n                    type=\"text\"\r\n                    tabindex=\"1\"\r\n                    formControlName=\"email\"\r\n                    [placeholder]=\"\r\n                        consumingProjectSSOLoginService?.isSsoIntegrated\r\n                            ? constants.enterUserCode\r\n                            : constants.enterEmail\r\n                    \"\r\n                    [ngClass]=\"{\r\n                        'input-invalid':\r\n                            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                    [anna-cognito-lib-SpinnerButton]=\"isLoading\"\r\n                    (click)=\"onLoginOrGetOtpButtonClick()\"\r\n                    [spinnerButtonText]=\"infoMessageToRedirectLogin ? constants.login : constants.forgotPasswordButton\"\r\n                ></button>\r\n            </form>\r\n        </article>\r\n        <footer>\r\n            <anna-cognito-lib-powered-by-logo-template> </anna-cognito-lib-powered-by-logo-template>\r\n        </footer>\r\n    </section>\r\n</div>\r\n\r\n<div class=\"page-footer\">\r\n    <anna-cognito-lib-surewaves-year-logo></anna-cognito-lib-surewaves-year-logo>\r\n    <anna-cognito-lib-version-and-term-policy></anna-cognito-lib-version-and-term-policy>\r\n</div>\r\n"]}
@@ -1,12 +1,12 @@
1
1
  // Angular import statements
2
- import { EventEmitter, Inject, Input, Output } from "@angular/core";
3
- import { Component } from "@angular/core";
4
- import { FormBuilder, Validators, FormsModule, ReactiveFormsModule, } from "@angular/forms";
2
+ import { EventEmitter, Inject, Input, Output } from '@angular/core';
3
+ import { Component } from '@angular/core';
4
+ import { FormBuilder, Validators, FormsModule, ReactiveFormsModule, } from '@angular/forms';
5
5
  // Third party import statements
6
- import { debounceTime } from "rxjs/operators";
6
+ import { debounceTime } from 'rxjs/operators';
7
7
  // User defined import statements
8
- import { LoginConstant } from "../../constants/loginConstant";
9
- import { NgIf, NgClass } from "@angular/common";
8
+ import { LoginConstant } from '../../constants/loginConstant';
9
+ import { NgIf, NgClass } from '@angular/common';
10
10
  import * as i0 from "@angular/core";
11
11
  import * as i1 from "@angular/forms";
12
12
  export class PasswordMatchingComponent {
@@ -21,18 +21,18 @@ export class PasswordMatchingComponent {
21
21
  this.formValueChanged();
22
22
  }
23
23
  formValueChanged() {
24
- const password = this.passwordForm.get("password");
25
- const confirmPassword = this.passwordForm.get("confirmPassword");
24
+ const password = this.passwordForm.get('password');
25
+ const confirmPassword = this.passwordForm.get('confirmPassword');
26
26
  password &&
27
27
  password.valueChanges.subscribe(() => {
28
28
  password &&
29
29
  password.setValidators([
30
30
  Validators.required,
31
- this.regexValidator(new RegExp(".{8,}"), { minLength: true }),
32
- this.regexValidator(new RegExp("[a-z]"), { lowercase: true }),
33
- this.regexValidator(new RegExp("[A-Z]"), { uppercase: true }),
34
- this.regexValidator(new RegExp("[0-9]"), { number: true }),
35
- this.regexValidator(new RegExp("[^a-zA-Z0-9]"), { specialCharacter: true }),
31
+ this.regexValidator(new RegExp('.{8,}'), { minLength: true }),
32
+ this.regexValidator(new RegExp('[a-z]'), { lowercase: true }),
33
+ this.regexValidator(new RegExp('[A-Z]'), { uppercase: true }),
34
+ this.regexValidator(new RegExp('[0-9]'), { number: true }),
35
+ this.regexValidator(new RegExp('[^a-zA-Z0-9]'), { specialCharacter: true }),
36
36
  ]);
37
37
  password.updateValueAndValidity({ emitEvent: false });
38
38
  this.onPasswordChange();
@@ -48,14 +48,14 @@ export class PasswordMatchingComponent {
48
48
  onPasswordChange() {
49
49
  let result = {
50
50
  value: this.passwordForm.value.password,
51
- status: this.passwordForm.controls["password"].status,
51
+ status: this.passwordForm.controls['password'].status,
52
52
  };
53
53
  this.passwordChange.emit(result);
54
54
  }
55
55
  onConfirmPasswordChange() {
56
56
  let result = {
57
57
  value: this.passwordForm.value.confirmPassword,
58
- status: this.passwordForm.controls["confirmPassword"].status,
58
+ status: this.passwordForm.controls['confirmPassword'].status,
59
59
  };
60
60
  this.confirmPasswordChange.emit(result);
61
61
  }
@@ -78,7 +78,7 @@ export class PasswordMatchingComponent {
78
78
  }
79
79
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: PasswordMatchingComponent, decorators: [{
80
80
  type: Component,
81
- args: [{ selector: "anna-cognito-lib-password-matching", standalone: true, imports: [FormsModule, ReactiveFormsModule, NgIf, NgClass], template: "<form [formGroup]=\"passwordForm\">\r\n <div\r\n id=\"alert-div\"\r\n *ngIf=\"passwordNotMatching\"\r\n >\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\r\n class=\"material-icons\"\r\n *ngIf=\"passwordForm.get('password')?.hasError('minLength')\"\r\n >\r\n cancel\r\n </span>\r\n <span\r\n class=\"material-icons\"\r\n *ngIf=\"!passwordForm.get('password')?.hasError('minLength')\"\r\n >\r\n check_circle\r\n </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\r\n class=\"material-icons\"\r\n *ngIf=\"passwordForm.get('password')?.hasError('uppercase')\"\r\n >\r\n cancel\r\n </span>\r\n <span\r\n class=\"material-icons\"\r\n *ngIf=\"!passwordForm.get('password')?.hasError('uppercase')\"\r\n >\r\n check_circle\r\n </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\r\n class=\"material-icons\"\r\n *ngIf=\"passwordForm.get('password')?.hasError('lowercase')\"\r\n >\r\n cancel\r\n </span>\r\n <span\r\n class=\"material-icons\"\r\n *ngIf=\"!passwordForm.get('password')?.hasError('lowercase')\"\r\n >\r\n check_circle\r\n </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\r\n class=\"material-icons\"\r\n *ngIf=\"passwordForm.get('password')?.hasError('number')\"\r\n >\r\n cancel\r\n </span>\r\n <span\r\n class=\"material-icons\"\r\n *ngIf=\"!passwordForm.get('password')?.hasError('number')\"\r\n >\r\n check_circle\r\n </span>\r\n </div>\r\n <span class=\"span-text\">{{ constants.oneNumber }}</span>\r\n </div>\r\n\r\n <div\r\n [ngClass]=\"passwordForm.get('password')?.hasError('specialCharacter') ? 'error-color' : 'success-color'\"\r\n >\r\n <div id=\"icon-div-msg\">\r\n <span\r\n class=\"material-icons\"\r\n *ngIf=\"passwordForm.get('password')?.hasError('specialCharacter')\"\r\n >\r\n cancel\r\n </span>\r\n <span\r\n class=\"material-icons\"\r\n *ngIf=\"!passwordForm.get('password')?.hasError('specialCharacter')\"\r\n >\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"] }]
81
+ args: [{ selector: 'anna-cognito-lib-password-matching', standalone: true, imports: [FormsModule, ReactiveFormsModule, NgIf, NgClass], template: "<form [formGroup]=\"passwordForm\">\r\n <div\r\n id=\"alert-div\"\r\n *ngIf=\"passwordNotMatching\"\r\n >\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\r\n class=\"material-icons\"\r\n *ngIf=\"passwordForm.get('password')?.hasError('minLength')\"\r\n >\r\n cancel\r\n </span>\r\n <span\r\n class=\"material-icons\"\r\n *ngIf=\"!passwordForm.get('password')?.hasError('minLength')\"\r\n >\r\n check_circle\r\n </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\r\n class=\"material-icons\"\r\n *ngIf=\"passwordForm.get('password')?.hasError('uppercase')\"\r\n >\r\n cancel\r\n </span>\r\n <span\r\n class=\"material-icons\"\r\n *ngIf=\"!passwordForm.get('password')?.hasError('uppercase')\"\r\n >\r\n check_circle\r\n </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\r\n class=\"material-icons\"\r\n *ngIf=\"passwordForm.get('password')?.hasError('lowercase')\"\r\n >\r\n cancel\r\n </span>\r\n <span\r\n class=\"material-icons\"\r\n *ngIf=\"!passwordForm.get('password')?.hasError('lowercase')\"\r\n >\r\n check_circle\r\n </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\r\n class=\"material-icons\"\r\n *ngIf=\"passwordForm.get('password')?.hasError('number')\"\r\n >\r\n cancel\r\n </span>\r\n <span\r\n class=\"material-icons\"\r\n *ngIf=\"!passwordForm.get('password')?.hasError('number')\"\r\n >\r\n check_circle\r\n </span>\r\n </div>\r\n <span class=\"span-text\">{{ constants.oneNumber }}</span>\r\n </div>\r\n\r\n <div\r\n [ngClass]=\"passwordForm.get('password')?.hasError('specialCharacter') ? 'error-color' : 'success-color'\"\r\n >\r\n <div id=\"icon-div-msg\">\r\n <span\r\n class=\"material-icons\"\r\n *ngIf=\"passwordForm.get('password')?.hasError('specialCharacter')\"\r\n >\r\n cancel\r\n </span>\r\n <span\r\n class=\"material-icons\"\r\n *ngIf=\"!passwordForm.get('password')?.hasError('specialCharacter')\"\r\n >\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"] }]
82
82
  }], ctorParameters: function () { return [{ type: i1.FormBuilder, decorators: [{
83
83
  type: Inject,
84
84
  args: [FormBuilder]
@@ -89,4 +89,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
89
89
  }], passwordNotMatching: [{
90
90
  type: Input
91
91
  }] } });
92
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"password-matching.component.js","sourceRoot":"","sources":["../../../../../../projects/anna-cognito-lib/src/lib/components/password-matching/password-matching.component.ts","../../../../../../projects/anna-cognito-lib/src/lib/components/password-matching/password-matching.component.html"],"names":[],"mappings":"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","sourcesContent":["// Angular import statements\r\nimport { EventEmitter, Inject, Input, Output } from \"@angular/core\";\r\nimport { Component, OnInit } from \"@angular/core\";\r\nimport {\r\n    AbstractControl,\r\n    FormBuilder,\r\n    FormGroup,\r\n    ValidationErrors,\r\n    ValidatorFn,\r\n    Validators,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n} from \"@angular/forms\";\r\n\r\n// Third party import statements\r\nimport { debounceTime } from \"rxjs/operators\";\r\n\r\n// User defined import statements\r\nimport { LoginConstant } from \"../../constants/loginConstant\";\r\nimport { NgIf, NgClass } from \"@angular/common\";\r\n\r\n@Component({\r\n    selector: \"anna-cognito-lib-password-matching\",\r\n    templateUrl: \"./password-matching.component.html\",\r\n    styleUrls: [\"./password-matching.component.scss\"],\r\n    standalone: true,\r\n    imports: [FormsModule, ReactiveFormsModule, NgIf, NgClass],\r\n})\r\nexport class PasswordMatchingComponent implements OnInit {\r\n    @Output() passwordChange = new EventEmitter();\r\n    @Output() confirmPasswordChange = new EventEmitter();\r\n\r\n    @Input() passwordNotMatching: boolean;\r\n    passwordForm: FormGroup;\r\n    constants: typeof LoginConstant;\r\n    constructor(@Inject(FormBuilder) private fb: FormBuilder) {}\r\n\r\n    ngOnInit() {\r\n        this.constants = LoginConstant;\r\n        this.createGroup();\r\n        this.formValueChanged();\r\n    }\r\n\r\n    formValueChanged() {\r\n        const password = this.passwordForm.get(\"password\");\r\n        const confirmPassword = this.passwordForm.get(\"confirmPassword\");\r\n\r\n        password &&\r\n            password.valueChanges.subscribe(() => {\r\n                password &&\r\n                    password.setValidators([\r\n                        Validators.required,\r\n                        this.regexValidator(new RegExp(\".{8,}\"), { minLength: true }),\r\n                        this.regexValidator(new RegExp(\"[a-z]\"), { lowercase: true }),\r\n                        this.regexValidator(new RegExp(\"[A-Z]\"), { uppercase: true }),\r\n                        this.regexValidator(new RegExp(\"[0-9]\"), { number: true }),\r\n                        this.regexValidator(new RegExp(\"[^a-zA-Z0-9]\"), { specialCharacter: true }),\r\n                    ]);\r\n                password.updateValueAndValidity({ emitEvent: false });\r\n                this.onPasswordChange();\r\n            });\r\n\r\n        if (confirmPassword) {\r\n            confirmPassword.valueChanges.pipe(debounceTime(300)).subscribe(() => {\r\n                confirmPassword.setValidators([Validators.required]);\r\n                confirmPassword.updateValueAndValidity({ emitEvent: false });\r\n                this.onConfirmPasswordChange();\r\n            });\r\n        }\r\n    }\r\n\r\n    onPasswordChange() {\r\n        let result = {\r\n            value: this.passwordForm.value.password,\r\n            status: this.passwordForm.controls[\"password\"].status,\r\n        };\r\n        this.passwordChange.emit(result);\r\n    }\r\n\r\n    onConfirmPasswordChange() {\r\n        let result = {\r\n            value: this.passwordForm.value.confirmPassword,\r\n            status: this.passwordForm.controls[\"confirmPassword\"].status,\r\n        };\r\n        this.confirmPasswordChange.emit(result);\r\n    }\r\n\r\n    createGroup() {\r\n        this.passwordForm = this.fb.group({\r\n            password: [null],\r\n            confirmPassword: [null],\r\n        });\r\n        return this.passwordForm;\r\n    }\r\n\r\n    // TODO: check the return again\r\n    regexValidator(regex: RegExp, error: ValidationErrors): any {\r\n        return (control: AbstractControl): { [key: string]: boolean } => {\r\n            const valid = regex.test(control.value);\r\n            return (valid ? null : error) as any;\r\n        };\r\n    }\r\n}\r\n","<form [formGroup]=\"passwordForm\">\r\n    <div\r\n        id=\"alert-div\"\r\n        *ngIf=\"passwordNotMatching\"\r\n    >\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\r\n                        class=\"material-icons\"\r\n                        *ngIf=\"passwordForm.get('password')?.hasError('minLength')\"\r\n                    >\r\n                        cancel\r\n                    </span>\r\n                    <span\r\n                        class=\"material-icons\"\r\n                        *ngIf=\"!passwordForm.get('password')?.hasError('minLength')\"\r\n                    >\r\n                        check_circle\r\n                    </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\r\n                        class=\"material-icons\"\r\n                        *ngIf=\"passwordForm.get('password')?.hasError('uppercase')\"\r\n                    >\r\n                        cancel\r\n                    </span>\r\n                    <span\r\n                        class=\"material-icons\"\r\n                        *ngIf=\"!passwordForm.get('password')?.hasError('uppercase')\"\r\n                    >\r\n                        check_circle\r\n                    </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\r\n                        class=\"material-icons\"\r\n                        *ngIf=\"passwordForm.get('password')?.hasError('lowercase')\"\r\n                    >\r\n                        cancel\r\n                    </span>\r\n                    <span\r\n                        class=\"material-icons\"\r\n                        *ngIf=\"!passwordForm.get('password')?.hasError('lowercase')\"\r\n                    >\r\n                        check_circle\r\n                    </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\r\n                        class=\"material-icons\"\r\n                        *ngIf=\"passwordForm.get('password')?.hasError('number')\"\r\n                    >\r\n                        cancel\r\n                    </span>\r\n                    <span\r\n                        class=\"material-icons\"\r\n                        *ngIf=\"!passwordForm.get('password')?.hasError('number')\"\r\n                    >\r\n                        check_circle\r\n                    </span>\r\n                </div>\r\n                <span class=\"span-text\">{{ constants.oneNumber }}</span>\r\n            </div>\r\n\r\n            <div\r\n                [ngClass]=\"passwordForm.get('password')?.hasError('specialCharacter') ? 'error-color' : 'success-color'\"\r\n            >\r\n                <div id=\"icon-div-msg\">\r\n                    <span\r\n                        class=\"material-icons\"\r\n                        *ngIf=\"passwordForm.get('password')?.hasError('specialCharacter')\"\r\n                    >\r\n                        cancel\r\n                    </span>\r\n                    <span\r\n                        class=\"material-icons\"\r\n                        *ngIf=\"!passwordForm.get('password')?.hasError('specialCharacter')\"\r\n                    >\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"]}
92
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"password-matching.component.js","sourceRoot":"","sources":["../../../../../../projects/anna-cognito-lib/src/lib/components/password-matching/password-matching.component.ts","../../../../../../projects/anna-cognito-lib/src/lib/components/password-matching/password-matching.component.html"],"names":[],"mappings":"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","sourcesContent":["// Angular import statements\r\nimport { EventEmitter, Inject, Input, Output } from '@angular/core';\r\nimport { Component, OnInit } from '@angular/core';\r\nimport {\r\n    AbstractControl,\r\n    FormBuilder,\r\n    FormGroup,\r\n    ValidationErrors,\r\n    ValidatorFn,\r\n    Validators,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n} from '@angular/forms';\r\n\r\n// Third party import statements\r\nimport { debounceTime } from 'rxjs/operators';\r\n\r\n// User defined import statements\r\nimport { LoginConstant } from '../../constants/loginConstant';\r\nimport { NgIf, NgClass } from '@angular/common';\r\n\r\n@Component({\r\n    selector: 'anna-cognito-lib-password-matching',\r\n    templateUrl: './password-matching.component.html',\r\n    styleUrls: ['./password-matching.component.scss'],\r\n    standalone: true,\r\n    imports: [FormsModule, ReactiveFormsModule, NgIf, NgClass],\r\n})\r\nexport class PasswordMatchingComponent implements OnInit {\r\n    @Output() passwordChange = new EventEmitter();\r\n    @Output() confirmPasswordChange = new EventEmitter();\r\n\r\n    @Input() passwordNotMatching: boolean;\r\n    passwordForm: FormGroup;\r\n    constants: typeof LoginConstant;\r\n    constructor(@Inject(FormBuilder) private fb: FormBuilder) {}\r\n\r\n    ngOnInit() {\r\n        this.constants = LoginConstant;\r\n        this.createGroup();\r\n        this.formValueChanged();\r\n    }\r\n\r\n    formValueChanged() {\r\n        const password = this.passwordForm.get('password');\r\n        const confirmPassword = this.passwordForm.get('confirmPassword');\r\n\r\n        password &&\r\n            password.valueChanges.subscribe(() => {\r\n                password &&\r\n                    password.setValidators([\r\n                        Validators.required,\r\n                        this.regexValidator(new RegExp('.{8,}'), { minLength: true }),\r\n                        this.regexValidator(new RegExp('[a-z]'), { lowercase: true }),\r\n                        this.regexValidator(new RegExp('[A-Z]'), { uppercase: true }),\r\n                        this.regexValidator(new RegExp('[0-9]'), { number: true }),\r\n                        this.regexValidator(new RegExp('[^a-zA-Z0-9]'), { specialCharacter: true }),\r\n                    ]);\r\n                password.updateValueAndValidity({ emitEvent: false });\r\n                this.onPasswordChange();\r\n            });\r\n\r\n        if (confirmPassword) {\r\n            confirmPassword.valueChanges.pipe(debounceTime(300)).subscribe(() => {\r\n                confirmPassword.setValidators([Validators.required]);\r\n                confirmPassword.updateValueAndValidity({ emitEvent: false });\r\n                this.onConfirmPasswordChange();\r\n            });\r\n        }\r\n    }\r\n\r\n    onPasswordChange() {\r\n        let result = {\r\n            value: this.passwordForm.value.password,\r\n            status: this.passwordForm.controls['password'].status,\r\n        };\r\n        this.passwordChange.emit(result);\r\n    }\r\n\r\n    onConfirmPasswordChange() {\r\n        let result = {\r\n            value: this.passwordForm.value.confirmPassword,\r\n            status: this.passwordForm.controls['confirmPassword'].status,\r\n        };\r\n        this.confirmPasswordChange.emit(result);\r\n    }\r\n\r\n    createGroup() {\r\n        this.passwordForm = this.fb.group({\r\n            password: [null],\r\n            confirmPassword: [null],\r\n        });\r\n        return this.passwordForm;\r\n    }\r\n\r\n    // TODO: check the return again\r\n    regexValidator(regex: RegExp, error: ValidationErrors): any {\r\n        return (control: AbstractControl): { [key: string]: boolean } => {\r\n            const valid = regex.test(control.value);\r\n            return (valid ? null : error) as any;\r\n        };\r\n    }\r\n}\r\n","<form [formGroup]=\"passwordForm\">\r\n    <div\r\n        id=\"alert-div\"\r\n        *ngIf=\"passwordNotMatching\"\r\n    >\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\r\n                        class=\"material-icons\"\r\n                        *ngIf=\"passwordForm.get('password')?.hasError('minLength')\"\r\n                    >\r\n                        cancel\r\n                    </span>\r\n                    <span\r\n                        class=\"material-icons\"\r\n                        *ngIf=\"!passwordForm.get('password')?.hasError('minLength')\"\r\n                    >\r\n                        check_circle\r\n                    </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\r\n                        class=\"material-icons\"\r\n                        *ngIf=\"passwordForm.get('password')?.hasError('uppercase')\"\r\n                    >\r\n                        cancel\r\n                    </span>\r\n                    <span\r\n                        class=\"material-icons\"\r\n                        *ngIf=\"!passwordForm.get('password')?.hasError('uppercase')\"\r\n                    >\r\n                        check_circle\r\n                    </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\r\n                        class=\"material-icons\"\r\n                        *ngIf=\"passwordForm.get('password')?.hasError('lowercase')\"\r\n                    >\r\n                        cancel\r\n                    </span>\r\n                    <span\r\n                        class=\"material-icons\"\r\n                        *ngIf=\"!passwordForm.get('password')?.hasError('lowercase')\"\r\n                    >\r\n                        check_circle\r\n                    </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\r\n                        class=\"material-icons\"\r\n                        *ngIf=\"passwordForm.get('password')?.hasError('number')\"\r\n                    >\r\n                        cancel\r\n                    </span>\r\n                    <span\r\n                        class=\"material-icons\"\r\n                        *ngIf=\"!passwordForm.get('password')?.hasError('number')\"\r\n                    >\r\n                        check_circle\r\n                    </span>\r\n                </div>\r\n                <span class=\"span-text\">{{ constants.oneNumber }}</span>\r\n            </div>\r\n\r\n            <div\r\n                [ngClass]=\"passwordForm.get('password')?.hasError('specialCharacter') ? 'error-color' : 'success-color'\"\r\n            >\r\n                <div id=\"icon-div-msg\">\r\n                    <span\r\n                        class=\"material-icons\"\r\n                        *ngIf=\"passwordForm.get('password')?.hasError('specialCharacter')\"\r\n                    >\r\n                        cancel\r\n                    </span>\r\n                    <span\r\n                        class=\"material-icons\"\r\n                        *ngIf=\"!passwordForm.get('password')?.hasError('specialCharacter')\"\r\n                    >\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"]}