@tuki-io/tuki-widgets 0.0.20 → 0.0.23

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.
@@ -26,11 +26,12 @@ export class UserService {
26
26
  return this.apiService.fetch(API.USER_TOKEN.replace(':siteId', String(this.siteId)).replace(':userId', encodeURIComponent(encodeURIComponent(userId))))
27
27
  .pipe(map((result) => {
28
28
  this.setSimplifiedUser(Object.values(result)[0]);
29
+ this.user.token = Object.keys(result)[0];
29
30
  }));
30
31
  // .pipe(this.handleError(false, true));
31
32
  }
32
33
  updateUserFields(body) {
33
- if (!this.userId || !this.siteId || !this.user?.token) {
34
+ if (!this.siteId) {
34
35
  return;
35
36
  }
36
37
  return this.apiService.post(API.UPDATE_USER_FIELDS.replace(':siteId', String(this.siteId)).replace(':token', this.user.token), body);
@@ -105,4 +106,4 @@ UserService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version:
105
106
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: UserService, decorators: [{
106
107
  type: Injectable
107
108
  }], ctorParameters: function () { return [{ type: i1.APIService }]; } });
108
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user.service.js","sourceRoot":"","sources":["../../../../../../../projects/tuki/widgets/user-manage/src/services/user.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable, OnInit} from '@angular/core';\nimport { Observable, of, forkJoin } from 'rxjs';\nimport { SimplifiedUser } from '../classes/simplified-user';\nimport { API } from '../app.constants';\nimport { APIService } from './api.service';\nimport { map } from 'rxjs/operators';\nimport { UtilsService } from './utils.service';\n\n@Injectable()\nexport class UserService implements OnInit{\n  siteId: number = -1;\n  userId: string = '';\n  userIdExistPending = false;\n  hasExistedUserId = false;\n  user!: SimplifiedUser;\n  originUser!: SimplifiedUser;\n\n  constructor(\n    private apiService: APIService\n  ) {\n\n  }\n\n  ngOnInit(): void {\n    console.log(this.siteId)\n  }\n\n  public fetchUserToken(siteId: number, userId: string): any {\n    if (this.siteId === siteId && this.userId === userId && this.user) {\n      return of(this.user);\n    }\n    this.siteId = siteId;\n    this.userId = userId;\n    return this.apiService.fetch(API.USER_TOKEN.replace(':siteId', String(this.siteId)).replace(':userId', encodeURIComponent(encodeURIComponent(userId))))\n      .pipe(map((result: any) => {\n        this.setSimplifiedUser(Object.values(result)[0]);\n      }))\n    // .pipe(this.handleError(false, true));\n  }\n\n  public updateUserFields(body: any): any {\n    if (!this.userId || !this.siteId || !this.user?.token) {\n      return;\n    }\n    return this.apiService.post(API.UPDATE_USER_FIELDS.replace(':siteId', String(this.siteId)).replace(':token', this.user.token), body)\n      // .pipe(this.handleError(false, true));\n  }\n\n  public fetchUserById(id: string) {\n    this.userIdExistPending = true;\n    return this.apiService.fetch(API.USER_BY_ID.replace(':siteId', String(this.siteId)).replace(':userId', encodeURIComponent(encodeURIComponent(id))))\n      .pipe(map(result => {\n        this.userIdExistPending = false;\n        return result;\n      }));\n  }\n\n  public persistCacheChanges() {\n    const params = {\n      excludeDeviceExtraOptions: true\n    };\n    return this.processUserChangesToCache()\n      .pipe(map((result: any) => {\n        return this.apiService.post(API.PERSIST_USER_CACHE.replace(':siteId', String(this.siteId)).replace(':token', this.user.token), {}, params)\n          .subscribe(() => {\n\n          })\n          // .pipe(map((user) => {\n          //   // this.setUser(user, false, this.user.token);\n          //   this.user.hasModifiedCache = false;\n          // }))\n          // .pipe(this.handleError(true, true));\n      }));\n  }\n\n  public processUserChangesToCache(): any {\n    const calls = [];\n    const body = UtilsService.diff(this.originUser.getSavableData(), this.user.getSavableData(), 'user');\n    if (body) {\n      calls.push(this.updateUserFields(body));\n    }\n    if (!calls?.length) {\n      return of(this.user);\n    }\n\n    return forkJoin(calls)\n      .pipe(map((responses: any) => {\n        // ApiUserResponse\n        this.handleSaveUserResponse(responses);\n      }))\n      // .pipe(this.handleError(false, true));\n\n  }\n\n  public hasUnsavedChanges() {\n    if (this.user && this.originUser) {\n      return !this.user.equal(this.originUser);\n    }\n    return false;\n  }\n\n  public setSimplifiedUser(user: any): void {\n    this.user = new SimplifiedUser(user);\n    const copiedUser = JSON.parse(JSON.stringify(user));\n    this.originUser = new SimplifiedUser(copiedUser);\n  }\n\n  private handleSaveUserResponse(responses: any) {\n    if (!responses?.length) {\n      return;\n    }\n    for (let len = responses.length, i = len - 1; i >= 0; i--) {\n      if (responses[i] && responses[i].currentUpdatedUser) {\n        // this.setUser(responses[i].currentUpdatedUser, false, this.user.token);\n        this.user.hasModifiedCache = true;\n        return;\n      }\n    }\n  }\n}\n"]}
109
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user.service.js","sourceRoot":"","sources":["../../../../../../../projects/tuki/widgets/user-manage/src/services/user.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable, OnInit} from '@angular/core';\nimport { Observable, of, forkJoin } from 'rxjs';\nimport { SimplifiedUser } from '../classes/simplified-user';\nimport { API } from '../app.constants';\nimport { APIService } from './api.service';\nimport { map } from 'rxjs/operators';\nimport { UtilsService } from './utils.service';\n\n@Injectable()\nexport class UserService implements OnInit{\n  siteId: number = -1;\n  userId: string = '';\n  userIdExistPending = false;\n  hasExistedUserId = false;\n  user!: SimplifiedUser;\n  originUser!: SimplifiedUser;\n\n  constructor(\n    private apiService: APIService\n  ) {\n\n  }\n\n  ngOnInit(): void {\n    console.log(this.siteId)\n  }\n\n  public fetchUserToken(siteId: number, userId: string): any {\n    if (this.siteId === siteId && this.userId === userId && this.user) {\n      return of(this.user);\n    }\n    this.siteId = siteId;\n    this.userId = userId;\n    return this.apiService.fetch(API.USER_TOKEN.replace(':siteId', String(this.siteId)).replace(':userId', encodeURIComponent(encodeURIComponent(userId))))\n      .pipe(map((result: any) => {\n        this.setSimplifiedUser(Object.values(result)[0]);\n        this.user.token = Object.keys(result)[0];\n      }))\n    // .pipe(this.handleError(false, true));\n  }\n\n  public updateUserFields(body: any): any {\n    if (!this.siteId ) {\n      return;\n    }\n    return this.apiService.post(API.UPDATE_USER_FIELDS.replace(':siteId', String(this.siteId)).replace(':token', this.user.token), body)\n      // .pipe(this.handleError(false, true));\n  }\n\n  public fetchUserById(id: string) {\n    this.userIdExistPending = true;\n    return this.apiService.fetch(API.USER_BY_ID.replace(':siteId', String(this.siteId)).replace(':userId', encodeURIComponent(encodeURIComponent(id))))\n      .pipe(map(result => {\n        this.userIdExistPending = false;\n        return result;\n      }));\n  }\n\n  public persistCacheChanges() {\n    const params = {\n      excludeDeviceExtraOptions: true\n    };\n    return this.processUserChangesToCache()\n      .pipe(map((result: any) => {\n        return this.apiService.post(API.PERSIST_USER_CACHE.replace(':siteId', String(this.siteId)).replace(':token', this.user.token), {}, params)\n          .subscribe(() => {\n\n          })\n          // .pipe(map((user) => {\n          //   // this.setUser(user, false, this.user.token);\n          //   this.user.hasModifiedCache = false;\n          // }))\n          // .pipe(this.handleError(true, true));\n      }));\n  }\n\n  public processUserChangesToCache(): any {\n    const calls = [];\n    const body = UtilsService.diff(this.originUser.getSavableData(), this.user.getSavableData(), 'user');\n    if (body) {\n      calls.push(this.updateUserFields(body));\n    }\n    if (!calls?.length) {\n      return of(this.user);\n    }\n\n    return forkJoin(calls)\n      .pipe(map((responses: any) => {\n        // ApiUserResponse\n        this.handleSaveUserResponse(responses);\n      }))\n      // .pipe(this.handleError(false, true));\n\n  }\n\n  public hasUnsavedChanges() {\n    if (this.user && this.originUser) {\n      return !this.user.equal(this.originUser);\n    }\n    return false;\n  }\n\n  public setSimplifiedUser(user: any): void {\n    this.user = new SimplifiedUser(user);\n    const copiedUser = JSON.parse(JSON.stringify(user));\n    this.originUser = new SimplifiedUser(copiedUser);\n  }\n\n  private handleSaveUserResponse(responses: any) {\n    if (!responses?.length) {\n      return;\n    }\n    for (let len = responses.length, i = len - 1; i >= 0; i--) {\n      if (responses[i] && responses[i].currentUpdatedUser) {\n        // this.setUser(responses[i].currentUpdatedUser, false, this.user.token);\n        this.user.hasModifiedCache = true;\n        return;\n      }\n    }\n  }\n}\n"]}
@@ -53,13 +53,12 @@ export class UserManageWidgetComponent {
53
53
  this.validateUserId();
54
54
  }
55
55
  saveChanges() {
56
- this.onSave.next("start saving..");
57
56
  if (!this.userService.hasUnsavedChanges() || this.form?.invalid) {
58
57
  return;
59
58
  }
60
59
  const subscription = this.userService.persistCacheChanges()
61
60
  .subscribe(() => {
62
- this.onSave.next("saved");
61
+ this.onSave.next("user has been saved successfully..");
63
62
  subscription.unsubscribe();
64
63
  });
65
64
  }
@@ -170,4 +169,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
170
169
  }], userId: [{
171
170
  type: Input
172
171
  }] } });
