nuxeo-development-framework 6.0.0 → 6.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (22) hide show
  1. package/bundles/nuxeo-development-framework.umd.js +107 -32
  2. package/bundles/nuxeo-development-framework.umd.js.map +1 -1
  3. package/esm2015/lib/components/correspondence-relation/components/correspondence-relation/correspondence-relation.component.js +18 -3
  4. package/esm2015/lib/components/correspondence-relation/components/correspondence-relation-list/correspondence-relation-list.component.js +29 -7
  5. package/esm2015/lib/components/correspondence-relation/components/correspondence-relation-reply/correspondence-relation-reply.component.js +16 -13
  6. package/esm2015/lib/components/dynamic-form/components/dynamic-form-select-users/dynamic-form-select-users.component.js +2 -2
  7. package/esm2015/lib/components/dynamic-form/components/dynamic-form-textitem/dynamic-form-textitem.component.js +2 -2
  8. package/esm2015/lib/components/notifications/components/notifications-settings/notifications-settings.component.js +10 -6
  9. package/esm2015/lib/components/notifications/services/notifications.service.js +8 -2
  10. package/esm2015/lib/shared/components/general-notification-popup/general-notification-popup.component.js +27 -0
  11. package/esm2015/lib/shared/libraryShared.module.js +10 -5
  12. package/esm2015/public-api.js +2 -1
  13. package/fesm2015/nuxeo-development-framework.js +106 -33
  14. package/fesm2015/nuxeo-development-framework.js.map +1 -1
  15. package/lib/components/correspondence-relation/components/correspondence-relation/correspondence-relation.component.d.ts +1 -0
  16. package/lib/components/correspondence-relation/components/correspondence-relation-list/correspondence-relation-list.component.d.ts +1 -0
  17. package/lib/components/dynamic-form/components/dynamic-form-textitem/dynamic-form-textitem.component.d.ts +1 -0
  18. package/lib/components/notifications/services/notifications.service.d.ts +2 -0
  19. package/lib/shared/components/general-notification-popup/general-notification-popup.component.d.ts +11 -0
  20. package/lib/shared/libraryShared.module.d.ts +15 -14
  21. package/package.json +1 -1
  22. package/public-api.d.ts +1 -0
@@ -3,6 +3,7 @@ import { MatDialogConfig } from "@angular/material/dialog";
3
3
  import { take } from "rxjs/operators";
4
4
  import { ConfirmCallerDialogComponent } from "../../../confirm-caller/confirm-caller.dialog";
5
5
  import { CorrespondenceRelationCreateFormComponent } from "../correspondence-relation-create-form/correspondence-relation-create-form.component";
6
+ import { GeneralNotificationPopupComponent } from '../../../../shared/components/general-notification-popup/general-notification-popup.component';
6
7
  import * as i0 from "@angular/core";
7
8
  import * as i1 from "@angular/material/dialog";
8
9
  import * as i2 from "../../services/correspondence-realation.service";
@@ -95,8 +96,22 @@ export class CorrespondenceRelationComponent {
95
96
  }
96
97
  }
97
98
  view_Corres(relation) {
98
- let url = window.location.href;
99
- window.open(url.replace(this.corr_id, relation.uid), "_blank");
99
+ if (relation.uid) {
100
+ let url = window.location.href;
101
+ window.open(url.replace(this.corr_id, relation.uid), "_blank");
102
+ }
103
+ else {
104
+ this.openGeneralNotificationPopup();
105
+ }
106
+ }
107
+ openGeneralNotificationPopup() {
108
+ this.dialog
109
+ .open(GeneralNotificationPopupComponent, {
110
+ width: '500px',
111
+ panelClass: 'updated-design-dialog'
112
+ })
113
+ .afterClosed()
114
+ .pipe(take(1));
100
115
  }
101
116
  showCorrespondenceInViewer(corres_id) {
102
117
  this.documentsApi.getDocument(corres_id).subscribe((file) => {
@@ -145,4 +160,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
145
160
  }], correspondance: [{
146
161
  type: Input
147
162
  }] } });
148
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"correspondence-relation.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/correspondence-relation/components/correspondence-relation/correspondence-relation.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/correspondence-relation/components/correspondence-relation/correspondence-relation.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from \"@angular/core\";\r\nimport { MatDialog, MatDialogConfig } from \"@angular/material/dialog\";\r\nimport { CustomToastrService } from \"../../../custom-toastr/services/custom-toastr.service\";\r\nimport { CorrespondenceRelationService } from \"../../services/correspondence-realation.service\";\r\nimport { take } from \"rxjs/operators\";\r\nimport { ConfirmCallerDialogComponent } from \"../../../confirm-caller/confirm-caller.dialog\";\r\nimport { CorrespondenceRelationCreateFormComponent } from \"../correspondence-relation-create-form/correspondence-relation-create-form.component\";\r\nimport { DocumentsService } from \"../../../documents/services/documents.service\";\r\nimport { ViewerFilesService } from \"../../services/viewer-files.service\";\r\nimport { UserPreferencesService } from \"../../../../core/services/user/user-preferences.service\";\r\nimport { NuxeoService } from \"../../../../core/services/nuxeo/nuxeo.service\";\r\n@Component({\r\n  selector: \"cts-correspondence-relation\",\r\n  templateUrl: \"./correspondence-relation.component.html\",\r\n  styleUrls: [\"./correspondence-relation.component.scss\"],\r\n})\r\nexport class CorrespondenceRelationComponent implements OnInit {\r\n  @Input()\r\n  corr_id;\r\n  /** Correspondance */\r\n  @Input()\r\n  correspondance;\r\n  relations_list: any;\r\n  reload: boolean = false;\r\n  constructor(\r\n    public dialog: MatDialog,\r\n    private corrrelationsvc: CorrespondenceRelationService,\r\n    private toastr: CustomToastrService,\r\n    private viewerFilesService: ViewerFilesService,\r\n    private documentsApi: DocumentsService,\r\n    private userPreference: UserPreferencesService,\r\n    public nuxeoService: NuxeoService\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    this.getallrelated();\r\n    this.corrrelationsvc.getUpdatedRelation.subscribe((res) => {\r\n      this.getallrelated();\r\n    });\r\n  }\r\n\r\n  openDialog() {\r\n    let data = {};\r\n    if (this.relations_list)\r\n      data = {\r\n        exist_relations_list: this.relations_list.value,\r\n        correspondance: this.correspondance,\r\n        corr_id: this.corr_id,\r\n      };\r\n    else data = { exist_relations_list: [] };\r\n    const dialogConfig = new MatDialogConfig();\r\n    dialogConfig.data = data;\r\n    dialogConfig.direction =\r\n      this.userPreference.locale === \"ar\" ? \"rtl\" : \"ltr\";\r\n    dialogConfig.panelClass = \"custom-dialog-container\";\r\n    dialogConfig.width = \"50%\";\r\n    dialogConfig.disableClose = true;\r\n    const dialogRef = this.dialog.open(\r\n      CorrespondenceRelationCreateFormComponent,\r\n      dialogConfig\r\n    );\r\n\r\n    dialogRef.afterClosed().subscribe((result) => {\r\n      if (result) {\r\n        this.reload = true;\r\n        // this.corrrelationsvc\r\n        //   .create_Named_Relation(this.corr_id, result.relationname, result.docs)\r\n        //   .subscribe(\r\n        //     (data) => {\r\n        //       this.reload = true;\r\n        //       this.corrrelationsvc.getUpdatedRelation.next();\r\n        //       this.toastr.show(\r\n        //         'success',\r\n        //         'success',\r\n        //         'Realation Successfuly added'\r\n        //       );\r\n        //     },\r\n        //     (err) => {\r\n        //       this.toastr.show('error', 'error',\r\n        //         err.ret.message ?\r\n        //           `errors.${err.ret.code}`\r\n        //           : 'genericError');\r\n        //     }\r\n        //   );\r\n      }\r\n    });\r\n  }\r\n\r\n  getallrelated() {\r\n    this.corrrelationsvc\r\n      .get_Correspondence_Relation_WithoutReply(this.corr_id)\r\n      .subscribe((results) => {\r\n        this.relations_list = results;\r\n      });\r\n  }\r\n\r\n  handleActions(event) {\r\n    if (event.action === \"view\") {\r\n      this.view_Corres(event.item);\r\n    } else if (event.action === \"delete\") {\r\n      this.deleteRelation(event.item);\r\n    } else if (event.action === \"show\") {\r\n      this.showCorrespondenceInViewer(event.item.uid);\r\n    }\r\n  }\r\n\r\n  view_Corres(relation) {\r\n    let url = window.location.href;\r\n    window.open(url.replace(this.corr_id, relation.uid), \"_blank\");\r\n  }\r\n\r\n  showCorrespondenceInViewer(corres_id) {\r\n    this.documentsApi.getDocument(corres_id).subscribe((file) => {\r\n      this.viewerFilesService.updateViewer.next(file);\r\n    });\r\n  }\r\n  openConfirmDialog(functionToPerform, title, msg) {\r\n    return this.dialog\r\n      .open(ConfirmCallerDialogComponent, {\r\n        width: \"400px\",\r\n        panelClass: \"relation-confirm-dialog\",\r\n        data: {\r\n          call: functionToPerform,\r\n          title: \"genericConfirm\",\r\n          toastrTitle: title,\r\n          toastrMsg: msg,\r\n        },\r\n      })\r\n      .afterClosed()\r\n      .pipe(take(1));\r\n  }\r\n  deleteRelation(relateddoc) {\r\n    let functionToPerform = () => {\r\n      return this.corrrelationsvc.Delete_Named_Relation(\r\n        this.corr_id,\r\n        relateddoc.relationId,\r\n        relateddoc.uid\r\n      );\r\n    };\r\n    let title = \"\";\r\n    let msg = \"\";\r\n    this.openConfirmDialog(\r\n      functionToPerform,\r\n      \"Success\",\r\n      \"correspondence-relation.deleted_success\"\r\n    ).subscribe((data) => {\r\n      if (data) {\r\n        this.corrrelationsvc.getUpdatedRelation.next();\r\n      }\r\n    });\r\n  }\r\n}\r\n","<div class=\"relations-container\">\r\n  <div  class=\"mb-3 relations-reply\">\r\n    <div class=\"subheader\">\r\n      <div>{{ \"correspondence-relation.reply_relation\" | translate }}</div>\r\n    </div>\r\n    <cts-correspondence-relation-reply\r\n      [correspondence_id]=\"corr_id\"\r\n      (actionclicked)=\"handleActions($event)\"\r\n    ></cts-correspondence-relation-reply>\r\n  </div>\r\n\r\n  <div class=\"mb-2 relations-listing\">\r\n    <div class=\"subheader\">\r\n      <div>{{ \"correspondence-relation.title\" | translate }}</div>\r\n      <div class=\"\" *permission=\"{\r\n        name: 'AddRelatedCorrespondence',\r\n        entity: correspondance , user: nuxeoService.nuxeoClient.user\r\n      }\" (click)=\"openDialog()\"><mat-icon>add</mat-icon></div>\r\n    </div>\r\n    <cts-correspondence-relation-list\r\n      [correspondence_id]=\"corr_id\"\r\n      [reload]=\"reload\"\r\n    ></cts-correspondence-relation-list>\r\n  </div>\r\n\r\n\r\n</div>\r\n"]}
163
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"correspondence-relation.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/correspondence-relation/components/correspondence-relation/correspondence-relation.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/correspondence-relation/components/correspondence-relation/correspondence-relation.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from \"@angular/core\";\r\nimport { MatDialog, MatDialogConfig } from \"@angular/material/dialog\";\r\nimport { CustomToastrService } from \"../../../custom-toastr/services/custom-toastr.service\";\r\nimport { CorrespondenceRelationService } from \"../../services/correspondence-realation.service\";\r\nimport { take } from \"rxjs/operators\";\r\nimport { ConfirmCallerDialogComponent } from \"../../../confirm-caller/confirm-caller.dialog\";\r\nimport { CorrespondenceRelationCreateFormComponent } from \"../correspondence-relation-create-form/correspondence-relation-create-form.component\";\r\nimport { DocumentsService } from \"../../../documents/services/documents.service\";\r\nimport { ViewerFilesService } from \"../../services/viewer-files.service\";\r\nimport { UserPreferencesService } from \"../../../../core/services/user/user-preferences.service\";\r\nimport { NuxeoService } from \"../../../../core/services/nuxeo/nuxeo.service\";\r\nimport { GeneralNotificationPopupComponent } from '../../../../shared/components/general-notification-popup/general-notification-popup.component';\r\n@Component({\r\n  selector: \"cts-correspondence-relation\",\r\n  templateUrl: \"./correspondence-relation.component.html\",\r\n  styleUrls: [\"./correspondence-relation.component.scss\"],\r\n})\r\nexport class CorrespondenceRelationComponent implements OnInit {\r\n  @Input()\r\n  corr_id;\r\n  /** Correspondance */\r\n  @Input()\r\n  correspondance;\r\n  relations_list: any;\r\n  reload: boolean = false;\r\n  constructor(\r\n    public dialog: MatDialog,\r\n    private corrrelationsvc: CorrespondenceRelationService,\r\n    private toastr: CustomToastrService,\r\n    private viewerFilesService: ViewerFilesService,\r\n    private documentsApi: DocumentsService,\r\n    private userPreference: UserPreferencesService,\r\n    public nuxeoService: NuxeoService\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    this.getallrelated();\r\n    this.corrrelationsvc.getUpdatedRelation.subscribe((res) => {\r\n      this.getallrelated();\r\n    });\r\n  }\r\n\r\n  openDialog() {\r\n    let data = {};\r\n    if (this.relations_list)\r\n      data = {\r\n        exist_relations_list: this.relations_list.value,\r\n        correspondance: this.correspondance,\r\n        corr_id: this.corr_id,\r\n      };\r\n    else data = { exist_relations_list: [] };\r\n    const dialogConfig = new MatDialogConfig();\r\n    dialogConfig.data = data;\r\n    dialogConfig.direction =\r\n      this.userPreference.locale === \"ar\" ? \"rtl\" : \"ltr\";\r\n    dialogConfig.panelClass = \"custom-dialog-container\";\r\n    dialogConfig.width = \"50%\";\r\n    dialogConfig.disableClose = true;\r\n    const dialogRef = this.dialog.open(\r\n      CorrespondenceRelationCreateFormComponent,\r\n      dialogConfig\r\n    );\r\n\r\n    dialogRef.afterClosed().subscribe((result) => {\r\n      if (result) {\r\n        this.reload = true;\r\n        // this.corrrelationsvc\r\n        //   .create_Named_Relation(this.corr_id, result.relationname, result.docs)\r\n        //   .subscribe(\r\n        //     (data) => {\r\n        //       this.reload = true;\r\n        //       this.corrrelationsvc.getUpdatedRelation.next();\r\n        //       this.toastr.show(\r\n        //         'success',\r\n        //         'success',\r\n        //         'Realation Successfuly added'\r\n        //       );\r\n        //     },\r\n        //     (err) => {\r\n        //       this.toastr.show('error', 'error',\r\n        //         err.ret.message ?\r\n        //           `errors.${err.ret.code}`\r\n        //           : 'genericError');\r\n        //     }\r\n        //   );\r\n      }\r\n    });\r\n  }\r\n\r\n  getallrelated() {\r\n    this.corrrelationsvc\r\n      .get_Correspondence_Relation_WithoutReply(this.corr_id)\r\n      .subscribe((results) => {\r\n        this.relations_list = results;\r\n      });\r\n  }\r\n\r\n  handleActions(event) {\r\n    if (event.action === \"view\") {\r\n      this.view_Corres(event.item);\r\n    } else if (event.action === \"delete\") {\r\n      this.deleteRelation(event.item);\r\n    } else if (event.action === \"show\") {\r\n      this.showCorrespondenceInViewer(event.item.uid);\r\n    }\r\n  }\r\n\r\n  view_Corres(relation) {\r\n    if(relation.uid){\r\n      let url = window.location.href;\r\n      window.open(url.replace(this.corr_id, relation.uid), \"_blank\");\r\n    }else{\r\n      this.openGeneralNotificationPopup();\r\n    }\r\n  }\r\n\r\n    openGeneralNotificationPopup(){\r\n      this.dialog\r\n        .open(GeneralNotificationPopupComponent, {\r\n          width: '500px',\r\n          panelClass: 'updated-design-dialog'\r\n        })\r\n        .afterClosed()\r\n        .pipe(take(1));\r\n    }\r\n\r\n  showCorrespondenceInViewer(corres_id) {\r\n    this.documentsApi.getDocument(corres_id).subscribe((file) => {\r\n      this.viewerFilesService.updateViewer.next(file);\r\n    });\r\n  }\r\n  openConfirmDialog(functionToPerform, title, msg) {\r\n    return this.dialog\r\n      .open(ConfirmCallerDialogComponent, {\r\n        width: \"400px\",\r\n        panelClass: \"relation-confirm-dialog\",\r\n        data: {\r\n          call: functionToPerform,\r\n          title: \"genericConfirm\",\r\n          toastrTitle: title,\r\n          toastrMsg: msg,\r\n        },\r\n      })\r\n      .afterClosed()\r\n      .pipe(take(1));\r\n  }\r\n  deleteRelation(relateddoc) {\r\n    let functionToPerform = () => {\r\n      return this.corrrelationsvc.Delete_Named_Relation(\r\n        this.corr_id,\r\n        relateddoc.relationId,\r\n        relateddoc.uid\r\n      );\r\n    };\r\n    let title = \"\";\r\n    let msg = \"\";\r\n    this.openConfirmDialog(\r\n      functionToPerform,\r\n      \"Success\",\r\n      \"correspondence-relation.deleted_success\"\r\n    ).subscribe((data) => {\r\n      if (data) {\r\n        this.corrrelationsvc.getUpdatedRelation.next();\r\n      }\r\n    });\r\n  }\r\n}\r\n","<div class=\"relations-container\">\r\n  <div  class=\"mb-3 relations-reply\">\r\n    <div class=\"subheader\">\r\n      <div>{{ \"correspondence-relation.reply_relation\" | translate }}</div>\r\n    </div>\r\n    <cts-correspondence-relation-reply\r\n      [correspondence_id]=\"corr_id\"\r\n      (actionclicked)=\"handleActions($event)\"\r\n    ></cts-correspondence-relation-reply>\r\n  </div>\r\n\r\n  <div class=\"mb-2 relations-listing\">\r\n    <div class=\"subheader\">\r\n      <div>{{ \"correspondence-relation.title\" | translate }}</div>\r\n      <div class=\"\" *permission=\"{\r\n        name: 'AddRelatedCorrespondence',\r\n        entity: correspondance , user: nuxeoService.nuxeoClient.user\r\n      }\" (click)=\"openDialog()\"><mat-icon>add</mat-icon></div>\r\n    </div>\r\n    <cts-correspondence-relation-list\r\n      [correspondence_id]=\"corr_id\"\r\n      [reload]=\"reload\"\r\n    ></cts-correspondence-relation-list>\r\n  </div>\r\n\r\n\r\n</div>\r\n"]}
@@ -1,6 +1,7 @@
1
1
  import { Component, Input, ViewEncapsulation } from '@angular/core';
