@trudb/tru-common-lib 0.1.457 → 0.1.458

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.
@@ -75,6 +75,10 @@ export class TruPasswordDialog {
75
75
  passwordChangeRequest.userRef = this.data.userRef;
76
76
  passwordChangeRequest.admin = this.admin;
77
77
  if (this.userRef < 0) {
78
+ this.data.entity.Password = this.newPasswordControl.value;
79
+ this.dialogRef.close(true);
80
+ }
81
+ else {
78
82
  this.busy = true;
79
83
  this.http
80
84
  .post(`${this.baseUrl}${TRU_AUTH_CONFIG.authUrl}/changePassword`, passwordChangeRequest)
@@ -87,10 +91,6 @@ export class TruPasswordDialog {
87
91
  this.errorMsg = ex.error;
88
92
  });
89
93
  }
90
- else {
91
- this.data.entity.Password = this.newPasswordControl.value;
92
- this.dialogRef.close(true);
93
- }
94
94
  };
95
95
  onDismiss = () => {
96
96
  this.dialogRef.close(false);
@@ -118,4 +118,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
118
118
  type: Inject,
119
119
  args: [MAT_DIALOG_DATA]
120
120
  }] }] });
121
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tru-password-dialog.js","sourceRoot":"","sources":["../../../../../../projects/tru-common-lib/src/lib/components/password-dialog/tru-password-dialog.ts","../../../../../../projects/tru-common-lib/src/lib/components/password-dialog/tru-password-dialog.html"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\r\nimport { Component, Inject, OnInit } from '@angular/core';\r\nimport { FormControl } from '@angular/forms';\r\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\r\nimport { Subscription } from 'rxjs';\r\nimport { TruAppEnvironment } from '../../services/tru-app-environment';\r\nimport { TruUiNotification } from '../../services/tru-ui-notification';\r\nimport { TRU_AUTH_CONFIG } from \"../login/classes/tru-auth-config\";\r\nimport { TruPasswordChangeRequest } from './classes/tru-password-change-request';\r\n\r\n@Component({\r\n  selector: 'tru-password-dialog',\r\n  templateUrl: './tru-password-dialog.html',\r\n  styleUrls: ['../../assets/tru-style.css', './tru-password-dialog.css']\r\n})\r\nexport class TruPasswordDialog implements OnInit {\r\n  currentPasswordControl: FormControl = new FormControl<string | null | undefined>('', []);\r\n  newPasswordControl: FormControl = new FormControl<string | null | undefined>('', []);\r\n  confirmNewPasswordControl: FormControl = new FormControl<string | null | undefined>('', []);\r\n  showPasswordControl: FormControl = new FormControl<boolean>(false, []);\r\n\r\n  title: string | null = null;\r\n  userRef: number  = 0;\r\n  username: string | null = null;\r\n  admin: boolean = false;\r\n  message: string | null = null;\r\n  showPassword: boolean = false;\r\n  passwordScore: number | null = 0;\r\n  errorMsg: string | null = null;\r\n  busy: boolean = false;\r\n\r\n  private baseUrl: string = '';\r\n  private subs: Array<Subscription> = [];\r\n\r\n  constructor(\r\n    public dialogRef: MatDialogRef<TruPasswordDialog>,\r\n    private http: HttpClient,\r\n    private appEnvironment: TruAppEnvironment,\r\n    private uiNotification: TruUiNotification,\r\n    @Inject(MAT_DIALOG_DATA) private data: any) {\r\n    this.baseUrl = this.appEnvironment.appUri;\r\n  }\r\n\r\n  onPasswordStrengthChanged = (score: number | null) => {\r\n    this.passwordScore = score;\r\n  }\r\n\r\n  onShowPasswordClicked = () => {\r\n    this.showPassword = this.showPasswordControl.value;\r\n  }\r\n\r\n  canSubmit = () => {\r\n    let canSubmit = false;\r\n    if (this.admin) {\r\n      canSubmit =\r\n        this.newPasswordControl.value &&\r\n        this.confirmNewPasswordControl.value &&\r\n        this.passwordScore !== null && this.passwordScore > 1 &&\r\n        (this.newPasswordControl.value === this.confirmNewPasswordControl.value);\r\n    } else {\r\n      canSubmit = this.currentPasswordControl.value &&\r\n        this.newPasswordControl.value &&\r\n        this.confirmNewPasswordControl.value &&\r\n        this.passwordScore !== null && this.passwordScore > 1 &&\r\n        (this.newPasswordControl.value === this.confirmNewPasswordControl.value);\r\n    }\r\n    return canSubmit;\r\n  }\r\n\r\n  onConfirm = (): void => {\r\n    let passwordChangeRequest = new TruPasswordChangeRequest();\r\n    passwordChangeRequest.currentPassword = this.currentPasswordControl.value;\r\n    passwordChangeRequest.newPassword = this.newPasswordControl.value;\r\n    passwordChangeRequest.userRef = this.data.userRef;\r\n    passwordChangeRequest.admin = this.admin;\r\n\r\n    if (this.userRef < 0) {\r\n      this.busy = true;\r\n      this.http\r\n        .post<any>(`${this.baseUrl}${TRU_AUTH_CONFIG.authUrl}/changePassword`, passwordChangeRequest)\r\n        .subscribe(() => {\r\n          this.busy = false;\r\n          this.uiNotification.success('Password update complete.')\r\n          this.dialogRef.close(true);\r\n        }, (ex: any) => {\r\n          this.busy = false;\r\n          this.errorMsg = ex.error;\r\n        });\r\n    } else {\r\n      this.data.entity.Password = this.newPasswordControl.value;\r\n      this.dialogRef.close(true);\r\n    }\r\n  }\r\n\r\n  onDismiss = (): void => {\r\n    this.dialogRef.close(false);\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.subs.push(this.currentPasswordControl.valueChanges.subscribe(() => {\r\n      this.errorMsg = null;\r\n    }));\r\n    this.userRef = this.data.userRef;\r\n    this.username = this.data.username;\r\n    this.admin = this.data.admin;\r\n \r\n    this.title = this.userRef < 0 ? 'Create Password' : 'Update Password';\r\n    this.username = this.userRef < 0 ? 'new user' : this.username;\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subs.forEach(s => s.unsubscribe());\r\n  }\r\n}\r\n\r\n","<div mat-dialog-title class=\"mat-dialog-title\">\r\n  <p class=\"tru-password-dialog-title\">{{title}}</p>\r\n  <p class=\"tru-password-dialog-username\">for {{username}}</p>\r\n</div>\r\n\r\n<div mat-dialog-content class=\"mat-dialog-content tru-control-container tru-password-dialog\">\r\n  <p>{{message}}</p>\r\n\r\n  <div class=\"tru-password-dialog-control-wrapper\" *ngIf=\"!admin\">\r\n    <mat-label>Current Password</mat-label>\r\n    <mat-form-field>\r\n      <input #currentInput\r\n             matInput\r\n             autocomplete=\"off webauthn\"\r\n             [formControl]=\"currentPasswordControl\"\r\n             [type]=\"showPassword ? 'text' : 'password'\" />\r\n    </mat-form-field>\r\n    <p class=\"tru-password-dialog-error-msg\" *ngIf=\"errorMsg\">{{errorMsg}}</p>\r\n  </div>\r\n  <div class=\"tru-password-dialog-control-wrapper\">\r\n    <mat-label>New Password</mat-label>\r\n    <mat-form-field>\r\n      <input #newInput\r\n             matInput\r\n             autocomplete=\"off webauthn\"\r\n             [formControl]=\"newPasswordControl\"\r\n             [type]=\"showPassword ? 'text' : 'password'\" />\r\n    </mat-form-field>\r\n    <password-strength-meter [password]=\"newPasswordControl.value\" (strengthChange)=\"onPasswordStrengthChanged($event)\" />\r\n  </div>\r\n  <div class=\"tru-password-dialog-control-wrapper\">\r\n    <mat-label>Confirm New Password</mat-label>\r\n    <mat-form-field>\r\n      <input #confirmInput\r\n             matInput\r\n             autocomplete=\"off webauthn\"\r\n             [formControl]=\"confirmNewPasswordControl\"\r\n             [type]=\"showPassword ? 'text' : 'password'\" />\r\n    </mat-form-field>\r\n  </div>\r\n  <mat-checkbox [formControl]=\"showPasswordControl\"\r\n                (click)=\"onShowPasswordClicked()\"\r\n                [labelPosition]=\"'before'\">\r\n    Show Password\r\n  </mat-checkbox>\r\n</div>\r\n\r\n<div mat-dialog-actions class=\"mat-dialog-actions\">\r\n  <button mat-raised-button (click)=\"onDismiss()\">Cancel</button>\r\n  <button [disabled]=\"!canSubmit() || busy || errorMsg ? 'disabled' : null\" mat-raised-button color=\"primary\" (click)=\"onConfirm()\">Submit</button>\r\n</div>\r\n"]}
121
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tru-password-dialog.js","sourceRoot":"","sources":["../../../../../../projects/tru-common-lib/src/lib/components/password-dialog/tru-password-dialog.ts","../../../../../../projects/tru-common-lib/src/lib/components/password-dialog/tru-password-dialog.html"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\r\nimport { Component, Inject, OnInit } from '@angular/core';\r\nimport { FormControl } from '@angular/forms';\r\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\r\nimport { Subscription } from 'rxjs';\r\nimport { TruAppEnvironment } from '../../services/tru-app-environment';\r\nimport { TruUiNotification } from '../../services/tru-ui-notification';\r\nimport { TRU_AUTH_CONFIG } from \"../login/classes/tru-auth-config\";\r\nimport { TruPasswordChangeRequest } from './classes/tru-password-change-request';\r\n\r\n@Component({\r\n  selector: 'tru-password-dialog',\r\n  templateUrl: './tru-password-dialog.html',\r\n  styleUrls: ['../../assets/tru-style.css', './tru-password-dialog.css']\r\n})\r\nexport class TruPasswordDialog implements OnInit {\r\n  currentPasswordControl: FormControl = new FormControl<string | null | undefined>('', []);\r\n  newPasswordControl: FormControl = new FormControl<string | null | undefined>('', []);\r\n  confirmNewPasswordControl: FormControl = new FormControl<string | null | undefined>('', []);\r\n  showPasswordControl: FormControl = new FormControl<boolean>(false, []);\r\n\r\n  title: string | null = null;\r\n  userRef: number  = 0;\r\n  username: string | null = null;\r\n  admin: boolean = false;\r\n  message: string | null = null;\r\n  showPassword: boolean = false;\r\n  passwordScore: number | null = 0;\r\n  errorMsg: string | null = null;\r\n  busy: boolean = false;\r\n\r\n  private baseUrl: string = '';\r\n  private subs: Array<Subscription> = [];\r\n\r\n  constructor(\r\n    public dialogRef: MatDialogRef<TruPasswordDialog>,\r\n    private http: HttpClient,\r\n    private appEnvironment: TruAppEnvironment,\r\n    private uiNotification: TruUiNotification,\r\n    @Inject(MAT_DIALOG_DATA) private data: any) {\r\n    this.baseUrl = this.appEnvironment.appUri;\r\n  }\r\n\r\n  onPasswordStrengthChanged = (score: number | null) => {\r\n    this.passwordScore = score;\r\n  }\r\n\r\n  onShowPasswordClicked = () => {\r\n    this.showPassword = this.showPasswordControl.value;\r\n  }\r\n\r\n  canSubmit = () => {\r\n    let canSubmit = false;\r\n    if (this.admin) {\r\n      canSubmit =\r\n        this.newPasswordControl.value &&\r\n        this.confirmNewPasswordControl.value &&\r\n        this.passwordScore !== null && this.passwordScore > 1 &&\r\n        (this.newPasswordControl.value === this.confirmNewPasswordControl.value);\r\n    } else {\r\n      canSubmit = this.currentPasswordControl.value &&\r\n        this.newPasswordControl.value &&\r\n        this.confirmNewPasswordControl.value &&\r\n        this.passwordScore !== null && this.passwordScore > 1 &&\r\n        (this.newPasswordControl.value === this.confirmNewPasswordControl.value);\r\n    }\r\n    return canSubmit;\r\n  }\r\n\r\n  onConfirm = (): void => {\r\n    let passwordChangeRequest = new TruPasswordChangeRequest();\r\n    passwordChangeRequest.currentPassword = this.currentPasswordControl.value;\r\n    passwordChangeRequest.newPassword = this.newPasswordControl.value;\r\n    passwordChangeRequest.userRef = this.data.userRef;\r\n    passwordChangeRequest.admin = this.admin;\r\n\r\n    if (this.userRef < 0) {\r\n      this.data.entity.Password = this.newPasswordControl.value;\r\n      this.dialogRef.close(true);\r\n    } else {\r\n      this.busy = true;\r\n      this.http\r\n        .post<any>(`${this.baseUrl}${TRU_AUTH_CONFIG.authUrl}/changePassword`, passwordChangeRequest)\r\n        .subscribe(() => {\r\n          this.busy = false;\r\n          this.uiNotification.success('Password update complete.')\r\n          this.dialogRef.close(true);\r\n        }, (ex: any) => {\r\n          this.busy = false;\r\n          this.errorMsg = ex.error;\r\n        });\r\n    }\r\n  }\r\n\r\n  onDismiss = (): void => {\r\n    this.dialogRef.close(false);\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.subs.push(this.currentPasswordControl.valueChanges.subscribe(() => {\r\n      this.errorMsg = null;\r\n    }));\r\n    this.userRef = this.data.userRef;\r\n    this.username = this.data.username;\r\n    this.admin = this.data.admin;\r\n \r\n    this.title = this.userRef < 0 ? 'Create Password' : 'Update Password';\r\n    this.username = this.userRef < 0 ? 'new user' : this.username;\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subs.forEach(s => s.unsubscribe());\r\n  }\r\n}\r\n\r\n","<div mat-dialog-title class=\"mat-dialog-title\">\r\n  <p class=\"tru-password-dialog-title\">{{title}}</p>\r\n  <p class=\"tru-password-dialog-username\">for {{username}}</p>\r\n</div>\r\n\r\n<div mat-dialog-content class=\"mat-dialog-content tru-control-container tru-password-dialog\">\r\n  <p>{{message}}</p>\r\n\r\n  <div class=\"tru-password-dialog-control-wrapper\" *ngIf=\"!admin\">\r\n    <mat-label>Current Password</mat-label>\r\n    <mat-form-field>\r\n      <input #currentInput\r\n             matInput\r\n             autocomplete=\"off webauthn\"\r\n             [formControl]=\"currentPasswordControl\"\r\n             [type]=\"showPassword ? 'text' : 'password'\" />\r\n    </mat-form-field>\r\n    <p class=\"tru-password-dialog-error-msg\" *ngIf=\"errorMsg\">{{errorMsg}}</p>\r\n  </div>\r\n  <div class=\"tru-password-dialog-control-wrapper\">\r\n    <mat-label>New Password</mat-label>\r\n    <mat-form-field>\r\n      <input #newInput\r\n             matInput\r\n             autocomplete=\"off webauthn\"\r\n             [formControl]=\"newPasswordControl\"\r\n             [type]=\"showPassword ? 'text' : 'password'\" />\r\n    </mat-form-field>\r\n    <password-strength-meter [password]=\"newPasswordControl.value\" (strengthChange)=\"onPasswordStrengthChanged($event)\" />\r\n  </div>\r\n  <div class=\"tru-password-dialog-control-wrapper\">\r\n    <mat-label>Confirm New Password</mat-label>\r\n    <mat-form-field>\r\n      <input #confirmInput\r\n             matInput\r\n             autocomplete=\"off webauthn\"\r\n             [formControl]=\"confirmNewPasswordControl\"\r\n             [type]=\"showPassword ? 'text' : 'password'\" />\r\n    </mat-form-field>\r\n  </div>\r\n  <mat-checkbox [formControl]=\"showPasswordControl\"\r\n                (click)=\"onShowPasswordClicked()\"\r\n                [labelPosition]=\"'before'\">\r\n    Show Password\r\n  </mat-checkbox>\r\n</div>\r\n\r\n<div mat-dialog-actions class=\"mat-dialog-actions\">\r\n  <button mat-raised-button (click)=\"onDismiss()\">Cancel</button>\r\n  <button [disabled]=\"!canSubmit() || busy || errorMsg ? 'disabled' : null\" mat-raised-button color=\"primary\" (click)=\"onConfirm()\">Submit</button>\r\n</div>\r\n"]}
@@ -773,6 +773,10 @@ class TruPasswordDialog {
773
773
  passwordChangeRequest.userRef = this.data.userRef;
774
774
  passwordChangeRequest.admin = this.admin;
775
775
  if (this.userRef < 0) {
776
+ this.data.entity.Password = this.newPasswordControl.value;
777
+ this.dialogRef.close(true);
778
+ }
779
+ else {
776
780
  this.busy = true;
777
781
  this.http
778
782
  .post(`${this.baseUrl}${TRU_AUTH_CONFIG.authUrl}/changePassword`, passwordChangeRequest)
@@ -785,10 +789,6 @@ class TruPasswordDialog {
785
789
  this.errorMsg = ex.error;
786
790
  });
787
791
  }
788
- else {
789
- this.data.entity.Password = this.newPasswordControl.value;
790
- this.dialogRef.close(true);
791
- }
792
792
  };
793
793
  onDismiss = () => {
794
794
  this.dialogRef.close(false);