173
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-manage-widget.component.js","sourceRoot":"","sources":["../../../../../../projects/tuki/widgets/user-manage/src/user-manage-widget.component.ts","../../../../../../projects/tuki/widgets/user-manage/src/user-manage-widget.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { FormGroup, Validators } from '@angular/forms';\nimport { UserService } from './services/user.service';\nimport { APIService } from \"./services/api.service\";\nimport { SimplifiedUser } from './classes/simplified-user';\n\n@Component({\n  selector: 'app-user-manage-widget',\n  templateUrl: './user-manage-widget.component.html',\n  styleUrls: ['./user-manage-widget.component.scss'],\n})\nexport class UserManageWidgetComponent implements OnInit {\n\n  public dataPending!: boolean;\n\n  @Output() onSave = new EventEmitter<string>();\n  @Output() onChange = new EventEmitter<string>();\n  @Input() token!: string;\n  @Input() host!: string;\n  @Input() siteId!: number;\n  @Input() userId!: string;\n\n  get form(): FormGroup {\n    return this.userService?.user?.form;\n  }\n\n  public isLdap():boolean{\n    return this.user.ldapIntegrated;\n  }\n  get user(): SimplifiedUser {\n    return this.userService.user;\n  }\n\n  get userName(): string {\n    return `${this.user?.firstName || ''} ${this.user?.lastName || ''}`;\n  }\n\n\n  constructor(\n    public userService: UserService,\n    private apiService: APIService,\n  ) {\n  }\n\n  ngOnInit(): void {\n    this.apiService.token = this.token;\n    this.apiService.apiUrl = this.host;\n    this.getData();\n  }\n\n  public onChangeField(token: string): void {\n      this.onChange.next(\"start change..\");\n\n    if (!token) {\n      return;\n    }\n    (this.userService.user as any)[token] = this.form?.get(token)?.value;\n\n    if (token === 'middleName') {\n      this.form?.get(token)?.setValidators([Validators.pattern('[ a-zA-Z-]+')]);\n    }\n    if (token === 'telephoneNumber' || token === 'mobileNumber' ||  token === 'pagerNumber' || token === 'homeNumber') {\n      this.form?.get(token)?.setValidators([Validators.pattern('[ 0-9-+]+')]);\n    }\n    this.form?.get(token)?.updateValueAndValidity();\n    this.validateUserId();\n  }\n\n  public saveChanges(): void {\n    this.onSave.next(\"start saving..\");\n    if (!this.userService.hasUnsavedChanges() || this.form?.invalid) {\n      return;\n    }\n    const subscription = this.userService.persistCacheChanges()\n      .subscribe(() => {\n        this.onSave.next(\"saved\");\n        subscription.unsubscribe();\n      })\n  }\n\n  public toggleEditMode() {\n    this.userService.user.toggleEditMode();\n  }\n\n  public isSavingDisabled(): boolean {\n    return !this.userService.hasUnsavedChanges() || this.userService.hasExistedUserId;\n  }\n\n  public changeField(token: string): void {\n    this.onChange.next(\"start change..\");\n    const formField = this.user?.form?.get(token);\n    if (token !== 'confirmDigestCredentials') {\n      // @ts-ignore\n      this.user[token] = formField?.value;\n    }\n    if (token === 'digestCredentials' || token === 'confirmDigestCredentials') {\n      this.digestCredentialsHandler(token, formField);\n    }\n  }\n\n  private digestCredentialsHandler(token: string, field: any) {\n    const fieldNameToCompare = token === 'digestCredentials' ? 'confirmDigestCredentials' : 'digestCredentials';\n    const fieldToCompare = this.userService.user.form.get(fieldNameToCompare);\n    if (this.userService.user?.form?.get(token)) {\n      this.userService.user?.form?.get(token)?.setErrors(null);\n      this.userService.user?.form?.get(fieldNameToCompare)?.setErrors(null);\n\n     /* if (!field.value && !fieldToCompare.value) {\n        this.userService.user?.digestCredentials = null;\n        return;\n      }\n\n      if (!field.value && fieldToCompare.value || !fieldToCompare.value && field.value) {\n        const requiredFieldName = field.value ? fieldNameToCompare : token;\n        this.userService.user.form.get(requiredFieldName).setErrors({required: true});\n        return;\n      }\n      if (field.value && fieldToCompare.value && field.value !== fieldToCompare.value) {\n        this.userService.user.form.get(token).setErrors({mismatch: true});\n        this.userService.user.form.get(fieldNameToCompare).setErrors({mismatch: true});\n      }*/\n    }\n\n  }\n\n  private getData() {\n    this.dataPending = true;\n    this.userService.fetchUserToken(this.siteId, this.userId)\n      .subscribe({\n        complete: (v: any) => {\n          this.dataPending = false;\n        },\n        error: (e: any) => this.dataPending = false,\n      });\n  }\n\n  private setCookie(name: string, value: string, days: number) {\n    var expires = \"\";\n    if (days) {\n      var date = new Date();\n      date.setTime(date.getTime() + (days * 24 * 60 * 60 * 1000));\n      expires = \"; expires=\" + date.toUTCString();\n    }\n    document.cookie = name + \"=\" + (value || \"\") + expires + \"; path=/\";\n  }\n\n  private validateUserId() {\n    const idControl = this.form.get('userid');\n    if (idControl?.value !== '' && idControl?.value !== this.userService.originUser.userid) {\n      this.userService.fetchUserById(idControl?.value)\n        .subscribe(\n          (res: any) => {\n            this.userService.userIdExistPending = false;\n            idControl?.setErrors({exist: true});\n            if (this.form?.get('userid')?.hasError('exist')) {\n              this.userService.hasExistedUserId = true;\n            } else {\n              this.userService.hasExistedUserId = false;\n            }\n          },\n          ((error) => {\n            this.userService.userIdExistPending = false;\n            if (error.status !== 404) {\n              // this.notificationService.warning(this.translate.instant('APP_USER_MSG.CHECK_USER_ID_FAILED'));\n            } else {\n              this.userService.user.newUserId = this.form?.get('userid')?.value\n            }\n          }));\n    } else {\n      delete this.userService?.user?.newUserId;\n    }\n  }\n\n  public save() {\n    this.saveChanges()\n  }\n\n}\n","<div *ngIf=\"dataPending == false\">\n<div class=\"header-box\">\n  <div class=\"content-box\">\n    <div class=\"header-back-block\">\n      <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n        <path d=\"M5.70746 7.99987L11.3539 2.35352C11.4453 2.25928 11.496 2.13287 11.495 2.00159C11.494 1.8703 11.4414 1.74467 11.3486 1.65183C11.2558 1.55899 11.1301 1.50639 10.9988 1.50539C10.8676 1.50438 10.7411 1.55506 10.6469 1.64647L4.64691 7.64647C4.55316 7.74023 4.50049 7.8674 4.50049 7.99999C4.50049 8.13259 4.55316 8.25975 4.64691 8.35352L10.6469 14.3535C10.6931 14.4011 10.7482 14.439 10.8092 14.4651C10.8702 14.4912 10.9357 14.5049 11.002 14.5054C11.0683 14.5059 11.134 14.4932 11.1954 14.468C11.2567 14.4429 11.3125 14.4058 11.3593 14.3589C11.4062 14.312 11.4433 14.2563 11.4685 14.1949C11.4936 14.1336 11.5063 14.0679 11.5058 14.0016C11.5053 13.9353 11.4916 13.8697 11.4655 13.8088C11.4394 13.7478 11.4015 13.6926 11.3539 13.6465L5.70746 7.99987Z\" fill=\"black\" fill-opacity=\"0.95\"/>\n      </svg>\n      Users\n    </div>\n<!--    <div class=\"header-button-block\">-->\n<!--      <button mat-raised-button-->\n<!--              [disabled]=\"!userService.hasUnsavedChanges()\"-->\n<!--              (click)=\"saveChanges()\">Save</button>-->\n<!--    </div>-->\n  </div>\n</div>\n<app-user-info *ngIf=\"user\" [name]=\"userName\" [email]=\"user.email\" [active]=\"false\" [position]=\"'Sales Senior VP'\"></app-user-info>\n\n<mat-tab-group disableRipple class=\"content-box\">\n  <mat-tab label=\"Profile\">\n    <ng-container *ngTemplateOutlet=\"userProfile\">\n    </ng-container>\n  </mat-tab>\n  <mat-tab label=\"Devices\" [disabled]=\"true\"></mat-tab>\n  <mat-tab label=\"Lines\" [disabled]=\"true\"></mat-tab>\n  <mat-tab label=\"Features\" [disabled]=\"true\"></mat-tab>\n</mat-tab-group>\n\n<ng-template #userProfile>\n  <form *ngIf=\"user && form\" [formGroup]=\"form\">\n    <div class=\"info-boxes-container\">\n      <!--    USER INFO BOX-->\n      <div class=\"user-info-box user-details-box\">\n        <h3 class=\"user-box-title\">User Details</h3>\n        <div class=\"form-holder__inputs\">\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">User Id</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input formControlName=\"userid\" [disabled]=\"this.isLdap() ? '' : false\" [readonly]=\"this.isLdap() ? '' : false\"\n                       matInput (input)=\"onChangeField('userid')\">\n                <mat-error\n                  *ngIf=\"form.get('userid').hasError('required')\">\n                  <i class=\"fa fa-exclamation-triangle\"></i>\n                  This field is required\n                </mat-error>\n                <mat-error *ngIf=\"form.get('userid').hasError('exist')\">\n                  <i class=\"fa fa-exclamation-triangle\"></i>\n                  User ID already exists\n                </mat-error>\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Email</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input formControlName=\"email\"\n                        [disabled]=\"this.isLdap() ? '' : false\" [readonly]=\"this.isLdap() ? '' : false\"\n                       matInput (input)=\"onChangeField('email')\">\n                <mat-error\n                  *ngIf=\"form.get('email').touched && form.get('email').hasError('required')\">\n                  <i class=\"fa fa-exclamation-triangle\"></i>\n                  This field is required\n                </mat-error>\n                <mat-error *ngIf=\"form.get('email').touched && form.get('email').hasError('pattern')\">\n                  <i class=\"fa fa-exclamation-triangle\"></i>\n                  Please enter valid email\n                </mat-error>\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Fisrt Name</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input formControlName=\"firstName\"\n                        [disabled]=\"this.isLdap() ? '' : false\" [readonly]=\"this.isLdap() ? '' : false\"\n                       matInput (input)=\"onChangeField('firstName')\">\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Last Name</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input formControlName=\"lastName\"\n                        [disabled]=\"this.isLdap() ? '' : false\" [readonly]=\"this.isLdap() ? '' : false\"\n                       matInput (input)=\"onChangeField('lastName')\">\n                <mat-error\n                  *ngIf=\"form.get('lastName').touched && form.get('lastName').hasError('required')\">\n                  <i class=\"fa fa-exclamation-triangle\"></i>\n                  This field is required\n                </mat-error>\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n        </div>\n\n      </div>\n\n\n      <!--    USER INFO BOX-->\n      <div class=\"user-info-box user-details-box\">\n        <h3 class=\"user-box-title\">General User Info</h3>\n        <div class=\"form-holder__inputs\">\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Department</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input formControlName=\"department\" matInput type=\"text\" (input)=\"onChangeField('department')\">\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Manager user ID</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input formControlName=\"manager\" matInput type=\"text\" (input)=\"onChangeField('manager')\">\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Associated PC</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input formControlName=\"associatedPc\" matInput type=\"text\" (input)=\"onChangeField('associatedPc')\">\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Digest credentials</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input formControlName=\"digestCredentials\" matInput type=\"text\" (input)=\"onChangeField('digestCredentials')\">\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">User profile</div>\n            <div class=\"input-holder__input\">\n              <app-lazy-loading-select\n                [siteId]=\"siteId\"\n                [controlName]=\"'userProfile'\"\n                [form]=\"user.form\"\n                (changeField)=\"changeField('userProfile')\"\n                [optionsToken]=\"'userProfiles'\"\n              ></app-lazy-loading-select>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Mobile voice access</div>\n            <div class=\"input-holder__input\">\n              <mat-slide-toggle\n                formControlName=\"enableMobileVoiceAccess\"\n                (change)=\"onChangeField('enableMobileVoiceAccess')\"\n                [checked]=\"user.enableMobileVoiceAccess\">\n              </mat-slide-toggle>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Userlocale</div>\n            <div class=\"input-holder__input\">\n              <app-lazy-loading-select\n                [siteId]=\"siteId\"\n                [controlName]=\"'userLocale'\"\n                [form]=\"user.form\"\n                (changeField)=\"changeField($event)\"\n                [optionsToken]=\"'userLocales'\"\n                [default]=\"{key: '', value: 'None', disabled: false}\">\n              </app-lazy-loading-select>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Confirm digest credentials</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input formControlName=\"confirmDigestCredentials\" matInput type=\"text\" (input)=\"onChangeField('confirmDigestCredentials')\">\n              </mat-form-field>\n            </div>\n          </div>\n        </div>\n      </div>\n\n      <!--    USER INFO BOX-->\n      <div class=\"user-info-box user-details-box\">\n        <h3 class=\"user-box-title\">Contact Information</h3>\n        <div class=\"form-holder__inputs\">\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Middle Name</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input matInput type=\"text\" formControlName=\"middleName\" (input)=\"onChangeField('middleName')\">\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Telephone Number</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input matInput type=\"number\" formControlName=\"telephoneNumber\" (input)=\"onChangeField('telephoneNumber')\">\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Mobile Number</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input matInput type=\"number\" formControlName=\"mobileNumber\" (input)=\"onChangeField('mobileNumber')\">\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Digest credentials</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input matInput type=\"text\" formControlName=\"digestCredentials\" (input)=\"onChangeField('digestCredentials')\">\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Diractory URI</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input matInput type=\"text\" formControlName=\"directoryUri\" (input)=\"onChangeField('directoryUri')\">\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Title</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input matInput type=\"text\" formControlName=\"title\" (input)=\"onChangeField('title')\">\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Home Number</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input matInput type=\"number\" formControlName=\"homeNumber\" (input)=\"onChangeField('homeNumber')\">\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Pager Number</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input matInput type=\"number\" formControlName=\"pagerNumber\" (input)=\"onChangeField('pagerNumber')\">\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Display Name</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input matInput type=\"text\" formControlName=\"displayName\" (input)=\"onChangeField('displayName')\">\n              </mat-form-field>\n            </div>\n          </div>\n        </div>\n      </div>\n\n    </div>\n\n  </form>\n</ng-template>\n</div>\n<div class=\"spinner-container\">\n  <div *ngIf=\"dataPending == true\" class=\"data-loader\">\n    <mat-spinner strokeWidth=\"3\" [diameter]=\"70\"></mat-spinner>\n  </div>\n</div>\n<!--<mat-progress-spinner *ngIf=\"dataPending\"-->\n<!--  class=\"page-spinner\"-->\n<!--  mode=\"indeterminate\"-->\n<!--  [diameter]=\"120\"></mat-progress-spinner>-->\n"]}
172
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-manage-widget.component.js","sourceRoot":"","sources":["../../../../../../projects/tuki/widgets/user-manage/src/user-manage-widget.component.ts","../../../../../../projects/tuki/widgets/user-manage/src/user-manage-widget.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { FormGroup, Validators } from '@angular/forms';\nimport { UserService } from './services/user.service';\nimport { APIService } from \"./services/api.service\";\nimport { SimplifiedUser } from './classes/simplified-user';\n\n@Component({\n  selector: 'app-user-manage-widget',\n  templateUrl: './user-manage-widget.component.html',\n  styleUrls: ['./user-manage-widget.component.scss'],\n})\nexport class UserManageWidgetComponent implements OnInit {\n\n  public dataPending!: boolean;\n\n  @Output() onSave = new EventEmitter<string>();\n  @Output() onChange = new EventEmitter<string>();\n  @Input() token!: string;\n  @Input() host!: string;\n  @Input() siteId!: number;\n  @Input() userId!: string;\n\n  get form(): FormGroup {\n    return this.userService?.user?.form;\n  }\n\n  public isLdap():boolean{\n    return this.user.ldapIntegrated;\n  }\n  get user(): SimplifiedUser {\n    return this.userService.user;\n  }\n\n  get userName(): string {\n    return `${this.user?.firstName || ''} ${this.user?.lastName || ''}`;\n  }\n\n\n  constructor(\n    public userService: UserService,\n    private apiService: APIService,\n  ) {\n  }\n\n  ngOnInit(): void {\n    this.apiService.token = this.token;\n    this.apiService.apiUrl = this.host;\n    this.getData();\n  }\n\n  public onChangeField(token: string): void {\n      this.onChange.next(\"start change..\");\n\n    if (!token) {\n      return;\n    }\n    (this.userService.user as any)[token] = this.form?.get(token)?.value;\n\n    if (token === 'middleName') {\n      this.form?.get(token)?.setValidators([Validators.pattern('[ a-zA-Z-]+')]);\n    }\n    if (token === 'telephoneNumber' || token === 'mobileNumber' ||  token === 'pagerNumber' || token === 'homeNumber') {\n      this.form?.get(token)?.setValidators([Validators.pattern('[ 0-9-+]+')]);\n    }\n    this.form?.get(token)?.updateValueAndValidity();\n    this.validateUserId();\n  }\n\n  public saveChanges(): void {\n    if (!this.userService.hasUnsavedChanges() || this.form?.invalid) {\n      return;\n    }\n    const subscription = this.userService.persistCacheChanges()\n      .subscribe(() => {\n        this.onSave.next(\"user has been saved successfully..\");\n        subscription.unsubscribe();\n      })\n  }\n\n  public toggleEditMode() {\n    this.userService.user.toggleEditMode();\n  }\n\n  public isSavingDisabled(): boolean {\n    return !this.userService.hasUnsavedChanges() || this.userService.hasExistedUserId;\n  }\n\n  public changeField(token: string): void {\n    this.onChange.next(\"start change..\");\n    const formField = this.user?.form?.get(token);\n    if (token !== 'confirmDigestCredentials') {\n      // @ts-ignore\n      this.user[token] = formField?.value;\n    }\n    if (token === 'digestCredentials' || token === 'confirmDigestCredentials') {\n      this.digestCredentialsHandler(token, formField);\n    }\n  }\n\n  private digestCredentialsHandler(token: string, field: any) {\n    const fieldNameToCompare = token === 'digestCredentials' ? 'confirmDigestCredentials' : 'digestCredentials';\n    const fieldToCompare = this.userService.user.form.get(fieldNameToCompare);\n    if (this.userService.user?.form?.get(token)) {\n      this.userService.user?.form?.get(token)?.setErrors(null);\n      this.userService.user?.form?.get(fieldNameToCompare)?.setErrors(null);\n\n     /* if (!field.value && !fieldToCompare.value) {\n        this.userService.user?.digestCredentials = null;\n        return;\n      }\n\n      if (!field.value && fieldToCompare.value || !fieldToCompare.value && field.value) {\n        const requiredFieldName = field.value ? fieldNameToCompare : token;\n        this.userService.user.form.get(requiredFieldName).setErrors({required: true});\n        return;\n      }\n      if (field.value && fieldToCompare.value && field.value !== fieldToCompare.value) {\n        this.userService.user.form.get(token).setErrors({mismatch: true});\n        this.userService.user.form.get(fieldNameToCompare).setErrors({mismatch: true});\n      }*/\n    }\n\n  }\n\n  private getData() {\n    this.dataPending = true;\n    this.userService.fetchUserToken(this.siteId, this.userId)\n      .subscribe({\n        complete: (v: any) => {\n          this.dataPending = false;\n        },\n        error: (e: any) => this.dataPending = false,\n      });\n  }\n\n  private setCookie(name: string, value: string, days: number) {\n    var expires = \"\";\n    if (days) {\n      var date = new Date();\n      date.setTime(date.getTime() + (days * 24 * 60 * 60 * 1000));\n      expires = \"; expires=\" + date.toUTCString();\n    }\n    document.cookie = name + \"=\" + (value || \"\") + expires + \"; path=/\";\n  }\n\n  private validateUserId() {\n    const idControl = this.form.get('userid');\n    if (idControl?.value !== '' && idControl?.value !== this.userService.originUser.userid) {\n      this.userService.fetchUserById(idControl?.value)\n        .subscribe(\n          (res: any) => {\n            this.userService.userIdExistPending = false;\n            idControl?.setErrors({exist: true});\n            if (this.form?.get('userid')?.hasError('exist')) {\n              this.userService.hasExistedUserId = true;\n            } else {\n              this.userService.hasExistedUserId = false;\n            }\n          },\n          ((error) => {\n            this.userService.userIdExistPending = false;\n            if (error.status !== 404) {\n              // this.notificationService.warning(this.translate.instant('APP_USER_MSG.CHECK_USER_ID_FAILED'));\n            } else {\n              this.userService.user.newUserId = this.form?.get('userid')?.value\n            }\n          }));\n    } else {\n      delete this.userService?.user?.newUserId;\n    }\n  }\n\n  public save() {\n    this.saveChanges()\n  }\n\n}\n","<div *ngIf=\"dataPending == false\">\n<div class=\"header-box\">\n  <div class=\"content-box\">\n    <div class=\"header-back-block\">\n      <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n        <path d=\"M5.70746 7.99987L11.3539 2.35352C11.4453 2.25928 11.496 2.13287 11.495 2.00159C11.494 1.8703 11.4414 1.74467 11.3486 1.65183C11.2558 1.55899 11.1301 1.50639 10.9988 1.50539C10.8676 1.50438 10.7411 1.55506 10.6469 1.64647L4.64691 7.64647C4.55316 7.74023 4.50049 7.8674 4.50049 7.99999C4.50049 8.13259 4.55316 8.25975 4.64691 8.35352L10.6469 14.3535C10.6931 14.4011 10.7482 14.439 10.8092 14.4651C10.8702 14.4912 10.9357 14.5049 11.002 14.5054C11.0683 14.5059 11.134 14.4932 11.1954 14.468C11.2567 14.4429 11.3125 14.4058 11.3593 14.3589C11.4062 14.312 11.4433 14.2563 11.4685 14.1949C11.4936 14.1336 11.5063 14.0679 11.5058 14.0016C11.5053 13.9353 11.4916 13.8697 11.4655 13.8088C11.4394 13.7478 11.4015 13.6926 11.3539 13.6465L5.70746 7.99987Z\" fill=\"black\" fill-opacity=\"0.95\"/>\n      </svg>\n      Users\n    </div>\n<!--    <div class=\"header-button-block\">-->\n<!--      <button mat-raised-button-->\n<!--              [disabled]=\"!userService.hasUnsavedChanges()\"-->\n<!--              (click)=\"saveChanges()\">Save</button>-->\n<!--    </div>-->\n  </div>\n</div>\n<app-user-info *ngIf=\"user\" [name]=\"userName\" [email]=\"user.email\" [active]=\"false\" [position]=\"'Sales Senior VP'\"></app-user-info>\n\n<mat-tab-group disableRipple class=\"content-box\">\n  <mat-tab label=\"Profile\">\n    <ng-container *ngTemplateOutlet=\"userProfile\">\n    </ng-container>\n  </mat-tab>\n  <mat-tab label=\"Devices\" [disabled]=\"true\"></mat-tab>\n  <mat-tab label=\"Lines\" [disabled]=\"true\"></mat-tab>\n  <mat-tab label=\"Features\" [disabled]=\"true\"></mat-tab>\n</mat-tab-group>\n\n<ng-template #userProfile>\n  <form *ngIf=\"user && form\" [formGroup]=\"form\">\n    <div class=\"info-boxes-container\">\n      <!--    USER INFO BOX-->\n      <div class=\"user-info-box user-details-box\">\n        <h3 class=\"user-box-title\">User Details</h3>\n        <div class=\"form-holder__inputs\">\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">User Id</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input formControlName=\"userid\" [disabled]=\"this.isLdap() ? '' : false\" [readonly]=\"this.isLdap() ? '' : false\"\n                       matInput (input)=\"onChangeField('userid')\">\n                <mat-error\n                  *ngIf=\"form.get('userid').hasError('required')\">\n                  <i class=\"fa fa-exclamation-triangle\"></i>\n                  This field is required\n                </mat-error>\n                <mat-error *ngIf=\"form.get('userid').hasError('exist')\">\n                  <i class=\"fa fa-exclamation-triangle\"></i>\n                  User ID already exists\n                </mat-error>\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Email</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input formControlName=\"email\"\n                        [disabled]=\"this.isLdap() ? '' : false\" [readonly]=\"this.isLdap() ? '' : false\"\n                       matInput (input)=\"onChangeField('email')\">\n                <mat-error\n                  *ngIf=\"form.get('email').touched && form.get('email').hasError('required')\">\n                  <i class=\"fa fa-exclamation-triangle\"></i>\n                  This field is required\n                </mat-error>\n                <mat-error *ngIf=\"form.get('email').touched && form.get('email').hasError('pattern')\">\n                  <i class=\"fa fa-exclamation-triangle\"></i>\n                  Please enter valid email\n                </mat-error>\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Fisrt Name</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input formControlName=\"firstName\"\n                        [disabled]=\"this.isLdap() ? '' : false\" [readonly]=\"this.isLdap() ? '' : false\"\n                       matInput (input)=\"onChangeField('firstName')\">\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Last Name</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input formControlName=\"lastName\"\n                        [disabled]=\"this.isLdap() ? '' : false\" [readonly]=\"this.isLdap() ? '' : false\"\n                       matInput (input)=\"onChangeField('lastName')\">\n                <mat-error\n                  *ngIf=\"form.get('lastName').touched && form.get('lastName').hasError('required')\">\n                  <i class=\"fa fa-exclamation-triangle\"></i>\n                  This field is required\n                </mat-error>\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n        </div>\n\n      </div>\n\n\n      <!--    USER INFO BOX-->\n      <div class=\"user-info-box user-details-box\">\n        <h3 class=\"user-box-title\">General User Info</h3>\n        <div class=\"form-holder__inputs\">\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Department</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input formControlName=\"department\" matInput type=\"text\" (input)=\"onChangeField('department')\">\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Manager user ID</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input formControlName=\"manager\" matInput type=\"text\" (input)=\"onChangeField('manager')\">\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Associated PC</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input formControlName=\"associatedPc\" matInput type=\"text\" (input)=\"onChangeField('associatedPc')\">\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Digest credentials</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input formControlName=\"digestCredentials\" matInput type=\"text\" (input)=\"onChangeField('digestCredentials')\">\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">User profile</div>\n            <div class=\"input-holder__input\">\n              <app-lazy-loading-select\n                [siteId]=\"siteId\"\n                [controlName]=\"'userProfile'\"\n                [form]=\"user.form\"\n                (changeField)=\"changeField('userProfile')\"\n                [optionsToken]=\"'userProfiles'\"\n              ></app-lazy-loading-select>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Mobile voice access</div>\n            <div class=\"input-holder__input\">\n              <mat-slide-toggle\n                formControlName=\"enableMobileVoiceAccess\"\n                (change)=\"onChangeField('enableMobileVoiceAccess')\"\n                [checked]=\"user.enableMobileVoiceAccess\">\n              </mat-slide-toggle>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Userlocale</div>\n            <div class=\"input-holder__input\">\n              <app-lazy-loading-select\n                [siteId]=\"siteId\"\n                [controlName]=\"'userLocale'\"\n                [form]=\"user.form\"\n                (changeField)=\"changeField($event)\"\n                [optionsToken]=\"'userLocales'\"\n                [default]=\"{key: '', value: 'None', disabled: false}\">\n              </app-lazy-loading-select>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Confirm digest credentials</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input formControlName=\"confirmDigestCredentials\" matInput type=\"text\" (input)=\"onChangeField('confirmDigestCredentials')\">\n              </mat-form-field>\n            </div>\n          </div>\n        </div>\n      </div>\n\n      <!--    USER INFO BOX-->\n      <div class=\"user-info-box user-details-box\">\n        <h3 class=\"user-box-title\">Contact Information</h3>\n        <div class=\"form-holder__inputs\">\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Middle Name</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input matInput type=\"text\" formControlName=\"middleName\" (input)=\"onChangeField('middleName')\">\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Telephone Number</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input matInput type=\"number\" formControlName=\"telephoneNumber\" (input)=\"onChangeField('telephoneNumber')\">\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Mobile Number</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input matInput type=\"number\" formControlName=\"mobileNumber\" (input)=\"onChangeField('mobileNumber')\">\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Digest credentials</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input matInput type=\"text\" formControlName=\"digestCredentials\" (input)=\"onChangeField('digestCredentials')\">\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Diractory URI</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input matInput type=\"text\" formControlName=\"directoryUri\" (input)=\"onChangeField('directoryUri')\">\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Title</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input matInput type=\"text\" formControlName=\"title\" (input)=\"onChangeField('title')\">\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Home Number</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input matInput type=\"number\" formControlName=\"homeNumber\" (input)=\"onChangeField('homeNumber')\">\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Pager Number</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input matInput type=\"number\" formControlName=\"pagerNumber\" (input)=\"onChangeField('pagerNumber')\">\n              </mat-form-field>\n            </div>\n          </div>\n          <mat-divider></mat-divider>\n          <div class=\"input-holder\">\n            <div class=\"input-holder__name\">Display Name</div>\n            <div class=\"input-holder__input\">\n              <mat-form-field appearance=\"outline\">\n                <input matInput type=\"text\" formControlName=\"displayName\" (input)=\"onChangeField('displayName')\">\n              </mat-form-field>\n            </div>\n          </div>\n        </div>\n      </div>\n\n    </div>\n\n  </form>\n</ng-template>\n</div>\n<div class=\"spinner-container\">\n  <div *ngIf=\"dataPending == true\" class=\"data-loader\">\n    <mat-spinner strokeWidth=\"3\" [diameter]=\"70\"></mat-spinner>\n  </div>\n</div>\n<!--<mat-progress-spinner *ngIf=\"dataPending\"-->\n<!--  class=\"page-spinner\"-->\n<!--  mode=\"indeterminate\"-->\n<!--  [diameter]=\"120\"></mat-progress-spinner>-->\n"]}
@@ -34,7 +34,7 @@ export class UsersSearchService {
34
34
  this.pageSizeOptions = PAGINATION_SIZE_OPTIONS;
35
35
  }