2
2
  import { take } from 'rxjs/operators';
3
3
  import { ConfirmCallerDialogComponent } from '../../../confirm-caller/confirm-caller.dialog';
4
+ import { GeneralNotificationPopupComponent } from '../../../../shared/components/general-notification-popup/general-notification-popup.component';
4
5
  import * as i0 from "@angular/core";
5
6
  import * as i1 from "../../services/correspondence-realation.service";
6
7
  import * as i2 from "@angular/material/dialog";
@@ -75,14 +76,35 @@ export class CorrespondenceRelationListComponent {
75
76
  .pipe(take(1));
76
77
  }
77
78
  view_Corres(relation) {
78
- let url = window.location.href;
79
- window.open(url.replace(this.correspondence_id, relation.uid), '_blank');
79
+ if (relation.uid) {
80
+ let url = window.location.href;
81
+ window.open(url.replace(this.correspondence_id, relation.uid), '_blank');
82
+ }
83
+ else {
84
+ // he don't have permission to read this correspo
85
+ this.openGeneralNotificationPopup();
86
+ }
80
87
  }
81
88
  showCorrespondenceInViewer(relation) {
82
- this.documentsApi.getDocument(relation.uid).subscribe((file) => {
83
- let adaptedFile = this.adapter.adaptIn(Object.assign({}, file), this.relationsvc.incomingConstant['fields']);
84
- this.viewerFilesService.updateViewer.next(adaptedFile);
85
- });
89
+ if (relation.uid) {
90
+ this.documentsApi.getDocument(relation.uid).subscribe((file) => {
91
+ let adaptedFile = this.adapter.adaptIn(Object.assign({}, file), this.relationsvc.incomingConstant['fields']);
92
+ this.viewerFilesService.updateViewer.next(adaptedFile);
93
+ });
94
+ }
95
+ else {
96
+ // he don't have permission to read this correspo
97
+ this.openGeneralNotificationPopup();
98
+ }
99
+ }
100
+ openGeneralNotificationPopup() {
101
+ this.dialog
102
+ .open(GeneralNotificationPopupComponent, {
103
+ width: '500px',
104
+ panelClass: 'updated-design-dialog'
105
+ })
106
+ .afterClosed()
107
+ .pipe(take(1));
86
108
  }
87
109
  handleMenuItemClicked(event) {
88
110
  if (event.action === 'view') {
@@ -108,4 +130,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
108
130
  }], reload: [{
109
131
  type: Input
110
132
  }] } });
