@annalib/anna-cognito-lib 2.2.41 → 2.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/{esm2020 → esm2022}/annalib-anna-cognito-lib.mjs +4 -4
- package/{esm2020 → esm2022}/lib/anna-cognito-lib.module.mjs +91 -91
- package/{esm2020 → esm2022}/lib/components/anna-login/anna-login.component.mjs +55 -54
- package/{esm2020 → esm2022}/lib/components/cognito-and-sso-login-container/cognito-and-sso-login-container.component.mjs +22 -22
- package/{esm2020 → esm2022}/lib/components/forgot-password/forgot-password.component.mjs +123 -123
- package/{esm2020 → esm2022}/lib/components/password-matching/password-matching.component.mjs +90 -90
- package/{esm2020 → esm2022}/lib/components/powered-by-logo-template/powered-by-logo-template.component.mjs +15 -15
- package/{esm2020 → esm2022}/lib/components/set-new-password/set-new-password.component.mjs +63 -63
- package/{esm2020 → esm2022}/lib/components/sso-login/sso-login.component.mjs +32 -32
- package/{esm2020 → esm2022}/lib/components/surewaves-year-logo/surewaves-year-logo.component.mjs +15 -15
- package/{esm2020 → esm2022}/lib/components/verify-and-set-new-password/verify-and-set-new-password.component.mjs +78 -78
- package/{esm2020 → esm2022}/lib/components/version-and-term-policy/version-and-term-policy.component.mjs +20 -20
- package/{esm2020 → esm2022}/lib/config/acl-service.token.mjs +3 -3
- package/{esm2020 → esm2022}/lib/config/auth-service.token.mjs +3 -3
- package/{esm2020 → esm2022}/lib/config/config-service.token.mjs +3 -3
- package/{esm2020 → esm2022}/lib/config/sso-login-service.token.mjs +3 -3
- package/esm2022/lib/constants/loginConstant.mjs +55 -0
- package/{esm2020 → esm2022}/lib/directives/spinner-button/index.mjs +1 -1
- package/{esm2020 → esm2022}/lib/directives/spinner-button/spinner-button.directive.mjs +42 -42
- package/{esm2020 → esm2022}/lib/models/auth.model.mjs +23 -23
- package/{esm2020 → esm2022}/lib/services/acl.service.mjs +27 -27
- package/{esm2020 → esm2022}/lib/services/auth.service.mjs +306 -306
- package/{esm2020 → esm2022}/lib/services/config.service.mjs +20 -20
- package/{esm2020 → esm2022}/lib/services/sso-login.service.mjs +20 -20
- package/{esm2020 → esm2022}/public-api.mjs +28 -28
- package/{fesm2020 → fesm2022}/annalib-anna-cognito-lib.mjs +922 -921
- package/fesm2022/annalib-anna-cognito-lib.mjs.map +1 -0
- package/index.d.ts +5 -5
- package/lib/anna-cognito-lib.module.d.ts +21 -21
- package/lib/components/anna-login/anna-login.component.d.ts +20 -20
- package/lib/components/cognito-and-sso-login-container/cognito-and-sso-login-container.component.d.ts +10 -10
- package/lib/components/forgot-password/forgot-password.component.d.ts +42 -42
- package/lib/components/password-matching/password-matching.component.d.ts +22 -22
- package/lib/components/powered-by-logo-template/powered-by-logo-template.component.d.ts +8 -8
- package/lib/components/set-new-password/set-new-password.component.d.ts +28 -28
- package/lib/components/sso-login/sso-login.component.d.ts +14 -14
- package/lib/components/surewaves-year-logo/surewaves-year-logo.component.d.ts +9 -9
- package/lib/components/verify-and-set-new-password/verify-and-set-new-password.component.d.ts +32 -32
- package/lib/components/version-and-term-policy/version-and-term-policy.component.d.ts +10 -10
- package/lib/config/acl-service.token.d.ts +36 -36
- package/lib/config/auth-service.token.d.ts +23 -23
- package/lib/config/config-service.token.d.ts +13 -13
- package/lib/config/sso-login-service.token.d.ts +10 -10
- package/lib/constants/loginConstant.d.ts +49 -49
- package/lib/directives/spinner-button/index.d.ts +1 -1
- package/lib/directives/spinner-button/spinner-button.directive.d.ts +15 -15
- package/lib/models/auth.model.d.ts +21 -21
- package/lib/services/acl.service.d.ts +11 -11
- package/lib/services/auth.service.d.ts +47 -47
- package/lib/services/config.service.d.ts +8 -8
- package/lib/services/sso-login.service.d.ts +8 -8
- package/package.json +7 -13
- package/public-api.d.ts +21 -21
- package/esm2020/lib/constants/loginConstant.mjs +0 -55
- package/fesm2015/annalib-anna-cognito-lib.mjs +0 -1030
- package/fesm2015/annalib-anna-cognito-lib.mjs.map +0 -1
- package/fesm2020/annalib-anna-cognito-lib.mjs.map +0 -1
package/{esm2020 → esm2022}/lib/components/password-matching/password-matching.component.mjs
RENAMED
|
@@ -1,90 +1,90 @@
|
|
|
1
|
-
// Angular import statements
|
|
2
|
-
import { EventEmitter, Inject, Input, Output } from "@angular/core";
|
|
3
|
-
import { Component } from "@angular/core";
|
|
4
|
-
import { FormBuilder, Validators } from "@angular/forms";
|
|
5
|
-
// Third party import statements
|
|
6
|
-
import { debounceTime } from "rxjs/operators";
|
|
7
|
-
// User defined import statements
|
|
8
|
-
import { LoginConstant } from "../../constants/loginConstant";
|
|
9
|
-
import * as i0 from "@angular/core";
|
|
10
|
-
import * as i1 from "@angular/forms";
|
|
11
|
-
import * as i2 from "@angular/common";
|
|
12
|
-
export class PasswordMatchingComponent {
|
|
13
|
-
constructor(fb) {
|
|
14
|
-
this.fb = fb;
|
|
15
|
-
this.passwordChange = new EventEmitter();
|
|
16
|
-
this.confirmPasswordChange = new EventEmitter();
|
|
17
|
-
}
|
|
18
|
-
ngOnInit() {
|
|
19
|
-
this.constants = LoginConstant;
|
|
20
|
-
this.createGroup();
|
|
21
|
-
this.formValueChanged();
|
|
22
|
-
}
|
|
23
|
-
formValueChanged() {
|
|
24
|
-
const password = this.passwordForm.get("password");
|
|
25
|
-
const confirmPassword = this.passwordForm.get("confirmPassword");
|
|
26
|
-
password && password.valueChanges.subscribe(() => {
|
|
27
|
-
password && password.setValidators([
|
|
28
|
-
Validators.required,
|
|
29
|
-
this.regexValidator(new RegExp(".{8,}"), { minLength: true }),
|
|
30
|
-
this.regexValidator(new RegExp("[a-z]"), { lowercase: true }),
|
|
31
|
-
this.regexValidator(new RegExp("[A-Z]"), { uppercase: true }),
|
|
32
|
-
this.regexValidator(new RegExp("[0-9]"), { number: true }),
|
|
33
|
-
this.regexValidator(new RegExp("[^a-zA-Z0-9]"), { specialCharacter: true }),
|
|
34
|
-
]);
|
|
35
|
-
password.updateValueAndValidity({ emitEvent: false });
|
|
36
|
-
this.onPasswordChange();
|
|
37
|
-
});
|
|
38
|
-
if (confirmPassword) {
|
|
39
|
-
confirmPassword.valueChanges.pipe(debounceTime(300)).subscribe(() => {
|
|
40
|
-
confirmPassword.setValidators([Validators.required]);
|
|
41
|
-
confirmPassword.updateValueAndValidity({ emitEvent: false });
|
|
42
|
-
this.onConfirmPasswordChange();
|
|
43
|
-
});
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
onPasswordChange() {
|
|
47
|
-
let result = {
|
|
48
|
-
value: this.passwordForm.value.password,
|
|
49
|
-
status: this.passwordForm.controls['password'].status,
|
|
50
|
-
};
|
|
51
|
-
this.passwordChange.emit(result);
|
|
52
|
-
}
|
|
53
|
-
onConfirmPasswordChange() {
|
|
54
|
-
let result = {
|
|
55
|
-
value: this.passwordForm.value.confirmPassword,
|
|
56
|
-
status: this.passwordForm.controls['confirmPassword'].status,
|
|
57
|
-
};
|
|
58
|
-
this.confirmPasswordChange.emit(result);
|
|
59
|
-
}
|
|
60
|
-
createGroup() {
|
|
61
|
-
this.passwordForm = this.fb.group({
|
|
62
|
-
password: [null],
|
|
63
|
-
confirmPassword: [null],
|
|
64
|
-
});
|
|
65
|
-
return this.passwordForm;
|
|
66
|
-
}
|
|
67
|
-
// TODO: check the return again
|
|
68
|
-
regexValidator(regex, error) {
|
|
69
|
-
return (control) => {
|
|
70
|
-
const valid = regex.test(control.value);
|
|
71
|
-
return (valid ? null : error);
|
|
72
|
-
};
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
78
|
-
type: Component,
|
|
79
|
-
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"] }]
|
|
80
|
-
}], ctorParameters: function () { return [{ type: i1.FormBuilder, decorators: [{
|
|
81
|
-
type: Inject,
|
|
82
|
-
args: [FormBuilder]
|
|
83
|
-
}] }]; }, propDecorators: { passwordChange: [{
|
|
84
|
-
type: Output
|
|
85
|
-
}], confirmPasswordChange: [{
|
|
86
|
-
type: Output
|
|
87
|
-
}], passwordNotMatching: [{
|
|
88
|
-
type: Input
|
|
89
|
-
}] } });
|
|
90
|
-
//# 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 { AbstractControl, FormBuilder, FormGroup, ValidationErrors, ValidatorFn, Validators } 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\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})\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 && password.valueChanges.subscribe(() => {\r\n        password && 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\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 {\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}\r\n","<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"]}
|
|
1
|
+
// Angular import statements
|
|
2
|
+
import { EventEmitter, Inject, Input, Output } from "@angular/core";
|
|
3
|
+
import { Component } from "@angular/core";
|
|
4
|
+
import { FormBuilder, Validators } from "@angular/forms";
|
|
5
|
+
// Third party import statements
|
|
6
|
+
import { debounceTime } from "rxjs/operators";
|
|
7
|
+
// User defined import statements
|
|
8
|
+
import { LoginConstant } from "../../constants/loginConstant";
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
import * as i1 from "@angular/forms";
|
|
11
|
+
import * as i2 from "@angular/common";
|
|
12
|
+
export class PasswordMatchingComponent {
|
|
13
|
+
constructor(fb) {
|
|
14
|
+
this.fb = fb;
|
|
15
|
+
this.passwordChange = new EventEmitter();
|
|
16
|
+
this.confirmPasswordChange = new EventEmitter();
|
|
17
|
+
}
|
|
18
|
+
ngOnInit() {
|
|
19
|
+
this.constants = LoginConstant;
|
|
20
|
+
this.createGroup();
|
|
21
|
+
this.formValueChanged();
|
|
22
|
+
}
|
|
23
|
+
formValueChanged() {
|
|
24
|
+
const password = this.passwordForm.get("password");
|
|
25
|
+
const confirmPassword = this.passwordForm.get("confirmPassword");
|
|
26
|
+
password && password.valueChanges.subscribe(() => {
|
|
27
|
+
password && password.setValidators([
|
|
28
|
+
Validators.required,
|
|
29
|
+
this.regexValidator(new RegExp(".{8,}"), { minLength: true }),
|
|
30
|
+
this.regexValidator(new RegExp("[a-z]"), { lowercase: true }),
|
|
31
|
+
this.regexValidator(new RegExp("[A-Z]"), { uppercase: true }),
|
|
32
|
+
this.regexValidator(new RegExp("[0-9]"), { number: true }),
|
|
33
|
+
this.regexValidator(new RegExp("[^a-zA-Z0-9]"), { specialCharacter: true }),
|
|
34
|
+
]);
|
|
35
|
+
password.updateValueAndValidity({ emitEvent: false });
|
|
36
|
+
this.onPasswordChange();
|
|
37
|
+
});
|
|
38
|
+
if (confirmPassword) {
|
|
39
|
+
confirmPassword.valueChanges.pipe(debounceTime(300)).subscribe(() => {
|
|
40
|
+
confirmPassword.setValidators([Validators.required]);
|
|
41
|
+
confirmPassword.updateValueAndValidity({ emitEvent: false });
|
|
42
|
+
this.onConfirmPasswordChange();
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
onPasswordChange() {
|
|
47
|
+
let result = {
|
|
48
|
+
value: this.passwordForm.value.password,
|
|
49
|
+
status: this.passwordForm.controls['password'].status,
|
|
50
|
+
};
|
|
51
|
+
this.passwordChange.emit(result);
|
|
52
|
+
}
|
|
53
|
+
onConfirmPasswordChange() {
|
|
54
|
+
let result = {
|
|
55
|
+
value: this.passwordForm.value.confirmPassword,
|
|
56
|
+
status: this.passwordForm.controls['confirmPassword'].status,
|
|
57
|
+
};
|
|
58
|
+
this.confirmPasswordChange.emit(result);
|
|
59
|
+
}
|
|
60
|
+
createGroup() {
|
|
61
|
+
this.passwordForm = this.fb.group({
|
|
62
|
+
password: [null],
|
|
63
|
+
confirmPassword: [null],
|
|
64
|
+
});
|
|
65
|
+
return this.passwordForm;
|
|
66
|
+
}
|
|
67
|
+
// TODO: check the return again
|
|
68
|
+
regexValidator(regex, error) {
|
|
69
|
+
return (control) => {
|
|
70
|
+
const valid = regex.test(control.value);
|
|
71
|
+
return (valid ? null : error);
|
|
72
|
+
};
|
|
73
|
+
}
|
|
74
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: PasswordMatchingComponent, deps: [{ token: FormBuilder }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
75
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", 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"], dependencies: [{ kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
|
|
76
|
+
}
|
|
77
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: PasswordMatchingComponent, decorators: [{
|
|
78
|
+
type: Component,
|
|
79
|
+
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"] }]
|
|
80
|
+
}], ctorParameters: function () { return [{ type: i1.FormBuilder, decorators: [{
|
|
81
|
+
type: Inject,
|
|
82
|
+
args: [FormBuilder]
|
|
83
|
+
}] }]; }, propDecorators: { passwordChange: [{
|
|
84
|
+
type: Output
|
|
85
|
+
}], confirmPasswordChange: [{
|
|
86
|
+
type: Output
|
|
87
|
+
}], passwordNotMatching: [{
|
|
88
|
+
type: Input
|
|
89
|
+
}] } });
|
|
90
|
+
//# 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 { AbstractControl, FormBuilder, FormGroup, ValidationErrors, ValidatorFn, Validators } 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\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})\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 && password.valueChanges.subscribe(() => {\r\n        password && 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\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 {\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}\r\n","<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"]}
|