36
36
  quickRegularUsersSearch() {
37
- this.searchParams = this.searchParams || { customerid: this.customerId };
37
+ this.searchParams = this.searchParams || { customerid: this.customerId, siteid: this.siteId };
38
38
  return this.apiService.fetchPagination(API.QUICK_USERS_SEARCH, this.pageSize, this.pageIndex, this.searchParams)
39
39
  .pipe(map((res) => {
40
40
  this.total = res.total;
@@ -52,4 +52,4 @@ UsersSearchService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", v
52
52
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: UsersSearchService, decorators: [{
53
53
  type: Injectable
54
54
  }], ctorParameters: function () { return [{ type: i1.APIService }, { type: i2.RemoveKynFromIBMService }]; } });
55
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlcnMtc2VhcmNoLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90dWtpL3dpZGdldHMvdXNlcnMtbGlzdC9zcmMvc2VydmljZXMvdXNlcnMtc2VhcmNoLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUduRCxPQUFPLEVBQUUsUUFBUSxFQUFxQixNQUFNLHNCQUFzQixDQUFDO0FBQ25FLE9BQU8sRUFBRSxlQUFlLEVBQWMsTUFBTSxNQUFNLENBQUM7QUFDbkQsT0FBTyxFQUFFLEdBQUcsRUFBRSxtQkFBbUIsRUFBRSx1QkFBdUIsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBRXJGLE9BQU8sRUFBRSxHQUFHLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7OztBQU9yQyxNQUFNLE9BQU8sa0JBQWtCO0lBYTdCLFlBQ1UsVUFBc0IsRUFDdEIsdUJBQWdEO1FBRGhELGVBQVUsR0FBVixVQUFVLENBQVk7UUFDdEIsNEJBQXVCLEdBQXZCLHVCQUF1QixDQUF5QjtRQWQxRCxXQUFNLEdBQVcsQ0FBQyxDQUFDLENBQUM7UUFDcEIsV0FBTSxHQUFXLEVBQUUsQ0FBQztRQUVwQix1QkFBa0IsR0FBRyxLQUFLLENBQUM7UUFDM0IscUJBQWdCLEdBQUcsS0FBSyxDQUFDO1FBQ3pCLGFBQVEsR0FBRyxtQkFBbUIsQ0FBQyxJQUFJLENBQUM7UUFDcEMsY0FBUyxHQUFHLG1CQUFtQixDQUFDLElBQUksQ0FBQztRQUNyQyxvQkFBZSxHQUFHLHVCQUF1QixDQUFDO1FBU3hDLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxlQUFlLENBQUMsSUFBSSxDQUFDLENBQUM7SUFFL0MsQ0FBQztJQUVNLGFBQWE7UUFDbEIsT0FBTztZQUNMLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSztZQUNqQixlQUFlLEVBQUUsSUFBSSxDQUFDLGVBQWU7WUFDckMsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRO1lBQ3ZCLFNBQVMsRUFBRSxJQUFJLENBQUMsU0FBUztTQUMxQixDQUFDO0lBQ0osQ0FBQztJQUVNLGdCQUFnQjtRQUNyQixJQUFJLENBQUMsS0FBSyxHQUFHLENBQUMsQ0FBQztRQUNmLElBQUksQ0FBQyxRQUFRLEdBQUcsbUJBQW1CLENBQUMsSUFBSSxDQUFDO1FBQ3pDLElBQUksQ0FBQyxTQUFTLEdBQUcsbUJBQW1CLENBQUMsS0FBSyxDQUFDO1FBQzNDLElBQUksQ0FBQyxlQUFlLEdBQUcsdUJBQXVCLENBQUM7SUFDakQsQ0FBQztJQUNNLHVCQUF1QjtRQUM1QixJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxZQUFZLElBQUksRUFBQyxVQUFVLEVBQUUsSUFBSSxDQUFDLFVBQVUsRUFBQyxDQUFDO1FBQ3ZFLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQyxlQUFlLENBQUMsR0FBRyxDQUFDLGtCQUFrQixFQUFFLElBQUksQ0FBQyxRQUFRLEVBQUUsSUFBSSxDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsWUFBWSxDQUFDO2FBQzdHLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxHQUF1QixFQUFFLEVBQUU7WUFDcEMsSUFBSSxDQUFDLEtBQUssR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDO1lBQ3ZCLG1DQUFtQztZQUNuQyxvQ0FBb0M7WUFDcEMsTUFBTSxLQUFLLEdBQUcsR0FBRyxDQUFDLFFBQVEsSUFBSSxHQUFHLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7WUFDdEcsMkZBQTJGO1lBQzNGLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQy9CLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDSixpQ0FBaUM7SUFDckMsQ0FBQzs7Z0hBaERVLGtCQUFrQjtvSEFBbEIsa0JBQWtCOzRGQUFsQixrQkFBa0I7a0JBRDlCLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFNpbXBsaWZpZWRVc2VyIH0gZnJvbSAnLi4vY2xhc3Nlcy9zaW1saWZpZWQtdXNlcic7XG5pbXBvcnQgeyBBUElTZXJ2aWNlIH0gZnJvbSAnLi9hcGkuc2VydmljZSc7XG5pbXBvcnQgeyBMaXN0VXNlciwgTGlzdFVzZXJJbnRlcmZhY2UgfSBmcm9tICcuLi9jbGFzc2VzL3VzZXItbGlzdCc7XG5pbXBvcnQgeyBCZWhhdmlvclN1YmplY3QsIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IEFQSSwgUEFHSU5BVElPTl9ERUZBVUxUUywgUEFHSU5BVElPTl9TSVpFX09QVElPTlMgfSBmcm9tICcuLi9hcHAuY29uc3RhbnRzJztcbmltcG9ydCB7IFRhYmxlRGF0YUludGVyZmFjZSB9IGZyb20gJy4uL2NsYXNzZXMvdGFibGUtZGF0YSc7XG5pbXBvcnQgeyBtYXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5pbXBvcnQgeyBSZW1vdmVLeW5Gcm9tSUJNU2VydmljZSB9IGZyb20gJy4vcmVtb3ZlS3luRnJvbUlCTS5zZXJ2aWNlJztcbmltcG9ydCB7IFBhZ2luYXRpb25EYXRhRHRvIH0gZnJvbSAnLi4vY2xhc3Nlcy9wYWdpbmF0aW9uJztcblxuXG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBVc2Vyc1NlYXJjaFNlcnZpY2UgIHtcbiAgc2l0ZUlkOiBudW1iZXIgPSAtMTtcbiAgdXNlcklkOiBzdHJpbmcgPSAnJztcbiAgY3VzdG9tZXJJZCE6IG51bWJlcjtcbiAgdXNlcklkRXhpc3RQZW5kaW5nID0gZmFsc2U7XG4gIGhhc0V4aXN0ZWRVc2VySWQgPSBmYWxzZTtcbiAgcGFnZVNpemUgPSBQQUdJTkFUSU9OX0RFRkFVTFRTLlNJWkU7XG4gIHBhZ2VJbmRleCA9IFBBR0lOQVRJT05fREVGQVVMVFMuU0laRTtcbiAgcGFnZVNpemVPcHRpb25zID0gUEFHSU5BVElPTl9TSVpFX09QVElPTlM7XG4gIHRvdGFsITogbnVtYmVyO1xuICBzZWFyY2hQYXJhbXMhOiBhbnk7XG4gIGZvdW5kVXNlcnMkITogYW55O1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgYXBpU2VydmljZTogQVBJU2VydmljZSxcbiAgICBwcml2YXRlIHJlbW92ZUt5bkZyb21JQk1TZXJ2aWNlOiBSZW1vdmVLeW5Gcm9tSUJNU2VydmljZVxuICApIHtcbiAgICB0aGlzLmZvdW5kVXNlcnMkID0gbmV3IEJlaGF2aW9yU3ViamVjdChudWxsKTtcblxuICB9XG5cbiAgcHVibGljIGdldFBhZ2luYXRpb24oKTogUGFnaW5hdGlvbkRhdGFEdG8ge1xuICAgIHJldHVybiB7XG4gICAgICB0b3RhbDogdGhpcy50b3RhbCxcbiAgICAgIHBhZ2VTaXplT3B0aW9uczogdGhpcy5wYWdlU2l6ZU9wdGlvbnMsXG4gICAgICBwYWdlU2l6ZTogdGhpcy5wYWdlU2l6ZSxcbiAgICAgIHBhZ2VJbmRleDogdGhpcy5wYWdlSW5kZXhcbiAgICB9O1xuICB9XG5cbiAgcHVibGljIHNldERlZmF1bHRWYWx1ZXMoKSB7XG4gICAgdGhpcy50b3RhbCA9IDA7XG4gICAgdGhpcy5wYWdlU2l6ZSA9IFBBR0lOQVRJT05fREVGQVVMVFMuU0laRTtcbiAgICB0aGlzLnBhZ2VJbmRleCA9IFBBR0lOQVRJT05fREVGQVVMVFMuSU5ERVg7XG4gICAgdGhpcy5wYWdlU2l6ZU9wdGlvbnMgPSBQQUdJTkFUSU9OX1NJWkVfT1BUSU9OUztcbiAgfVxuICBwdWJsaWMgcXVpY2tSZWd1bGFyVXNlcnNTZWFyY2goKSB7XG4gICAgdGhpcy5zZWFyY2hQYXJhbXMgPSB0aGlzLnNlYXJjaFBhcmFtcyB8fCB7Y3VzdG9tZXJpZDogdGhpcy5jdXN0b21lcklkfTtcbiAgICByZXR1cm4gdGhpcy5hcGlTZXJ2aWNlLmZldGNoUGFnaW5hdGlvbihBUEkuUVVJQ0tfVVNFUlNfU0VBUkNILCB0aGlzLnBhZ2VTaXplLCB0aGlzLnBhZ2VJbmRleCwgdGhpcy5zZWFyY2hQYXJhbXMpXG4gICAgICAucGlwZShtYXAoKHJlczogVGFibGVEYXRhSW50ZXJmYWNlKSA9PiB7XG4gICAgICAgIHRoaXMudG90YWwgPSByZXMudG90YWw7XG4gICAgICAgIC8vIHRoaXMudG90YWxzID0gdGhpcy50b3RhbHMgfHwge307XG4gICAgICAgIC8vIHRoaXMudG90YWxzWyd1c2VycyddID0gcmVzLnRvdGFsO1xuICAgICAgICBjb25zdCB1c2VycyA9IHJlcy5wYWdlRGF0YSAmJiByZXMucGFnZURhdGEubGVuZ3RoID8gcmVzLnBhZ2VEYXRhLm1hcCh1c2VyID0+IG5ldyBMaXN0VXNlcih1c2VyKSkgOiBbXTtcbiAgICAgICAgLy8gdGhpcy5mb3VuZFVzZXJzJC5uZXh0KHRoaXMucmVtb3ZlS3luRnJvbUlCTVNlcnZpY2UucmVtb3ZlQ1VDTVModXNlcnMsIHRoaXMuY3VzdG9tZXJJZCkpO1xuICAgICAgICB0aGlzLmZvdW5kVXNlcnMkLm5leHQodXNlcnMpO1xuICAgICAgfSkpO1xuICAgICAgLy8gLnBpcGUodGhpcy5oYW5kbGVFcnJvcih0cnVlKSk7XG4gIH1cbn1cbiJdfQ==
55
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlcnMtc2VhcmNoLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90dWtpL3dpZGdldHMvdXNlcnMtbGlzdC9zcmMvc2VydmljZXMvdXNlcnMtc2VhcmNoLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUduRCxPQUFPLEVBQUUsUUFBUSxFQUFxQixNQUFNLHNCQUFzQixDQUFDO0FBQ25FLE9BQU8sRUFBRSxlQUFlLEVBQWMsTUFBTSxNQUFNLENBQUM7QUFDbkQsT0FBTyxFQUFFLEdBQUcsRUFBRSxtQkFBbUIsRUFBRSx1QkFBdUIsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBRXJGLE9BQU8sRUFBRSxHQUFHLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7OztBQU9yQyxNQUFNLE9BQU8sa0JBQWtCO0lBYzdCLFlBQ1UsVUFBc0IsRUFDdEIsdUJBQWdEO1FBRGhELGVBQVUsR0FBVixVQUFVLENBQVk7UUFDdEIsNEJBQXVCLEdBQXZCLHVCQUF1QixDQUF5QjtRQWYxRCxXQUFNLEdBQVcsQ0FBQyxDQUFDLENBQUM7UUFDcEIsV0FBTSxHQUFXLEVBQUUsQ0FBQztRQUdwQix1QkFBa0IsR0FBRyxLQUFLLENBQUM7UUFDM0IscUJBQWdCLEdBQUcsS0FBSyxDQUFDO1FBQ3pCLGFBQVEsR0FBRyxtQkFBbUIsQ0FBQyxJQUFJLENBQUM7UUFDcEMsY0FBUyxHQUFHLG1CQUFtQixDQUFDLElBQUksQ0FBQztRQUNyQyxvQkFBZSxHQUFHLHVCQUF1QixDQUFDO1FBU3hDLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxlQUFlLENBQUMsSUFBSSxDQUFDLENBQUM7SUFFL0MsQ0FBQztJQUVNLGFBQWE7UUFDbEIsT0FBTztZQUNMLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSztZQUNqQixlQUFlLEVBQUUsSUFBSSxDQUFDLGVBQWU7WUFDckMsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRO1lBQ3ZCLFNBQVMsRUFBRSxJQUFJLENBQUMsU0FBUztTQUMxQixDQUFDO0lBQ0osQ0FBQztJQUVNLGdCQUFnQjtRQUNyQixJQUFJLENBQUMsS0FBSyxHQUFHLENBQUMsQ0FBQztRQUNmLElBQUksQ0FBQyxRQUFRLEdBQUcsbUJBQW1CLENBQUMsSUFBSSxDQUFDO1FBQ3pDLElBQUksQ0FBQyxTQUFTLEdBQUcsbUJBQW1CLENBQUMsS0FBSyxDQUFDO1FBQzNDLElBQUksQ0FBQyxlQUFlLEdBQUcsdUJBQXVCLENBQUM7SUFDakQsQ0FBQztJQUNNLHVCQUF1QjtRQUM1QixJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxZQUFZLElBQUksRUFBQyxVQUFVLEVBQUUsSUFBSSxDQUFDLFVBQVUsRUFBRSxNQUFNLEVBQUUsSUFBSSxDQUFDLE1BQU0sRUFBQyxDQUFDO1FBQzVGLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQyxlQUFlLENBQUMsR0FBRyxDQUFDLGtCQUFrQixFQUFFLElBQUksQ0FBQyxRQUFRLEVBQUUsSUFBSSxDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsWUFBWSxDQUFDO2FBQzdHLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxHQUF1QixFQUFFLEVBQUU7WUFDcEMsSUFBSSxDQUFDLEtBQUssR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDO1lBQ3ZCLG1DQUFtQztZQUNuQyxvQ0FBb0M7WUFDcEMsTUFBTSxLQUFLLEdBQUcsR0FBRyxDQUFDLFFBQVEsSUFBSSxHQUFHLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7WUFDdEcsMkZBQTJGO1lBQzNGLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQy9CLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDSixpQ0FBaUM7SUFDckMsQ0FBQzs7Z0hBakRVLGtCQUFrQjtvSEFBbEIsa0JBQWtCOzRGQUFsQixrQkFBa0I7a0JBRDlCLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFNpbXBsaWZpZWRVc2VyIH0gZnJvbSAnLi4vY2xhc3Nlcy9zaW1saWZpZWQtdXNlcic7XG5pbXBvcnQgeyBBUElTZXJ2aWNlIH0gZnJvbSAnLi9hcGkuc2VydmljZSc7XG5pbXBvcnQgeyBMaXN0VXNlciwgTGlzdFVzZXJJbnRlcmZhY2UgfSBmcm9tICcuLi9jbGFzc2VzL3VzZXItbGlzdCc7XG5pbXBvcnQgeyBCZWhhdmlvclN1YmplY3QsIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IEFQSSwgUEFHSU5BVElPTl9ERUZBVUxUUywgUEFHSU5BVElPTl9TSVpFX09QVElPTlMgfSBmcm9tICcuLi9hcHAuY29uc3RhbnRzJztcbmltcG9ydCB7IFRhYmxlRGF0YUludGVyZmFjZSB9IGZyb20gJy4uL2NsYXNzZXMvdGFibGUtZGF0YSc7XG5pbXBvcnQgeyBtYXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5pbXBvcnQgeyBSZW1vdmVLeW5Gcm9tSUJNU2VydmljZSB9IGZyb20gJy4vcmVtb3ZlS3luRnJvbUlCTS5zZXJ2aWNlJztcbmltcG9ydCB7IFBhZ2luYXRpb25EYXRhRHRvIH0gZnJvbSAnLi4vY2xhc3Nlcy9wYWdpbmF0aW9uJztcblxuXG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBVc2Vyc1NlYXJjaFNlcnZpY2UgIHtcbiAgc2l0ZUlkOiBudW1iZXIgPSAtMTtcbiAgdXNlcklkOiBzdHJpbmcgPSAnJztcbiAgY3VzdG9tZXJJZCE6IG51bWJlcjtcbiAgc2l0ZWlkITogbnVtYmVyO1xuICB1c2VySWRFeGlzdFBlbmRpbmcgPSBmYWxzZTtcbiAgaGFzRXhpc3RlZFVzZXJJZCA9IGZhbHNlO1xuICBwYWdlU2l6ZSA9IFBBR0lOQVRJT05fREVGQVVMVFMuU0laRTtcbiAgcGFnZUluZGV4ID0gUEFHSU5BVElPTl9ERUZBVUxUUy5TSVpFO1xuICBwYWdlU2l6ZU9wdGlvbnMgPSBQQUdJTkFUSU9OX1NJWkVfT1BUSU9OUztcbiAgdG90YWwhOiBudW1iZXI7XG4gIHNlYXJjaFBhcmFtcyE6IGFueTtcbiAgZm91bmRVc2VycyQhOiBhbnk7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSBhcGlTZXJ2aWNlOiBBUElTZXJ2aWNlLFxuICAgIHByaXZhdGUgcmVtb3ZlS3luRnJvbUlCTVNlcnZpY2U6IFJlbW92ZUt5bkZyb21JQk1TZXJ2aWNlXG4gICkge1xuICAgIHRoaXMuZm91bmRVc2VycyQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0KG51bGwpO1xuXG4gIH1cblxuICBwdWJsaWMgZ2V0UGFnaW5hdGlvbigpOiBQYWdpbmF0aW9uRGF0YUR0byB7XG4gICAgcmV0dXJuIHtcbiAgICAgIHRvdGFsOiB0aGlzLnRvdGFsLFxuICAgICAgcGFnZVNpemVPcHRpb25zOiB0aGlzLnBhZ2VTaXplT3B0aW9ucyxcbiAgICAgIHBhZ2VTaXplOiB0aGlzLnBhZ2VTaXplLFxuICAgICAgcGFnZUluZGV4OiB0aGlzLnBhZ2VJbmRleFxuICAgIH07XG4gIH1cblxuICBwdWJsaWMgc2V0RGVmYXVsdFZhbHVlcygpIHtcbiAgICB0aGlzLnRvdGFsID0gMDtcbiAgICB0aGlzLnBhZ2VTaXplID0gUEFHSU5BVElPTl9ERUZBVUxUUy5TSVpFO1xuICAgIHRoaXMucGFnZUluZGV4ID0gUEFHSU5BVElPTl9ERUZBVUxUUy5JTkRFWDtcbiAgICB0aGlzLnBhZ2VTaXplT3B0aW9ucyA9IFBBR0lOQVRJT05fU0laRV9PUFRJT05TO1xuICB9XG4gIHB1YmxpYyBxdWlja1JlZ3VsYXJVc2Vyc1NlYXJjaCgpIHtcbiAgICB0aGlzLnNlYXJjaFBhcmFtcyA9IHRoaXMuc2VhcmNoUGFyYW1zIHx8IHtjdXN0b21lcmlkOiB0aGlzLmN1c3RvbWVySWQsIHNpdGVpZDogdGhpcy5zaXRlSWR9O1xuICAgIHJldHVybiB0aGlzLmFwaVNlcnZpY2UuZmV0Y2hQYWdpbmF0aW9uKEFQSS5RVUlDS19VU0VSU19TRUFSQ0gsIHRoaXMucGFnZVNpemUsIHRoaXMucGFnZUluZGV4LCB0aGlzLnNlYXJjaFBhcmFtcylcbiAgICAgIC5waXBlKG1hcCgocmVzOiBUYWJsZURhdGFJbnRlcmZhY2UpID0+IHtcbiAgICAgICAgdGhpcy50b3RhbCA9IHJlcy50b3RhbDtcbiAgICAgICAgLy8gdGhpcy50b3RhbHMgPSB0aGlzLnRvdGFscyB8fCB7fTtcbiAgICAgICAgLy8gdGhpcy50b3RhbHNbJ3VzZXJzJ10gPSByZXMudG90YWw7XG4gICAgICAgIGNvbnN0IHVzZXJzID0gcmVzLnBhZ2VEYXRhICYmIHJlcy5wYWdlRGF0YS5sZW5ndGggPyByZXMucGFnZURhdGEubWFwKHVzZXIgPT4gbmV3IExpc3RVc2VyKHVzZXIpKSA6IFtdO1xuICAgICAgICAvLyB0aGlzLmZvdW5kVXNlcnMkLm5leHQodGhpcy5yZW1vdmVLeW5Gcm9tSUJNU2VydmljZS5yZW1vdmVDVUNNUyh1c2VycywgdGhpcy5jdXN0b21lcklkKSk7XG4gICAgICAgIHRoaXMuZm91bmRVc2VycyQubmV4dCh1c2Vycyk7XG4gICAgICB9KSk7XG4gICAgICAvLyAucGlwZSh0aGlzLmhhbmRsZUVycm9yKHRydWUpKTtcbiAgfVxufVxuIl19
@@ -32,6 +32,7 @@ export class UsersListComponent {
32
32
  console.log('users list 2');
33
33
  this.usersSearchService.setDefaultValues();
34
34
  this.usersSearchService.customerId = this.customerId;
35
+ this.usersSearchService.siteId = this.siteId;
35
36
  this.apiService.token = this.token;
36
37
  this.apiWebexService.token = this.token;
37
38
  this.apiService.apiUrl = this.host + '/dcp';
@@ -117,7 +118,7 @@ export class UsersListComponent {
117
118
  }
118
119
  }
119
120
  UsersListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: UsersListComponent, deps: [{ token: i1.UserService }, { token: i2.APIService }, { token: i3.ApiWebexService }, { token: i4.NotificationService }, { token: i5.UsersSearchService }], target: i0.ɵɵFactoryTarget.Component });