111
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"correspondence-relation-list.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/correspondence-relation/components/correspondence-relation-list/correspondence-relation-list.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/correspondence-relation/components/correspondence-relation-list/correspondence-relation-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, ViewEncapsulation } from '@angular/core';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { take } from 'rxjs/operators';\r\nimport { AdapterService } from '../../../../core/adapters/adapter.service';\r\nimport { ConfirmCallerDialogComponent } from '../../../confirm-caller/confirm-caller.dialog';\r\nimport { DocumentsService } from '../../../documents/services/documents.service';\r\nimport { ViewerFilesService } from '../../services/viewer-files.service';\r\nimport { CorrespondenceRelationService } from '../../services/correspondence-realation.service';\r\nimport { NuxeoDialogService } from '../../../../shared/components/nuxeo-dialog/services/nuxeo-dialog.service';\r\n\r\n@Component({\r\n\tselector: 'cts-correspondence-relation-list',\r\n\ttemplateUrl: './correspondence-relation-list.component.html',\r\n\tstyleUrls: ['./correspondence-relation-list.component.scss'],\r\n\tencapsulation: ViewEncapsulation.None\r\n})\r\nexport class CorrespondenceRelationListComponent implements OnInit {\r\n\t@Input()\r\n\tcorrespondence_id;\r\n\t@Input()\r\n\treload: boolean = false;\r\n\trelateddoc: any[] = [];\r\n\tmenu_actions = [\r\n\t\t{ title: 'correspondence-relation.view_corr', name: 'view' },\r\n\t\t{ title: 'correspondence-relation.delete', name: 'delete' }\r\n\t];\r\n\tconstructor(\r\n\t\tprivate relationsvc: CorrespondenceRelationService,\r\n\t\tprivate dialog: MatDialog,\r\n\t\tprivate viewerFilesService: ViewerFilesService,\r\n\t\tprivate documentsApi: DocumentsService,\r\n\t\tprivate adapter: AdapterService\r\n\t) {}\r\n\tngOnInit(): void {\r\n\t\tthis.loadData();\r\n\t\tthis.relationsvc.getUpdatedRelation.subscribe((res) => {\r\n\t\t\tthis.loadData();\r\n\t\t});\r\n\t}\r\n\tloadData() {\r\n\t\tthis.relationsvc\r\n\t\t\t.get_Correspondence_Relation_WithoutReply(this.correspondence_id)\r\n\t\t\t.subscribe((result) => {\r\n\t\t\t\tlet resultarray = result.value;\r\n\t\t\t\tlet resultsgrouped = resultarray.reduce((r, a) => {\r\n\t\t\t\t\tr[a.relationId] = [...(r[a.relationId] || []), a];\r\n\t\t\t\t\treturn r;\r\n\t\t\t\t}, {});\r\n\t\t\t\tthis.relateddoc = [];\r\n\t\t\t\tfor (let group of Object.entries(resultsgrouped)) {\r\n\t\t\t\t\tthis.relateddoc.push(group);\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t}\r\n\tonDeleteClick(relateddoc) {\r\n\t\tlet functionToPerform = () => {\r\n\t\t\treturn this.relationsvc.Delete_Named_Relation(\r\n\t\t\t\tthis.correspondence_id,\r\n\t\t\t\trelateddoc.relationId,\r\n\t\t\t\trelateddoc.uid\r\n\t\t\t);\r\n\t\t};\r\n\t\tlet title = '';\r\n\t\tlet msg = '';\r\n\t\tthis.openDialog(\r\n\t\t\tfunctionToPerform,\r\n\t\t\t'Success',\r\n\t\t\t'correspondence-relation.deleted_success'\r\n\t\t).subscribe((data) => {\r\n\t\t\tif (data) {\r\n\t\t\t\tthis.relationsvc.getUpdatedRelation.next();\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\topenDialog(functionToPerform, title, msg) {\r\n\t\treturn this.dialog\r\n\t\t\t.open(ConfirmCallerDialogComponent, {\r\n\t\t\t\twidth: '400px',\r\n\t\t\t\tpanelClass: 'relation-confirm-dialog',\r\n\t\t\t\tdata: {\r\n\t\t\t\t\tcall: functionToPerform,\r\n\t\t\t\t\ttitle: 'genericConfirm',\r\n\t\t\t\t\ttoastrTitle: title,\r\n\t\t\t\t\ttoastrMsg: msg\r\n\t\t\t\t}\r\n\t\t\t})\r\n\t\t\t.afterClosed()\r\n\t\t\t.pipe(take(1));\r\n\t}\r\n\r\n\tview_Corres(relation) {\r\n\t\tlet url = window.location.href;\r\n\t\twindow.open(url.replace(this.correspondence_id, relation.uid), '_blank');\r\n\t}\r\n\r\n\tshowCorrespondenceInViewer(relation) {\r\n\t\tthis.documentsApi.getDocument(relation.uid).subscribe((file) => {\r\n\t\t\tlet adaptedFile = this.adapter.adaptIn(\r\n\t\t\t\t{ ...file },\r\n\t\t\t\tthis.relationsvc.incomingConstant['fields']\r\n\t\t\t);\r\n\t\t\tthis.viewerFilesService.updateViewer.next(adaptedFile);\r\n\t\t});\r\n\t}\r\n\r\n\thandleMenuItemClicked(event) {\r\n\t\tif (event.action === 'view') {\r\n\t\t\tthis.view_Corres(event.item);\r\n\t\t} else if (event.action === 'delete') {\r\n\t\t\tthis.onDeleteClick(event.item);\r\n\t\t}\r\n\t}\r\n}\r\n","<div class=\"relations-list\" *ngIf=\"relateddoc.length > 0\">\r\n  <ng-container>\r\n    <div *ngFor=\"let group of relateddoc; first as isFirst\">\r\n      <mat-accordion class=\"example-headers-align\" multi>\r\n        <mat-expansion-panel [expanded]=\"isFirst\">\r\n          <mat-expansion-panel-header>\r\n            <mat-panel-title>\r\n              {{\r\n                \"vocabulary.VOC_CorrespondenceRelationsNames.\" + group[0]\r\n                  | translate\r\n              }}\r\n            </mat-panel-title>\r\n          </mat-expansion-panel-header>\r\n          <ng-template matExpansionPanelContent>\r\n            <mat-list>\r\n              <div class=\"mat-list-items\" *ngFor=\"let item of group[1]\">\r\n                <cts-item-list\r\n                  [item]=\"item\"\r\n                  [title]=\"item.title\"\r\n                  [iconname]=\"'link'\"\r\n                  [actions]=\"menu_actions\"\r\n                  (actionclicked)=\"handleMenuItemClicked($event)\"\r\n                  (itemClicked)=\"showCorrespondenceInViewer(item)\"\r\n                  [moreclasses]=\"'link-relation'\"\r\n                ></cts-item-list>\r\n              </div>\r\n            </mat-list>\r\n          </ng-template>\r\n        </mat-expansion-panel>\r\n      </mat-accordion>\r\n    </div>\r\n  </ng-container>\r\n</div>\r\n<div class=\"nocontent\" *ngIf=\"relateddoc.length === 0\">\r\n  <p>{{ \"correspondence-relation.nocontent\" | translate }}</p>\r\n</div>\r\n"]}
133
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"correspondence-relation-list.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/correspondence-relation/components/correspondence-relation-list/correspondence-relation-list.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/correspondence-relation/components/correspondence-relation-list/correspondence-relation-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, ViewEncapsulation } from '@angular/core';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { take } from 'rxjs/operators';\r\nimport { AdapterService } from '../../../../core/adapters/adapter.service';\r\nimport { ConfirmCallerDialogComponent } from '../../../confirm-caller/confirm-caller.dialog';\r\nimport { DocumentsService } from '../../../documents/services/documents.service';\r\nimport { ViewerFilesService } from '../../services/viewer-files.service';\r\nimport { CorrespondenceRelationService } from '../../services/correspondence-realation.service';\r\nimport { GeneralNotificationPopupComponent } from '../../../../shared/components/general-notification-popup/general-notification-popup.component';\r\n\r\n@Component({\r\n\tselector: 'cts-correspondence-relation-list',\r\n\ttemplateUrl: './correspondence-relation-list.component.html',\r\n\tstyleUrls: ['./correspondence-relation-list.component.scss'],\r\n\tencapsulation: ViewEncapsulation.None\r\n})\r\nexport class CorrespondenceRelationListComponent implements OnInit {\r\n\t@Input()\r\n\tcorrespondence_id;\r\n\t@Input()\r\n\treload: boolean = false;\r\n\trelateddoc: any[] = [];\r\n\tmenu_actions = [\r\n\t\t{ title: 'correspondence-relation.view_corr', name: 'view' },\r\n\t\t{ title: 'correspondence-relation.delete', name: 'delete' }\r\n\t];\r\n\tconstructor(\r\n\t\tprivate relationsvc: CorrespondenceRelationService,\r\n\t\tprivate dialog: MatDialog,\r\n\t\tprivate viewerFilesService: ViewerFilesService,\r\n\t\tprivate documentsApi: DocumentsService,\r\n\t\tprivate adapter: AdapterService\r\n\t) {}\r\n\tngOnInit(): void {\r\n\t\tthis.loadData();\r\n\t\tthis.relationsvc.getUpdatedRelation.subscribe((res) => {\r\n\t\t\tthis.loadData();\r\n\t\t});\r\n\t}\r\n\tloadData() {\r\n\t\tthis.relationsvc\r\n\t\t\t.get_Correspondence_Relation_WithoutReply(this.correspondence_id)\r\n\t\t\t.subscribe((result) => {\r\n\t\t\t\tlet resultarray = result.value;\r\n\t\t\t\tlet resultsgrouped = resultarray.reduce((r, a) => {\r\n\t\t\t\t\tr[a.relationId] = [...(r[a.relationId] || []), a];\r\n\t\t\t\t\treturn r;\r\n\t\t\t\t}, {});\r\n\t\t\t\tthis.relateddoc = [];\r\n\t\t\t\tfor (let group of Object.entries(resultsgrouped)) {\r\n\t\t\t\t\tthis.relateddoc.push(group);\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t}\r\n\tonDeleteClick(relateddoc) {\r\n\t\tlet functionToPerform = () => {\r\n\t\t\treturn this.relationsvc.Delete_Named_Relation(\r\n\t\t\t\tthis.correspondence_id,\r\n\t\t\t\trelateddoc.relationId,\r\n\t\t\t\trelateddoc.uid\r\n\t\t\t);\r\n\t\t};\r\n\t\tlet title = '';\r\n\t\tlet msg = '';\r\n\t\tthis.openDialog(\r\n\t\t\tfunctionToPerform,\r\n\t\t\t'Success',\r\n\t\t\t'correspondence-relation.deleted_success'\r\n\t\t).subscribe((data) => {\r\n\t\t\tif (data) {\r\n\t\t\t\tthis.relationsvc.getUpdatedRelation.next();\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\topenDialog(functionToPerform, title, msg) {\r\n\t\treturn this.dialog\r\n\t\t\t.open(ConfirmCallerDialogComponent, {\r\n\t\t\t\twidth: '400px',\r\n\t\t\t\tpanelClass: 'relation-confirm-dialog',\r\n\t\t\t\tdata: {\r\n\t\t\t\t\tcall: functionToPerform,\r\n\t\t\t\t\ttitle: 'genericConfirm',\r\n\t\t\t\t\ttoastrTitle: title,\r\n\t\t\t\t\ttoastrMsg: msg\r\n\t\t\t\t}\r\n\t\t\t})\r\n\t\t\t.afterClosed()\r\n\t\t\t.pipe(take(1));\r\n\t}\r\n\r\n\tview_Corres(relation) {\r\n\t\tif(relation.uid){\r\n\t\t\tlet url = window.location.href;\r\n\t\t\twindow.open(url.replace(this.correspondence_id, relation.uid), '_blank');\r\n\t\t}else{\r\n\t\t\t// he don't have permission to read this correspo\r\n\t\t\tthis.openGeneralNotificationPopup();\r\n\t\t}\r\n\t}\r\n\r\n\tshowCorrespondenceInViewer(relation) {\r\n\t\tif(relation.uid){\r\n\t\t\tthis.documentsApi.getDocument(relation.uid).subscribe((file) => {\r\n\t\t\t\tlet adaptedFile = this.adapter.adaptIn(\r\n\t\t\t\t\t{ ...file },\r\n\t\t\t\t\tthis.relationsvc.incomingConstant['fields']\r\n\t\t\t\t);\r\n\t\t\t\tthis.viewerFilesService.updateViewer.next(adaptedFile);\r\n\t\t\t});\r\n\t\t}else{\r\n\t\t\t// he don't have permission to read this correspo\r\n\t\t\tthis.openGeneralNotificationPopup();\r\n\t\t}\r\n\t}\r\n\r\n\topenGeneralNotificationPopup(){\r\n\t\tthis.dialog\r\n\t\t\t.open(GeneralNotificationPopupComponent, {\r\n\t\t\t\twidth: '500px',\r\n\t\t\t\tpanelClass: 'updated-design-dialog'\r\n\t\t\t})\r\n\t\t\t.afterClosed()\r\n\t\t\t.pipe(take(1));\r\n\t}\r\n\r\n\thandleMenuItemClicked(event) {\r\n\t\tif (event.action === 'view') {\r\n\t\t\tthis.view_Corres(event.item);\r\n\t\t} else if (event.action === 'delete') {\r\n\t\t\tthis.onDeleteClick(event.item);\r\n\t\t}\r\n\t}\r\n}\r\n","<div class=\"relations-list\" *ngIf=\"relateddoc.length > 0\">\r\n  <ng-container>\r\n    <div *ngFor=\"let group of relateddoc; first as isFirst\">\r\n      <mat-accordion class=\"example-headers-align\" multi>\r\n        <mat-expansion-panel [expanded]=\"isFirst\">\r\n          <mat-expansion-panel-header>\r\n            <mat-panel-title>\r\n              {{\r\n                \"vocabulary.VOC_CorrespondenceRelationsNames.\" + group[0]\r\n                  | translate\r\n              }}\r\n            </mat-panel-title>\r\n          </mat-expansion-panel-header>\r\n          <ng-template matExpansionPanelContent>\r\n            <mat-list>\r\n              <div class=\"mat-list-items\" *ngFor=\"let item of group[1]\">\r\n                <cts-item-list\r\n                  [item]=\"item\"\r\n                  [title]=\"item.title\"\r\n                  [iconname]=\"'link'\"\r\n                  [actions]=\"menu_actions\"\r\n                  (actionclicked)=\"handleMenuItemClicked($event)\"\r\n                  (itemClicked)=\"showCorrespondenceInViewer(item)\"\r\n                  [moreclasses]=\"'link-relation'\"\r\n                ></cts-item-list>\r\n              </div>\r\n            </mat-list>\r\n          </ng-template>\r\n        </mat-expansion-panel>\r\n      </mat-accordion>\r\n    </div>\r\n  </ng-container>\r\n</div>\r\n<div class=\"nocontent\" *ngIf=\"relateddoc.length === 0\">\r\n  <p>{{ \"correspondence-relation.nocontent\" | translate }}</p>\r\n</div>\r\n"]}
@@ -19,14 +19,15 @@ export class CorrespondenceRelationReplyComponent {
19
19
  this.corres_relationsvc
20
20
  .getCorrespondeceRelationRevers(this.correspondence_id)
21
21
  .subscribe((res) => {
22
- if (res['entries'].length > 0) {
23
- res['entries'].map(item => {
22
+ if ((res['entries'] && res['entries'].length > 0) || (res['value'] && res['value'].length > 0)) {
23
+ let data = res['entries'] || res['value'];
24
+ data.map(item => {
24
25
  this.replyrelation.push({
25
- title: item.title,
26
- uid: item.uid,
26
+ title: item.title || item.subject,
27
+ uid: item.uid || item.id,
27
28
  type: item.type,
28
- filecontent: item.properties['file:content'],
29
- direction: item.properties['corr:direction'],
29
+ filecontent: item.properties ? item.properties['file:content'] : item['file:content'],
30
+ direction: item.properties ? item.properties['corr:direction'] : item['corr:direction'],
30
31
  iconName: 'arrow_upward',
31
32
  moreclasses: "relation-file-icons"
32
33
  });
@@ -36,13 +37,15 @@ export class CorrespondenceRelationReplyComponent {
36
37
  this.corres_relationsvc
37
38
  .getCorrespondeceRelation(this.correspondence_id)
38
39
  .subscribe((res) => {
39
- if (res['entries'].length > 0) {
40
- res['entries'].map(item => {
40
+ if ((res['entries'] && res['entries'].length > 0) || (res['value'] && res['value'].length > 0)) {
41
+ let data = res['entries'] || res['value'];
42
+ data.map(item => {
41
43
  this.replyrelation.push({
42
- title: item.title,
43
- uid: item.uid, type: item.type,
44
- filecontent: item.properties['file:content'],
45
- direction: item.properties['corr:direction'],
44
+ title: item.title || item.subject,
45
+ uid: item.uid || item.id,
46
+ type: item.type,
47
+ filecontent: item.properties ? item.properties['file:content'] : item['file:content'],
48
+ direction: item.properties ? item.properties['corr:direction'] : item['corr:direction'],
46
49
  iconName: 'arrow_downward',
47
50
  moreclasses: "relation-file-icons"
48
51
  });
@@ -66,4 +69,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
66
69
  }], actionclicked: [{
67
70
  type: Output
68
71
  }] } });
69
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29ycmVzcG9uZGVuY2UtcmVsYXRpb24tcmVwbHkuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9jb3JyZXNwb25kZW5jZS1yZWxhdGlvbi9jb21wb25lbnRzL2NvcnJlc3BvbmRlbmNlLXJlbGF0aW9uLXJlcGx5L2NvcnJlc3BvbmRlbmNlLXJlbGF0aW9uLXJlcGx5LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL251eGVvLWRldmVsb3BtZW50LWZyYW1ld29yay9zcmMvbGliL2NvbXBvbmVudHMvY29ycmVzcG9uZGVuY2UtcmVsYXRpb24vY29tcG9uZW50cy9jb3JyZXNwb25kZW5jZS1yZWxhdGlvbi1yZXBseS9jb3JyZXNwb25kZW5jZS1yZWxhdGlvbi1yZXBseS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQVUsTUFBTSxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDOzs7Ozs7O0FBVWxHLE1BQU0sT0FBTyxvQ0FBb0M7SUFZL0MsWUFBb0Isa0JBQWlEO1FBQWpELHVCQUFrQixHQUFsQixrQkFBa0IsQ0FBK0I7UUFYckUsa0JBQWEsR0FBVSxFQUFFLENBQUM7UUFJMUIsa0JBQWEsR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFDO1FBTW5DLGlCQUFZLEdBQUcsQ0FBQyxFQUFFLEtBQUssRUFBRSxtQ0FBbUMsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQztJQUNMLENBQUM7SUFMMUUsVUFBVSxDQUFDLElBQUksRUFBRSxNQUFNLEdBQUcsTUFBTTtRQUM5QixJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxFQUFFLE1BQU0sRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7SUFDMUQsQ0FBQztJQUtELFFBQVE7UUFDTixJQUFJLENBQUMsa0JBQWtCO2FBQ3BCLDhCQUE4QixDQUFDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQzthQUN0RCxTQUFTLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRTtZQUNqQixJQUFJLEdBQUcsQ0FBQyxTQUFTLENBQUMsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFO2dCQUM3QixHQUFHLENBQUMsU0FBUyxDQUFDLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxFQUFFO29CQUN4QixJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FDckI7d0JBQ0UsS0FBSyxFQUFFLElBQUksQ0FBQyxLQUFLO3dCQUNqQixHQUFHLEVBQUUsSUFBSSxDQUFDLEdBQUc7d0JBQ2IsSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJO3dCQUNmLFdBQVcsRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLGNBQWMsQ0FBQzt3QkFDNUMsU0FBUyxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsZ0JBQWdCLENBQUM7d0JBQzVDLFFBQVEsRUFBRSxjQUFjO3dCQUN4QixXQUFXLEVBQUUscUJBQXFCO3FCQUNuQyxDQUNGLENBQUE7Z0JBQ0gsQ0FBQyxDQUFDLENBQUM7YUFDSjtRQUNILENBQUMsQ0FBQyxDQUFDO1FBQ0wsSUFBSSxDQUFDLGtCQUFrQjthQUNwQix3QkFBd0IsQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUM7YUFDaEQsU0FBUyxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUU7WUFDakIsSUFBSSxHQUFHLENBQUMsU0FBUyxDQUFDLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtnQkFDN0IsR0FBRyxDQUFDLFNBQVMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRTtvQkFDeEIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQ3JCO3dCQUNFLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSzt3QkFDakIsR0FBRyxFQUFFLElBQUksQ0FBQyxHQUFHLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJO3dCQUM5QixXQUFXLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxjQUFjLENBQUM7d0JBQzVDLFNBQVMsRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLGdCQUFnQixDQUFDO3dCQUM1QyxRQUFRLEVBQUUsZ0JBQWdCO3dCQUMxQixXQUFXLEVBQUUscUJBQXFCO3FCQUNuQyxDQUNGLENBQUE7Z0JBQ0gsQ0FBQyxDQUFDLENBQUM7YUFDSjtRQUNILENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQzs7a0lBcERVLG9DQUFvQztzSEFBcEMsb0NBQW9DLDBLQ1ZqRCxxdkJBb0JBOzRGRFZhLG9DQUFvQztrQkFOaEQsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsbUNBQW1DO29CQUM3QyxXQUFXLEVBQUUsZ0RBQWdEO29CQUM3RCxTQUFTLEVBQUUsQ0FBQyw2RUFBNkUsQ0FBQztvQkFDMUYsYUFBYSxFQUFHLGlCQUFpQixDQUFDLElBQUk7aUJBQ3ZDO29IQUlDLGlCQUFpQjtzQkFEaEIsS0FBSztnQkFHTixhQUFhO3NCQURaLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE9uSW5pdCwgT3V0cHV0LCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuaW1wb3J0IHsgQ29ycmVzcG9uZGVuY2VSZWxhdGlvblNlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9jb3JyZXNwb25kZW5jZS1yZWFsYXRpb24uc2VydmljZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2N0cy1jb3JyZXNwb25kZW5jZS1yZWxhdGlvbi1yZXBseScsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2NvcnJlc3BvbmRlbmNlLXJlbGF0aW9uLXJlcGx5LmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi4vY29ycmVzcG9uZGVuY2UtcmVsYXRpb24tbGlzdC9jb3JyZXNwb25kZW5jZS1yZWxhdGlvbi1saXN0LmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgZW5jYXBzdWxhdGlvbiA6IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmVcclxufSlcclxuZXhwb3J0IGNsYXNzIENvcnJlc3BvbmRlbmNlUmVsYXRpb25SZXBseUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgcmVwbHlyZWxhdGlvbjogYW55W10gPSBbXTtcclxuICBASW5wdXQoKVxyXG4gIGNvcnJlc3BvbmRlbmNlX2lkOiBzdHJpbmc7XHJcbiAgQE91dHB1dCgpXHJcbiAgYWN0aW9uY2xpY2tlZCA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcclxuXHJcbiAgZmlyZUFjdGlvbihpdGVtLCBhY3Rpb24gPSAnc2hvdycpIHtcclxuICAgIHRoaXMuYWN0aW9uY2xpY2tlZC5uZXh0KHsgYWN0aW9uOiBhY3Rpb24sIGl0ZW06IGl0ZW0gfSk7XHJcbiAgfVxyXG5cclxuICBtZW51X2FjdGlvbnMgPSBbeyB0aXRsZTogJ2NvcnJlc3BvbmRlbmNlLXJlbGF0aW9uLnZpZXdfY29ycicsIG5hbWU6ICd2aWV3JyB9XTtcclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGNvcnJlc19yZWxhdGlvbnN2YzogQ29ycmVzcG9uZGVuY2VSZWxhdGlvblNlcnZpY2UpIHsgfVxyXG5cclxuICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgIHRoaXMuY29ycmVzX3JlbGF0aW9uc3ZjXHJcbiAgICAgIC5nZXRDb3JyZXNwb25kZWNlUmVsYXRpb25SZXZlcnModGhpcy5jb3JyZXNwb25kZW5jZV9pZClcclxuICAgICAgLnN1YnNjcmliZSgocmVzKSA9PiB7XHJcbiAgICAgICAgaWYgKHJlc1snZW50cmllcyddLmxlbmd0aCA+IDApIHtcclxuICAgICAgICAgIHJlc1snZW50cmllcyddLm1hcChpdGVtID0+IHtcclxuICAgICAgICAgICAgdGhpcy5yZXBseXJlbGF0aW9uLnB1c2goXHJcbiAgICAgICAgICAgICAge1xyXG4gICAgICAgICAgICAgICAgdGl0bGU6IGl0ZW0udGl0bGUsIFxyXG4gICAgICAgICAgICAgICAgdWlkOiBpdGVtLnVpZCwgXHJcbiAgICAgICAgICAgICAgICB0eXBlOiBpdGVtLnR5cGUsIFxyXG4gICAgICAgICAgICAgICAgZmlsZWNvbnRlbnQ6IGl0ZW0ucHJvcGVydGllc1snZmlsZTpjb250ZW50J10sIFxyXG4gICAgICAgICAgICAgICAgZGlyZWN0aW9uOiBpdGVtLnByb3BlcnRpZXNbJ2NvcnI6ZGlyZWN0aW9uJ10sIFxyXG4gICAgICAgICAgICAgICAgaWNvbk5hbWU6ICdhcnJvd191cHdhcmQnLCBcclxuICAgICAgICAgICAgICAgIG1vcmVjbGFzc2VzOiBcInJlbGF0aW9uLWZpbGUtaWNvbnNcIlxyXG4gICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgKVxyXG4gICAgICAgICAgfSk7XHJcbiAgICAgICAgfVxyXG4gICAgICB9KTtcclxuICAgIHRoaXMuY29ycmVzX3JlbGF0aW9uc3ZjXHJcbiAgICAgIC5nZXRDb3JyZXNwb25kZWNlUmVsYXRpb24odGhpcy5jb3JyZXNwb25kZW5jZV9pZClcclxuICAgICAgLnN1YnNjcmliZSgocmVzKSA9PiB7XHJcbiAgICAgICAgaWYgKHJlc1snZW50cmllcyddLmxlbmd0aCA+IDApIHtcclxuICAgICAgICAgIHJlc1snZW50cmllcyddLm1hcChpdGVtID0+IHtcclxuICAgICAgICAgICAgdGhpcy5yZXBseXJlbGF0aW9uLnB1c2goXHJcbiAgICAgICAgICAgICAge1xyXG4gICAgICAgICAgICAgICAgdGl0bGU6IGl0ZW0udGl0bGUsIFxyXG4gICAgICAgICAgICAgICAgdWlkOiBpdGVtLnVpZCwgdHlwZTogaXRlbS50eXBlLCBcclxuICAgICAgICAgICAgICAgIGZpbGVjb250ZW50OiBpdGVtLnByb3BlcnRpZXNbJ2ZpbGU6Y29udGVudCddLCBcclxuICAgICAgICAgICAgICAgIGRpcmVjdGlvbjogaXRlbS5wcm9wZXJ0aWVzWydjb3JyOmRpcmVjdGlvbiddLCBcclxuICAgICAgICAgICAgICAgIGljb25OYW1lOiAnYXJyb3dfZG93bndhcmQnLCBcclxuICAgICAgICAgICAgICAgIG1vcmVjbGFzc2VzOiBcInJlbGF0aW9uLWZpbGUtaWNvbnNcIlxyXG4gICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgKVxyXG4gICAgICAgICAgfSk7XHJcbiAgICAgICAgfVxyXG4gICAgICB9KTtcclxuICB9XHJcblxyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJyZWxhdGlvbnMtbGlzdFwiICpuZ0lmPVwicmVwbHlyZWxhdGlvbi5sZW5ndGggPiAwXCI+XHJcbiAgPG5nLWNvbnRhaW5lcj5cclxuICAgIDxtYXQtbGlzdD5cclxuICAgICAgPGRpdiBjbGFzcz1cIm1hdC1saXN0LWl0ZW1zXCIgKm5nRm9yPVwibGV0IGl0ZW0gb2YgcmVwbHlyZWxhdGlvblwiPlxyXG4gICAgICAgIDxjdHMtaXRlbS1saXN0XHJcbiAgICAgICAgICBbaXRlbV09XCJpdGVtXCJcclxuICAgICAgICAgIFt0aXRsZV09XCJpdGVtLnRpdGxlXCJcclxuICAgICAgICAgIFthY3Rpb25zXT1cIm1lbnVfYWN0aW9uc1wiXHJcbiAgICAgICAgICBbaWNvbm5hbWVdPVwiaXRlbS5pY29uTmFtZVwiXHJcbiAgICAgICAgICBbbW9yZWNsYXNzZXNdPVwiaXRlbS5tb3JlY2xhc3Nlc1wiXHJcbiAgICAgICAgICAoYWN0aW9uY2xpY2tlZCk9XCJmaXJlQWN0aW9uKGl0ZW0sICd2aWV3JylcIlxyXG4gICAgICAgICAgKGl0ZW1DbGlja2VkKT1cImZpcmVBY3Rpb24oaXRlbSlcIlxyXG4gICAgICAgID48L2N0cy1pdGVtLWxpc3Q+XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgPC9tYXQtbGlzdD5cclxuICA8L25nLWNvbnRhaW5lcj5cclxuPC9kaXY+XHJcbjxkaXYgY2xhc3M9XCJub2NvbnRlbnRcIiAqbmdJZj1cInJlcGx5cmVsYXRpb24ubGVuZ3RoID09PSAwXCI+XHJcbiAgPHA+e3sgXCJjb3JyZXNwb25kZW5jZS1yZWxhdGlvbi5ub2NvbnRlbnRyZXBseVwiIHwgdHJhbnNsYXRlIH19PC9wPlxyXG48L2Rpdj5cclxuIl19
72
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"correspondence-relation-reply.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/correspondence-relation/components/correspondence-relation-reply/correspondence-relation-reply.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/correspondence-relation/components/correspondence-relation-reply/correspondence-relation-reply.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, ViewEncapsulation } from '@angular/core';\r\n\r\nimport { CorrespondenceRelationService } from '../../services/correspondence-realation.service';\r\n\r\n@Component({\r\n  selector: 'cts-correspondence-relation-reply',\r\n  templateUrl: './correspondence-relation-reply.component.html',\r\n  styleUrls: ['../correspondence-relation-list/correspondence-relation-list.component.scss'],\r\n  encapsulation : ViewEncapsulation.None\r\n})\r\nexport class CorrespondenceRelationReplyComponent implements OnInit {\r\n  replyrelation: any[] = [];\r\n  @Input()\r\n  correspondence_id: string;\r\n  @Output()\r\n  actionclicked = new EventEmitter();\r\n\r\n  fireAction(item, action = 'show') {\r\n    this.actionclicked.next({ action: action, item: item });\r\n  }\r\n\r\n  menu_actions = [{ title: 'correspondence-relation.view_corr', name: 'view' }];\r\n  constructor(private corres_relationsvc: CorrespondenceRelationService) { }\r\n\r\n  ngOnInit(): void {\r\n    this.corres_relationsvc\r\n      .getCorrespondeceRelationRevers(this.correspondence_id)\r\n      .subscribe((res) => {\r\n        if ((res['entries'] && res['entries'].length > 0) || (res['value'] && res['value'].length > 0)) {\r\n          let data = res['entries'] || res['value']\r\n          data.map(item => {\r\n            this.replyrelation.push(\r\n              {\r\n                title: item.title || item.subject, \r\n                uid: item.uid || item.id, \r\n                type: item.type, \r\n                filecontent: item.properties ? item.properties['file:content'] : item['file:content'], \r\n                direction: item.properties ? item.properties['corr:direction'] : item['corr:direction'], \r\n                iconName: 'arrow_upward', \r\n                moreclasses: \"relation-file-icons\"\r\n              }\r\n            )\r\n          });\r\n        }\r\n      });\r\n    this.corres_relationsvc\r\n      .getCorrespondeceRelation(this.correspondence_id)\r\n      .subscribe((res) => {\r\n        if ((res['entries'] && res['entries'].length > 0) || (res['value'] && res['value'].length > 0)) {\r\n          let data = res['entries'] || res['value']\r\n          data.map(item => {\r\n            this.replyrelation.push(\r\n              {\r\n                title: item.title || item.subject, \r\n                uid: item.uid || item.id, \r\n                type: item.type, \r\n                filecontent: item.properties ? item.properties['file:content'] : item['file:content'], \r\n                direction: item.properties ? item.properties['corr:direction'] : item['corr:direction'], \r\n                iconName: 'arrow_downward', \r\n                moreclasses: \"relation-file-icons\"\r\n              }\r\n            )\r\n          });\r\n        }\r\n      });\r\n  }\r\n\r\n}\r\n","<div class=\"relations-list\" *ngIf=\"replyrelation.length > 0\">\r\n  <ng-container>\r\n    <mat-list>\r\n      <div class=\"mat-list-items\" *ngFor=\"let item of replyrelation\">\r\n        <cts-item-list\r\n          [item]=\"item\"\r\n          [title]=\"item.title\"\r\n          [actions]=\"menu_actions\"\r\n          [iconname]=\"item.iconName\"\r\n          [moreclasses]=\"item.moreclasses\"\r\n          (actionclicked)=\"fireAction(item, 'view')\"\r\n          (itemClicked)=\"fireAction(item)\"\r\n        ></cts-item-list>\r\n      </div>\r\n    </mat-list>\r\n  </ng-container>\r\n</div>\r\n<div class=\"nocontent\" *ngIf=\"replyrelation.length === 0\">\r\n  <p>{{ \"correspondence-relation.nocontentreply\" | translate }}</p>\r\n</div>\r\n"]}
@@ -306,7 +306,7 @@ export class DynamicFormSelectUsersComponent {
306
306
  }
307
307
  }
308
308
  DynamicFormSelectUsersComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: DynamicFormSelectUsersComponent, deps: [{ token: i1.UsersInDepartmentsApiService }, { token: i2.TranslateService }, { token: i3.TranslationService }, { token: i4.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component });
309
- DynamicFormSelectUsersComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: DynamicFormSelectUsersComponent, selector: "cts-dynamic-form-select-users", inputs: { deptTitle: "deptTitle", groupName: "groupName", label: "label", bindValue: "bindValue", bindLabel: "bindLabel", arabicBindLabel: "arabicBindLabel", placeholder: "placeholder", multiple: "multiple", searchable: "searchable", closeOnSelect: "closeOnSelect", hideSelectedItems: "hideSelectedItems", preSelectedValues: "preSelectedValues", usePreSelectedValue: "usePreSelectedValue", disabled: "disabled", filter: "filter", useArabicName: "useArabicName", fetchUsersByCustomApi: "fetchUsersByCustomApi", fetchedUsers: "fetchedUsers" }, outputs: { onSelectItems: "onSelectItems", onSearch: "onSearch" }, viewQueries: [{ propertyName: "ngSelectComponent", first: true, predicate: ["ngSelectComponent"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"label\">\r\n\t<div>\r\n\t\t<label class=\"select-label\"\r\n\t\t\t>{{ label | translate }}<span *ngIf=\"isRequired()\" class=\"text-danger mx-1\">*</span></label\r\n\t\t>\r\n\t</div>\r\n</ng-container>\r\n<div class=\"user-select\" [ngClass]=\"{ 'multiple-wrapper': multiple }\" SetRtl>\r\n\t<ng-select\r\n\t\t#ngSelectComponent\r\n\t\t[items]=\"buffer\"\r\n\t\t[bindLabel]=\"useArabicName ? (isArabic ? arabicBindLabel : bindLabel) : bindLabel\"\r\n\t\t[placeholder]=\"multiple && selection && selection.length > 0 ? selectionstrg : placeholder\"\r\n\t\t[multiple]=\"multiple\"\r\n\t\t[searchable]=\"searchable\"\r\n\t\t[closeOnSelect]=\"closeOnSelect\"\r\n\t\t[hideSelected]=\"hideSelectedItems\"\r\n\t\t[loading]=\"loading\"\r\n\t\t(scrollToEnd)=\"onScrollToEnd()\"\r\n\t\t[disabled]=\"disabled\"\r\n\t\t[typeahead]=\"userNameInput$\"\r\n\t\t[compareWith]=\"compareFn\"\r\n\t\t[(ngModel)]=\"selection\"\r\n\t\t[searchFn]=\"searchFn\"\r\n\t\t(change)=\"emitSelection($event)\"\r\n\t>\r\n\t\t<ng-template ng-label-tmp let-item=\"item\" let-clear=\"clear\" *ngIf=\"!loading\">\r\n\t\t\t<span style=\"display: flex; align-items: center; column-gap: 4px; font-size: 16px\">\r\n\t\t\t\t<div style=\"width: 30px; height: 30px\">\r\n\t\t\t\t\t<cts-avatar [user]=\"item\"></cts-avatar>\r\n\t\t\t\t</div>\r\n\t\t\t\t<div class=\"user-name\">\r\n\t\t\t\t\t{{\r\n\t\t\t\t\t\titem?.id === 'system'\r\n\t\t\t\t\t\t\t? ('SYSTEM_ADMIN' | translate)\r\n\t\t\t\t\t\t\t: useArabicName\r\n\t\t\t\t\t\t\t? isArabic\r\n\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t: item?.properties?.firstName + ' ' + item?.properties?.lastName\r\n\t\t\t\t\t}}\r\n\t\t\t\t</div>\r\n\t\t\t\t<div>\r\n\t\t\t\t\t<span class=\"ng-value-icon right\" (click)=\"clear(item)\" aria-hidden=\"true\">\u00D7</span>\r\n\t\t\t\t</div>\r\n\t\t\t</span>\r\n\t\t</ng-template>\r\n\r\n\t\t<ng-template ng-option-tmp let-item=\"item\" let-item$=\"item$\" let-index=\"index\">\r\n\t\t\t<span style=\"display: flex; align-items: center; column-gap: 4px; font-size: 16px\">\r\n\t\t\t\t<mat-checkbox\r\n\t\t\t\t\t*ngIf=\"multiple\"\r\n\t\t\t\t\tid=\"item-{{ index }}\"\r\n\t\t\t\t\t[ngModel]=\"item$.selected\"\r\n\t\t\t\t\t(click)=\"(false)\"\r\n\t\t\t\t></mat-checkbox>\r\n\t\t\t\t<div style=\"width: 30px; height: 30px\">\r\n\t\t\t\t\t<cts-avatar [user]=\"item\"></cts-avatar>\r\n\t\t\t\t</div>\r\n\t\t\t\t<div>\r\n\t\t\t\t\t{{\r\n\t\t\t\t\t\titem?.id === 'system'\r\n\t\t\t\t\t\t\t? ('SYSTEM_ADMIN' | translate)\r\n\t\t\t\t\t\t\t: useArabicName\r\n\t\t\t\t\t\t\t? isArabic\r\n\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t: item?.properties?.firstName + ' ' + item?.properties?.lastName\r\n\t\t\t\t\t}}\r\n\t\t\t\t</div>\r\n\r\n\t\t\t\t<div></div>\r\n\t\t\t</span>\r\n\t\t</ng-template>\r\n\t</ng-select>\r\n</div>\r\n<mat-error [attr.data-automation-id]=\"'card-textitem-error-'\" class=\"app-textitem-editable-error\" *ngIf=\"hasErrors()\">\r\n\t<ul>\r\n\t\t<li *ngIf=\"control.errors.required\">\r\n\t\t\t{{ 'VALIDATORS.REQUIRED' | translate }}\r\n\t\t</li>\r\n\t</ul>\r\n</mat-error>\r\n", styles: [".bi{margin:0!important}.memo-sorting-wrapper{width:265px;margin:0 10px;height:100%;display:flex}.memo-sorting-wrapper .sorting-direction{width:65px;height:40px;background-color:#465573;color:#fff;font-size:20px;display:flex;justify-content:center;align-items:center;cursor:pointer}.memo-sorting-wrapper .memo-sorting-trigger{width:calc(100% - 65px);height:100%;background-color:transparent;border:1px solid lightgrey;display:flex;justify-content:space-between;align-items:center;padding:0 15px;font-size:14px}.memo-sorting-wrapper .memo-sorting-trigger i{font-size:16px;color:gray}.memo-sorting-menu{width:200px}.my-button{border:1px solid #465573;color:#465573;border-radius:5px;background-color:transparent;font-weight:bold;min-width:80px;height:40px}.my-button.reset{border:none}.my-button:hover{color:#fff;background-color:#465573}.my-button:hover.reset{color:#465573;border:1px solid #465573;background-color:#fff}.app-property-value .app-input-wrapper label{color:#646f85;font-size:13px;margin-bottom:5px}.app-property-value .app-input-wrapper label .text-danger{font-size:16px;line-height:14px;margin:0 5px!important}.app-property-value .app-input-wrapper .form-control{border:1px solid #ccc;border-radius:5px;background-color:#8f98aa1a;height:40px}.app-property-value .app-input-wrapper .form-control:disabled{background-color:#e9ecef!important}.app-property-value .app-input-wrapper .form-control:focus{border:1px solid #1a96c6;box-shadow:0 0 4px #79c3c26b!important}.app-property-value .app-input-wrapper .app-textitem-editable-error .error-containers{list-style:none;padding:0;margin:0;font-size:14px}.app-property-value .app-input-wrapper .app-textitem-editable-error .error-containers .error{margin-top:5px}.autocomplete-container .input-container input:focus,hijri-gregorian-datepicker .form-group .input-group .form-control:focus,.ng-select.ng-select-focused .ng-select-container{border:1px solid #1a96c6!important;box-shadow:0 0 4px #79c3c26b!important}input::placeholder{font-size:12px}.form-control:focus{box-shadow:none!important}.mat-stepper-horizontal{margin-top:-25px}.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header.cdk-program-focused{background-color:transparent}.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header .mat-step-icon-selected{background-color:transparent;color:#fff;background-image:linear-gradient(to right,#0dbab5,#1a96c6)}@media only screen and (max-width: 576px){.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header .mat-step-label .mat-step-text-label{white-space:pre-wrap;overflow:visible}}.mat-stepper-horizontal .mat-horizontal-content-container{overflow:visible}@media only screen and (max-width: 768px){.mat-stepper-horizontal .mat-horizontal-content-container{padding:0 0 24px}}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:first-child:after,.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:last-child:before{display:none}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:first-child:before{border-top-width:1px;border-top-style:solid;content:\"\";display:inline-block;height:0;position:absolute;width:calc(50% - 20px);left:0}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:last-child:after{border-top-width:1px;border-top-style:solid;content:\"\";display:inline-block;height:0;position:absolute;width:calc(50% - 20px);right:0}.form-wrapper{padding:30px 15px;border:1px solid #dde0e2}.form-wrapper .buttons-wrapper{display:flex;justify-content:space-between}.form-wrapper .buttons-wrapper .action-buttons-wrapper{display:flex}.form-wrapper .buttons-wrapper button{background-image:linear-gradient(to right,#0dbab5,#1a96c6);height:40px;color:#fff;border:none;width:125px;margin-top:20px;border-radius:5px}.form-wrapper .buttons-wrapper button:disabled{opacity:.4;cursor:not-allowed}.form-wrapper .buttons-wrapper button:hover{opacity:.7}.form-wrapper .upload-wrapper{display:flex;flex-direction:column;justify-content:flex-end}.form-wrapper .upload-wrapper label{color:#8f98aa;font-size:14px}.form-wrapper .upload-wrapper button{padding:10px;border:1px solid lightgray}.form-wrapper .upload-wrapper button span{margin:0 10px}.renameFileComponent .form-wrapper{padding:30px 15px;border:none!important}.renameFileComponent .form-wrapper .buttons-wrapper{display:flex;justify-content:space-between}.renameFileComponent .form-wrapper .buttons-wrapper .action-buttons-wrapper{display:flex}.renameFileComponent .form-wrapper .buttons-wrapper button{background-image:linear-gradient(to right,#0dbab5,#1a96c6);height:40px;color:#fff;border:none;width:125px;margin-top:20px;border-radius:5px}.renameFileComponent .form-wrapper .buttons-wrapper button:disabled{opacity:.4;cursor:not-allowed}.renameFileComponent .form-wrapper .buttons-wrapper button:hover{opacity:.7}.renameFileComponent .form-wrapper .upload-wrapper{display:flex;flex-direction:column;justify-content:flex-end}.renameFileComponent .form-wrapper .upload-wrapper label{color:#8f98aa;font-size:14px}.renameFileComponent .form-wrapper .upload-wrapper button{padding:10px;border:1px solid lightgray}.renameFileComponent .form-wrapper .upload-wrapper button span{margin:0 10px}.my-dynamic-viewer{display:flex;align-items:center;font-size:12px;min-height:30px}.my-dynamic-viewer .my-label{font-size:12px;font-weight:500;width:150px;word-break:break-word}@media (max-width: 992px){.my-dynamic-viewer .my-label{width:50%}}.my-dynamic-viewer .my-value{width:calc(100% - 150px);word-break:break-word}@media (max-width: 992px){.my-dynamic-viewer .my-value{width:50%}}.my-dynamic-viewer .direction-img{font-size:14px}.my-dynamic-viewer .direction-img .incoming{display:none}.my-dynamic-viewer .direction-img .outgoing{display:none}.my-dynamic-viewer .direction-img .internal{display:none}.my-dynamic-viewer.draft .my-value{color:#596973}.my-dynamic-viewer.inProgress .my-value{color:#3c3cf0}.my-dynamic-viewer.registered .my-value{color:#4f008c}.my-dynamic-viewer.archived .my-value{color:#fbb62c}.my-dynamic-viewer.closed .my-value{color:#00dca5}.my-dynamic-viewer.approved .my-value{color:#06a57e}.my-dynamic-viewer.assigned .my-value{color:#fd6670}.my-dynamic-viewer.sent .my-value{color:#3c3cf0}.my-dynamic-viewer.published .my-value{color:#00dca5}.my-dynamic-viewer.Outgoing .my-value{display:flex}.my-dynamic-viewer.Outgoing .my-value .direction-img .outgoing{color:#fbb62c;margin:1px 5px;display:flex}.my-dynamic-viewer.Outgoing .my-value .text{margin:0 5px}.my-dynamic-viewer.Internal .my-value{display:flex}.my-dynamic-viewer.Internal .my-value .direction-img .internal{color:#3c3cf0;margin:1px 5px;display:flex}.my-dynamic-viewer.Internal .my-value .text{margin:0 5px}.my-dynamic-viewer.Incoming .my-value{display:flex}.my-dynamic-viewer.Incoming .my-value .direction-img .incoming{color:#00dca5;display:flex}.my-dynamic-viewer.Incoming .my-value .text{margin:-3px 5px 0}.my-dynamic-viewer.vertical{display:block}.my-dynamic-viewer.vertical .my-label{width:auto}.my-dynamic-viewer.vertical .my-value{width:auto}.my-dynamic-viewer.with-out-label{width:100%!important}.select-label{color:#8f98aa;font-size:12px;margin-bottom:0}.user-select .ng-select-container{border:1px solid #ccc!important;border-radius:5px!important;background-color:#8f98aa1a!important}.user-select .ng-select-container .ng-value-container{padding:5px 7px 0!important}.user-select .ng-select-container .ng-value-container .ng-placeholder{padding:0 5px;font-size:12px}.user-select .ng-select-container .ng-value-container .ng-value{color:#495057}.user-select .ng-select-container .ng-arrow-wrapper{padding:0 20px}.user-select .ng-select-container .ng-input{left:10px;right:10px;width:auto}.user-select .mat-checkbox-ripple .mat-ripple-element,.user-select .mat-checkbox-checked.mat-accent .mat-checkbox-background{background-color:#33e3b7!important}.user-select .mat-checkbox-ripple .mat-ripple-element{position:fixed;left:inherit;top:inherit;transform:translate(-3px,-3px)!important}.user-select mat-checkbox .mat-checkbox-background{background-color:#d9dce2!important}.multiple-wrapper .ng-select-container{overflow:visible!important}.multiple-wrapper .ng-select-container.ng-has-value{margin-bottom:65px}.multiple-wrapper .ng-select-container .ng-value-container{position:absolute;top:40px;width:100%;max-height:65px;overflow-y:auto}.multiple-wrapper .ng-select-container .ng-value-container .ng-placeholder{display:block;position:absolute;top:-26px!important}.multiple-wrapper .ng-select-container .ng-value-container .ng-value{padding:5px 10px}.multiple-wrapper .ng-select-container .ng-value-container .ng-value .user-name{font-size:12px}.multiple-wrapper .ng-select-container .ng-value-container .ng-input{position:absolute;top:-35px!important}.multiple-wrapper .ng-select-container .ng-clear-wrapper{display:none}.multiple-wrapper .ng-select-container .ng-arrow-wrapper{position:absolute;right:5px}.multiple-wrapper .ng-select-filtered .ng-value-container .ng-placeholder{display:none!important}.multiple-wrapper.rtl .ng-select-container .ng-value-container .ng-value{padding:5px 10px}.multiple-wrapper.rtl .ng-select-container .ng-value-container .ng-value .ng-value-icon{border-left:none!important;border-right:1px solid #b8dbff}.multiple-wrapper.rtl .ng-select-container .ng-arrow-wrapper{left:5px;right:auto}.ng-select-disabled .ng-select-container{background-color:#e9ecef!important}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option .option-wrapper .check-box-wrapper{position:relative}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option .option-wrapper .check-box-wrapper input{visibility:hidden;width:20px;height:20px}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option .option-wrapper .check-box-wrapper .icon-wrapper{position:absolute;top:0px;left:0px;width:20px;height:20px;border:1px solid #2e62df;display:flex;justify-content:center;align-items:center}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option .option-wrapper .check-box-wrapper .icon-wrapper .icon{color:#2e62df;display:none;justify-content:center;align-items:center;font-weight:bold}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option-selected .option-wrapper .check-box-wrapper .icon-wrapper .icon{display:flex}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option-selected .option-wrapper .label-wrapper{color:#2e62df}.ng-select .ng-select-focused:not(.ng-select-opened) .ng-select-container{border-color:#ccc;box-shadow:none}\n"], components: [{ type: i5.NgSelectComponent, selector: "ng-select", inputs: ["markFirst", "dropdownPosition", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "bufferAmount", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "bindLabel", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "virtualScroll", "openOnEnter", "appendTo", "bindValue", "appearance", "maxSelectedItems", "groupBy", "groupValue", "tabIndex", "typeahead"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }, { type: i6.AvatarComponent, selector: "cts-avatar", inputs: ["user"] }, { type: i7.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex", "aria-label", "aria-labelledby", "id", "labelPosition", "name", "required", "checked", "disabled", "indeterminate", "aria-describedby", "value"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }], directives: [{ type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i9.SetRtlDirective, selector: "[SetRtl]" }, { type: i8.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i5.ɵh, selector: "[ng-label-tmp]" }, { type: i5.ɵf, selector: "[ng-option-tmp]" }, { type: i10.MatError, selector: "mat-error", inputs: ["id"] }], pipes: { "translate": i2.TranslatePipe }, encapsulation: i0.ViewEncapsulation.None });
309
+ DynamicFormSelectUsersComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: DynamicFormSelectUsersComponent, selector: "cts-dynamic-form-select-users", inputs: { deptTitle: "deptTitle", groupName: "groupName", label: "label", bindValue: "bindValue", bindLabel: "bindLabel", arabicBindLabel: "arabicBindLabel", placeholder: "placeholder", multiple: "multiple", searchable: "searchable", closeOnSelect: "closeOnSelect", hideSelectedItems: "hideSelectedItems", preSelectedValues: "preSelectedValues", usePreSelectedValue: "usePreSelectedValue", disabled: "disabled", filter: "filter", useArabicName: "useArabicName", fetchUsersByCustomApi: "fetchUsersByCustomApi", fetchedUsers: "fetchedUsers" }, outputs: { onSelectItems: "onSelectItems", onSearch: "onSearch" }, viewQueries: [{ propertyName: "ngSelectComponent", first: true, predicate: ["ngSelectComponent"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\t<ng-container *ngIf=\"label\">\r\n\t\t<div>\r\n\t\t\t<label class=\"select-label\"\r\n\t\t\t\t>{{ label | translate }}<span *ngIf=\"isRequired()\" class=\"text-danger mx-1\">*</span></label\r\n\t\t\t>\r\n\t\t</div>\r\n\t</ng-container>\r\n\t<div class=\"user-select\" [ngClass]=\"{ 'multiple-wrapper': multiple }\" SetRtl>\r\n\t\t<ng-select\r\n\t\t\t#ngSelectComponent\r\n\t\t\t[items]=\"buffer\"\r\n\t\t\t[bindLabel]=\"useArabicName ? (isArabic ? arabicBindLabel : bindLabel) : bindLabel\"\r\n\t\t\t[placeholder]=\"multiple && selection && selection.length > 0 ? selectionstrg : placeholder\"\r\n\t\t\t[multiple]=\"multiple\"\r\n\t\t\t[searchable]=\"searchable\"\r\n\t\t\t[closeOnSelect]=\"closeOnSelect\"\r\n\t\t\t[hideSelected]=\"hideSelectedItems\"\r\n\t\t\t[loading]=\"loading\"\r\n\t\t\t(scrollToEnd)=\"onScrollToEnd()\"\r\n\t\t\t[disabled]=\"disabled\"\r\n\t\t\t[typeahead]=\"userNameInput$\"\r\n\t\t\t[compareWith]=\"compareFn\"\r\n\t\t\t[(ngModel)]=\"selection\"\r\n\t\t\t[searchFn]=\"searchFn\"\r\n\t\t\t(change)=\"emitSelection($event)\"\r\n\t\t>\r\n\t\t\t<ng-template ng-label-tmp let-item=\"item\" let-clear=\"clear\" *ngIf=\"!loading\">\r\n\t\t\t\t<span style=\"display: flex; align-items: center; column-gap: 4px; font-size: 16px\">\r\n\t\t\t\t\t<div style=\"width: 30px; height: 30px\">\r\n\t\t\t\t\t\t<cts-avatar [user]=\"item\"></cts-avatar>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t\t<div class=\"user-name\">\r\n\t\t\t\t\t\t{{\r\n\t\t\t\t\t\t\titem?.id === 'system'\r\n\t\t\t\t\t\t\t\t? ('SYSTEM_ADMIN' | translate)\r\n\t\t\t\t\t\t\t\t: useArabicName\r\n\t\t\t\t\t\t\t\t? isArabic\r\n\t\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t\t: item?.properties?.firstName + ' ' + item?.properties?.lastName\r\n\t\t\t\t\t\t}}\r\n\t\t\t\t\t</div>\r\n\t\t\t\t\t<div>\r\n\t\t\t\t\t\t<span class=\"ng-value-icon right\" (click)=\"clear(item)\" aria-hidden=\"true\">\u00D7</span>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</span>\r\n\t\t\t</ng-template>\r\n\r\n\t\t\t<ng-template ng-option-tmp let-item=\"item\" let-item$=\"item$\" let-index=\"index\">\r\n\t\t\t\t<span style=\"display: flex; align-items: center; column-gap: 4px; font-size: 16px\">\r\n\t\t\t\t\t<mat-checkbox\r\n\t\t\t\t\t\t*ngIf=\"multiple\"\r\n\t\t\t\t\t\tid=\"item-{{ index }}\"\r\n\t\t\t\t\t\t[ngModel]=\"item$.selected\"\r\n\t\t\t\t\t\t(click)=\"(false)\"\r\n\t\t\t\t\t></mat-checkbox>\r\n\t\t\t\t\t<div style=\"width: 30px; height: 30px\">\r\n\t\t\t\t\t\t<cts-avatar [user]=\"item\"></cts-avatar>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t\t<div>\r\n\t\t\t\t\t\t{{\r\n\t\t\t\t\t\t\titem?.id === 'system'\r\n\t\t\t\t\t\t\t\t? ('SYSTEM_ADMIN' | translate)\r\n\t\t\t\t\t\t\t\t: useArabicName\r\n\t\t\t\t\t\t\t\t? isArabic\r\n\t\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t\t: item?.properties?.firstName + ' ' + item?.properties?.lastName\r\n\t\t\t\t\t\t}}\r\n\t\t\t\t\t</div>\r\n\r\n\t\t\t\t\t<div></div>\r\n\t\t\t\t</span>\r\n\t\t\t</ng-template>\r\n\t\t</ng-select>\r\n\t</div>\r\n\t<mat-error [attr.data-automation-id]=\"'card-textitem-error-'\" class=\"app-textitem-editable-error\" *ngIf=\"hasErrors()\">\r\n\t\t<ul>\r\n\t\t\t<li *ngIf=\"control.errors.required\">\r\n\t\t\t\t{{ 'VALIDATORS.REQUIRED' | translate }}\r\n\t\t\t</li>\r\n\t\t</ul>\r\n\t</mat-error>\r\n", styles: [".bi{margin:0!important}.memo-sorting-wrapper{width:265px;margin:0 10px;height:100%;display:flex}.memo-sorting-wrapper .sorting-direction{width:65px;height:40px;background-color:#465573;color:#fff;font-size:20px;display:flex;justify-content:center;align-items:center;cursor:pointer}.memo-sorting-wrapper .memo-sorting-trigger{width:calc(100% - 65px);height:100%;background-color:transparent;border:1px solid lightgrey;display:flex;justify-content:space-between;align-items:center;padding:0 15px;font-size:14px}.memo-sorting-wrapper .memo-sorting-trigger i{font-size:16px;color:gray}.memo-sorting-menu{width:200px}.my-button{border:1px solid #465573;color:#465573;border-radius:5px;background-color:transparent;font-weight:bold;min-width:80px;height:40px}.my-button.reset{border:none}.my-button:hover{color:#fff;background-color:#465573}.my-button:hover.reset{color:#465573;border:1px solid #465573;background-color:#fff}.app-property-value .app-input-wrapper label{color:#646f85;font-size:13px;margin-bottom:5px}.app-property-value .app-input-wrapper label .text-danger{font-size:16px;line-height:14px;margin:0 5px!important}.app-property-value .app-input-wrapper .form-control{border:1px solid #ccc;border-radius:5px;background-color:#8f98aa1a;height:40px}.app-property-value .app-input-wrapper .form-control:disabled{background-color:#e9ecef!important}.app-property-value .app-input-wrapper .form-control:focus{border:1px solid #1a96c6;box-shadow:0 0 4px #79c3c26b!important}.app-property-value .app-input-wrapper .app-textitem-editable-error .error-containers{list-style:none;padding:0;margin:0;font-size:14px}.app-property-value .app-input-wrapper .app-textitem-editable-error .error-containers .error{margin-top:5px}.autocomplete-container .input-container input:focus,hijri-gregorian-datepicker .form-group .input-group .form-control:focus,.ng-select.ng-select-focused .ng-select-container{border:1px solid #1a96c6!important;box-shadow:0 0 4px #79c3c26b!important}input::placeholder{font-size:12px}.form-control:focus{box-shadow:none!important}.mat-stepper-horizontal{margin-top:-25px}.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header.cdk-program-focused{background-color:transparent}.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header .mat-step-icon-selected{background-color:transparent;color:#fff;background-image:linear-gradient(to right,#0dbab5,#1a96c6)}@media only screen and (max-width: 576px){.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header .mat-step-label .mat-step-text-label{white-space:pre-wrap;overflow:visible}}.mat-stepper-horizontal .mat-horizontal-content-container{overflow:visible}@media only screen and (max-width: 768px){.mat-stepper-horizontal .mat-horizontal-content-container{padding:0 0 24px}}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:first-child:after,.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:last-child:before{display:none}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:first-child:before{border-top-width:1px;border-top-style:solid;content:\"\";display:inline-block;height:0;position:absolute;width:calc(50% - 20px);left:0}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:last-child:after{border-top-width:1px;border-top-style:solid;content:\"\";display:inline-block;height:0;position:absolute;width:calc(50% - 20px);right:0}.form-wrapper{padding:30px 15px;border:1px solid #dde0e2}.form-wrapper .buttons-wrapper{display:flex;justify-content:space-between}.form-wrapper .buttons-wrapper .action-buttons-wrapper{display:flex}.form-wrapper .buttons-wrapper button{background-image:linear-gradient(to right,#0dbab5,#1a96c6);height:40px;color:#fff;border:none;width:125px;margin-top:20px;border-radius:5px}.form-wrapper .buttons-wrapper button:disabled{opacity:.4;cursor:not-allowed}.form-wrapper .buttons-wrapper button:hover{opacity:.7}.form-wrapper .upload-wrapper{display:flex;flex-direction:column;justify-content:flex-end}.form-wrapper .upload-wrapper label{color:#8f98aa;font-size:14px}.form-wrapper .upload-wrapper button{padding:10px;border:1px solid lightgray}.form-wrapper .upload-wrapper button span{margin:0 10px}.renameFileComponent .form-wrapper{padding:30px 15px;border:none!important}.renameFileComponent .form-wrapper .buttons-wrapper{display:flex;justify-content:space-between}.renameFileComponent .form-wrapper .buttons-wrapper .action-buttons-wrapper{display:flex}.renameFileComponent .form-wrapper .buttons-wrapper button{background-image:linear-gradient(to right,#0dbab5,#1a96c6);height:40px;color:#fff;border:none;width:125px;margin-top:20px;border-radius:5px}.renameFileComponent .form-wrapper .buttons-wrapper button:disabled{opacity:.4;cursor:not-allowed}.renameFileComponent .form-wrapper .buttons-wrapper button:hover{opacity:.7}.renameFileComponent .form-wrapper .upload-wrapper{display:flex;flex-direction:column;justify-content:flex-end}.renameFileComponent .form-wrapper .upload-wrapper label{color:#8f98aa;font-size:14px}.renameFileComponent .form-wrapper .upload-wrapper button{padding:10px;border:1px solid lightgray}.renameFileComponent .form-wrapper .upload-wrapper button span{margin:0 10px}.my-dynamic-viewer{display:flex;align-items:center;font-size:12px;min-height:30px}.my-dynamic-viewer .my-label{font-size:12px;font-weight:500;width:150px;word-break:break-word}@media (max-width: 992px){.my-dynamic-viewer .my-label{width:50%}}.my-dynamic-viewer .my-value{width:calc(100% - 150px);word-break:break-word}@media (max-width: 992px){.my-dynamic-viewer .my-value{width:50%}}.my-dynamic-viewer .direction-img{font-size:14px}.my-dynamic-viewer .direction-img .incoming{display:none}.my-dynamic-viewer .direction-img .outgoing{display:none}.my-dynamic-viewer .direction-img .internal{display:none}.my-dynamic-viewer.draft .my-value{color:#596973}.my-dynamic-viewer.inProgress .my-value{color:#3c3cf0}.my-dynamic-viewer.registered .my-value{color:#4f008c}.my-dynamic-viewer.archived .my-value{color:#fbb62c}.my-dynamic-viewer.closed .my-value{color:#00dca5}.my-dynamic-viewer.approved .my-value{color:#06a57e}.my-dynamic-viewer.assigned .my-value{color:#fd6670}.my-dynamic-viewer.sent .my-value{color:#3c3cf0}.my-dynamic-viewer.published .my-value{color:#00dca5}.my-dynamic-viewer.Outgoing .my-value{display:flex}.my-dynamic-viewer.Outgoing .my-value .direction-img .outgoing{color:#fbb62c;margin:1px 5px;display:flex}.my-dynamic-viewer.Outgoing .my-value .text{margin:0 5px}.my-dynamic-viewer.Internal .my-value{display:flex}.my-dynamic-viewer.Internal .my-value .direction-img .internal{color:#3c3cf0;margin:1px 5px;display:flex}.my-dynamic-viewer.Internal .my-value .text{margin:0 5px}.my-dynamic-viewer.Incoming .my-value{display:flex}.my-dynamic-viewer.Incoming .my-value .direction-img .incoming{color:#00dca5;display:flex}.my-dynamic-viewer.Incoming .my-value .text{margin:-3px 5px 0}.my-dynamic-viewer.vertical{display:block}.my-dynamic-viewer.vertical .my-label{width:auto}.my-dynamic-viewer.vertical .my-value{width:auto}.my-dynamic-viewer.with-out-label{width:100%!important}.select-label{color:#8f98aa;font-size:12px;margin-bottom:0}.user-select .ng-select-container{border:1px solid #ccc!important;border-radius:5px!important;background-color:#8f98aa1a!important}.user-select .ng-select-container .ng-value-container{padding:5px 7px 0!important}.user-select .ng-select-container .ng-value-container .ng-placeholder{padding:0 5px;font-size:12px}.user-select .ng-select-container .ng-value-container .ng-value{color:#495057}.user-select .ng-select-container .ng-arrow-wrapper{padding:0 20px}.user-select .ng-select-container .ng-input{left:10px;right:10px;width:auto}.user-select .mat-checkbox-ripple .mat-ripple-element,.user-select .mat-checkbox-checked.mat-accent .mat-checkbox-background{background-color:#33e3b7!important}.user-select .mat-checkbox-ripple .mat-ripple-element{position:fixed;left:inherit;top:inherit;transform:translate(-3px,-3px)!important}.user-select mat-checkbox .mat-checkbox-background{background-color:#d9dce2!important}.multiple-wrapper .ng-select-container{overflow:visible!important}.multiple-wrapper .ng-select-container.ng-has-value{margin-bottom:65px}.multiple-wrapper .ng-select-container .ng-value-container{position:absolute;top:40px;width:100%;max-height:65px;overflow-y:auto}.multiple-wrapper .ng-select-container .ng-value-container .ng-placeholder{display:block;position:absolute;top:-26px!important}.multiple-wrapper .ng-select-container .ng-value-container .ng-value{padding:5px 10px}.multiple-wrapper .ng-select-container .ng-value-container .ng-value .user-name{font-size:12px}.multiple-wrapper .ng-select-container .ng-value-container .ng-input{position:absolute;top:-35px!important}.multiple-wrapper .ng-select-container .ng-clear-wrapper{display:none}.multiple-wrapper .ng-select-container .ng-arrow-wrapper{position:absolute;right:5px}.multiple-wrapper .ng-select-filtered .ng-value-container .ng-placeholder{display:none!important}.multiple-wrapper.rtl .ng-select-container .ng-value-container .ng-value{padding:5px 10px}.multiple-wrapper.rtl .ng-select-container .ng-value-container .ng-value .ng-value-icon{border-left:none!important;border-right:1px solid #b8dbff}.multiple-wrapper.rtl .ng-select-container .ng-arrow-wrapper{left:5px;right:auto}.ng-select-disabled .ng-select-container{background-color:#e9ecef!important}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option .option-wrapper .check-box-wrapper{position:relative}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option .option-wrapper .check-box-wrapper input{visibility:hidden;width:20px;height:20px}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option .option-wrapper .check-box-wrapper .icon-wrapper{position:absolute;top:0px;left:0px;width:20px;height:20px;border:1px solid #2e62df;display:flex;justify-content:center;align-items:center}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option .option-wrapper .check-box-wrapper .icon-wrapper .icon{color:#2e62df;display:none;justify-content:center;align-items:center;font-weight:bold}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option-selected .option-wrapper .check-box-wrapper .icon-wrapper .icon{display:flex}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option-selected .option-wrapper .label-wrapper{color:#2e62df}.ng-select .ng-select-focused:not(.ng-select-opened) .ng-select-container{border-color:#ccc;box-shadow:none}\n"], components: [{ type: i5.NgSelectComponent, selector: "ng-select", inputs: ["markFirst", "dropdownPosition", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "bufferAmount", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "bindLabel", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "virtualScroll", "openOnEnter", "appendTo", "bindValue", "appearance", "maxSelectedItems", "groupBy", "groupValue", "tabIndex", "typeahead"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }, { type: i6.AvatarComponent, selector: "cts-avatar", inputs: ["user"] }, { type: i7.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex", "aria-label", "aria-labelledby", "id", "labelPosition", "name", "required", "checked", "disabled", "indeterminate", "aria-describedby", "value"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }], directives: [{ type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i9.SetRtlDirective, selector: "[SetRtl]" }, { type: i8.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i5.ɵh, selector: "[ng-label-tmp]" }, { type: i5.ɵf, selector: "[ng-option-tmp]" }, { type: i10.MatError, selector: "mat-error", inputs: ["id"] }], pipes: { "translate": i2.TranslatePipe }, encapsulation: i0.ViewEncapsulation.None });
310
310
  __decorate([
311
311
  Cacheable({
312
312
  maxCacheCount: 1000,
@@ -369,4 +369,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
369
369
  }], onSearch: [{
370
370
  type: Output
371
371
  }], getUsersSuggestions: [] } });
372
- //# 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  @Input() fetchUsersByCustomApi: boolean = false;\r\n  @Input() set fetchedUsers(res: Record<string, any>[]) {\r\n    this.loading = true;\r\n    let newData = this.constructUserArray(res, 'id');\r\n    this.data = this.data.concat(newData);\r\n    this.isNextPageAvailable = false;\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;\r\n  }\r\n  @Output() onSearch = new EventEmitter<string>();\r\n  searchFn = null;\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.fetchUsersByCustomApi) {\r\n      if (this.allUsers) {\r\n        this.loadUsers();\r\n      }\r\n      this.getDepartments();\r\n    } else {\r\n      this.searchFn = (term: string, item: Record<string, any>) => {\r\n        const fullName = `${item.properties.firstName} ${item.properties.lastName}`.toLowerCase();\r\n        return fullName.includes(term.toLowerCase());\r\n      }\r\n    }\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    this.loading = true;\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        this.loading = false;\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          this.loading = false;\r\n        });\r\n      }\r\n    } else {\r\n      this.loading = false;\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\t<div>\r\n\t\t<label class=\"select-label\"\r\n\t\t\t>{{ label | translate }}<span *ngIf=\"isRequired()\" class=\"text-danger mx-1\">*</span></label\r\n\t\t>\r\n\t</div>\r\n</ng-container>\r\n<div class=\"user-select\" [ngClass]=\"{ 'multiple-wrapper': multiple }\" SetRtl>\r\n\t<ng-select\r\n\t\t#ngSelectComponent\r\n\t\t[items]=\"buffer\"\r\n\t\t[bindLabel]=\"useArabicName ? (isArabic ? arabicBindLabel : bindLabel) : bindLabel\"\r\n\t\t[placeholder]=\"multiple && selection && selection.length > 0 ? selectionstrg : placeholder\"\r\n\t\t[multiple]=\"multiple\"\r\n\t\t[searchable]=\"searchable\"\r\n\t\t[closeOnSelect]=\"closeOnSelect\"\r\n\t\t[hideSelected]=\"hideSelectedItems\"\r\n\t\t[loading]=\"loading\"\r\n\t\t(scrollToEnd)=\"onScrollToEnd()\"\r\n\t\t[disabled]=\"disabled\"\r\n\t\t[typeahead]=\"userNameInput$\"\r\n\t\t[compareWith]=\"compareFn\"\r\n\t\t[(ngModel)]=\"selection\"\r\n\t\t[searchFn]=\"searchFn\"\r\n\t\t(change)=\"emitSelection($event)\"\r\n\t>\r\n\t\t<ng-template ng-label-tmp let-item=\"item\" let-clear=\"clear\" *ngIf=\"!loading\">\r\n\t\t\t<span style=\"display: flex; align-items: center; column-gap: 4px; font-size: 16px\">\r\n\t\t\t\t<div style=\"width: 30px; height: 30px\">\r\n\t\t\t\t\t<cts-avatar [user]=\"item\"></cts-avatar>\r\n\t\t\t\t</div>\r\n\t\t\t\t<div class=\"user-name\">\r\n\t\t\t\t\t{{\r\n\t\t\t\t\t\titem?.id === 'system'\r\n\t\t\t\t\t\t\t? ('SYSTEM_ADMIN' | translate)\r\n\t\t\t\t\t\t\t: useArabicName\r\n\t\t\t\t\t\t\t? isArabic\r\n\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t: item?.properties?.firstName + ' ' + item?.properties?.lastName\r\n\t\t\t\t\t}}\r\n\t\t\t\t</div>\r\n\t\t\t\t<div>\r\n\t\t\t\t\t<span class=\"ng-value-icon right\" (click)=\"clear(item)\" aria-hidden=\"true\">×</span>\r\n\t\t\t\t</div>\r\n\t\t\t</span>\r\n\t\t</ng-template>\r\n\r\n\t\t<ng-template ng-option-tmp let-item=\"item\" let-item$=\"item$\" let-index=\"index\">\r\n\t\t\t<span style=\"display: flex; align-items: center; column-gap: 4px; font-size: 16px\">\r\n\t\t\t\t<mat-checkbox\r\n\t\t\t\t\t*ngIf=\"multiple\"\r\n\t\t\t\t\tid=\"item-{{ index }}\"\r\n\t\t\t\t\t[ngModel]=\"item$.selected\"\r\n\t\t\t\t\t(click)=\"(false)\"\r\n\t\t\t\t></mat-checkbox>\r\n\t\t\t\t<div style=\"width: 30px; height: 30px\">\r\n\t\t\t\t\t<cts-avatar [user]=\"item\"></cts-avatar>\r\n\t\t\t\t</div>\r\n\t\t\t\t<div>\r\n\t\t\t\t\t{{\r\n\t\t\t\t\t\titem?.id === 'system'\r\n\t\t\t\t\t\t\t? ('SYSTEM_ADMIN' | translate)\r\n\t\t\t\t\t\t\t: useArabicName\r\n\t\t\t\t\t\t\t? isArabic\r\n\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t: item?.properties?.firstName + ' ' + item?.properties?.lastName\r\n\t\t\t\t\t}}\r\n\t\t\t\t</div>\r\n\r\n\t\t\t\t<div></div>\r\n\t\t\t</span>\r\n\t\t</ng-template>\r\n\t</ng-select>\r\n</div>\r\n<mat-error [attr.data-automation-id]=\"'card-textitem-error-'\" class=\"app-textitem-editable-error\" *ngIf=\"hasErrors()\">\r\n\t<ul>\r\n\t\t<li *ngIf=\"control.errors.required\">\r\n\t\t\t{{ 'VALIDATORS.REQUIRED' | translate }}\r\n\t\t</li>\r\n\t</ul>\r\n</mat-error>\r\n"]}
372
+ //# 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  @Input() fetchUsersByCustomApi: boolean = false;\r\n  @Input() set fetchedUsers(res: Record<string, any>[]) {\r\n    this.loading = true;\r\n    let newData = this.constructUserArray(res, 'id');\r\n    this.data = this.data.concat(newData);\r\n    this.isNextPageAvailable = false;\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;\r\n  }\r\n  @Output() onSearch = new EventEmitter<string>();\r\n  searchFn = null;\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.fetchUsersByCustomApi) {\r\n      if (this.allUsers) {\r\n        this.loadUsers();\r\n      }\r\n      this.getDepartments();\r\n    } else {\r\n      this.searchFn = (term: string, item: Record<string, any>) => {\r\n        const fullName = `${item.properties.firstName} ${item.properties.lastName}`.toLowerCase();\r\n        return fullName.includes(term.toLowerCase());\r\n      }\r\n    }\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    this.loading = true;\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        this.loading = false;\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          this.loading = false;\r\n        });\r\n      }\r\n    } else {\r\n      this.loading = false;\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","\t<ng-container *ngIf=\"label\">\r\n\t\t<div>\r\n\t\t\t<label class=\"select-label\"\r\n\t\t\t\t>{{ label | translate }}<span *ngIf=\"isRequired()\" class=\"text-danger mx-1\">*</span></label\r\n\t\t\t>\r\n\t\t</div>\r\n\t</ng-container>\r\n\t<div class=\"user-select\" [ngClass]=\"{ 'multiple-wrapper': multiple }\" SetRtl>\r\n\t\t<ng-select\r\n\t\t\t#ngSelectComponent\r\n\t\t\t[items]=\"buffer\"\r\n\t\t\t[bindLabel]=\"useArabicName ? (isArabic ? arabicBindLabel : bindLabel) : bindLabel\"\r\n\t\t\t[placeholder]=\"multiple && selection && selection.length > 0 ? selectionstrg : placeholder\"\r\n\t\t\t[multiple]=\"multiple\"\r\n\t\t\t[searchable]=\"searchable\"\r\n\t\t\t[closeOnSelect]=\"closeOnSelect\"\r\n\t\t\t[hideSelected]=\"hideSelectedItems\"\r\n\t\t\t[loading]=\"loading\"\r\n\t\t\t(scrollToEnd)=\"onScrollToEnd()\"\r\n\t\t\t[disabled]=\"disabled\"\r\n\t\t\t[typeahead]=\"userNameInput$\"\r\n\t\t\t[compareWith]=\"compareFn\"\r\n\t\t\t[(ngModel)]=\"selection\"\r\n\t\t\t[searchFn]=\"searchFn\"\r\n\t\t\t(change)=\"emitSelection($event)\"\r\n\t\t>\r\n\t\t\t<ng-template ng-label-tmp let-item=\"item\" let-clear=\"clear\" *ngIf=\"!loading\">\r\n\t\t\t\t<span style=\"display: flex; align-items: center; column-gap: 4px; font-size: 16px\">\r\n\t\t\t\t\t<div style=\"width: 30px; height: 30px\">\r\n\t\t\t\t\t\t<cts-avatar [user]=\"item\"></cts-avatar>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t\t<div class=\"user-name\">\r\n\t\t\t\t\t\t{{\r\n\t\t\t\t\t\t\titem?.id === 'system'\r\n\t\t\t\t\t\t\t\t? ('SYSTEM_ADMIN' | translate)\r\n\t\t\t\t\t\t\t\t: useArabicName\r\n\t\t\t\t\t\t\t\t? isArabic\r\n\t\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t\t: item?.properties?.firstName + ' ' + item?.properties?.lastName\r\n\t\t\t\t\t\t}}\r\n\t\t\t\t\t</div>\r\n\t\t\t\t\t<div>\r\n\t\t\t\t\t\t<span class=\"ng-value-icon right\" (click)=\"clear(item)\" aria-hidden=\"true\">×</span>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</span>\r\n\t\t\t</ng-template>\r\n\r\n\t\t\t<ng-template ng-option-tmp let-item=\"item\" let-item$=\"item$\" let-index=\"index\">\r\n\t\t\t\t<span style=\"display: flex; align-items: center; column-gap: 4px; font-size: 16px\">\r\n\t\t\t\t\t<mat-checkbox\r\n\t\t\t\t\t\t*ngIf=\"multiple\"\r\n\t\t\t\t\t\tid=\"item-{{ index }}\"\r\n\t\t\t\t\t\t[ngModel]=\"item$.selected\"\r\n\t\t\t\t\t\t(click)=\"(false)\"\r\n\t\t\t\t\t></mat-checkbox>\r\n\t\t\t\t\t<div style=\"width: 30px; height: 30px\">\r\n\t\t\t\t\t\t<cts-avatar [user]=\"item\"></cts-avatar>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t\t<div>\r\n\t\t\t\t\t\t{{\r\n\t\t\t\t\t\t\titem?.id === 'system'\r\n\t\t\t\t\t\t\t\t? ('SYSTEM_ADMIN' | translate)\r\n\t\t\t\t\t\t\t\t: useArabicName\r\n\t\t\t\t\t\t\t\t? isArabic\r\n\t\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t\t: item?.properties?.firstName + ' ' + item?.properties?.lastName\r\n\t\t\t\t\t\t}}\r\n\t\t\t\t\t</div>\r\n\r\n\t\t\t\t\t<div></div>\r\n\t\t\t\t</span>\r\n\t\t\t</ng-template>\r\n\t\t</ng-select>\r\n\t</div>\r\n\t<mat-error [attr.data-automation-id]=\"'card-textitem-error-'\" class=\"app-textitem-editable-error\" *ngIf=\"hasErrors()\">\r\n\t\t<ul>\r\n\t\t\t<li *ngIf=\"control.errors.required\">\r\n\t\t\t\t{{ 'VALIDATORS.REQUIRED' | translate }}\r\n\t\t\t</li>\r\n\t\t</ul>\r\n\t</mat-error>\r\n"]}