nuxeo-development-framework 5.5.4 → 5.5.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/nuxeo-development-framework.umd.js +2 -1
- package/bundles/nuxeo-development-framework.umd.js.map +1 -1
- package/esm2015/lib/components/dynamic-form/components/dynamic-form-select-users/dynamic-form-select-users.component.js +3 -2
- package/esm2015/lib/components/spell-checker-field/spell-checker-field.module.js +1 -1
- package/fesm2015/nuxeo-development-framework.js +2 -1
- package/fesm2015/nuxeo-development-framework.js.map +1 -1
- package/package.json +1 -1
|
@@ -112,8 +112,9 @@ export class DynamicFormSelectUsersComponent {
|
|
|
112
112
|
}
|
|
113
113
|
}
|
|
114
114
|
ngOnInit() {
|
|
115
|
+
var _a;
|
|
115
116
|
this.allUsers = this.deptTitle === 'all' ? true : false;
|
|
116
|
-
this.selection = this.multiple ? [] : undefined;
|
|
117
|
+
this.selection = (_a = this.selection) !== null && _a !== void 0 ? _a : (this.multiple ? [] : undefined);
|
|
117
118
|
if (this.allUsers) {
|
|
118
119
|
this.loadUsers();
|
|
119
120
|
}
|
|
@@ -334,4 +335,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
334
335
|
}], onSelectItems: [{
|
|
335
336
|
type: Output
|
|
336
337
|
}], getUsersSuggestions: [] } });
|
|
337
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form-select-users.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-select-users/dynamic-form-select-users.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-select-users/dynamic-form-select-users.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  Optional,\r\n  Output,\r\n  Self,\r\n  SimpleChanges,\r\n  ViewChild,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport {\r\n  AbstractControl,\r\n  ControlValueAccessor,\r\n  FormControl,\r\n  NgControl,\r\n} from '@angular/forms';\r\nimport { NgSelectComponent } from '@ng-select/ng-select';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { Observable, of, Subject } from 'rxjs';\r\nimport {\r\n  catchError,\r\n  debounceTime,\r\n  distinctUntilChanged,\r\n  switchMap,\r\n  tap,\r\n} from 'rxjs/operators';\r\nimport { TranslationService } from '../../../../core/services/translation/translation.service';\r\nimport { UsersInDepartmentsApiService } from './services/user-api.service';\r\nimport * as _ from 'lodash';\r\nimport { Cacheable } from 'ts-cacheable';\r\n/**\r\n * Users dropdown input integrated with users API,\r\n * that can be used inside reactive or template driven forms\r\n * @title\r\n * Users dropdown\r\n * @example\r\n * <cts-dynamic-form-select-users\r\n *     formControlName=\"controlName\"\r\n *     [bindValue]=\"bindToProperty\"\r\n *     [bindLabel]=\"'bindToLabel'\"\r\n *     [searchable]=\"true\"\r\n *     [label]=\"'PATH.TO.TRANSLATION'\"\r\n *     [deptTitle]=\"'all'\"\r\n *   ></cts-dynamic-form-select-users>\r\n */\r\nconst minute = 60000;\r\n@Component({\r\n  selector: 'cts-dynamic-form-select-users',\r\n  templateUrl: './dynamic-form-select-users.component.html',\r\n  styleUrls: ['./dynamic-form-select-users.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class DynamicFormSelectUsersComponent\r\n  implements OnChanges, OnDestroy, ControlValueAccessor {\r\n  @ViewChild('ngSelectComponent') ngSelectComponent: NgSelectComponent;\r\n  selectionstrg: string;\r\n  data = [];\r\n  allUsers: boolean;\r\n  userNameInput$ = new Subject<string>();\r\n  /** filter users by department (departmentName | all) */\r\n  @Input() deptTitle: string;\r\n  /** filter users by group name => this will replce dep title */\r\n  @Input() groupName: string;\r\n  /** Field Label */\r\n  @Input() label: string;\r\n  /** Bind value to object property */\r\n  @Input() bindValue;\r\n  /** Bind label to object property */\r\n  @Input() bindLabel;\r\n  @Input() arabicBindLabel;\r\n  /** Placeholder text */\r\n  @Input() placeholder;\r\n  /** Can select multiple */\r\n  @Input() multiple = false;\r\n  /** is dropdown searchable */\r\n  @Input() searchable = false;\r\n  /** should close dropdown on value selection */\r\n  @Input() closeOnSelect = true;\r\n  /** should hide selected items */\r\n  @Input() hideSelectedItems = false;\r\n  /** Pre Selected values */\r\n  @Input() preSelectedValues;\r\n  /** flage to use preselected values or not */\r\n  @Input() usePreSelectedValue = false;\r\n  /** is Disabled */\r\n  @Input() disabled = false;\r\n  /** List of usernames that should be exluded  */\r\n  @Input() filter: string[] = [];\r\n\r\n  /** flage to indicate if use full arabic name or not beside fullName  */\r\n  @Input() useArabicName = false;\r\n\r\n  /** event emitted when item is selected */\r\n  @Output() onSelectItems = new EventEmitter();\r\n  loading = false;\r\n  selection;\r\n  buffer = [];\r\n  bufferSize = 1000;\r\n  numberOfItemsFromEndBeforeFetchingMore = 10;\r\n  suffix;\r\n\r\n  propagateChange: any = () => { };\r\n  validateFn: any = () => { };\r\n  isArabic = false;\r\n  public onTouched: any = () => {\r\n    /*Empty*/\r\n  };\r\n  pageIndex: number = 0;\r\n  isNextPageAvailable: boolean;\r\n  public get invalid(): boolean {\r\n    return this.control ? this.control.invalid : false;\r\n  }\r\n\r\n  public get showError(): boolean {\r\n    if (!this.control) {\r\n      return false;\r\n    }\r\n\r\n    const { dirty, touched } = this.control;\r\n\r\n    return this.invalid ? dirty || touched : false;\r\n  }\r\n  constructor(\r\n    private userApiService: UsersInDepartmentsApiService,\r\n    public translate: TranslateService,\r\n    private translation: TranslationService,\r\n    @Self() @Optional() public control: NgControl\r\n  ) {\r\n    if (this.control) {\r\n      this.control.valueAccessor = this;\r\n    }\r\n  }\r\n\r\n  emitSelection(event) {\r\n    if (this.multiple) {\r\n      this.selectionstrg = `${this.selection.length} ${this.suffix}`;\r\n    }\r\n    this.propagateChange(this.selection);\r\n    this.onSelectItems.emit(event);\r\n  }\r\n\r\n  onScrollToEnd() {\r\n    this.fetchMore();\r\n    ++this.pageIndex;\r\n    if (this.isNextPageAvailable && this.allUsers) {\r\n      this.getDepartments(this.pageIndex);\r\n    }\r\n  }\r\n\r\n  private fetchMore() {\r\n    this.loading = true;\r\n    const len = this.buffer.length;\r\n    const more = this.data.slice(len, this.bufferSize + len);\r\n    this.buffer = this.data.concat(more);\r\n    this.loading = false;\r\n  }\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if ((changes.deptTitle && !changes.deptTitle?.firstChange) || (changes.groupName && !changes.groupName?.firstChange)) {\r\n      this.data = [];\r\n      this.buffer = [];\r\n      this.getDepartments();\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.allUsers = this.deptTitle === 'all' ? true : false;\r\n    this.selection = this.multiple ? [] : undefined;\r\n    if (this.allUsers) {\r\n      this.loadUsers();\r\n    }\r\n    this.getDepartments();\r\n    this.translation.isArabic.subscribe((ar) => {\r\n      this.isArabic = ar;\r\n      ar\r\n        ? (this.suffix = 'مستخدم تم إختياره')\r\n        : (this.suffix = 'Users Selected');\r\n      if (this.multiple) {\r\n        this.selectionstrg = `${this.selection.length} ${this.suffix}`;\r\n      }\r\n    });\r\n  }\r\n\r\n  getDepartments(page = 0) {\r\n    if (this.groupName) {\r\n      this.userApiService.getUsersUnderCertainGroup(this.groupName).subscribe(data => {\r\n        let newData = this.constructUserArray(\r\n          data.users,\r\n          'properties.username'\r\n        );\r\n        this.data = this.data.concat(newData);\r\n        this.isNextPageAvailable = data.isNextPageAvailable;\r\n        this.buffer = (this.data || []).slice(0, this.bufferSize);\r\n        this.buffer.map((item) => {\r\n          item.isSelected = false;\r\n        });\r\n      })\r\n    } else if (this.deptTitle) {\r\n      if (this.allUsers) {\r\n        this.getAllUsers(page).subscribe((data) => {\r\n          let newData = this.constructUserArray(data.entries, 'id');\r\n          this.data = this.data.concat(newData);\r\n          this.isNextPageAvailable = data.isNextPageAvailable;\r\n          this.buffer = (this.data || []).slice(0, this.bufferSize);\r\n          this.buffer.map((item) => {\r\n            item.isSelected = false;\r\n          });\r\n          this.loading = false; // for loading spinner\r\n        });\r\n      } else {\r\n        this.getCtsUsers(this.deptTitle).subscribe((data) => {\r\n          let newData = this.constructUserArray(\r\n            data.users,\r\n            'properties.username'\r\n          );\r\n          this.data = this.data.concat(newData);\r\n          this.isNextPageAvailable = data.isNextPageAvailable;\r\n          this.buffer = (this.data || []).slice(0, this.bufferSize);\r\n          this.buffer.map((item) => {\r\n            item.isSelected = false;\r\n          });\r\n        });\r\n      }\r\n    }\r\n  }\r\n\r\n  getAllUsers(page = 0): Observable<any> {\r\n    return this.userApiService.getAllUsers({\r\n      currentPageIndex: page,\r\n      pageSize: 100,\r\n    });\r\n  }\r\n\r\n  private loadUsers() {\r\n    this.userNameInput$\r\n      .pipe(\r\n        debounceTime(200),\r\n        distinctUntilChanged(),\r\n        tap(() => (this.loading = true)),\r\n        switchMap((term) => {\r\n          if (term && term.length) {\r\n            return this.getUsersSuggestions(term);\r\n          } else {\r\n            return this.getAllUsers();\r\n          }\r\n        })\r\n      )\r\n      .subscribe(\r\n        (data: any) => {\r\n          if (data.entries.length) {\r\n            let newData = this.constructUserArray(data.entries, 'id');\r\n            this.buffer = (newData || []).slice(0, this.bufferSize);\r\n            this.isNextPageAvailable = data.isNextPageAvailable;\r\n            this.loading = false;\r\n          } else {\r\n            this.buffer = [];\r\n            this.loading = false;\r\n          }\r\n        },\r\n        (err) => {\r\n          this.loading = false;\r\n          this.buffer = [];\r\n        }\r\n      );\r\n  }\r\n\r\n  writeValue(value) {\r\n    if (value) {\r\n      this.selection = value;\r\n      if (this.multiple) {\r\n        this.selectionstrg = `${this.selection.length} ${this.suffix}`;\r\n      }\r\n    } else {\r\n      this.selection = null;\r\n      this.selectionstrg = null\r\n    }\r\n  }\r\n\r\n  compareFn(item, selected) {\r\n    console.log(\"item 1\", item);\r\n    console.log(\"Item 2\", selected);\r\n    return item.id === selected.id;\r\n  }\r\n\r\n  registerOnChange(fn) {\r\n    this.propagateChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any) {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  validate(c: FormControl) {\r\n    return this.validateFn(c);\r\n  }\r\n  isRequired() {\r\n    if (!this.control || !this.control.control.validator) {\r\n      return false;\r\n    }\r\n\r\n    const validator = this.control.control.validator({} as AbstractControl);\r\n    return validator && validator.required;\r\n  }\r\n  hasErrors(): boolean {\r\n    return this.showError;\r\n  }\r\n\r\n  // @Cacheable({\r\n  //   maxCacheCount: 1000,\r\n  //   maxAge: 20000,\r\n  // })\r\n\r\n  getCtsUsers(deptTitle): Observable<any> {\r\n    return this.userApiService.getCtsUsers(deptTitle);\r\n  }\r\n\r\n  @Cacheable({\r\n    maxCacheCount: 1000,\r\n    maxAge: 5 * minute,\r\n  })\r\n  getUsersSuggestions(term): Observable<any> {\r\n    return this.userApiService.getUsersSuggestions(term);\r\n  }\r\n\r\n  private constructUserArray(data, filterValue: string) {\r\n    let ConstructedData: any[];\r\n    // if not using arabic name then construct full name here\r\n    if (!this.useArabicName) {\r\n      ConstructedData = this.insertFUllName(data);\r\n    }\r\n    ConstructedData = this.filterUsers(data, filterValue);\r\n    return ConstructedData;\r\n  }\r\n\r\n  private insertFUllName(data) {\r\n    return data.map((user) => {\r\n      user.fullName = `${user.properties?.firstName} ${user.properties?.lastName}`;\r\n    });\r\n  }\r\n  private filterUsers(data, path: string) {\r\n    let filterData = data.filter((user) => {\r\n      const includedInFilter =\r\n        this.filter.includes(_.get(user, path)) ||\r\n        _.get(user, path) === 'Administrator';\r\n      return !includedInFilter;\r\n    });\r\n    return filterData;\r\n  }\r\n\r\n  getUsersUnderCertainGroup() {\r\n\r\n  }\r\n  reset() {\r\n    this.ngSelectComponent.handleClearClick();\r\n  }\r\n  ngOnDestroy(): void {\r\n    this.userNameInput$.unsubscribe();\r\n  }\r\n}\r\n","<ng-container *ngIf=\"label\">\r\n  <div>\r\n    <label class=\"select-label\"\r\n      >{{ label | translate\r\n      }}<span *ngIf=\"isRequired()\" class=\"text-danger mx-1\">*</span></label\r\n    >\r\n  </div>\r\n</ng-container>\r\n<div class=\"user-select\" [ngClass]=\"{ 'multiple-wrapper': multiple }\" SetRtl>\r\n  <ng-select\r\n    #ngSelectComponent\r\n    [items]=\"buffer\"\r\n    [bindLabel]=\"useArabicName ? (isArabic ? arabicBindLabel : bindLabel)  : bindLabel\"\r\n    [placeholder]=\"\r\n      multiple && (selection && selection.length > 0) ? selectionstrg : placeholder\r\n    \"\r\n    [multiple]=\"multiple\"\r\n    [searchable]=\"searchable\"\r\n    [closeOnSelect]=\"closeOnSelect\"\r\n    [hideSelected]=\"hideSelectedItems\"\r\n    [loading]=\"loading\"\r\n    (scrollToEnd)=\"onScrollToEnd()\"\r\n    [disabled]=\"disabled\"\r\n    [typeahead]=\"userNameInput$\"\r\n    [compareWith]=\"compareFn\"\r\n    [(ngModel)]=\"selection\"\r\n    (change)=\"emitSelection($event)\"\r\n  >\r\n    <ng-template ng-label-tmp let-item=\"item\" let-clear=\"clear\">\r\n      <span\r\n        style=\"\r\n          display: flex;\r\n          align-items: center;\r\n          column-gap: 4px;\r\n          font-size: 16px;\r\n        \"\r\n      >\r\n        <div style=\"width: 30px; height: 30px\">\r\n          <cts-avatar [user]=\"item\"></cts-avatar>\r\n        </div>\r\n        <div class=\"user-name\">\r\n          {{ item?.id === 'system' ? ('SYSTEM_ADMIN' | translate) : \r\n          (useArabicName ? (isArabic ? (item?.fullNameAr ? item?.fullNameAr : item?.fullName) : item?.fullName) : \r\n          (item?.properties?.firstName + \" \" +item?.properties?.lastName)) }}\r\n\r\n\r\n        </div>\r\n        <div>\r\n          <span\r\n            class=\"ng-value-icon right\"\r\n            (click)=\"clear(item)\"\r\n            aria-hidden=\"true\"\r\n            >×</span\r\n          >\r\n        </div>\r\n      </span>\r\n    </ng-template>\r\n\r\n    <ng-template\r\n      ng-option-tmp\r\n      let-item=\"item\"\r\n      let-item$=\"item$\"\r\n      let-index=\"index\"\r\n    >\r\n      <span\r\n        style=\"\r\n          display: flex;\r\n          align-items: center;\r\n          column-gap: 4px;\r\n          font-size: 16px;\r\n        \"\r\n      >\r\n        <mat-checkbox\r\n          *ngIf=\"multiple\"\r\n          id=\"item-{{ index }}\"\r\n          [ngModel]=\"item$.selected\"\r\n          (click)=\"(false)\"\r\n        ></mat-checkbox>\r\n        <div style=\"width: 30px; height: 30px\">\r\n          <cts-avatar [user]=\"item\"></cts-avatar>\r\n        </div>\r\n        <div>\r\n          {{ item?.id === 'system' ? ('SYSTEM_ADMIN' | translate) : \r\n          (useArabicName ? (isArabic ? (item?.fullNameAr ? item?.fullNameAr : item?.fullName) : item?.fullName) : \r\n          (item?.properties?.firstName + \" \" +item?.properties?.lastName)) }}\r\n        </div>\r\n\r\n        <div></div>\r\n      </span>\r\n    </ng-template>\r\n  </ng-select>\r\n</div>\r\n<mat-error\r\n  [attr.data-automation-id]=\"'card-textitem-error-'\"\r\n  class=\"app-textitem-editable-error\"\r\n  *ngIf=\"hasErrors()\"\r\n>\r\n  <ul>\r\n    <li *ngIf=\"control.errors.required\">\r\n      {{ \"VALIDATORS.REQUIRED\" | translate }}\r\n    </li>\r\n  </ul>\r\n</mat-error>\r\n"]}
|
|
338
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form-select-users.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-select-users/dynamic-form-select-users.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-select-users/dynamic-form-select-users.component.html"],"names":[],"mappings":";AAAA,OAAO,EACL,SAAS,EACT,YAAY,EACZ,KAAK,EAGL,QAAQ,EACR,MAAM,EACN,IAAI,EAEJ,SAAS,EACT,iBAAiB,GAClB,MAAM,eAAe,CAAC;AASvB,OAAO,EAAkB,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/C,OAAO,EAEL,YAAY,EACZ,oBAAoB,EACpB,SAAS,EACT,GAAG,GACJ,MAAM,gBAAgB,CAAC;AAGxB,OAAO,KAAK,CAAC,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;;;;;;;;;;;;AACzC;;;;;;;;;;;;;;GAcG;AACH,MAAM,MAAM,GAAG,KAAK,CAAC;AAOrB,MAAM,OAAO,+BAA+B;IAsE1C,YACU,cAA4C,EAC7C,SAA2B,EAC1B,WAA+B,EACZ,OAAkB;QAHrC,mBAAc,GAAd,cAAc,CAA8B;QAC7C,cAAS,GAAT,SAAS,CAAkB;QAC1B,gBAAW,GAAX,WAAW,CAAoB;QACZ,YAAO,GAAP,OAAO,CAAW;QAtE/C,SAAI,GAAG,EAAE,CAAC;QAEV,mBAAc,GAAG,IAAI,OAAO,EAAU,CAAC;QAcvC,0BAA0B;QACjB,aAAQ,GAAG,KAAK,CAAC;QAC1B,6BAA6B;QACpB,eAAU,GAAG,KAAK,CAAC;QAC5B,+CAA+C;QACtC,kBAAa,GAAG,IAAI,CAAC;QAC9B,iCAAiC;QACxB,sBAAiB,GAAG,KAAK,CAAC;QAGnC,6CAA6C;QACpC,wBAAmB,GAAG,KAAK,CAAC;QACrC,kBAAkB;QACT,aAAQ,GAAG,KAAK,CAAC;QAC1B,gDAAgD;QACvC,WAAM,GAAa,EAAE,CAAC;QAE/B,wEAAwE;QAC/D,kBAAa,GAAG,KAAK,CAAC;QAE/B,0CAA0C;QAChC,kBAAa,GAAG,IAAI,YAAY,EAAE,CAAC;QAC7C,YAAO,GAAG,KAAK,CAAC;QAEhB,WAAM,GAAG,EAAE,CAAC;QACZ,eAAU,GAAG,IAAI,CAAC;QAClB,2CAAsC,GAAG,EAAE,CAAC;QAG5C,oBAAe,GAAQ,GAAG,EAAE,GAAG,CAAC,CAAC;QACjC,eAAU,GAAQ,GAAG,EAAE,GAAG,CAAC,CAAC;QAC5B,aAAQ,GAAG,KAAK,CAAC;QACV,cAAS,GAAQ,GAAG,EAAE;YAC3B,SAAS;QACX,CAAC,CAAC;QACF,cAAS,GAAW,CAAC,CAAC;QAqBpB,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,CAAC,OAAO,CAAC,aAAa,GAAG,IAAI,CAAC;SACnC;IACH,CAAC;IAtBD,IAAW,OAAO;QAChB,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC;IACrD,CAAC;IAED,IAAW,SAAS;QAClB,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YACjB,OAAO,KAAK,CAAC;SACd;QAED,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC;QAExC,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,IAAI,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC;IACjD,CAAC;IAYD,aAAa,CAAC,KAAK;QACjB,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,aAAa,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;SAChE;QACD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACrC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAED,aAAa;QACX,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,EAAE,IAAI,CAAC,SAAS,CAAC;QACjB,IAAI,IAAI,CAAC,mBAAmB,IAAI,IAAI,CAAC,QAAQ,EAAE;YAC7C,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;SACrC;IACH,CAAC;IAEO,SAAS;QACf,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC;QAC/B,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC,CAAC;QACzD,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACrC,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;IACD,WAAW,CAAC,OAAsB;;QAChC,IAAI,CAAC,OAAO,CAAC,SAAS,IAAI,CAAC,CAAA,MAAA,OAAO,CAAC,SAAS,0CAAE,WAAW,CAAA,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,IAAI,CAAC,CAAA,MAAA,OAAO,CAAC,SAAS,0CAAE,WAAW,CAAA,CAAC,EAAE;YACpH,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;YACf,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;YACjB,IAAI,CAAC,cAAc,EAAE,CAAC;SACvB;IACH,CAAC;IAED,QAAQ;;QACN,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,KAAK,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;QACxD,IAAI,CAAC,SAAS,GAAG,MAAA,IAAI,CAAC,SAAS,mCAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;QACpE,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,SAAS,EAAE,CAAC;SAClB;QACD,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,EAAE;YACzC,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;YACnB,EAAE;gBACA,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,mBAAmB,CAAC;gBACrC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,gBAAgB,CAAC,CAAC;YACrC,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,IAAI,CAAC,aAAa,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;aAChE;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,cAAc,CAAC,IAAI,GAAG,CAAC;QACrB,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,cAAc,CAAC,yBAAyB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE;gBAC7E,IAAI,OAAO,GAAG,IAAI,CAAC,kBAAkB,CACnC,IAAI,CAAC,KAAK,EACV,qBAAqB,CACtB,CAAC;gBACF,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;gBACtC,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,mBAAmB,CAAC;gBACpD,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;gBAC1D,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;oBACvB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;gBAC1B,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAA;SACH;aAAM,IAAI,IAAI,CAAC,SAAS,EAAE;YACzB,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;oBACxC,IAAI,OAAO,GAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;oBAC1D,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;oBACtC,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,mBAAmB,CAAC;oBACpD,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;oBAC1D,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;wBACvB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;oBAC1B,CAAC,CAAC,CAAC;oBACH,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,CAAC,sBAAsB;gBAC9C,CAAC,CAAC,CAAC;aACJ;iBAAM;gBACL,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;oBAClD,IAAI,OAAO,GAAG,IAAI,CAAC,kBAAkB,CACnC,IAAI,CAAC,KAAK,EACV,qBAAqB,CACtB,CAAC;oBACF,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;oBACtC,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,mBAAmB,CAAC;oBACpD,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;oBAC1D,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;wBACvB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;oBAC1B,CAAC,CAAC,CAAC;gBACL,CAAC,CAAC,CAAC;aACJ;SACF;IACH,CAAC;IAED,WAAW,CAAC,IAAI,GAAG,CAAC;QAClB,OAAO,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC;YACrC,gBAAgB,EAAE,IAAI;YACtB,QAAQ,EAAE,GAAG;SACd,CAAC,CAAC;IACL,CAAC;IAEO,SAAS;QACf,IAAI,CAAC,cAAc;aAChB,IAAI,CACH,YAAY,CAAC,GAAG,CAAC,EACjB,oBAAoB,EAAE,EACtB,GAAG,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,CAAC,EAChC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;YACjB,IAAI,IAAI,IAAI,IAAI,CAAC,MAAM,EAAE;gBACvB,OAAO,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;aACvC;iBAAM;gBACL,OAAO,IAAI,CAAC,WAAW,EAAE,CAAC;aAC3B;QACH,CAAC,CAAC,CACH;aACA,SAAS,CACR,CAAC,IAAS,EAAE,EAAE;YACZ,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE;gBACvB,IAAI,OAAO,GAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;gBAC1D,IAAI,CAAC,MAAM,GAAG,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;gBACxD,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,mBAAmB,CAAC;gBACpD,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;aACtB;iBAAM;gBACL,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;gBACjB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;aACtB;QACH,CAAC,EACD,CAAC,GAAG,EAAE,EAAE;YACN,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;QACnB,CAAC,CACF,CAAC;IACN,CAAC;IAED,UAAU,CAAC,KAAK;QACd,IAAI,KAAK,EAAE;YACT,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;YACvB,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,IAAI,CAAC,aAAa,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;aAChE;SACF;aAAM;YACL,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;YACtB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAA;SAC1B;IACH,CAAC;IAED,SAAS,CAAC,IAAI,EAAE,QAAQ;QACtB,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;QAC5B,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QAChC,OAAO,IAAI,CAAC,EAAE,KAAK,QAAQ,CAAC,EAAE,CAAC;IACjC,CAAC;IAED,gBAAgB,CAAC,EAAE;QACjB,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;IAC5B,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,QAAQ,CAAC,CAAc;QACrB,OAAO,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;IAC5B,CAAC;IACD,UAAU;QACR,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,SAAS,EAAE;YACpD,OAAO,KAAK,CAAC;SACd;QAED,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,EAAqB,CAAC,CAAC;QACxE,OAAO,SAAS,IAAI,SAAS,CAAC,QAAQ,CAAC;IACzC,CAAC;IACD,SAAS;QACP,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAED,eAAe;IACf,yBAAyB;IACzB,mBAAmB;IACnB,KAAK;IAEL,WAAW,CAAC,SAAS;QACnB,OAAO,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;IACpD,CAAC;IAMD,mBAAmB,CAAC,IAAI;QACtB,OAAO,IAAI,CAAC,cAAc,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;IACvD,CAAC;IAEO,kBAAkB,CAAC,IAAI,EAAE,WAAmB;QAClD,IAAI,eAAsB,CAAC;QAC3B,yDAAyD;QACzD,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;YACvB,eAAe,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;SAC7C;QACD,eAAe,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC;QACtD,OAAO,eAAe,CAAC;IACzB,CAAC;IAEO,cAAc,CAAC,IAAI;QACzB,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;;YACvB,IAAI,CAAC,QAAQ,GAAG,GAAG,MAAA,IAAI,CAAC,UAAU,0CAAE,SAAS,IAAI,MAAA,IAAI,CAAC,UAAU,0CAAE,QAAQ,EAAE,CAAC;QAC/E,CAAC,CAAC,CAAC;IACL,CAAC;IACO,WAAW,CAAC,IAAI,EAAE,IAAY;QACpC,IAAI,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE;YACpC,MAAM,gBAAgB,GACpB,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;gBACvC,CAAC,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,eAAe,CAAC;YACxC,OAAO,CAAC,gBAAgB,CAAC;QAC3B,CAAC,CAAC,CAAC;QACH,OAAO,UAAU,CAAC;IACpB,CAAC;IAED,yBAAyB;IAEzB,CAAC;IACD,KAAK;QACH,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,EAAE,CAAC;IAC5C,CAAC;IACD,WAAW;QACT,IAAI,CAAC,cAAc,CAAC,WAAW,EAAE,CAAC;IACpC,CAAC;;6HAhTU,+BAA+B;iHAA/B,+BAA+B,+sBCvD5C,+vGAuGA;AD2NE;IAJC,SAAS,CAAC;QACT,aAAa,EAAE,IAAI;QACnB,MAAM,EAAE,CAAC,GAAG,MAAM;KACnB,CAAC;0EAGD;4FA7QU,+BAA+B;kBAN3C,SAAS;mBAAC;oBACT,QAAQ,EAAE,+BAA+B;oBACzC,WAAW,EAAE,4CAA4C;oBACzD,SAAS,EAAE,CAAC,4CAA4C,CAAC;oBACzD,aAAa,EAAE,iBAAiB,CAAC,IAAI;iBACtC;;0BA2EI,IAAI;;0BAAI,QAAQ;4CAxEa,iBAAiB;sBAAhD,SAAS;uBAAC,mBAAmB;gBAMrB,SAAS;sBAAjB,KAAK;gBAEG,SAAS;sBAAjB,KAAK;gBAEG,KAAK;sBAAb,KAAK;gBAEG,SAAS;sBAAjB,KAAK;gBAEG,SAAS;sBAAjB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBAEG,WAAW;sBAAnB,KAAK;gBAEG,QAAQ;sBAAhB,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBAEG,aAAa;sBAArB,KAAK;gBAEG,iBAAiB;sBAAzB,KAAK;gBAEG,iBAAiB;sBAAzB,KAAK;gBAEG,mBAAmB;sBAA3B,KAAK;gBAEG,QAAQ;sBAAhB,KAAK;gBAEG,MAAM;sBAAd,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBAGI,aAAa;sBAAtB,MAAM;gBAkOP,mBAAmB","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  Optional,\r\n  Output,\r\n  Self,\r\n  SimpleChanges,\r\n  ViewChild,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport {\r\n  AbstractControl,\r\n  ControlValueAccessor,\r\n  FormControl,\r\n  NgControl,\r\n} from '@angular/forms';\r\nimport { NgSelectComponent } from '@ng-select/ng-select';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { Observable, of, Subject } from 'rxjs';\r\nimport {\r\n  catchError,\r\n  debounceTime,\r\n  distinctUntilChanged,\r\n  switchMap,\r\n  tap,\r\n} from 'rxjs/operators';\r\nimport { TranslationService } from '../../../../core/services/translation/translation.service';\r\nimport { UsersInDepartmentsApiService } from './services/user-api.service';\r\nimport * as _ from 'lodash';\r\nimport { Cacheable } from 'ts-cacheable';\r\n/**\r\n * Users dropdown input integrated with users API,\r\n * that can be used inside reactive or template driven forms\r\n * @title\r\n * Users dropdown\r\n * @example\r\n * <cts-dynamic-form-select-users\r\n *     formControlName=\"controlName\"\r\n *     [bindValue]=\"bindToProperty\"\r\n *     [bindLabel]=\"'bindToLabel'\"\r\n *     [searchable]=\"true\"\r\n *     [label]=\"'PATH.TO.TRANSLATION'\"\r\n *     [deptTitle]=\"'all'\"\r\n *   ></cts-dynamic-form-select-users>\r\n */\r\nconst minute = 60000;\r\n@Component({\r\n  selector: 'cts-dynamic-form-select-users',\r\n  templateUrl: './dynamic-form-select-users.component.html',\r\n  styleUrls: ['./dynamic-form-select-users.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class DynamicFormSelectUsersComponent\r\n  implements OnChanges, OnDestroy, ControlValueAccessor {\r\n  @ViewChild('ngSelectComponent') ngSelectComponent: NgSelectComponent;\r\n  selectionstrg: string;\r\n  data = [];\r\n  allUsers: boolean;\r\n  userNameInput$ = new Subject<string>();\r\n  /** filter users by department (departmentName | all) */\r\n  @Input() deptTitle: string;\r\n  /** filter users by group name => this will replce dep title */\r\n  @Input() groupName: string;\r\n  /** Field Label */\r\n  @Input() label: string;\r\n  /** Bind value to object property */\r\n  @Input() bindValue;\r\n  /** Bind label to object property */\r\n  @Input() bindLabel;\r\n  @Input() arabicBindLabel;\r\n  /** Placeholder text */\r\n  @Input() placeholder;\r\n  /** Can select multiple */\r\n  @Input() multiple = false;\r\n  /** is dropdown searchable */\r\n  @Input() searchable = false;\r\n  /** should close dropdown on value selection */\r\n  @Input() closeOnSelect = true;\r\n  /** should hide selected items */\r\n  @Input() hideSelectedItems = false;\r\n  /** Pre Selected values */\r\n  @Input() preSelectedValues;\r\n  /** flage to use preselected values or not */\r\n  @Input() usePreSelectedValue = false;\r\n  /** is Disabled */\r\n  @Input() disabled = false;\r\n  /** List of usernames that should be exluded  */\r\n  @Input() filter: string[] = [];\r\n\r\n  /** flage to indicate if use full arabic name or not beside fullName  */\r\n  @Input() useArabicName = false;\r\n\r\n  /** event emitted when item is selected */\r\n  @Output() onSelectItems = new EventEmitter();\r\n  loading = false;\r\n  selection;\r\n  buffer = [];\r\n  bufferSize = 1000;\r\n  numberOfItemsFromEndBeforeFetchingMore = 10;\r\n  suffix;\r\n\r\n  propagateChange: any = () => { };\r\n  validateFn: any = () => { };\r\n  isArabic = false;\r\n  public onTouched: any = () => {\r\n    /*Empty*/\r\n  };\r\n  pageIndex: number = 0;\r\n  isNextPageAvailable: boolean;\r\n  public get invalid(): boolean {\r\n    return this.control ? this.control.invalid : false;\r\n  }\r\n\r\n  public get showError(): boolean {\r\n    if (!this.control) {\r\n      return false;\r\n    }\r\n\r\n    const { dirty, touched } = this.control;\r\n\r\n    return this.invalid ? dirty || touched : false;\r\n  }\r\n  constructor(\r\n    private userApiService: UsersInDepartmentsApiService,\r\n    public translate: TranslateService,\r\n    private translation: TranslationService,\r\n    @Self() @Optional() public control: NgControl\r\n  ) {\r\n    if (this.control) {\r\n      this.control.valueAccessor = this;\r\n    }\r\n  }\r\n\r\n  emitSelection(event) {\r\n    if (this.multiple) {\r\n      this.selectionstrg = `${this.selection.length} ${this.suffix}`;\r\n    }\r\n    this.propagateChange(this.selection);\r\n    this.onSelectItems.emit(event);\r\n  }\r\n\r\n  onScrollToEnd() {\r\n    this.fetchMore();\r\n    ++this.pageIndex;\r\n    if (this.isNextPageAvailable && this.allUsers) {\r\n      this.getDepartments(this.pageIndex);\r\n    }\r\n  }\r\n\r\n  private fetchMore() {\r\n    this.loading = true;\r\n    const len = this.buffer.length;\r\n    const more = this.data.slice(len, this.bufferSize + len);\r\n    this.buffer = this.data.concat(more);\r\n    this.loading = false;\r\n  }\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if ((changes.deptTitle && !changes.deptTitle?.firstChange) || (changes.groupName && !changes.groupName?.firstChange)) {\r\n      this.data = [];\r\n      this.buffer = [];\r\n      this.getDepartments();\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.allUsers = this.deptTitle === 'all' ? true : false;\r\n    this.selection = this.selection ?? (this.multiple ? [] : undefined);\r\n    if (this.allUsers) {\r\n      this.loadUsers();\r\n    }\r\n    this.getDepartments();\r\n    this.translation.isArabic.subscribe((ar) => {\r\n      this.isArabic = ar;\r\n      ar\r\n        ? (this.suffix = 'مستخدم تم إختياره')\r\n        : (this.suffix = 'Users Selected');\r\n      if (this.multiple) {\r\n        this.selectionstrg = `${this.selection.length} ${this.suffix}`;\r\n      }\r\n    });\r\n  }\r\n\r\n  getDepartments(page = 0) {\r\n    if (this.groupName) {\r\n      this.userApiService.getUsersUnderCertainGroup(this.groupName).subscribe(data => {\r\n        let newData = this.constructUserArray(\r\n          data.users,\r\n          'properties.username'\r\n        );\r\n        this.data = this.data.concat(newData);\r\n        this.isNextPageAvailable = data.isNextPageAvailable;\r\n        this.buffer = (this.data || []).slice(0, this.bufferSize);\r\n        this.buffer.map((item) => {\r\n          item.isSelected = false;\r\n        });\r\n      })\r\n    } else if (this.deptTitle) {\r\n      if (this.allUsers) {\r\n        this.getAllUsers(page).subscribe((data) => {\r\n          let newData = this.constructUserArray(data.entries, 'id');\r\n          this.data = this.data.concat(newData);\r\n          this.isNextPageAvailable = data.isNextPageAvailable;\r\n          this.buffer = (this.data || []).slice(0, this.bufferSize);\r\n          this.buffer.map((item) => {\r\n            item.isSelected = false;\r\n          });\r\n          this.loading = false; // for loading spinner\r\n        });\r\n      } else {\r\n        this.getCtsUsers(this.deptTitle).subscribe((data) => {\r\n          let newData = this.constructUserArray(\r\n            data.users,\r\n            'properties.username'\r\n          );\r\n          this.data = this.data.concat(newData);\r\n          this.isNextPageAvailable = data.isNextPageAvailable;\r\n          this.buffer = (this.data || []).slice(0, this.bufferSize);\r\n          this.buffer.map((item) => {\r\n            item.isSelected = false;\r\n          });\r\n        });\r\n      }\r\n    }\r\n  }\r\n\r\n  getAllUsers(page = 0): Observable<any> {\r\n    return this.userApiService.getAllUsers({\r\n      currentPageIndex: page,\r\n      pageSize: 100,\r\n    });\r\n  }\r\n\r\n  private loadUsers() {\r\n    this.userNameInput$\r\n      .pipe(\r\n        debounceTime(200),\r\n        distinctUntilChanged(),\r\n        tap(() => (this.loading = true)),\r\n        switchMap((term) => {\r\n          if (term && term.length) {\r\n            return this.getUsersSuggestions(term);\r\n          } else {\r\n            return this.getAllUsers();\r\n          }\r\n        })\r\n      )\r\n      .subscribe(\r\n        (data: any) => {\r\n          if (data.entries.length) {\r\n            let newData = this.constructUserArray(data.entries, 'id');\r\n            this.buffer = (newData || []).slice(0, this.bufferSize);\r\n            this.isNextPageAvailable = data.isNextPageAvailable;\r\n            this.loading = false;\r\n          } else {\r\n            this.buffer = [];\r\n            this.loading = false;\r\n          }\r\n        },\r\n        (err) => {\r\n          this.loading = false;\r\n          this.buffer = [];\r\n        }\r\n      );\r\n  }\r\n\r\n  writeValue(value) {\r\n    if (value) {\r\n      this.selection = value;\r\n      if (this.multiple) {\r\n        this.selectionstrg = `${this.selection.length} ${this.suffix}`;\r\n      }\r\n    } else {\r\n      this.selection = null;\r\n      this.selectionstrg = null\r\n    }\r\n  }\r\n\r\n  compareFn(item, selected) {\r\n    console.log(\"item 1\", item);\r\n    console.log(\"Item 2\", selected);\r\n    return item.id === selected.id;\r\n  }\r\n\r\n  registerOnChange(fn) {\r\n    this.propagateChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any) {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  validate(c: FormControl) {\r\n    return this.validateFn(c);\r\n  }\r\n  isRequired() {\r\n    if (!this.control || !this.control.control.validator) {\r\n      return false;\r\n    }\r\n\r\n    const validator = this.control.control.validator({} as AbstractControl);\r\n    return validator && validator.required;\r\n  }\r\n  hasErrors(): boolean {\r\n    return this.showError;\r\n  }\r\n\r\n  // @Cacheable({\r\n  //   maxCacheCount: 1000,\r\n  //   maxAge: 20000,\r\n  // })\r\n\r\n  getCtsUsers(deptTitle): Observable<any> {\r\n    return this.userApiService.getCtsUsers(deptTitle);\r\n  }\r\n\r\n  @Cacheable({\r\n    maxCacheCount: 1000,\r\n    maxAge: 5 * minute,\r\n  })\r\n  getUsersSuggestions(term): Observable<any> {\r\n    return this.userApiService.getUsersSuggestions(term);\r\n  }\r\n\r\n  private constructUserArray(data, filterValue: string) {\r\n    let ConstructedData: any[];\r\n    // if not using arabic name then construct full name here\r\n    if (!this.useArabicName) {\r\n      ConstructedData = this.insertFUllName(data);\r\n    }\r\n    ConstructedData = this.filterUsers(data, filterValue);\r\n    return ConstructedData;\r\n  }\r\n\r\n  private insertFUllName(data) {\r\n    return data.map((user) => {\r\n      user.fullName = `${user.properties?.firstName} ${user.properties?.lastName}`;\r\n    });\r\n  }\r\n  private filterUsers(data, path: string) {\r\n    let filterData = data.filter((user) => {\r\n      const includedInFilter =\r\n        this.filter.includes(_.get(user, path)) ||\r\n        _.get(user, path) === 'Administrator';\r\n      return !includedInFilter;\r\n    });\r\n    return filterData;\r\n  }\r\n\r\n  getUsersUnderCertainGroup() {\r\n\r\n  }\r\n  reset() {\r\n    this.ngSelectComponent.handleClearClick();\r\n  }\r\n  ngOnDestroy(): void {\r\n    this.userNameInput$.unsubscribe();\r\n  }\r\n}\r\n","<ng-container *ngIf=\"label\">\r\n  <div>\r\n    <label class=\"select-label\"\r\n      >{{ label | translate\r\n      }}<span *ngIf=\"isRequired()\" class=\"text-danger mx-1\">*</span></label\r\n    >\r\n  </div>\r\n</ng-container>\r\n<div class=\"user-select\" [ngClass]=\"{ 'multiple-wrapper': multiple }\" SetRtl>\r\n  <ng-select\r\n    #ngSelectComponent\r\n    [items]=\"buffer\"\r\n    [bindLabel]=\"useArabicName ? (isArabic ? arabicBindLabel : bindLabel)  : bindLabel\"\r\n    [placeholder]=\"\r\n      multiple && (selection && selection.length > 0) ? selectionstrg : placeholder\r\n    \"\r\n    [multiple]=\"multiple\"\r\n    [searchable]=\"searchable\"\r\n    [closeOnSelect]=\"closeOnSelect\"\r\n    [hideSelected]=\"hideSelectedItems\"\r\n    [loading]=\"loading\"\r\n    (scrollToEnd)=\"onScrollToEnd()\"\r\n    [disabled]=\"disabled\"\r\n    [typeahead]=\"userNameInput$\"\r\n    [compareWith]=\"compareFn\"\r\n    [(ngModel)]=\"selection\"\r\n    (change)=\"emitSelection($event)\"\r\n  >\r\n    <ng-template ng-label-tmp let-item=\"item\" let-clear=\"clear\">\r\n      <span\r\n        style=\"\r\n          display: flex;\r\n          align-items: center;\r\n          column-gap: 4px;\r\n          font-size: 16px;\r\n        \"\r\n      >\r\n        <div style=\"width: 30px; height: 30px\">\r\n          <cts-avatar [user]=\"item\"></cts-avatar>\r\n        </div>\r\n        <div class=\"user-name\">\r\n          {{ item?.id === 'system' ? ('SYSTEM_ADMIN' | translate) : \r\n          (useArabicName ? (isArabic ? (item?.fullNameAr ? item?.fullNameAr : item?.fullName) : item?.fullName) : \r\n          (item?.properties?.firstName + \" \" +item?.properties?.lastName)) }}\r\n\r\n\r\n        </div>\r\n        <div>\r\n          <span\r\n            class=\"ng-value-icon right\"\r\n            (click)=\"clear(item)\"\r\n            aria-hidden=\"true\"\r\n            >×</span\r\n          >\r\n        </div>\r\n      </span>\r\n    </ng-template>\r\n\r\n    <ng-template\r\n      ng-option-tmp\r\n      let-item=\"item\"\r\n      let-item$=\"item$\"\r\n      let-index=\"index\"\r\n    >\r\n      <span\r\n        style=\"\r\n          display: flex;\r\n          align-items: center;\r\n          column-gap: 4px;\r\n          font-size: 16px;\r\n        \"\r\n      >\r\n        <mat-checkbox\r\n          *ngIf=\"multiple\"\r\n          id=\"item-{{ index }}\"\r\n          [ngModel]=\"item$.selected\"\r\n          (click)=\"(false)\"\r\n        ></mat-checkbox>\r\n        <div style=\"width: 30px; height: 30px\">\r\n          <cts-avatar [user]=\"item\"></cts-avatar>\r\n        </div>\r\n        <div>\r\n          {{ item?.id === 'system' ? ('SYSTEM_ADMIN' | translate) : \r\n          (useArabicName ? (isArabic ? (item?.fullNameAr ? item?.fullNameAr : item?.fullName) : item?.fullName) : \r\n          (item?.properties?.firstName + \" \" +item?.properties?.lastName)) }}\r\n        </div>\r\n\r\n        <div></div>\r\n      </span>\r\n    </ng-template>\r\n  </ng-select>\r\n</div>\r\n<mat-error\r\n  [attr.data-automation-id]=\"'card-textitem-error-'\"\r\n  class=\"app-textitem-editable-error\"\r\n  *ngIf=\"hasErrors()\"\r\n>\r\n  <ul>\r\n    <li *ngIf=\"control.errors.required\">\r\n      {{ \"VALIDATORS.REQUIRED\" | translate }}\r\n    </li>\r\n  </ul>\r\n</mat-error>\r\n"]}
|
|
@@ -34,4 +34,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
34
34
|
]
|
|
35
35
|
}]
|
|
36
36
|
}] });
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3BlbGwtY2hlY2tlci1maWVsZC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9udXhlby1kZXZlbG9wbWVudC1mcmFtZXdvcmsvc3JjL2xpYi9jb21wb25lbnRzL3NwZWxsLWNoZWNrZXItZmllbGQvc3BlbGwtY2hlY2tlci1maWVsZC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUV0RCxPQUFPLEVBQUUsOEJBQThCLEVBQUUsTUFBTSwrREFBK0QsQ0FBQzs7QUFrQi9HLE1BQU0sT0FBTyx1QkFBdUI7O3FIQUF2Qix1QkFBdUI7c0hBQXZCLHVCQUF1QixpQkFaaEMsOEJBQThCLGFBRzlCLFlBQVk7UUFDWixXQUFXO1FBQ1gsZUFBZTtRQUNmLG1CQUFtQixhQUduQiw4QkFBOEI7c0hBR3JCLHVCQUF1QixZQVZ6QjtZQUNQLFlBQVk7WUFDWixXQUFXO1lBQ1gsZUFBZTtZQUNmLG1CQUFtQjtTQUNwQjs0RkFLVSx1QkFBdUI7a0JBZG5DLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLDhCQUE4QjtxQkFDL0I7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osV0FBVzt3QkFDWCxlQUFlO3dCQUNmLG1CQUFtQjtxQkFDcEI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLDhCQUE4QjtxQkFDL0I7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgVHJhbnNsYXRlTW9kdWxlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XG5cbmltcG9ydCB7IFNwZWxsQ2hlY2tlclRleHRGaWVsZENvbXBvbmVudCB9IGZyb20gJy4vc3BlbGwtY2hlY2tlci10ZXh0LWZpZWxkL3NwZWxsLWNoZWNrZXItdGV4dC1maWVsZC5jb21wb25lbnQnO1xuXG5cblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgU3BlbGxDaGVja2VyVGV4dEZpZWxkQ29tcG9uZW50XG4gIF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgRm9ybXNNb2R1bGUsXG4gICAgVHJhbnNsYXRlTW9kdWxlLFxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGVcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIFNwZWxsQ2hlY2tlclRleHRGaWVsZENvbXBvbmVudFxuICBdXG59KVxuZXhwb3J0IGNsYXNzIFNwZWxsQ2hlY2tlckZpZWxkTW9kdWxlIHsgfVxuIl19
|
|
@@ -11028,8 +11028,9 @@ class DynamicFormSelectUsersComponent {
|
|
|
11028
11028
|
}
|
|
11029
11029
|
}
|
|
11030
11030
|
ngOnInit() {
|
|
11031
|
+
var _a;
|
|
11031
11032
|
this.allUsers = this.deptTitle === 'all' ? true : false;
|
|
11032
|
-
this.selection = this.multiple ? [] : undefined;
|
|
11033
|
+
this.selection = (_a = this.selection) !== null && _a !== void 0 ? _a : (this.multiple ? [] : undefined);
|
|
11033
11034
|
if (this.allUsers) {
|
|
11034
11035
|
this.loadUsers();
|
|
11035
11036
|
}
|