120
- UsersListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: UsersListComponent, selector: "app-users-list", inputs: { token: "token", customerId: "customerId", host: "host" }, outputs: { openUser: "openUser", userMoved: "userMoved" }, ngImport: i0, template: "<app-pagination\n [pagination]=\"usersSearchService.getPagination()\"\n [showPageSizeOptions]=\"true\"\n (pageNumberChangeEmitter)=\"pageNumberChangeEvent($event)\"\n (pageEmitter)=\"pageEvent($event)\">\n</app-pagination>\n\n<table class=\"webex-table\" mat-table *ngIf=\"users?.length\" #table [dataSource]=\"dataSource\">\n\n <ng-container matColumnDef=\"user-icon\">\n <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\"></th>\n <td class=\"user-site\" mat-cell *matCellDef=\"let user\"\n [ngClass]=\"{'disabled-user-row': moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid}\"\n (click)=\"onUserClick(user)\">\n <span class=\"icon-webex-box\"><span class=\"icon-webex icon-webex-user\"></span></span>\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"name\">\n <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\">First / Last Name</th>\n <td class=\"user-site\" mat-cell *matCellDef=\"let user\"\n [ngClass]=\"{'disabled-user-row': moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid}\"\n (click)=\"onUserClick(user)\"> {{ user.firstName }} {{ user.lastName }}\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"email\">\n <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\">Email</th>\n <td class=\"user-site\" [ngClass]=\"{'disabled-user-row': moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid}\"\n mat-cell *matCellDef=\"let user\" (click)=\"onUserClick(user)\">\n {{ user.email }}\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"status\">\n <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\">Status</th>\n <td class=\"user-site\" mat-cell *matCellDef=\"let user\"\n [ngClass]=\"{'disabled-user-row': moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid}\"\n (click)=\"onUserClick(user)\">\n <span class=\"icon-user-status icon-user-status-active\"></span>{{user.status || user.webexUUID ? 'Migrated' : 'Active'}}\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"actions\">\n <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\"></th>\n <td class=\"user-site\" mat-cell *matCellDef=\"let user, let i = index\"\n [ngClass]=\"{'disabled-user-row': moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid}\">\n <mat-progress-spinner class=\"field-spinner\"\n [diameter]=\"20\"\n mode=\"indeterminate\"\n *ngIf=\"moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid\"></mat-progress-spinner>\n <button *ngIf=\"!(moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid)\"\n class=\"button-action-dot\" mat-icon-button [matMenuTriggerFor]=\"menu\">\n <div class=\"icon-actions-dots\">\n <span class=\"icon-dot\">.</span>\n <span class=\"icon-dot\">.</span>\n <span class=\"icon-dot\">.</span>\n </div>\n </button>\n <mat-menu #menu=\"matMenu\">\n <button mat-menu-item [disabled]=\"true\">Resend Invitation</button>\n <button mat-menu-item [disabled]=\"true\">Reset Password</button>\n <button mat-menu-item (click)=\"moveUser(user, i)\">Move User</button>\n <button mat-menu-item [disabled]=\"true\">Deactivate User</button>\n <button mat-menu-item [disabled]=\"true\">Delete User</button>\n </mat-menu>\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"role\">\n <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\">Administrator Role</th>\n <td class=\"user-site\" mat-cell *matCellDef=\"let user\" (click)=\"onUserClick(user)\">{{ user.roleName || '' }}</td>\n </ng-container>\n\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns; sticky: true\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\"></tr>\n</table>\n", styles: ["@import\"https://fonts.googleapis.com/css?family=Poppins:400,100,200,300,500,600,800,700,900\";table.mat-table{border-spacing:0;width:100%}::ng-deep .mat-paginator{background:none}.icon-user-status{width:.5rem;height:.5rem;border-radius:50%;background-color:#707070;margin:0 5px 0 0}.icon-user-status.icon-user-status-active{background-color:#1d805f;display:inline-block}.mat-select{height:100%;line-height:35px}.mat-form-field-wrapper{padding-bottom:0!important}.mat-form-field{padding:0;max-width:300px}.fa:hover{color:#0d56aa!important}.mat-icon-button{background:transparent}.icon-webex-box{width:2rem;height:2rem;font-size:.7rem;line-height:1rem;display:inline-block;background:#d0d0d0;border-radius:2rem;line-height:40px;text-align:center}.icon-webex{filter:invert(12%) sepia(14%) saturate(4%) hue-rotate(354deg) brightness(103%) contrast(90%);background-repeat:no-repeat;background-position:center;display:inline-block;height:1rem;width:1rem}.icon-webex-user{background-image:url(\"data:image/svg+xml,%3C%3Fxml version%3D%221.0%22 encoding%3D%22UTF-8%22%3F%3E%3Csvg id%3D%22a%22 xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22 viewBox%3D%220 0 16.67 15.56%22%3E%3Cdefs%3E%3Cstyle%3E.b%7Bfill%3Anone%3Bstroke%3A%232c355d%3Bstroke-width%3A1.4px%3B%7D%3C%2Fstyle%3E%3C%2Fdefs%3E%3Cpath class%3D%22b%22 d%3D%22M4.87%2C3.89c0-1.72%2C1.51-3.19%2C3.47-3.19s3.47%2C1.47%2C3.47%2C3.19-1.51%2C3.19-3.47%2C3.19-3.47-1.47-3.47-3.19ZM.7%2C12.64c0-.37%2C.19-.76%2C.67-1.17%2C.48-.41%2C1.17-.78%2C2-1.09%2C1.66-.62%2C3.66-.93%2C4.97-.93s3.31%2C.31%2C4.97%2C.93c.83%2C.31%2C1.52%2C.68%2C2%2C1.09%2C.47%2C.41%2C.67%2C.8%2C.67%2C1.17v2.22H.7v-2.22Z%22%2F%3E%3C%2Fsvg%3E\")}.icon-user-status{display:inline-block}*{margin:0}body{background:#f7f7f7}body,th,td{font-family:Poppins,Poppins,sans-serif;font-size:14px}th{color:#0000008a;text-align:left}td{box-sizing:border-box;padding:10px 5px 10px 0}.content-box{margin:auto;position:relative;width:95%}.content-box table{width:100%}.edit-icon-td{width:50px;position:relative}.edit-icon-td button{position:absolute;top:4px}.mat-progress-spinner circle,.mat-spinner circle{stroke:#009fdb!important}.data-loader{position:absolute;top:calc(50% - 25px);left:calc(50% - 25px)}.flex-box{display:flex;justify-content:flex-start}.user-info-box{background:white;display:grid;grid-template-columns:30% 70%;border-radius:8px;border:rgba(0,0,0,.2) 1px solid;padding:24px;font-weight:400;font-size:14px}.user-info-box h3{display:block;font-weight:500;font-size:16px}.mat-divider{margin:5px 0!important}.info-boxes-container{padding:24px 0;display:flex;flex-direction:column;gap:24px}.header-box{height:60px;width:100%;line-height:60px;background:white;border-bottom:1px solid #dedddd}.header-box .header-back-block{float:left}.header-box .header-button-block{float:right}.webex-table{width:100%;margin:auto}.webex-table tr{border-bottom:1px solid #dedede}.webex-table th{background:#f7f7f7;color:#636363;font-size:12px}.webex-table td{background:#fff;color:#000;font-size:14px}.webex-table tr:hover td:not(.disabled-user-row){background:#ededed;cursor:pointer}.webex-table th.mat-header-cell,.webex-table td.mat-cell,.webex-table td.mat-footer-cell{border-bottom:1px solid #dedede}.webex-table tr.mat-header-row{height:37px}.mat-form-field{padding:0 0 5px;width:93%}.mat-form-field.mat-form-field-disabled{border-bottom:none}.mat-error{color:#c73636;margin:13px 0 0}.select-box{border-radius:30px;background:#F3F6F6;border:1px solid #E2E9EF;height:35px;position:relative}.select-box select{border:none!important;background:transparent;height:100%;width:92%;margin:auto;display:block}option:focus,option:focus-visible{border:none!important;outline:none!important}option{height:30px;cursor:pointer;color:#636363}option:hover{background:#ededed!important}.mat-select{height:100%!important;line-height:35px!important}.info-holder,.input-holder{display:grid;grid-template-columns:30% 70%;align-items:baseline}.info-holder__name,.input-holder__name{font-weight:500!important;font-size:14px!important}.info-holder__inputs .input-holder,.input-holder__inputs .input-holder{display:grid;grid-template-columns:30% 70%;align-items:baseline}.info-holder__inputs .input-holder__name,.input-holder__inputs .input-holder__name{font-weight:400!important;font-size:14px!important}.mat-form-field-wrapper,.mat-form-field-flex{height:30px!important}.mat-form-field-appearance-outline .mat-form-field-outline,.mat-form-field-outline .mat-form-field-outline-thick{height:35px!important}.mat-select{line-height:20px!important}.mat-form-field-appearance-outline .mat-form-field-infix{padding:14px 12px 10px;border-top:0;max-width:300px}.mat-tab-group{font-family:Inter,sans-serif}.mat-tab-label{font-weight:500!important;font-size:14px!important;height:auto!important;min-width:auto!important;padding:0!important}.mat-ink-bar{background-color:#000000e6!important;height:3px!important}.mat-form-field-wrapper{padding-bottom:0}.mat-form-field{max-width:300px}table{border-collapse:collapse;border-spacing:0}.mat-form-field-appearance-outline .mat-form-field-infix{padding:0!important}.mat-divider{margin:12px 0}::ng-deep .mat-form-field-wrapper{height:30px}::ng-deep .mat-form-field-flex{height:30px}::ng-deep .mat-form-field-appearance-outline .mat-form-field-outline{height:35px}:ng-deep .mat-form-field-outline .mat-form-field-outline-thick{height:35px}::ng-deep .mat-select{line-height:20px}::ng-deep .mat-form-field-infix{border-top:0px!important}::ng-deep .mat-paginator{background:transparent!important}::ng-deep .mat-paginator-container{min-height:30px!important}::ng-deep .mat-paginator-range-label{margin:0 10px 0 24px!important;font-size:15px!important}::ng-deep .pagination{font-size:13px;color:#0000008a}::ng-deep .per-page-block{display:flex;line-height:42px!important}::ng-deep .item_per_page{line-height:42px!important}::ng-deep .select-page-size{line-height:42px!important}.icon-dot{display:block;color:#4f4f4f;font-size:16px;line-height:5px}.button-action-dot:hover{background:#dfdfdf}.button-action-dot{padding:0 5px 5px;border-radius:.25rem}\n"], dependencies: [{ kind: "directive", type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i7.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i8.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "diameter", "strokeWidth", "mode", "value"], exportAs: ["matProgressSpinner"] }, { kind: "component", type: i9.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i9.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i9.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i9.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i9.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i9.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i9.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i9.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i9.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i9.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "component", type: i10.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i10.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i10.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "component", type: i11.PaginationComponent, selector: "app-pagination", inputs: ["pagination", "showPageSizeOptions", "showRefreshButton", "lengthPending"], outputs: ["pageEmitter", "pageNumberChangeEmitter"] }] });
121
+ UsersListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: UsersListComponent, selector: "app-users-list", inputs: { token: "token", customerId: "customerId", siteId: "siteId", host: "host" }, outputs: { openUser: "openUser", userMoved: "userMoved" }, ngImport: i0, template: "<app-pagination\n [pagination]=\"usersSearchService.getPagination()\"\n [showPageSizeOptions]=\"true\"\n (pageNumberChangeEmitter)=\"pageNumberChangeEvent($event)\"\n (pageEmitter)=\"pageEvent($event)\">\n</app-pagination>\n\n<table class=\"webex-table\" mat-table *ngIf=\"users?.length\" #table [dataSource]=\"dataSource\">\n\n <ng-container matColumnDef=\"user-icon\">\n <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\"></th>\n <td class=\"user-site\" mat-cell *matCellDef=\"let user\"\n [ngClass]=\"{'disabled-user-row': moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid}\"\n (click)=\"onUserClick(user)\">\n <span class=\"icon-webex-box\"><span class=\"icon-webex icon-webex-user\"></span></span>\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"name\">\n <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\">First / Last Name</th>\n <td class=\"user-site\" mat-cell *matCellDef=\"let user\"\n [ngClass]=\"{'disabled-user-row': moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid}\"\n (click)=\"onUserClick(user)\"> {{ user.firstName }} {{ user.lastName }}\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"email\">\n <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\">Email</th>\n <td class=\"user-site\" [ngClass]=\"{'disabled-user-row': moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid}\"\n mat-cell *matCellDef=\"let user\" (click)=\"onUserClick(user)\">\n {{ user.email }}\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"status\">\n <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\">Status</th>\n <td class=\"user-site\" mat-cell *matCellDef=\"let user\"\n [ngClass]=\"{'disabled-user-row': moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid}\"\n (click)=\"onUserClick(user)\">\n <span class=\"icon-user-status icon-user-status-active\"></span>{{user.status || user.webexUUID ? 'Migrated' : 'Active'}}\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"actions\">\n <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\"></th>\n <td class=\"user-site\" mat-cell *matCellDef=\"let user, let i = index\"\n [ngClass]=\"{'disabled-user-row': moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid}\">\n <mat-progress-spinner class=\"field-spinner\"\n [diameter]=\"20\"\n mode=\"indeterminate\"\n *ngIf=\"moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid\"></mat-progress-spinner>\n <button *ngIf=\"!(moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid)\"\n class=\"button-action-dot\" mat-icon-button [matMenuTriggerFor]=\"menu\">\n <div class=\"icon-actions-dots\">\n <span class=\"icon-dot\">.</span>\n <span class=\"icon-dot\">.</span>\n <span class=\"icon-dot\">.</span>\n </div>\n </button>\n <mat-menu #menu=\"matMenu\">\n <button mat-menu-item [disabled]=\"true\">Resend Invitation</button>\n <button mat-menu-item [disabled]=\"true\">Reset Password</button>\n <button mat-menu-item (click)=\"moveUser(user, i)\">Move User</button>\n <button mat-menu-item [disabled]=\"true\">Deactivate User</button>\n <button mat-menu-item [disabled]=\"true\">Delete User</button>\n </mat-menu>\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"role\">\n <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\">Administrator Role</th>\n <td class=\"user-site\" mat-cell *matCellDef=\"let user\" (click)=\"onUserClick(user)\">{{ user.roleName || '' }}</td>\n </ng-container>\n\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns; sticky: true\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\"></tr>\n</table>\n", styles: ["@import\"https://fonts.googleapis.com/css?family=Poppins:400,100,200,300,500,600,800,700,900\";table.mat-table{border-spacing:0;width:100%}::ng-deep .mat-paginator{background:none}.icon-user-status{width:.5rem;height:.5rem;border-radius:50%;background-color:#707070;margin:0 5px 0 0}.icon-user-status.icon-user-status-active{background-color:#1d805f;display:inline-block}.mat-select{height:100%;line-height:35px}.mat-form-field-wrapper{padding-bottom:0!important}.mat-form-field{padding:0;max-width:300px}.fa:hover{color:#0d56aa!important}.mat-icon-button{background:transparent}.icon-webex-box{width:2rem;height:2rem;font-size:.7rem;line-height:1rem;display:inline-block;background:#d0d0d0;border-radius:2rem;line-height:40px;text-align:center}.icon-webex{filter:invert(12%) sepia(14%) saturate(4%) hue-rotate(354deg) brightness(103%) contrast(90%);background-repeat:no-repeat;background-position:center;display:inline-block;height:1rem;width:1rem}.icon-webex-user{background-image:url(\"data:image/svg+xml,%3C%3Fxml version%3D%221.0%22 encoding%3D%22UTF-8%22%3F%3E%3Csvg id%3D%22a%22 xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22 viewBox%3D%220 0 16.67 15.56%22%3E%3Cdefs%3E%3Cstyle%3E.b%7Bfill%3Anone%3Bstroke%3A%232c355d%3Bstroke-width%3A1.4px%3B%7D%3C%2Fstyle%3E%3C%2Fdefs%3E%3Cpath class%3D%22b%22 d%3D%22M4.87%2C3.89c0-1.72%2C1.51-3.19%2C3.47-3.19s3.47%2C1.47%2C3.47%2C3.19-1.51%2C3.19-3.47%2C3.19-3.47-1.47-3.47-3.19ZM.7%2C12.64c0-.37%2C.19-.76%2C.67-1.17%2C.48-.41%2C1.17-.78%2C2-1.09%2C1.66-.62%2C3.66-.93%2C4.97-.93s3.31%2C.31%2C4.97%2C.93c.83%2C.31%2C1.52%2C.68%2C2%2C1.09%2C.47%2C.41%2C.67%2C.8%2C.67%2C1.17v2.22H.7v-2.22Z%22%2F%3E%3C%2Fsvg%3E\")}.icon-user-status{display:inline-block}*{margin:0}body{background:#f7f7f7}body,th,td{font-family:Poppins,Poppins,sans-serif;font-size:14px}th{color:#0000008a;text-align:left}td{box-sizing:border-box;padding:10px 5px 10px 0}.content-box{margin:auto;position:relative;width:95%}.content-box table{width:100%}.edit-icon-td{width:50px;position:relative}.edit-icon-td button{position:absolute;top:4px}.mat-progress-spinner circle,.mat-spinner circle{stroke:#009fdb!important}.data-loader{position:absolute;top:calc(50% - 25px);left:calc(50% - 25px)}.flex-box{display:flex;justify-content:flex-start}.user-info-box{background:white;display:grid;grid-template-columns:30% 70%;border-radius:8px;border:rgba(0,0,0,.2) 1px solid;padding:24px;font-weight:400;font-size:14px}.user-info-box h3{display:block;font-weight:500;font-size:16px}.mat-divider{margin:5px 0!important}.info-boxes-container{padding:24px 0;display:flex;flex-direction:column;gap:24px}.header-box{height:60px;width:100%;line-height:60px;background:white;border-bottom:1px solid #dedddd}.header-box .header-back-block{float:left}.header-box .header-button-block{float:right}.webex-table{width:100%;margin:auto}.webex-table tr{border-bottom:1px solid #dedede}.webex-table th{background:#f7f7f7;color:#636363;font-size:12px}.webex-table td{background:#fff;color:#000;font-size:14px}.webex-table tr:hover td:not(.disabled-user-row){background:#ededed;cursor:pointer}.webex-table th.mat-header-cell,.webex-table td.mat-cell,.webex-table td.mat-footer-cell{border-bottom:1px solid #dedede}.webex-table tr.mat-header-row{height:37px}.mat-form-field{padding:0 0 5px;width:93%}.mat-form-field.mat-form-field-disabled{border-bottom:none}.mat-error{color:#c73636;margin:13px 0 0}.select-box{border-radius:30px;background:#F3F6F6;border:1px solid #E2E9EF;height:35px;position:relative}.select-box select{border:none!important;background:transparent;height:100%;width:92%;margin:auto;display:block}option:focus,option:focus-visible{border:none!important;outline:none!important}option{height:30px;cursor:pointer;color:#636363}option:hover{background:#ededed!important}.mat-select{height:100%!important;line-height:35px!important}.info-holder,.input-holder{display:grid;grid-template-columns:30% 70%;align-items:baseline}.info-holder__name,.input-holder__name{font-weight:500!important;font-size:14px!important}.info-holder__inputs .input-holder,.input-holder__inputs .input-holder{display:grid;grid-template-columns:30% 70%;align-items:baseline}.info-holder__inputs .input-holder__name,.input-holder__inputs .input-holder__name{font-weight:400!important;font-size:14px!important}.mat-form-field-wrapper,.mat-form-field-flex{height:30px!important}.mat-form-field-appearance-outline .mat-form-field-outline,.mat-form-field-outline .mat-form-field-outline-thick{height:35px!important}.mat-select{line-height:20px!important}.mat-form-field-appearance-outline .mat-form-field-infix{padding:14px 12px 10px;border-top:0;max-width:300px}.mat-tab-group{font-family:Inter,sans-serif}.mat-tab-label{font-weight:500!important;font-size:14px!important;height:auto!important;min-width:auto!important;padding:0!important}.mat-ink-bar{background-color:#000000e6!important;height:3px!important}.mat-form-field-wrapper{padding-bottom:0}.mat-form-field{max-width:300px}table{border-collapse:collapse;border-spacing:0}.mat-form-field-appearance-outline .mat-form-field-infix{padding:0!important}.mat-divider{margin:12px 0}::ng-deep .mat-form-field-wrapper{height:30px}::ng-deep .mat-form-field-flex{height:30px}::ng-deep .mat-form-field-appearance-outline .mat-form-field-outline{height:35px}:ng-deep .mat-form-field-outline .mat-form-field-outline-thick{height:35px}::ng-deep .mat-select{line-height:20px}::ng-deep .mat-form-field-infix{border-top:0px!important}::ng-deep .mat-paginator{background:transparent!important}::ng-deep .mat-paginator-container{min-height:30px!important}::ng-deep .mat-paginator-range-label{margin:0 10px 0 24px!important;font-size:15px!important}::ng-deep .pagination{font-size:13px;color:#0000008a}::ng-deep .per-page-block{display:flex;line-height:42px!important}::ng-deep .item_per_page{line-height:42px!important}::ng-deep .select-page-size{line-height:42px!important}.icon-dot{display:block;color:#4f4f4f;font-size:16px;line-height:5px}.button-action-dot:hover{background:#dfdfdf}.button-action-dot{padding:0 5px 5px;border-radius:.25rem}\n"], dependencies: [{ kind: "directive", type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i7.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i8.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "diameter", "strokeWidth", "mode", "value"], exportAs: ["matProgressSpinner"] }, { kind: "component", type: i9.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i9.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i9.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i9.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i9.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i9.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i9.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i9.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i9.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i9.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "component", type: i10.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i10.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i10.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "component", type: i11.PaginationComponent, selector: "app-pagination", inputs: ["pagination", "showPageSizeOptions", "showRefreshButton", "lengthPending"], outputs: ["pageEmitter", "pageNumberChangeEmitter"] }] });
121
122
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: UsersListComponent, decorators: [{
122
123
  type: Component,
123
124
  args: [{ selector: 'app-users-list', template: "<app-pagination\n [pagination]=\"usersSearchService.getPagination()\"\n [showPageSizeOptions]=\"true\"\n (pageNumberChangeEmitter)=\"pageNumberChangeEvent($event)\"\n (pageEmitter)=\"pageEvent($event)\">\n</app-pagination>\n\n<table class=\"webex-table\" mat-table *ngIf=\"users?.length\" #table [dataSource]=\"dataSource\">\n\n <ng-container matColumnDef=\"user-icon\">\n <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\"></th>\n <td class=\"user-site\" mat-cell *matCellDef=\"let user\"\n [ngClass]=\"{'disabled-user-row': moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid}\"\n (click)=\"onUserClick(user)\">\n <span class=\"icon-webex-box\"><span class=\"icon-webex icon-webex-user\"></span></span>\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"name\">\n <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\">First / Last Name</th>\n <td class=\"user-site\" mat-cell *matCellDef=\"let user\"\n [ngClass]=\"{'disabled-user-row': moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid}\"\n (click)=\"onUserClick(user)\"> {{ user.firstName }} {{ user.lastName }}\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"email\">\n <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\">Email</th>\n <td class=\"user-site\" [ngClass]=\"{'disabled-user-row': moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid}\"\n mat-cell *matCellDef=\"let user\" (click)=\"onUserClick(user)\">\n {{ user.email }}\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"status\">\n <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\">Status</th>\n <td class=\"user-site\" mat-cell *matCellDef=\"let user\"\n [ngClass]=\"{'disabled-user-row': moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid}\"\n (click)=\"onUserClick(user)\">\n <span class=\"icon-user-status icon-user-status-active\"></span>{{user.status || user.webexUUID ? 'Migrated' : 'Active'}}\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"actions\">\n <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\"></th>\n <td class=\"user-site\" mat-cell *matCellDef=\"let user, let i = index\"\n [ngClass]=\"{'disabled-user-row': moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid}\">\n <mat-progress-spinner class=\"field-spinner\"\n [diameter]=\"20\"\n mode=\"indeterminate\"\n *ngIf=\"moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid\"></mat-progress-spinner>\n <button *ngIf=\"!(moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid)\"\n class=\"button-action-dot\" mat-icon-button [matMenuTriggerFor]=\"menu\">\n <div class=\"icon-actions-dots\">\n <span class=\"icon-dot\">.</span>\n <span class=\"icon-dot\">.</span>\n <span class=\"icon-dot\">.</span>\n </div>\n </button>\n <mat-menu #menu=\"matMenu\">\n <button mat-menu-item [disabled]=\"true\">Resend Invitation</button>\n <button mat-menu-item [disabled]=\"true\">Reset Password</button>\n <button mat-menu-item (click)=\"moveUser(user, i)\">Move User</button>\n <button mat-menu-item [disabled]=\"true\">Deactivate User</button>\n <button mat-menu-item [disabled]=\"true\">Delete User</button>\n </mat-menu>\n </td>\n </ng-container>\n\n <ng-container matColumnDef=\"role\">\n <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\">Administrator Role</th>\n <td class=\"user-site\" mat-cell *matCellDef=\"let user\" (click)=\"onUserClick(user)\">{{ user.roleName || '' }}</td>\n </ng-container>\n\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns; sticky: true\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\"></tr>\n</table>\n", styles: ["@import\"https://fonts.googleapis.com/css?family=Poppins:400,100,200,300,500,600,800,700,900\";table.mat-table{border-spacing:0;width:100%}::ng-deep .mat-paginator{background:none}.icon-user-status{width:.5rem;height:.5rem;border-radius:50%;background-color:#707070;margin:0 5px 0 0}.icon-user-status.icon-user-status-active{background-color:#1d805f;display:inline-block}.mat-select{height:100%;line-height:35px}.mat-form-field-wrapper{padding-bottom:0!important}.mat-form-field{padding:0;max-width:300px}.fa:hover{color:#0d56aa!important}.mat-icon-button{background:transparent}.icon-webex-box{width:2rem;height:2rem;font-size:.7rem;line-height:1rem;display:inline-block;background:#d0d0d0;border-radius:2rem;line-height:40px;text-align:center}.icon-webex{filter:invert(12%) sepia(14%) saturate(4%) hue-rotate(354deg) brightness(103%) contrast(90%);background-repeat:no-repeat;background-position:center;display:inline-block;height:1rem;width:1rem}.icon-webex-user{background-image:url(\"data:image/svg+xml,%3C%3Fxml version%3D%221.0%22 encoding%3D%22UTF-8%22%3F%3E%3Csvg id%3D%22a%22 xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22 viewBox%3D%220 0 16.67 15.56%22%3E%3Cdefs%3E%3Cstyle%3E.b%7Bfill%3Anone%3Bstroke%3A%232c355d%3Bstroke-width%3A1.4px%3B%7D%3C%2Fstyle%3E%3C%2Fdefs%3E%3Cpath class%3D%22b%22 d%3D%22M4.87%2C3.89c0-1.72%2C1.51-3.19%2C3.47-3.19s3.47%2C1.47%2C3.47%2C3.19-1.51%2C3.19-3.47%2C3.19-3.47-1.47-3.47-3.19ZM.7%2C12.64c0-.37%2C.19-.76%2C.67-1.17%2C.48-.41%2C1.17-.78%2C2-1.09%2C1.66-.62%2C3.66-.93%2C4.97-.93s3.31%2C.31%2C4.97%2C.93c.83%2C.31%2C1.52%2C.68%2C2%2C1.09%2C.47%2C.41%2C.67%2C.8%2C.67%2C1.17v2.22H.7v-2.22Z%22%2F%3E%3C%2Fsvg%3E\")}.icon-user-status{display:inline-block}*{margin:0}body{background:#f7f7f7}body,th,td{font-family:Poppins,Poppins,sans-serif;font-size:14px}th{color:#0000008a;text-align:left}td{box-sizing:border-box;padding:10px 5px 10px 0}.content-box{margin:auto;position:relative;width:95%}.content-box table{width:100%}.edit-icon-td{width:50px;position:relative}.edit-icon-td button{position:absolute;top:4px}.mat-progress-spinner circle,.mat-spinner circle{stroke:#009fdb!important}.data-loader{position:absolute;top:calc(50% - 25px);left:calc(50% - 25px)}.flex-box{display:flex;justify-content:flex-start}.user-info-box{background:white;display:grid;grid-template-columns:30% 70%;border-radius:8px;border:rgba(0,0,0,.2) 1px solid;padding:24px;font-weight:400;font-size:14px}.user-info-box h3{display:block;font-weight:500;font-size:16px}.mat-divider{margin:5px 0!important}.info-boxes-container{padding:24px 0;display:flex;flex-direction:column;gap:24px}.header-box{height:60px;width:100%;line-height:60px;background:white;border-bottom:1px solid #dedddd}.header-box .header-back-block{float:left}.header-box .header-button-block{float:right}.webex-table{width:100%;margin:auto}.webex-table tr{border-bottom:1px solid #dedede}.webex-table th{background:#f7f7f7;color:#636363;font-size:12px}.webex-table td{background:#fff;color:#000;font-size:14px}.webex-table tr:hover td:not(.disabled-user-row){background:#ededed;cursor:pointer}.webex-table th.mat-header-cell,.webex-table td.mat-cell,.webex-table td.mat-footer-cell{border-bottom:1px solid #dedede}.webex-table tr.mat-header-row{height:37px}.mat-form-field{padding:0 0 5px;width:93%}.mat-form-field.mat-form-field-disabled{border-bottom:none}.mat-error{color:#c73636;margin:13px 0 0}.select-box{border-radius:30px;background:#F3F6F6;border:1px solid #E2E9EF;height:35px;position:relative}.select-box select{border:none!important;background:transparent;height:100%;width:92%;margin:auto;display:block}option:focus,option:focus-visible{border:none!important;outline:none!important}option{height:30px;cursor:pointer;color:#636363}option:hover{background:#ededed!important}.mat-select{height:100%!important;line-height:35px!important}.info-holder,.input-holder{display:grid;grid-template-columns:30% 70%;align-items:baseline}.info-holder__name,.input-holder__name{font-weight:500!important;font-size:14px!important}.info-holder__inputs .input-holder,.input-holder__inputs .input-holder{display:grid;grid-template-columns:30% 70%;align-items:baseline}.info-holder__inputs .input-holder__name,.input-holder__inputs .input-holder__name{font-weight:400!important;font-size:14px!important}.mat-form-field-wrapper,.mat-form-field-flex{height:30px!important}.mat-form-field-appearance-outline .mat-form-field-outline,.mat-form-field-outline .mat-form-field-outline-thick{height:35px!important}.mat-select{line-height:20px!important}.mat-form-field-appearance-outline .mat-form-field-infix{padding:14px 12px 10px;border-top:0;max-width:300px}.mat-tab-group{font-family:Inter,sans-serif}.mat-tab-label{font-weight:500!important;font-size:14px!important;height:auto!important;min-width:auto!important;padding:0!important}.mat-ink-bar{background-color:#000000e6!important;height:3px!important}.mat-form-field-wrapper{padding-bottom:0}.mat-form-field{max-width:300px}table{border-collapse:collapse;border-spacing:0}.mat-form-field-appearance-outline .mat-form-field-infix{padding:0!important}.mat-divider{margin:12px 0}::ng-deep .mat-form-field-wrapper{height:30px}::ng-deep .mat-form-field-flex{height:30px}::ng-deep .mat-form-field-appearance-outline .mat-form-field-outline{height:35px}:ng-deep .mat-form-field-outline .mat-form-field-outline-thick{height:35px}::ng-deep .mat-select{line-height:20px}::ng-deep .mat-form-field-infix{border-top:0px!important}::ng-deep .mat-paginator{background:transparent!important}::ng-deep .mat-paginator-container{min-height:30px!important}::ng-deep .mat-paginator-range-label{margin:0 10px 0 24px!important;font-size:15px!important}::ng-deep .pagination{font-size:13px;color:#0000008a}::ng-deep .per-page-block{display:flex;line-height:42px!important}::ng-deep .item_per_page{line-height:42px!important}::ng-deep .select-page-size{line-height:42px!important}.icon-dot{display:block;color:#4f4f4f;font-size:16px;line-height:5px}.button-action-dot:hover{background:#dfdfdf}.button-action-dot{padding:0 5px 5px;border-radius:.25rem}\n"] }]
@@ -125,6 +126,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
125
126
  type: Input
126
127
  }], customerId: [{
127
128
  type: Input
129
+ }], siteId: [{
130
+ type: Input
128
131
  }], openUser: [{
129
132
  type: Output
130
133
  }], userMoved: [{
@@ -132,4 +135,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
132
135
  }], host: [{
133
136
  type: Input
134
137
  }] } });
135
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"users-list.component.js","sourceRoot":"","sources":["../../../../../../projects/tuki/widgets/users-list/src/users-list.component.ts","../../../../../../projects/tuki/widgets/users-list/src/users-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { FormGroup } from '@angular/forms';\nimport { UserService } from './services/user.service';\nimport { APIService } from \"./services/api.service\";\nimport { NotificationService } from './services/notification.service';\nimport { Subscription } from 'rxjs';\nimport { UsersSearchService } from './services/users-search.service';\nimport { ListUser } from './classes/user-list';\nimport { MatTableDataSource } from '@angular/material/table';\nimport { PageEvent } from '@angular/material/paginator';\nimport { ApiWebexService } from './services/api-webex.service';\n\nconst DISPLAYED_COLS = ['user-icon', 'name', 'email', 'status', 'role', 'actions'];\n\n@Component({\n  selector: 'app-users-list',\n  templateUrl: './users-list.component.html',\n  styleUrls: ['./users-list.component.scss']\n})\nexport class UsersListComponent implements OnInit {\n  @Input() token!: string;\n  @Input() customerId!: number;\n  @Output() openUser = new EventEmitter();\n  @Output() userMoved = new EventEmitter();\n  @Input() host!: string;\n  dataPending!: boolean;\n  moveUserPending!: boolean;\n  moveInProgressUserId!: string;\n  users!: ListUser[];\n  dataSource!: MatTableDataSource<ListUser>;\n  displayedColumns = DISPLAYED_COLS;\n  private searchSubscription!: Subscription;\n\n  get form(): FormGroup {\n    return this.userService?.user?.form;\n  }\n\n  constructor(\n    public userService: UserService,\n    private apiService: APIService,\n    private apiWebexService: ApiWebexService,\n    private notifications: NotificationService,\n    public usersSearchService: UsersSearchService\n  ) {\n    console.log('users list 1');\n  }\n\n  ngOnInit(): void {\n    console.log('users list 2');\n    this.usersSearchService.setDefaultValues();\n    this.usersSearchService.customerId = this.customerId;\n    this.apiService.token = this.token;\n    this.apiWebexService.token = this.token;\n    this.apiService.apiUrl = this.host + '/dcp';\n    this.apiWebexService.apiUrl = this.host + '/webex';\n\n    this.runSearch();\n    this.searchSubscription = this.usersSearchService.foundUsers$\n      .subscribe((users: ListUser[]) => {\n        this.initializeDataSource(users);\n      });\n  }\n\n  public pageNumberChangeEvent(perPageNumber: number): void {\n    this.usersSearchService.pageSize = perPageNumber;\n    this.usersSearchService.pageIndex = 0;\n    this.runSearch();\n  }\n\n  public pageEvent(event: PageEvent): void {\n    this.usersSearchService.pageSize = event.pageSize;\n    this.usersSearchService.pageIndex = event.pageIndex;\n    this.runSearch();\n  }\n\n  public onUserClick(user: ListUser): void {\n    this.openUser.emit(user);\n  }\n\n  public moveUser(user: ListUser, index: number): void {\n    this.moveUserPending = true;\n    this.moveInProgressUserId = user.userid;\n    this.setStatusToUser(index, 'In Progress');\n    if (user && user.siteId && user.userid) {\n      const subscription = this.userService.moveUser(this.customerId, user)\n        .subscribe(() => {\n          this.moveInProgressUserId = '';\n          this.moveUserPending = false;\n          this.setStatusToUser(index, 'Migrated');\n        }, () => {\n          this.moveUserPending = false;\n          this.moveInProgressUserId = '';\n          this.setStatusToUser(index, 'Migration Error');\n        });\n    }\n  }\n\n  private setStatusToUser(index: number, status: string): void {\n    if (this.users && this.users[index]) {\n      this.users[index].status = status;\n    }\n    this.dataSource = new MatTableDataSource(this.users);\n  }\n\n  private initializeDataSource(users: ListUser[]): void {\n    if(users?.length) {\n      this.setRandomUserRole(users);\n      this.users = users;\n      this.dataSource = new MatTableDataSource(users);\n    }\n  }\n\n  private setRandomUserRole(users: ListUser[]): void {\n      const max = Math.round(this.usersSearchService.pageSize - this.usersSearchService.pageSize / 4);\n      const min = Math.round(this.usersSearchService.pageSize / 2);\n      const randomAmount = Math.round(Math.random() * (max - min) + min);\n      const indexes = this.getArrayOfRandomUserIndexes(randomAmount);\n      indexes.forEach(index => {\n        if (users[index]) {\n          users[index].roleName = 'Dedicated Instance Calling user'\n        }\n      });\n    }\n\n    private getArrayOfRandomUserIndexes(randomAmount: number): number[] {\n      const indexes = [];\n      while (randomAmount > 0) {\n        const index = Math.round(Math.random() * (this.usersSearchService.pageSize - 1));\n        indexes.push(index)\n        randomAmount--;\n      }\n      return indexes;\n    }\n\n  private runSearch(): void {\n    this.dataPending = true;\n    this.usersSearchService.quickRegularUsersSearch()\n      .subscribe(() => {\n        this.dataPending = false;\n      }, () => {\n        this.dataPending = false;\n        this.notifications.error('The data can not be received');\n      });\n  }\n}\n","<app-pagination\n  [pagination]=\"usersSearchService.getPagination()\"\n  [showPageSizeOptions]=\"true\"\n  (pageNumberChangeEmitter)=\"pageNumberChangeEvent($event)\"\n  (pageEmitter)=\"pageEvent($event)\">\n</app-pagination>\n\n<table class=\"webex-table\" mat-table *ngIf=\"users?.length\" #table [dataSource]=\"dataSource\">\n\n  <ng-container matColumnDef=\"user-icon\">\n    <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\"></th>\n    <td class=\"user-site\" mat-cell *matCellDef=\"let user\"\n        [ngClass]=\"{'disabled-user-row': moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid}\"\n        (click)=\"onUserClick(user)\">\n      <span class=\"icon-webex-box\"><span class=\"icon-webex icon-webex-user\"></span></span>\n    </td>\n  </ng-container>\n\n  <ng-container matColumnDef=\"name\">\n    <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\">First / Last Name</th>\n    <td class=\"user-site\" mat-cell *matCellDef=\"let user\"\n        [ngClass]=\"{'disabled-user-row': moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid}\"\n        (click)=\"onUserClick(user)\"> {{ user.firstName }} {{ user.lastName }}\n    </td>\n  </ng-container>\n\n  <ng-container matColumnDef=\"email\">\n    <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\">Email</th>\n    <td class=\"user-site\" [ngClass]=\"{'disabled-user-row': moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid}\"\n        mat-cell *matCellDef=\"let user\" (click)=\"onUserClick(user)\">\n      {{ user.email }}\n    </td>\n  </ng-container>\n\n  <ng-container matColumnDef=\"status\">\n    <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\">Status</th>\n    <td class=\"user-site\" mat-cell *matCellDef=\"let user\"\n        [ngClass]=\"{'disabled-user-row': moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid}\"\n        (click)=\"onUserClick(user)\">\n      <span class=\"icon-user-status icon-user-status-active\"></span>{{user.status || user.webexUUID ? 'Migrated' : 'Active'}}\n    </td>\n  </ng-container>\n\n  <ng-container matColumnDef=\"actions\">\n    <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\"></th>\n    <td class=\"user-site\" mat-cell *matCellDef=\"let user, let i = index\"\n        [ngClass]=\"{'disabled-user-row': moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid}\">\n      <mat-progress-spinner class=\"field-spinner\"\n                            [diameter]=\"20\"\n                            mode=\"indeterminate\"\n                            *ngIf=\"moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid\"></mat-progress-spinner>\n      <button *ngIf=\"!(moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid)\"\n              class=\"button-action-dot\" mat-icon-button [matMenuTriggerFor]=\"menu\">\n        <div class=\"icon-actions-dots\">\n          <span class=\"icon-dot\">.</span>\n          <span class=\"icon-dot\">.</span>\n          <span class=\"icon-dot\">.</span>\n        </div>\n      </button>\n      <mat-menu #menu=\"matMenu\">\n        <button mat-menu-item [disabled]=\"true\">Resend Invitation</button>\n        <button mat-menu-item [disabled]=\"true\">Reset Password</button>\n        <button mat-menu-item (click)=\"moveUser(user, i)\">Move User</button>\n        <button mat-menu-item [disabled]=\"true\">Deactivate User</button>\n        <button mat-menu-item [disabled]=\"true\">Delete User</button>\n      </mat-menu>\n    </td>\n  </ng-container>\n\n  <ng-container matColumnDef=\"role\">\n    <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\">Administrator Role</th>\n    <td class=\"user-site\" mat-cell *matCellDef=\"let user\" (click)=\"onUserClick(user)\">{{ user.roleName || '' }}</td>\n  </ng-container>\n\n  <tr mat-header-row *matHeaderRowDef=\"displayedColumns; sticky: true\"></tr>\n  <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\"></tr>\n</table>\n"]}
138
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"users-list.component.js","sourceRoot":"","sources":["../../../../../../projects/tuki/widgets/users-list/src/users-list.component.ts","../../../../../../projects/tuki/widgets/users-list/src/users-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { FormGroup } from '@angular/forms';\nimport { UserService } from './services/user.service';\nimport { APIService } from \"./services/api.service\";\nimport { NotificationService } from './services/notification.service';\nimport { Subscription } from 'rxjs';\nimport { UsersSearchService } from './services/users-search.service';\nimport { ListUser } from './classes/user-list';\nimport { MatTableDataSource } from '@angular/material/table';\nimport { PageEvent } from '@angular/material/paginator';\nimport { ApiWebexService } from './services/api-webex.service';\n\nconst DISPLAYED_COLS = ['user-icon', 'name', 'email', 'status', 'role', 'actions'];\n\n@Component({\n  selector: 'app-users-list',\n  templateUrl: './users-list.component.html',\n  styleUrls: ['./users-list.component.scss']\n})\nexport class UsersListComponent implements OnInit {\n  @Input() token!: string;\n  @Input() customerId!: number;\n  @Input() siteId!: number;\n  @Output() openUser = new EventEmitter();\n  @Output() userMoved = new EventEmitter();\n  @Input() host!: string;\n  dataPending!: boolean;\n  moveUserPending!: boolean;\n  moveInProgressUserId!: string;\n  users!: ListUser[];\n  dataSource!: MatTableDataSource<ListUser>;\n  displayedColumns = DISPLAYED_COLS;\n  private searchSubscription!: Subscription;\n\n  get form(): FormGroup {\n    return this.userService?.user?.form;\n  }\n\n  constructor(\n    public userService: UserService,\n    private apiService: APIService,\n    private apiWebexService: ApiWebexService,\n    private notifications: NotificationService,\n    public usersSearchService: UsersSearchService\n  ) {\n    console.log('users list 1');\n  }\n\n  ngOnInit(): void {\n    console.log('users list 2');\n    this.usersSearchService.setDefaultValues();\n    this.usersSearchService.customerId = this.customerId;\n    this.usersSearchService.siteId = this.siteId;\n    this.apiService.token = this.token;\n    this.apiWebexService.token = this.token;\n    this.apiService.apiUrl = this.host + '/dcp';\n    this.apiWebexService.apiUrl = this.host + '/webex';\n\n    this.runSearch();\n    this.searchSubscription = this.usersSearchService.foundUsers$\n      .subscribe((users: ListUser[]) => {\n        this.initializeDataSource(users);\n      });\n  }\n\n  public pageNumberChangeEvent(perPageNumber: number): void {\n    this.usersSearchService.pageSize = perPageNumber;\n    this.usersSearchService.pageIndex = 0;\n    this.runSearch();\n  }\n\n  public pageEvent(event: PageEvent): void {\n    this.usersSearchService.pageSize = event.pageSize;\n    this.usersSearchService.pageIndex = event.pageIndex;\n    this.runSearch();\n  }\n\n  public onUserClick(user: ListUser): void {\n    this.openUser.emit(user);\n  }\n\n  public moveUser(user: ListUser, index: number): void {\n    this.moveUserPending = true;\n    this.moveInProgressUserId = user.userid;\n    this.setStatusToUser(index, 'In Progress');\n    if (user && user.siteId && user.userid) {\n      const subscription = this.userService.moveUser(this.customerId, user)\n        .subscribe(() => {\n          this.moveInProgressUserId = '';\n          this.moveUserPending = false;\n          this.setStatusToUser(index, 'Migrated');\n        }, () => {\n          this.moveUserPending = false;\n          this.moveInProgressUserId = '';\n          this.setStatusToUser(index, 'Migration Error');\n        });\n    }\n  }\n\n  private setStatusToUser(index: number, status: string): void {\n    if (this.users && this.users[index]) {\n      this.users[index].status = status;\n    }\n    this.dataSource = new MatTableDataSource(this.users);\n  }\n\n  private initializeDataSource(users: ListUser[]): void {\n    if(users?.length) {\n      this.setRandomUserRole(users);\n      this.users = users;\n      this.dataSource = new MatTableDataSource(users);\n    }\n  }\n\n  private setRandomUserRole(users: ListUser[]): void {\n      const max = Math.round(this.usersSearchService.pageSize - this.usersSearchService.pageSize / 4);\n      const min = Math.round(this.usersSearchService.pageSize / 2);\n      const randomAmount = Math.round(Math.random() * (max - min) + min);\n      const indexes = this.getArrayOfRandomUserIndexes(randomAmount);\n      indexes.forEach(index => {\n        if (users[index]) {\n          users[index].roleName = 'Dedicated Instance Calling user'\n        }\n      });\n    }\n\n    private getArrayOfRandomUserIndexes(randomAmount: number): number[] {\n      const indexes = [];\n      while (randomAmount > 0) {\n        const index = Math.round(Math.random() * (this.usersSearchService.pageSize - 1));\n        indexes.push(index)\n        randomAmount--;\n      }\n      return indexes;\n    }\n\n  private runSearch(): void {\n    this.dataPending = true;\n    this.usersSearchService.quickRegularUsersSearch()\n      .subscribe(() => {\n        this.dataPending = false;\n      }, () => {\n        this.dataPending = false;\n        this.notifications.error('The data can not be received');\n      });\n  }\n}\n","<app-pagination\n  [pagination]=\"usersSearchService.getPagination()\"\n  [showPageSizeOptions]=\"true\"\n  (pageNumberChangeEmitter)=\"pageNumberChangeEvent($event)\"\n  (pageEmitter)=\"pageEvent($event)\">\n</app-pagination>\n\n<table class=\"webex-table\" mat-table *ngIf=\"users?.length\" #table [dataSource]=\"dataSource\">\n\n  <ng-container matColumnDef=\"user-icon\">\n    <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\"></th>\n    <td class=\"user-site\" mat-cell *matCellDef=\"let user\"\n        [ngClass]=\"{'disabled-user-row': moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid}\"\n        (click)=\"onUserClick(user)\">\n      <span class=\"icon-webex-box\"><span class=\"icon-webex icon-webex-user\"></span></span>\n    </td>\n  </ng-container>\n\n  <ng-container matColumnDef=\"name\">\n    <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\">First / Last Name</th>\n    <td class=\"user-site\" mat-cell *matCellDef=\"let user\"\n        [ngClass]=\"{'disabled-user-row': moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid}\"\n        (click)=\"onUserClick(user)\"> {{ user.firstName }} {{ user.lastName }}\n    </td>\n  </ng-container>\n\n  <ng-container matColumnDef=\"email\">\n    <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\">Email</th>\n    <td class=\"user-site\" [ngClass]=\"{'disabled-user-row': moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid}\"\n        mat-cell *matCellDef=\"let user\" (click)=\"onUserClick(user)\">\n      {{ user.email }}\n    </td>\n  </ng-container>\n\n  <ng-container matColumnDef=\"status\">\n    <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\">Status</th>\n    <td class=\"user-site\" mat-cell *matCellDef=\"let user\"\n        [ngClass]=\"{'disabled-user-row': moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid}\"\n        (click)=\"onUserClick(user)\">\n      <span class=\"icon-user-status icon-user-status-active\"></span>{{user.status || user.webexUUID ? 'Migrated' : 'Active'}}\n    </td>\n  </ng-container>\n\n  <ng-container matColumnDef=\"actions\">\n    <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\"></th>\n    <td class=\"user-site\" mat-cell *matCellDef=\"let user, let i = index\"\n        [ngClass]=\"{'disabled-user-row': moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid}\">\n      <mat-progress-spinner class=\"field-spinner\"\n                            [diameter]=\"20\"\n                            mode=\"indeterminate\"\n                            *ngIf=\"moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid\"></mat-progress-spinner>\n      <button *ngIf=\"!(moveUserPending && moveInProgressUserId && moveInProgressUserId === user?.userid)\"\n              class=\"button-action-dot\" mat-icon-button [matMenuTriggerFor]=\"menu\">\n        <div class=\"icon-actions-dots\">\n          <span class=\"icon-dot\">.</span>\n          <span class=\"icon-dot\">.</span>\n          <span class=\"icon-dot\">.</span>\n        </div>\n      </button>\n      <mat-menu #menu=\"matMenu\">\n        <button mat-menu-item [disabled]=\"true\">Resend Invitation</button>\n        <button mat-menu-item [disabled]=\"true\">Reset Password</button>\n        <button mat-menu-item (click)=\"moveUser(user, i)\">Move User</button>\n        <button mat-menu-item [disabled]=\"true\">Deactivate User</button>\n        <button mat-menu-item [disabled]=\"true\">Delete User</button>\n      </mat-menu>\n    </td>\n  </ng-container>\n\n  <ng-container matColumnDef=\"role\">\n    <th mat-header-cell *matHeaderCellDef class=\"webex-table-th\">Administrator Role</th>\n    <td class=\"user-site\" mat-cell *matCellDef=\"let user\" (click)=\"onUserClick(user)\">{{ user.roleName || '' }}</td>\n  </ng-container>\n\n  <tr mat-header-row *matHeaderRowDef=\"displayedColumns; sticky: true\"></tr>\n  <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\"></tr>\n</table>\n"]}
@@ -378,12 +378,12 @@ class UserService {
378
378
  return this.apiService.fetch(API.USER_TOKEN.replace(':siteId', String(this.siteId)).replace(':userId', encodeURIComponent(encodeURIComponent(userId))))
379
379
  .pipe(map((result) => {
380
380
  this.setSimplifiedUser(Object.values(result)[0]);
381
+ this.user.token = Object.keys(result)[0];
381
382
  }));
382
383
  // .pipe(this.handleError(false, true));
383
384
  }
384
385
  updateUserFields(body) {
385
- var _a;
386
- if (!this.userId || !this.siteId || !((_a = this.user) === null || _a === void 0 ? void 0 : _a.token)) {
386
+ if (!this.siteId) {
387
387
  return;
388
388
  }
389
389
  return this.apiService.post(API.UPDATE_USER_FIELDS.replace(':siteId', String(this.siteId)).replace(':token', this.user.token), body);
@@ -1054,13 +1054,12 @@ class UserManageWidgetComponent {
1054
1054
  }
1055
1055
  saveChanges() {
1056
1056
  var _a;
1057
- this.onSave.next("start saving..");
1058
1057
  if (!this.userService.hasUnsavedChanges() || ((_a = this.form) === null || _a === void 0 ? void 0 : _a.invalid)) {
1059
1058
  return;
1060
1059
  }
1061
1060
  const subscription = this.userService.persistCacheChanges()
1062
1061
  .subscribe(() => {
1063
- this.onSave.next("saved");
1062
+ this.onSave.next("user has been saved successfully..");
1064
1063
  subscription.unsubscribe();
1065
1064
  });
1066
1065
  }