vcomply-workflow-engine 6.1.69 → 6.1.70

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.
@@ -190,6 +190,7 @@ export class FormatAndEvidenceComponent {
190
190
  original_filename: data.org_file,
191
191
  linkSet: '',
192
192
  type: file.type,
193
+ fid: data?.fid,
193
194
  });
194
195
  delete this.formate.uploadInProgress[uid];
195
196
  this.emitValue();
@@ -330,4 +331,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
330
331
  }], formatEvidanceData: [{
331
332
  type: Input
332
333
  }] } });
333
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"format-and-evidence.component.js","sourceRoot":"","sources":["../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/format-and-evidence/format-and-evidence.component.ts","../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/format-and-evidence/format-and-evidence.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  OnChanges,\n  Output,\n  EventEmitter,\n  Input,\n} from '@angular/core';\nimport { AuthService } from '../../workflow-services/auth.service';\nimport { PolicyService } from '../../workflow-services/policy.service';\nimport { SnackBarService } from '../../ui-kit/snack-bar/snack-bar.service';\nimport { ResponsibilityService } from '../../workflow-services/responsibility.service';\nimport { ASSETS } from '../../constants/assets.constants';\nimport { FILE_URL } from '../../constants/file-upload.constant';\nimport { FILE_SIZE } from '../../constants/policy.constant';\n\n@Component({\n  selector: 'app-format-and-evidence',\n  templateUrl: './format-and-evidence.component.html',\n  styleUrls: ['./format-and-evidence.component.less', '../../forms.less'],\n})\nexport class FormatAndEvidenceComponent implements OnInit {\n  ASSETS = ASSETS;\n  @Output() updateFiles = new EventEmitter();\n  @Input() mode = '';\n  @Input() categories: any[] = [];\n  @Input() organization_id: any = '';\n  @Input() set formatEvidanceData(value: any) {\n    if (value) {\n      this.initializeData(value, 'not ng on init');\n    }\n  }\n  isNewLinkDisabled = false;\n  isEditDisabled = false;\n  constructor(\n    private responsibilityService: ResponsibilityService,\n    private policyService: PolicyService,\n    private authService: AuthService,\n    private snackbarService: SnackBarService\n  ) { }\n\n  formate: any = {\n    hasUploadFormate: false,\n    formateType: 'FILE', // LINK\n    isEvidenceRequired: false,\n    links: [],\n    files: [],\n    uploadInProgress: {},\n  };\n\n  newLink = {\n    link: '',\n    containsError: false,\n  };\n  ngOnInit(): void {\n    if (this.formatEvidanceData) {\n      this.initializeData(this.formatEvidanceData, 'ng on init');\n    }\n  }\n\n  initializeData(settings: any, type: string) {\n    console.log('initializeData',settings);\n    this.formate.hasUploadFormate = settings?.formatRequired ?? false;\n    this.formate.formateType =\n      settings?.formatLinks?.length > 0 ? 'LINK' : 'FILE';\n    this.formate.isEvidenceRequired = settings?.evidenceRequired ?? false;\n    this.formate.links = this.arraytoLinkObject(settings?.formatLinks) ?? [];\n    if (this.mode == 'reportACase') {\n      this.formate.files = settings;\n    } else {\n      this.formate.files = settings?.formatFiles ?? [];\n    }\n  }\n  toggleIsFormateUpload(status: boolean) {\n    if (status === true) {\n      this.formate.hasUploadFormate = true;\n    } else {\n      this.formate.hasUploadFormate = false;\n    }\n    this.emitValue();\n  }\n\n  toggleIsFormatRequired(status: boolean) {\n    if (status === true) {\n      this.formate.isEvidenceRequired = true;\n    } else {\n      this.formate.isEvidenceRequired = false;\n    }\n    this.emitValue();\n  }\n\n  toggleAttachmentType(type: string) {\n    this.formate.formateType = type;\n    if (type === 'LINK' && this.formate.links.length === 0) {\n      // TODO\n    }\n    this.emitValue();\n  }\n\n  insertLink(mode: any, index: number = -1) {\n    // const urlRegex = new RegExp('(https?://)?([\\\\da-z.-]+)\\\\.([a-z.]{2,6})[/\\\\w .-]*/?');\n    const urlRegex =\n      /(https?:\\/\\/(?:www\\.|(?!www))[a-zA-Z0-9][a-zA-Z0-9-]+[a-zA-Z0-9]\\.[^\\s]{2,}|www\\.[a-zA-Z0-9][a-zA-Z0-9-]+[a-zA-Z0-9]\\.[^\\s]{2,}|https?:\\/\\/(?:www\\.|(?!www))[a-zA-Z0-9]+\\.[^\\s]{2,}|www\\.[a-zA-Z0-9]+\\.[^\\s]{2,})/gi;\n    if (mode === 'CREATE') {\n      if (this.newLink.link.length === 0) {\n        this.resetNewLink();\n        return;\n      }\n      const isValid = urlRegex.test(this.newLink.link);\n      if (isValid) {\n        this.newLink.containsError = false;\n        this.formate.links.push(this.newLink);\n        this.resetNewLink();\n      } else {\n        this.newLink.containsError = true;\n      }\n    } else if (mode === 'EDIT') {\n      if (this.formate.links[index].link.length === 0) {\n        this.formate.links.splice(index, 1);\n        this.isEditEnabled();\n        this.isNewLinkDisabled = false;\n        this.emitValue();\n        return;\n      }\n      const isValid = urlRegex.test(this.formate.links[index].link);\n      if (isValid) {\n        this.formate.links[index].isEditing = false;\n        this.formate.links[index].containsError = false;\n        this.formate.links[index].isEditing = false;\n        this.isNewLinkDisabled = false;\n        this.isEditEnabled();\n      } else {\n        this.formate.links[index].containsError = true;\n      }\n    }\n    this.emitValue();\n  }\n\n  editLink(index: number) {\n    this.formate.links[index].isEditing = true;\n    this.isNewLinkDisabled = true;\n    this.isEditEnabled();\n  }\n\n  deleteLink(index: number) {\n    this.formate.links.splice(index, 1);\n    this.isEditEnabled();\n    this.emitValue();\n  }\n\n  resetNewLink() {\n    this.newLink = {\n      link: '',\n      containsError: false,\n    };\n    this.emitValue();\n  }\n\n  private fileProcessing(file: File, uid: string) {\n    if (this.policyService.fileSizeLimit(file)) {\n      this.uploadFile(file, uid);\n    } else {\n      this.snackbarService.show(FILE_SIZE.MESSAGE, FILE_SIZE.ERROR);\n    }\n  }\n\n  onFileDropped(files: any) {\n    Array.from(files).forEach((file: any) => {\n      const uid: string = Math.random().toString(36).substring(2, 14);\n      this.fileProcessing(file, uid);\n    });\n  }\n\n  uploadFile(file: any, uid: string) {\n    this.formate.uploadInProgress[uid] = file.name;\n    const formData = new FormData();\n    formData.append('file', file);\n    if (this.mode == 'policy' || this.mode == 'policyReviewer') {\n      const path = 'o/' + this.organization_id + '/policy/';\n      this.policyService\n        .fileUploadWorkroom(formData, path)\n        .subscribe((data: any) => {\n          this.formate.files.push({\n            filepath: path,\n            file_name: data.org_file,\n            filename: data.name,\n            original_filename: data.org_file,\n            linkSet: '',\n            type: file.type,\n          });\n          delete this.formate.uploadInProgress[uid];\n          this.emitValue();\n        });\n    } else {\n      const url = `org-${this.organization_id}${FILE_URL.format}`;\n      this.responsibilityService\n        .uploadToNode(formData, url)\n        .subscribe((data: any) => {\n          this.formate.files.push({\n            filepath:data?.file_url_path,\n            file_name: data.org_file,\n            filename: data.name,\n            original_filename: data.org_file,\n            type: file.type,\n          });\n          delete this.formate.uploadInProgress[uid];\n          this.emitValue();\n        });\n    }\n  }\n\n  deleteAttachment(index: number) {\n    this.formate.files.splice(index, 1);\n    this.emitValue();\n  }\n\n  emitValue() {\n    if (this.mode == 'reportACase') {\n      this.updateFiles.emit(this.formate);\n      return;\n    }\n    if (this.mode == 'policy' || this.mode == 'policyReviewer') {\n      const payload = {\n        isFormateUploaded: this.formate.hasUploadFormate,\n        links:\n          this.formate.formateType === 'LINK'\n            ? this.getLinksArray(\n                this.formate.links?.length ? [...this.formate.links] : []\n              )\n            : [],\n        files: this.formate.formateType === 'FILE' ? this.formate.files : [],\n        formateType: this.formate.formateType,\n        isEvidenceRequired: this.formate.isEvidenceRequired,\n      };\n      payload.links = payload.links.filter((ele: any) => ele !== undefined);\n\n      this.updateFiles.emit(payload);\n    } else {\n      const payload = {\n        isFormateUploaded: this.formate.hasUploadFormate,\n        links:\n          this.formate.hasUploadFormate && this.formate.formateType === 'LINK'\n            ? this.getLinksArray([...this.formate.links])\n            : [],\n        files:\n          this.formate.hasUploadFormate && this.formate.formateType === 'FILE'\n            ? this.formate.files\n            : [],\n        formateType: this.formate.formateType,\n        isEvidenceRequired: this.formate.isEvidenceRequired,\n      };\n      payload.links = payload.links.filter((ele: any) => ele !== undefined);\n      this.updateFiles.emit(payload);\n    }\n  }\n  getLinksArray(links: any) {\n    const link = links.map((e: any) => {\n      if (e.link && !e?.containsError && !e?.isEditing) {\n        return e.link;\n      }\n    });\n    if (link?.length <= 1 && link[0] === undefined) {\n      return [];\n    } else {\n      return link;\n    }\n  }\n\n  arraytoLinkObject(linksArray: any) {\n    if (linksArray) {\n      const links = linksArray.map((e: any) => {\n        return { link: e, containsError: false, isEditing: false };\n      });\n\n      return links;\n    } else {\n      return [];\n    }\n  }\n\n  isEditEnabled() {\n    for (const item of this.formate.links) {\n      if (item.isEditing === true) {\n        this.isEditDisabled = true;\n        return;\n      } else {\n        this.isEditDisabled = false;\n      }\n    }\n  }\n  policyLinkSetList = [\n    // 'Policy Charter',\n    // 'Related Policy Documents/Other References',\n    // 'Procedures Linked to this Policy',\n    // 'Implementation Guidelines for this Policy',\n    // 'Training Materials for this Policy'\n    'Charter',\n    'Related Documents',\n    'Reference Materials',\n    'Related procedures',\n    'Implementation guidelines',\n    'Training Materials',\n    'Regulatory Documents',\n    'Other',\n  ];\n  selectedLinkSetChange(event: any, index: number) {\n    this.formate.files[index].linkSet = event;\n    if (event === 'Other' && !this.formate?.files[index]?.others) {\n      this.formate.files[index].others = [''];\n    }\n    this.emitValue();\n  }\n\n  addMoreDocumentsDetails(index: number) {\n    this.formate.files[index].others.push('');\n  }\n\n  uploadPolicyAttachments(formData: any) {\n    const path = 'o/' + this.organization_id + '/policy/';\n    this.policyService\n      .fileUploadWorkroom(formData, path)\n      .subscribe((data: any) => {\n        const payload = {\n          file_name: data.name,\n          original_file_name: data.org_file,\n          path: path,\n          organisation_id: this.authService.getOrganizationId(),\n          member_id: this.authService.getMemberId(),\n          category_id: this.categories,\n          clap_id: 0,\n          contract_type: 4,\n          folder_id: 0,\n        };\n      });\n  }\n}\n","<div class=\"vx-form-group\" [class.policy-upload-file]=\"['policy', 'reportACase']?.includes(mode)\">\n  <label class=\"vx-control-panel\" *ngIf=\"mode == 'responsibility'\">\n    Format & Evidence\n  </label>\n  <div class=\"upload-format\" *ngIf=\"\n      mode != 'policy' && mode != 'policyReviewer' && mode != 'reportACase'\n    \">\n    <span class=\"text\">Do you want to upload a format for this responsibility?</span>\n    <div class=\"radio-group\">\n      <app-cs-radio [name]=\"'format_required'\" [checked]=\"formate.hasUploadFormate === true\"\n        (checkedEvent)=\"toggleIsFormateUpload(true)\">Yes</app-cs-radio>\n      <app-cs-radio [name]=\"'format_required'\" [checked]=\"formate.hasUploadFormate === false\"\n        (checkedEvent)=\"toggleIsFormateUpload(false)\">No\n      </app-cs-radio>\n    </div>\n  </div>\n  <div class=\"form-tab\" *ngIf=\"formate?.hasUploadFormate || mode == 'policyReviewer'\">\n    <button type=\"button\" [class.active]=\"formate?.formateType === 'FILE'\" (click)=\"toggleAttachmentType('FILE')\"\n      [disabled]=\"formate.links?.length > 0\">\n      Insert File\n    </button>\n    <button type=\"button\" [class.active]=\"formate?.formateType === 'LINK'\" (click)=\"toggleAttachmentType('LINK')\"\n      [disabled]=\"formate.files?.length > 0\">\n      Insert Link\n    </button>\n  </div>\n\n  <ng-container *ngIf=\"\n      (formate?.hasUploadFormate && formate.formateType === 'FILE') ||\n      (mode == 'policy' && formate.formateType === 'FILE') ||\n      (mode == 'policyReviewer' && formate.formateType === 'FILE') ||\n      (mode == 'reportACase' && formate.formateType === 'FILE')\n    \">\n    <!-- -----------------------------file upload in progress ----------------------------------  -->\n    <ng-container *ngIf=\"(formate?.uploadInProgress | keyvalue).length > 0\">\n      <div class=\"file-list\" *ngFor=\"\n          let eachFile of formate?.uploadInProgress | keyvalue;\n          let i = index\n        \">\n        <div class=\"file-container\">\n          <span class=\"file-name\">{{ eachFile.value }}</span>\n        </div>\n        <app-line-loader [loaderHeight]=\"2\"></app-line-loader>\n      </div>\n    </ng-container>\n    <!-- --------------------------------file upload ends here -----------------------------------------  -->\n    <ng-container *ngIf=\"formate.files?.length > 0\">\n      <ng-container *ngIf=\"mode != 'policy'\">\n        <div class=\"file-list\" *ngFor=\"let eachFile of formate.files; let i = index\">\n          <div class=\"file-container\">\n            <span class=\"file-name\">{{ eachFile?.file_name }}</span>\n            <button (click)=\"deleteAttachment(i)\">\n              <i class=\"icons\">&#xe90d;</i>\n            </button>\n          </div>\n        </div>\n      </ng-container>\n\n      <div *ngIf=\"mode == 'policy'\" class=\"policy-related-document-field vx-p-3 vx-pt-2\">\n        <div class=\"vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase vx-mb-2\">\n          LINK THE DOCUMENT AND SPECIFY THE RELATIONSHIP WITH THIS POLICY\n        </div>\n        <div class=\"file-list policy\" *ngFor=\"let eachFile of formate.files; let i = index\">\n          <div class=\"file-container\">\n            <span class=\"file table {{\n                eachFile?.file_name.split('.')[\n                  eachFile?.file_name.split('.')?.length - 1\n                ]\n              }}\">\n              <i class=\"icons\">&#xe92e;</i>\n              <span class=\"format {{\n                  eachFile?.file_name.split('.')[\n                    eachFile?.file_name.split('.')?.length - 1\n                  ]\n                }}\">{{\n                eachFile?.file_name.split(\".\")[\n                eachFile?.file_name.split(\".\")?.length - 1\n                ]\n                }}\n              </span>\n            </span>\n            <span class=\"file-name\">{{ eachFile?.file_name }}</span>\n            <div class=\"button-group\">\n              <button (click)=\"deleteAttachment(i)\">\n                <i class=\"icons\">&#xe90d;</i>\n              </button>\n            </div>\n          </div>\n          <cs-select [(ngModel)]=\"eachFile.linkSet\" (ngModelChange)=\"selectedLinkSetChange($event, i)\"\n            [placeholder]=\"'Define the document\\'s relationship to this policy'\" name=\"selected\">\n            <cs-option *ngFor=\"let data of policyLinkSetList\" [value]=\"data\">\n              {{ data }}\n            </cs-option>\n          </cs-select>\n          <!-- <ng-container *ngFor=\"let other of eachFile?.others; let j = index\">\n                        <input *ngIf=\"eachFile?.linkSet === 'Other (specify own)'\" [ngModel]=\"eachFile.others[j]\" (ngModelChange)=\"selectedLinkSetChange('Other (specify own)',i, $event, j)\" class=\"linkage-input\" type=\"text\" placeholder=\"Type the linkage details\" />\n                    </ng-container>\n                    <button *ngIf=\"eachFile?.linkSet === 'Other (specify own)'\" class=\"linkage-btn vx-fs-11 vx-fw-500 vx-txt-blue vx-tt-uppercase vx-p-0 vx-mt-2\" (click)=\"addMoreDocumentsDetails(i)\">+ ADD MORE</button> -->\n        </div>\n      </div>\n\n      <!-- <label class=\"vx-control-panel\" *ngIf=\"mode=='policy'\">\n                LINK THE DOCUMENT AND SPECIFY THE RELATIONSHIP WITH THIS POLICY\n            </label>\n            <ng-container *ngFor=\"let eachFile of formate.files; let i = index\">\n                <div class=\"file-list\" *ngIf=\"mode!='policy'\">\n                    <div class=\"file-container\">\n                        <span class=\"file-name\">{{ eachFile?.file_name }} </span>\n                        <button (click)=\"deleteAttachment(i)\">\n                            <i class=\"icons\">&#xe90d;</i>\n                        </button>\n                    </div>\n                </div>\n                <div class=\"file-list policy\" *ngIf=\"mode=='policy'\">\n                    <div class=\"file-container\">\n                        <span class=\"file-name\">{{eachFile?.file_name}}</span>\n                        <div class=\"button-group\">\n                            <!- - <button class=\"edit\">\n                                <i class=\"icons\">&#xe9ba;</i>\n                            </button> - ->\n                            <button (click)=\"deleteAttachment(i)\">\n                                <i class=\"icons\">&#xe90d;</i>\n                            </button>\n                        </div>\n                    </div>\n                    <cs-select [(ngModel)]=\"eachFile.linkSet\" (ngModelChange)=\"selectedLinkSetChange($event,i)\" [placeholder]=\"'Define the document\\'s relationship to this policy'\" name=\"selected\" >\n                        <cs-option *ngFor=\"let data of policyLinkSetList\" [value]=\"data\">\n                            {{data}}\n                        </cs-option>\n                    </cs-select>\n                </div>\n            </ng-container> -->\n    </ng-container>\n    <!-- -----------------------------------drag and drop ---------------------------------------------- -->\n    <div class=\"tab-group\" [class.uploaded]=\"formate.files?.length > 0\" appDragDrop\n      (fileDropped)=\"onFileDropped($event)\">\n      <label class=\"upload-file\">\n        <img [src]=\"ASSETS.upload\" alt=\"\" class=\"image\" />\n        <div class=\"browse\">\n          <span>\n            <ng-container *ngIf=\"mode != 'policy' && mode != 'reportACase'\">Drop your files here /\n            </ng-container>\n            <ng-container *ngIf=\"mode == 'policy' || mode == 'reportACase'\">Drop your files here /\n            </ng-container>\n            <span class=\"label\">Browse\n              <input type=\"file\" multiple (change)=\"onFileDropped($event.target.files)\" />\n            </span>\n          </span>\n          <!-- <span *ngIf=\"mode!='policy'\">Drop your files here /</span>\n                    <span *ngIf=\"mode=='policy'\">Drag & drop to upload files associated with this policy /</span>\n                    <span class=\"label\">Browse\n                        <input type=\"file\" multiple (change)=\"onFileDropped($event.target.files)\">\n                    </span> -->\n        </div>\n      </label>\n    </div>\n    <!-- ------------------------------------------drag drop ends here -------------------------------------------- -->\n  </ng-container>\n\n  <ng-container *ngIf=\"\n      (formate?.hasUploadFormate && formate.formateType === 'LINK') ||\n      (mode == 'policyReviewer' && formate.formateType === 'LINK')\n    \">\n    <ng-container *ngIf=\"formate.links.length > 0\">\n      <ng-container *ngFor=\"let link of formate.links; let i = index\">\n        <div class=\"file-list\" *ngIf=\"!link.isEditing\">\n          <div class=\"file-container\">\n            <span class=\"file-name\">{{ link.link }} </span>\n            <span class=\"button-group\">\n              <button [class.disabled]=\"isEditDisabled\" class=\"edit\" (click)=\"editLink(i)\">\n                <i class=\"icons\">&#xe9ba;</i>\n              </button>\n              <button (click)=\"deleteLink(i)\">\n                <i class=\"icons\">&#xe90d;</i>\n              </button>\n            </span>\n          </div>\n        </div>\n        <ng-container *ngIf=\"link.isEditing\">\n          <input type=\"text\" class=\"edit-link\" appAutofocus placeholder=\"Enter the link here\" [(ngModel)]=\"link.link\"\n            (focusout)=\"insertLink('EDIT', i)\" (keydown.enter)=\"insertLink('EDIT', i)\" />\n          <p class=\"error-message\" *ngIf=\"link.containsError\">\n            Please insert a valid link\n          </p>\n        </ng-container>\n      </ng-container>\n    </ng-container>\n    <input [disabled]=\"isNewLinkDisabled\" class=\"edit-link\" type=\"text\" [(ngModel)]=\"newLink.link\"\n      placeholder=\"Enter the link here\" (focusout)=\"insertLink('CREATE')\" (keydown.enter)=\"insertLink('CREATE')\" />\n    <p class=\"error-message\" *ngIf=\"newLink.containsError\">\n      Please insert a valid link\n    </p>\n  </ng-container>\n  <div class=\"upload-format\" *ngIf=\"mode == 'responsibility'\">\n    <span class=\"text\">Do you want evidence of completion of the responsibility to be\n      uploaded?</span>\n    <div class=\"radio-group\">\n      <app-cs-radio [name]=\"'evidence_required'\" [checked]=\"formate.isEvidenceRequired === true\"\n        (checkedEvent)=\"toggleIsFormatRequired(true)\">Yes</app-cs-radio>\n      <app-cs-radio [name]=\"'evidence_required'\" [checked]=\"formate.isEvidenceRequired === false\"\n        (checkedEvent)=\"toggleIsFormatRequired(false)\">No\n      </app-cs-radio>\n    </div>\n  </div>\n</div>"]}
334
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"format-and-evidence.component.js","sourceRoot":"","sources":["../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/format-and-evidence/format-and-evidence.component.ts","../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/format-and-evidence/format-and-evidence.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  OnChanges,\n  Output,\n  EventEmitter,\n  Input,\n} from '@angular/core';\nimport { AuthService } from '../../workflow-services/auth.service';\nimport { PolicyService } from '../../workflow-services/policy.service';\nimport { SnackBarService } from '../../ui-kit/snack-bar/snack-bar.service';\nimport { ResponsibilityService } from '../../workflow-services/responsibility.service';\nimport { ASSETS } from '../../constants/assets.constants';\nimport { FILE_URL } from '../../constants/file-upload.constant';\nimport { FILE_SIZE } from '../../constants/policy.constant';\n\n@Component({\n  selector: 'app-format-and-evidence',\n  templateUrl: './format-and-evidence.component.html',\n  styleUrls: ['./format-and-evidence.component.less', '../../forms.less'],\n})\nexport class FormatAndEvidenceComponent implements OnInit {\n  ASSETS = ASSETS;\n  @Output() updateFiles = new EventEmitter();\n  @Input() mode = '';\n  @Input() categories: any[] = [];\n  @Input() organization_id: any = '';\n  @Input() set formatEvidanceData(value: any) {\n    if (value) {\n      this.initializeData(value, 'not ng on init');\n    }\n  }\n  isNewLinkDisabled = false;\n  isEditDisabled = false;\n  constructor(\n    private responsibilityService: ResponsibilityService,\n    private policyService: PolicyService,\n    private authService: AuthService,\n    private snackbarService: SnackBarService\n  ) { }\n\n  formate: any = {\n    hasUploadFormate: false,\n    formateType: 'FILE', // LINK\n    isEvidenceRequired: false,\n    links: [],\n    files: [],\n    uploadInProgress: {},\n  };\n\n  newLink = {\n    link: '',\n    containsError: false,\n  };\n  ngOnInit(): void {\n    if (this.formatEvidanceData) {\n      this.initializeData(this.formatEvidanceData, 'ng on init');\n    }\n  }\n\n  initializeData(settings: any, type: string) {\n    console.log('initializeData',settings);\n    this.formate.hasUploadFormate = settings?.formatRequired ?? false;\n    this.formate.formateType =\n      settings?.formatLinks?.length > 0 ? 'LINK' : 'FILE';\n    this.formate.isEvidenceRequired = settings?.evidenceRequired ?? false;\n    this.formate.links = this.arraytoLinkObject(settings?.formatLinks) ?? [];\n    if (this.mode == 'reportACase') {\n      this.formate.files = settings;\n    } else {\n      this.formate.files = settings?.formatFiles ?? [];\n    }\n  }\n  toggleIsFormateUpload(status: boolean) {\n    if (status === true) {\n      this.formate.hasUploadFormate = true;\n    } else {\n      this.formate.hasUploadFormate = false;\n    }\n    this.emitValue();\n  }\n\n  toggleIsFormatRequired(status: boolean) {\n    if (status === true) {\n      this.formate.isEvidenceRequired = true;\n    } else {\n      this.formate.isEvidenceRequired = false;\n    }\n    this.emitValue();\n  }\n\n  toggleAttachmentType(type: string) {\n    this.formate.formateType = type;\n    if (type === 'LINK' && this.formate.links.length === 0) {\n      // TODO\n    }\n    this.emitValue();\n  }\n\n  insertLink(mode: any, index: number = -1) {\n    // const urlRegex = new RegExp('(https?://)?([\\\\da-z.-]+)\\\\.([a-z.]{2,6})[/\\\\w .-]*/?');\n    const urlRegex =\n      /(https?:\\/\\/(?:www\\.|(?!www))[a-zA-Z0-9][a-zA-Z0-9-]+[a-zA-Z0-9]\\.[^\\s]{2,}|www\\.[a-zA-Z0-9][a-zA-Z0-9-]+[a-zA-Z0-9]\\.[^\\s]{2,}|https?:\\/\\/(?:www\\.|(?!www))[a-zA-Z0-9]+\\.[^\\s]{2,}|www\\.[a-zA-Z0-9]+\\.[^\\s]{2,})/gi;\n    if (mode === 'CREATE') {\n      if (this.newLink.link.length === 0) {\n        this.resetNewLink();\n        return;\n      }\n      const isValid = urlRegex.test(this.newLink.link);\n      if (isValid) {\n        this.newLink.containsError = false;\n        this.formate.links.push(this.newLink);\n        this.resetNewLink();\n      } else {\n        this.newLink.containsError = true;\n      }\n    } else if (mode === 'EDIT') {\n      if (this.formate.links[index].link.length === 0) {\n        this.formate.links.splice(index, 1);\n        this.isEditEnabled();\n        this.isNewLinkDisabled = false;\n        this.emitValue();\n        return;\n      }\n      const isValid = urlRegex.test(this.formate.links[index].link);\n      if (isValid) {\n        this.formate.links[index].isEditing = false;\n        this.formate.links[index].containsError = false;\n        this.formate.links[index].isEditing = false;\n        this.isNewLinkDisabled = false;\n        this.isEditEnabled();\n      } else {\n        this.formate.links[index].containsError = true;\n      }\n    }\n    this.emitValue();\n  }\n\n  editLink(index: number) {\n    this.formate.links[index].isEditing = true;\n    this.isNewLinkDisabled = true;\n    this.isEditEnabled();\n  }\n\n  deleteLink(index: number) {\n    this.formate.links.splice(index, 1);\n    this.isEditEnabled();\n    this.emitValue();\n  }\n\n  resetNewLink() {\n    this.newLink = {\n      link: '',\n      containsError: false,\n    };\n    this.emitValue();\n  }\n\n  private fileProcessing(file: File, uid: string) {\n    if (this.policyService.fileSizeLimit(file)) {\n      this.uploadFile(file, uid);\n    } else {\n      this.snackbarService.show(FILE_SIZE.MESSAGE, FILE_SIZE.ERROR);\n    }\n  }\n\n  onFileDropped(files: any) {\n    Array.from(files).forEach((file: any) => {\n      const uid: string = Math.random().toString(36).substring(2, 14);\n      this.fileProcessing(file, uid);\n    });\n  }\n\n  uploadFile(file: any, uid: string) {\n    this.formate.uploadInProgress[uid] = file.name;\n    const formData = new FormData();\n    formData.append('file', file);\n    if (this.mode == 'policy' || this.mode == 'policyReviewer') {\n      const path = 'o/' + this.organization_id + '/policy/';\n      this.policyService\n        .fileUploadWorkroom(formData, path)\n        .subscribe((data: any) => {\n          this.formate.files.push({\n            filepath: path,\n            file_name: data.org_file,\n            filename: data.name,\n            original_filename: data.org_file,\n            linkSet: '',\n            type: file.type,\n            fid: data?.fid,\n          });\n          delete this.formate.uploadInProgress[uid];\n          this.emitValue();\n        });\n    } else {\n      const url = `org-${this.organization_id}${FILE_URL.format}`;\n      this.responsibilityService\n        .uploadToNode(formData, url)\n        .subscribe((data: any) => {\n          this.formate.files.push({\n            filepath:data?.file_url_path,\n            file_name: data.org_file,\n            filename: data.name,\n            original_filename: data.org_file,\n            type: file.type,\n          });\n          delete this.formate.uploadInProgress[uid];\n          this.emitValue();\n        });\n    }\n  }\n\n  deleteAttachment(index: number) {\n    this.formate.files.splice(index, 1);\n    this.emitValue();\n  }\n\n  emitValue() {\n    if (this.mode == 'reportACase') {\n      this.updateFiles.emit(this.formate);\n      return;\n    }\n    if (this.mode == 'policy' || this.mode == 'policyReviewer') {\n      const payload = {\n        isFormateUploaded: this.formate.hasUploadFormate,\n        links:\n          this.formate.formateType === 'LINK'\n            ? this.getLinksArray(\n                this.formate.links?.length ? [...this.formate.links] : []\n              )\n            : [],\n        files: this.formate.formateType === 'FILE' ? this.formate.files : [],\n        formateType: this.formate.formateType,\n        isEvidenceRequired: this.formate.isEvidenceRequired,\n      };\n      payload.links = payload.links.filter((ele: any) => ele !== undefined);\n\n      this.updateFiles.emit(payload);\n    } else {\n      const payload = {\n        isFormateUploaded: this.formate.hasUploadFormate,\n        links:\n          this.formate.hasUploadFormate && this.formate.formateType === 'LINK'\n            ? this.getLinksArray([...this.formate.links])\n            : [],\n        files:\n          this.formate.hasUploadFormate && this.formate.formateType === 'FILE'\n            ? this.formate.files\n            : [],\n        formateType: this.formate.formateType,\n        isEvidenceRequired: this.formate.isEvidenceRequired,\n      };\n      payload.links = payload.links.filter((ele: any) => ele !== undefined);\n      this.updateFiles.emit(payload);\n    }\n  }\n  getLinksArray(links: any) {\n    const link = links.map((e: any) => {\n      if (e.link && !e?.containsError && !e?.isEditing) {\n        return e.link;\n      }\n    });\n    if (link?.length <= 1 && link[0] === undefined) {\n      return [];\n    } else {\n      return link;\n    }\n  }\n\n  arraytoLinkObject(linksArray: any) {\n    if (linksArray) {\n      const links = linksArray.map((e: any) => {\n        return { link: e, containsError: false, isEditing: false };\n      });\n\n      return links;\n    } else {\n      return [];\n    }\n  }\n\n  isEditEnabled() {\n    for (const item of this.formate.links) {\n      if (item.isEditing === true) {\n        this.isEditDisabled = true;\n        return;\n      } else {\n        this.isEditDisabled = false;\n      }\n    }\n  }\n  policyLinkSetList = [\n    // 'Policy Charter',\n    // 'Related Policy Documents/Other References',\n    // 'Procedures Linked to this Policy',\n    // 'Implementation Guidelines for this Policy',\n    // 'Training Materials for this Policy'\n    'Charter',\n    'Related Documents',\n    'Reference Materials',\n    'Related procedures',\n    'Implementation guidelines',\n    'Training Materials',\n    'Regulatory Documents',\n    'Other',\n  ];\n  selectedLinkSetChange(event: any, index: number) {\n    this.formate.files[index].linkSet = event;\n    if (event === 'Other' && !this.formate?.files[index]?.others) {\n      this.formate.files[index].others = [''];\n    }\n    this.emitValue();\n  }\n\n  addMoreDocumentsDetails(index: number) {\n    this.formate.files[index].others.push('');\n  }\n\n  uploadPolicyAttachments(formData: any) {\n    const path = 'o/' + this.organization_id + '/policy/';\n    this.policyService\n      .fileUploadWorkroom(formData, path)\n      .subscribe((data: any) => {\n        const payload = {\n          file_name: data.name,\n          original_file_name: data.org_file,\n          path: path,\n          organisation_id: this.authService.getOrganizationId(),\n          member_id: this.authService.getMemberId(),\n          category_id: this.categories,\n          clap_id: 0,\n          contract_type: 4,\n          folder_id: 0,\n        };\n      });\n  }\n}\n","<div class=\"vx-form-group\" [class.policy-upload-file]=\"['policy', 'reportACase']?.includes(mode)\">\n  <label class=\"vx-control-panel\" *ngIf=\"mode == 'responsibility'\">\n    Format & Evidence\n  </label>\n  <div class=\"upload-format\" *ngIf=\"\n      mode != 'policy' && mode != 'policyReviewer' && mode != 'reportACase'\n    \">\n    <span class=\"text\">Do you want to upload a format for this responsibility?</span>\n    <div class=\"radio-group\">\n      <app-cs-radio [name]=\"'format_required'\" [checked]=\"formate.hasUploadFormate === true\"\n        (checkedEvent)=\"toggleIsFormateUpload(true)\">Yes</app-cs-radio>\n      <app-cs-radio [name]=\"'format_required'\" [checked]=\"formate.hasUploadFormate === false\"\n        (checkedEvent)=\"toggleIsFormateUpload(false)\">No\n      </app-cs-radio>\n    </div>\n  </div>\n  <div class=\"form-tab\" *ngIf=\"formate?.hasUploadFormate || mode == 'policyReviewer'\">\n    <button type=\"button\" [class.active]=\"formate?.formateType === 'FILE'\" (click)=\"toggleAttachmentType('FILE')\"\n      [disabled]=\"formate.links?.length > 0\">\n      Insert File\n    </button>\n    <button type=\"button\" [class.active]=\"formate?.formateType === 'LINK'\" (click)=\"toggleAttachmentType('LINK')\"\n      [disabled]=\"formate.files?.length > 0\">\n      Insert Link\n    </button>\n  </div>\n\n  <ng-container *ngIf=\"\n      (formate?.hasUploadFormate && formate.formateType === 'FILE') ||\n      (mode == 'policy' && formate.formateType === 'FILE') ||\n      (mode == 'policyReviewer' && formate.formateType === 'FILE') ||\n      (mode == 'reportACase' && formate.formateType === 'FILE')\n    \">\n    <!-- -----------------------------file upload in progress ----------------------------------  -->\n    <ng-container *ngIf=\"(formate?.uploadInProgress | keyvalue).length > 0\">\n      <div class=\"file-list\" *ngFor=\"\n          let eachFile of formate?.uploadInProgress | keyvalue;\n          let i = index\n        \">\n        <div class=\"file-container\">\n          <span class=\"file-name\">{{ eachFile.value }}</span>\n        </div>\n        <app-line-loader [loaderHeight]=\"2\"></app-line-loader>\n      </div>\n    </ng-container>\n    <!-- --------------------------------file upload ends here -----------------------------------------  -->\n    <ng-container *ngIf=\"formate.files?.length > 0\">\n      <ng-container *ngIf=\"mode != 'policy'\">\n        <div class=\"file-list\" *ngFor=\"let eachFile of formate.files; let i = index\">\n          <div class=\"file-container\">\n            <span class=\"file-name\">{{ eachFile?.file_name }}</span>\n            <button (click)=\"deleteAttachment(i)\">\n              <i class=\"icons\">&#xe90d;</i>\n            </button>\n          </div>\n        </div>\n      </ng-container>\n\n      <div *ngIf=\"mode == 'policy'\" class=\"policy-related-document-field vx-p-3 vx-pt-2\">\n        <div class=\"vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase vx-mb-2\">\n          LINK THE DOCUMENT AND SPECIFY THE RELATIONSHIP WITH THIS POLICY\n        </div>\n        <div class=\"file-list policy\" *ngFor=\"let eachFile of formate.files; let i = index\">\n          <div class=\"file-container\">\n            <span class=\"file table {{\n                eachFile?.file_name.split('.')[\n                  eachFile?.file_name.split('.')?.length - 1\n                ]\n              }}\">\n              <i class=\"icons\">&#xe92e;</i>\n              <span class=\"format {{\n                  eachFile?.file_name.split('.')[\n                    eachFile?.file_name.split('.')?.length - 1\n                  ]\n                }}\">{{\n                eachFile?.file_name.split(\".\")[\n                eachFile?.file_name.split(\".\")?.length - 1\n                ]\n                }}\n              </span>\n            </span>\n            <span class=\"file-name\">{{ eachFile?.file_name }}</span>\n            <div class=\"button-group\">\n              <button (click)=\"deleteAttachment(i)\">\n                <i class=\"icons\">&#xe90d;</i>\n              </button>\n            </div>\n          </div>\n          <cs-select [(ngModel)]=\"eachFile.linkSet\" (ngModelChange)=\"selectedLinkSetChange($event, i)\"\n            [placeholder]=\"'Define the document\\'s relationship to this policy'\" name=\"selected\">\n            <cs-option *ngFor=\"let data of policyLinkSetList\" [value]=\"data\">\n              {{ data }}\n            </cs-option>\n          </cs-select>\n          <!-- <ng-container *ngFor=\"let other of eachFile?.others; let j = index\">\n                        <input *ngIf=\"eachFile?.linkSet === 'Other (specify own)'\" [ngModel]=\"eachFile.others[j]\" (ngModelChange)=\"selectedLinkSetChange('Other (specify own)',i, $event, j)\" class=\"linkage-input\" type=\"text\" placeholder=\"Type the linkage details\" />\n                    </ng-container>\n                    <button *ngIf=\"eachFile?.linkSet === 'Other (specify own)'\" class=\"linkage-btn vx-fs-11 vx-fw-500 vx-txt-blue vx-tt-uppercase vx-p-0 vx-mt-2\" (click)=\"addMoreDocumentsDetails(i)\">+ ADD MORE</button> -->\n        </div>\n      </div>\n\n      <!-- <label class=\"vx-control-panel\" *ngIf=\"mode=='policy'\">\n                LINK THE DOCUMENT AND SPECIFY THE RELATIONSHIP WITH THIS POLICY\n            </label>\n            <ng-container *ngFor=\"let eachFile of formate.files; let i = index\">\n                <div class=\"file-list\" *ngIf=\"mode!='policy'\">\n                    <div class=\"file-container\">\n                        <span class=\"file-name\">{{ eachFile?.file_name }} </span>\n                        <button (click)=\"deleteAttachment(i)\">\n                            <i class=\"icons\">&#xe90d;</i>\n                        </button>\n                    </div>\n                </div>\n                <div class=\"file-list policy\" *ngIf=\"mode=='policy'\">\n                    <div class=\"file-container\">\n                        <span class=\"file-name\">{{eachFile?.file_name}}</span>\n                        <div class=\"button-group\">\n                            <!- - <button class=\"edit\">\n                                <i class=\"icons\">&#xe9ba;</i>\n                            </button> - ->\n                            <button (click)=\"deleteAttachment(i)\">\n                                <i class=\"icons\">&#xe90d;</i>\n                            </button>\n                        </div>\n                    </div>\n                    <cs-select [(ngModel)]=\"eachFile.linkSet\" (ngModelChange)=\"selectedLinkSetChange($event,i)\" [placeholder]=\"'Define the document\\'s relationship to this policy'\" name=\"selected\" >\n                        <cs-option *ngFor=\"let data of policyLinkSetList\" [value]=\"data\">\n                            {{data}}\n                        </cs-option>\n                    </cs-select>\n                </div>\n            </ng-container> -->\n    </ng-container>\n    <!-- -----------------------------------drag and drop ---------------------------------------------- -->\n    <div class=\"tab-group\" [class.uploaded]=\"formate.files?.length > 0\" appDragDrop\n      (fileDropped)=\"onFileDropped($event)\">\n      <label class=\"upload-file\">\n        <img [src]=\"ASSETS.upload\" alt=\"\" class=\"image\" />\n        <div class=\"browse\">\n          <span>\n            <ng-container *ngIf=\"mode != 'policy' && mode != 'reportACase'\">Drop your files here /\n            </ng-container>\n            <ng-container *ngIf=\"mode == 'policy' || mode == 'reportACase'\">Drop your files here /\n            </ng-container>\n            <span class=\"label\">Browse\n              <input type=\"file\" multiple (change)=\"onFileDropped($event.target.files)\" />\n            </span>\n          </span>\n          <!-- <span *ngIf=\"mode!='policy'\">Drop your files here /</span>\n                    <span *ngIf=\"mode=='policy'\">Drag & drop to upload files associated with this policy /</span>\n                    <span class=\"label\">Browse\n                        <input type=\"file\" multiple (change)=\"onFileDropped($event.target.files)\">\n                    </span> -->\n        </div>\n      </label>\n    </div>\n    <!-- ------------------------------------------drag drop ends here -------------------------------------------- -->\n  </ng-container>\n\n  <ng-container *ngIf=\"\n      (formate?.hasUploadFormate && formate.formateType === 'LINK') ||\n      (mode == 'policyReviewer' && formate.formateType === 'LINK')\n    \">\n    <ng-container *ngIf=\"formate.links.length > 0\">\n      <ng-container *ngFor=\"let link of formate.links; let i = index\">\n        <div class=\"file-list\" *ngIf=\"!link.isEditing\">\n          <div class=\"file-container\">\n            <span class=\"file-name\">{{ link.link }} </span>\n            <span class=\"button-group\">\n              <button [class.disabled]=\"isEditDisabled\" class=\"edit\" (click)=\"editLink(i)\">\n                <i class=\"icons\">&#xe9ba;</i>\n              </button>\n              <button (click)=\"deleteLink(i)\">\n                <i class=\"icons\">&#xe90d;</i>\n              </button>\n            </span>\n          </div>\n        </div>\n        <ng-container *ngIf=\"link.isEditing\">\n          <input type=\"text\" class=\"edit-link\" appAutofocus placeholder=\"Enter the link here\" [(ngModel)]=\"link.link\"\n            (focusout)=\"insertLink('EDIT', i)\" (keydown.enter)=\"insertLink('EDIT', i)\" />\n          <p class=\"error-message\" *ngIf=\"link.containsError\">\n            Please insert a valid link\n          </p>\n        </ng-container>\n      </ng-container>\n    </ng-container>\n    <input [disabled]=\"isNewLinkDisabled\" class=\"edit-link\" type=\"text\" [(ngModel)]=\"newLink.link\"\n      placeholder=\"Enter the link here\" (focusout)=\"insertLink('CREATE')\" (keydown.enter)=\"insertLink('CREATE')\" />\n    <p class=\"error-message\" *ngIf=\"newLink.containsError\">\n      Please insert a valid link\n    </p>\n  </ng-container>\n  <div class=\"upload-format\" *ngIf=\"mode == 'responsibility'\">\n    <span class=\"text\">Do you want evidence of completion of the responsibility to be\n      uploaded?</span>\n    <div class=\"radio-group\">\n      <app-cs-radio [name]=\"'evidence_required'\" [checked]=\"formate.isEvidenceRequired === true\"\n        (checkedEvent)=\"toggleIsFormatRequired(true)\">Yes</app-cs-radio>\n      <app-cs-radio [name]=\"'evidence_required'\" [checked]=\"formate.isEvidenceRequired === false\"\n        (checkedEvent)=\"toggleIsFormatRequired(false)\">No\n      </app-cs-radio>\n    </div>\n  </div>\n</div>"]}
@@ -159,7 +159,7 @@ export class FrequencyResponsibilityListComponent {
159
159
  return {
160
160
  id: item.id,
161
161
  title: item.title,
162
- controlId: item?.controlId ? '[CID-' + (item?.controlId?.slice(4)) + '] ' : '',
162
+ controlId: item?.controlId ? '[CID-' + item?.controlId + '] ' : '',
163
163
  assigneeDetails,
164
164
  allAssignee,
165
165
  allRc
@@ -222,4 +222,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
222
222
  }], selectedResponsibility: [{
223
223
  type: Output
224
224
  }] } });
225
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"frequency-responsibility-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency/frequency-responsibility-list/frequency-responsibility-list.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency/frequency-responsibility-list/frequency-responsibility-list.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAE/E,OAAO,EAAE,MAAM,EAAE,MAAM,qCAAqC,CAAC;;;;;;;;;;;;;;;;AAS7D,MAAM,OAAO,oCAAoC;IA4C/C,YACU,gBAAkC,EAClC,aAA4B;QAD5B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,kBAAa,GAAb,aAAa,CAAe;QA7C7B,kCAA6B,GAAQ,EAAE,CAAC;QAEvC,eAAU,GAAG,IAAI,YAAY,EAAE,CAAC;QAChC,2BAAsB,GAAG,IAAI,YAAY,EAAE,CAAC;QAEtD,cAAS,GAAG,KAAK,CAAC;QAClB,WAAM,GAAG,MAAM,CAAC;QAChB,yBAAoB,GAAQ,EAAE,CAAC;QAC/B,yBAAoB,GAAY,KAAK,CAAC;QACtC,6BAAwB,GAAQ,EAAE,CAAC;QAGnC,6BAAwB,GAAW,EAAE,CAAC;QACtC,8BAAyB,GAAW,CAAC,CAAC;QACtC,eAAU,GAAG,KAAK,CAAC;QAEnB,0BAAqB,GAAG;YACtB,IAAI,EAAE,QAAQ;YACd,cAAc,EAAE,OAAO;YACvB,CAAC,EAAE,EAAE;YACL,UAAU,EAAE,EAAE;YACd,UAAU,EAAE;gBACV,OAAO,EAAE,EAAE;gBACX,OAAO,EAAE,EAAE;gBACX,UAAU,EAAE,EAAE;gBACd,oBAAoB,EAAE,EAAE;gBACxB,WAAW,EAAE,EAAE;gBACf,WAAW,EAAE,EAAE;gBACf,sBAAsB,EAAE,EAAE;gBAC1B,cAAc,EAAE,CAAC,CAAC,CAAC;aACpB;YACD,MAAM,EAAE,CAAC;YACT,OAAO,EAAE;gBACP,MAAM,EAAE,EAAE;gBACV,IAAI,EAAE,EAAE;aACT;YACD,QAAQ,EAAE,UAAU;SACrB,CAAC;QAGF,yBAAoB,GAAU,EAAE,CAAC;IAM7B,CAAC;IAEL,QAAQ;QACN,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACzB,CAAC,EAAE,GAAG,CAAC,CAAC;QACR,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC7B,IAAI,CAAC,sBAAsB,EAAE,CAAC;IAChC,CAAC;IAED,IAAI;QACF,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;IAC7C,CAAC;IAGD,qBAAqB;QACnB,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC;QACjC,IAAI,CAAC,gBAAgB;YACnB,EAAE,qBAAqB,CAAC,IAAI,CAAC,qBAAqB,CAAC;aAClD,SAAS,CAAC,CAAC,GAAQ,EAAE,EAAE;YACtB,IAAI,CAAC,oBAAoB,GAAG,GAAG,EAAE,IAAI,CAAC;YACtC,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;YAC/D,IAAI,CAAC,oBAAoB,CAAC,YAAY,CAAC,GAAG,UAAU,CAAC;YACrD,IAAI,CAAC,oBAAoB,CAAC,kBAAkB,CAAC,GAAG,IAAI,CAAC,qBAAqB,CAAE,IAAI,CAAC,oBAAoB,CAAC,CAAA;YAEtG,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;YAClC,MAAM,iBAAiB,GAAG,IAAI,CAAC,oBAAoB,EAAE,gBAAgB,EAAE,IAAI,CAAC,CAAC,cAAmB,EAAE,EAAE,CAAC,cAAc,CAAC,EAAE,KAAK,IAAI,CAAC,4BAA4B,EAAE,cAAc,EAAE,EAAE,CAAC,CAAC;YAClL,IAAG,iBAAiB,EAAE;gBACpB,IAAI,CAAC,sBAAsB,CAAC,iBAAiB,CAAC,CAAC;aAChD;QACH,CAAC,EAAE,CAAC,KAAU,EAAE,EAAE;YAChB,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;YAClC,OAAO,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,EAAE,sCAAsC,CAAC,CAAC;QACjE,CAAC,CAAC,CAAC;IACP,CAAC;IAED,wBAAwB,CAAC,UAAkB;QACzC,IAAI,CAAC,yBAAyB,GAAG,UAAU,CAAC;QAC5C,IAAI,CAAC,qBAAqB,CAAC,MAAM,GAAG,IAAI,CAAC,yBAAyB,CAAC;QACnE,IAAI,CAAC,qBAAqB,CAAC,UAAU,GAAG,IAAI,CAAC,wBAAwB,CAAC;QACtE,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,CAAC;IAGD,UAAU,CAAC,IAAS;QAClB,IAAI,CAAC,4BAA4B,GAAG,EAAE,CAAC;QACvC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,wBAAwB,GAAG,EAAE,CAAC;IACrC,CAAC;IACD,IAAI,CAAC,KAAU;QACb,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;QAC3C,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,IAAI,CAAC,4BAA4B,CAAC,CAAC;IACtE,CAAC;IAGD,MAAM;QACJ,IAAI,CAAC,qBAAqB,CAAC,UAAU,GAAG,IAAI,CAAC,wBAAwB,CAAC;QACtE,IAAI,CAAC,yBAAyB,GAAG,CAAC,CAAC;QACnC,IAAI,CAAC,qBAAqB,CAAC,MAAM,GAAG,IAAI,CAAC,yBAAyB,CAAC;QACnE,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,CAAC;IAID,sBAAsB,CAAC,cAAmB;QACxC,IAAG,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC,cAAc,CAAC,EAAE,CAAC,EAAE;YACxD,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC,EAAO,EAAE,EAAE,CAAC,EAAE,KAAK,cAAc,CAAC,EAAE,CAAC,CAAC;SACrG;aAAM;YACL,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;SACnD;IACH,CAAC;IAGC,8BAA8B;IACvB,qBAAqB,CAAC,cAAmB;QAC9C,IAAI,CAAC,cAAc;YAAE,OAAO,EAAE,CAAC;QAE/B,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,KAAK,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QAC1E,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACrC,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,qBAAqB,CAAC,CAAC;QAElE,OAAO,CAAC,cAAc,CAAC,gBAAgB,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,IAAS,EAAE,EAAE,CAC/D,IAAI,CAAC,qBAAqB,CAAC,IAAI,EAAE,OAAO,EAAE,KAAK,CAAC,CACjD,CAAC;IACJ,CAAC;IAED,wBAAwB;IAEhB,aAAa,CAAC,KAAY,EAAE,YAAsC;QACxE,OAAO,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YAChC,GAAG,IAAI;YACP,SAAS,EAAE,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC;SACnC,CAAC,CAAC,CAAC;IACN,CAAC;IAEO,QAAQ,CAAC,GAAU;QACzB,OAAO,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;IAC3D,CAAC;IAEO,gBAAgB,CAAC,QAAa,EAAE,aAAuB,EAAE,OAAyB;QACxF,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE;YACtB,OAAO,CAAC,aAAa,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;SACzE;QACD,MAAM,GAAG,GAAG,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QACvF,OAAO,GAAG,CAAC,GAAG,CAAC,CAAC,EAAO,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IACjE,CAAC;IAEO,wBAAwB,CAAC,QAAa,EAAE,SAAmB,EAAE,KAAuB;QAC1F,IAAI,CAAC,QAAQ,CAAC,oBAAoB,EAAE;YAClC,OAAO,CAAC,SAAS,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;SACnE;QACD,MAAM,GAAG,GAAG,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,oBAAoB,CAAC,CAAC;QAC3H,OAAO,GAAG,CAAC,GAAG,CAAC,CAAC,EAAO,EAAE,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IAC7D,CAAC;IAEO,qBAAqB,CAAC,IAAS,EAAE,OAAyB,EAAE,KAAuB;QACzF,MAAM,eAAe,GAAG,CAAC,IAAI,CAAC,eAAe,IAAI,EAAE,CAAC;aACjD,MAAM,CAAC,CAAC,EAAO,EAAE,EAAE,CAAC,EAAE,CAAC,MAAM,IAAI,EAAE,CAAC,MAAM,CAAC,WAAW,EAAE,KAAK,QAAQ,CAAC;aACtE,GAAG,CAAC,CAAC,EAAO,EAAE,EAAE,CAAC,CAAC;YACjB,GAAG,EAAE;YACL,YAAY,EAAE,IAAI,CAAC,gBAAgB,CAAC,EAAE,EAAE,IAAI,CAAC,SAAS,EAAE,YAAY,IAAI,EAAE,EAAE,OAAO,CAAC;YACpF,wBAAwB,EAAE,IAAI,CAAC,wBAAwB,CAAC,EAAE,EAAE,IAAI,CAAC,qBAAqB,IAAI,EAAE,EAAE,KAAK,CAAC;SACrG,CAAC,CAAC,CAAC;QACJ,MAAM,WAAW,GAAG,IAAI,CAAC,uBAAuB,CAAC,eAAe,CAAC,CAAC,GAAG,CAAC,CAAC,EAAO,EAAE,EAAE,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC;QACvG,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;QACxD,OAAO;YACL,EAAE,EAAE,IAAI,CAAC,EAAE;YACX,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,SAAS,EAAE,IAAI,EAAE,SAAS,CAAC,CAAC,CAAC,OAAO,GAAG,CAAC,IAAI,EAAE,SAAS,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,EAAE;YAC9E,eAAe;YACd,WAAW;YACX,KAAK;SACP,CAAC;IACJ,CAAC;IAED,uBAAuB,CAAC,eAAoB;QAC1C,MAAM,SAAS,GAAG,IAAI,GAAG,EAAE,CAAC;QAC5B,eAAe,CAAC,OAAO,CAAC,CAAC,GAAQ,EAAE,EAAE;YACnC,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;QACnC,CAAC,CAAC,CAAC;QACH,MAAM,WAAW,GAAG,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,CAAC;QAC/C,OAAO,WAAW,CAAC;IACrB,CAAC;IAEH,MAAM,CAAC,GAAQ;QACb,OAAO,IAAI,CAAC,oBAAoB,EAAE,qBAAqB,EAAE,MAAM,CAAC,CAAC,EAAO,EAAE,EAAE,CAAC,GAAG,EAAE,QAAQ,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IACtG,CAAC;IAEL,YAAY,CAAC,IAAY;QACvB,MAAM,SAAS,GAAG,IAAI,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC;QACnC,IAAG,SAAS,EAAE,MAAM,GAAG,CAAC,EAAE;YACxB,OAAO,SAAS,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,SAAS,EAAE,MAAM,GAAG,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;SAC9E;QACD,OAAO,SAAS,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,WAAW,EAAE,CAAC;IAC1E,CAAC;IAED,sBAAsB;QACpB,IAAG,CAAC,IAAI,CAAC,6BAA6B,EAAE,QAAQ,EAAE;YAChD,OAAO;SACR;QACD,IAAI,CAAC,4BAA4B,GAAI;YACnC,YAAY,EAAE;gBACZ,QAAQ,EAAE,IAAI,CAAC,6BAA6B,CAAC,QAAQ;gBACrD,oBAAoB,EAAE,IAAI,CAAC,6BAA6B,CAAC,oBAAoB;aAC9E;YACD,cAAc,EAAE;gBACd,KAAK,EAAE,IAAI,CAAC,6BAA6B,CAAC,KAAK;gBAC/C,EAAE,EAAE,IAAI,CAAC,6BAA6B,CAAC,EAAE;gBACzC,KAAK,EAAE,EAAE;gBACT,WAAW,EAAE,EAAE;gBACf,eAAe,EAAE,CAAC;wBAChB,QAAQ,EAAE,IAAI,CAAC,6BAA6B,CAAC,QAAQ;wBACrD,oBAAoB,EAAE,IAAI,CAAC,6BAA6B,CAAC,oBAAoB;qBAC9E,CAAC;gBACF,YAAY,EAAE,EAAE;aACjB;SACF,CAAA;IACH,CAAC;IAED,kBAAkB,CAAC,KAAU;QAC3B,IAAI,CAAC,4BAA4B,GAAG,KAAK,CAAA;QACzC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,4BAA4B,EAAE,8BAA8B,CAAC,CAAC;IACjF,CAAC;+GAtOU,oCAAoC;mGAApC,oCAAoC,8OCXjD,0/RAsKM;;4FD3JO,oCAAoC;kBALhD,SAAS;+BACE,mCAAmC;mIAKpC,6BAA6B;sBAArC,KAAK;gBAEI,UAAU;sBAAnB,MAAM;gBACG,sBAAsB;sBAA/B,MAAM","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { FrequencyService } from '../frequency.service';\nimport { ASSETS } from '../../../constants/assets.constants';\nimport { CommonService } from '../../../services/common.service';\nimport { slice } from 'lodash';\n\n@Component({\n  selector: 'app-frequency-responsibility-list',\n  templateUrl: './frequency-responsibility-list.component.html',\n  styleUrls: ['./frequency-responsibility-list.component.less'],\n})\nexport class FrequencyResponsibilityListComponent implements OnInit {\n  @Input() selectedResponsibilityDetails: any = {};\n\n  @Output() backButton = new EventEmitter();\n  @Output() selectedResponsibility = new EventEmitter();\n  \n  animation = false;\n  ASSETS = ASSETS;\n  responsibilitiesData: any = {};\n  responsibilityLoader: boolean = false;\n  selectedResponsibilityId: any = [];\n  selectedResponsibilityValues: any;\n  \n  responsibilitySearchText: string = '';\n  responsibilityCurrentPage: number = 1;\n  isValidObj = false;\n\n  responsibilityPayload = {\n    type: 'active',\n    paginationType: 'large',\n    a: '',\n    searchTerm: '',\n    filterData: {\n      appList: [],\n      riskIds: [],\n      reviewerId: [],\n      responsibilityCenter: [],\n      entrustedBy: [],\n      entrustedTo: [],\n      responsibilityCategory: [],\n      complianceType: [1],\n    },\n    pageNo: 1,\n    sortObj: {\n      sortBy: '',\n      type: '',\n    },\n    pageName: 'overview',\n  };\n  responsibilityList: any;\n  close: any;\n  openedResponsibility: any[] = [];\n\n\n  constructor(\n    private frequencyService: FrequencyService,\n    private commonService: CommonService\n  ) { }\n\n  ngOnInit(): void {\n    this.animation = true;\n    setTimeout(() => {\n      this.animation = false;\n    }, 300);\n    this.getResponsibilityList();\n    this.populateResponsibility();\n  }\n\n  back() {\n    this.backButton.emit('backToOnCompletion');\n  }\n\n\n  getResponsibilityList() {\n    this.responsibilityLoader = true;\n    this.frequencyService\n      ?.getResponsibilityList(this.responsibilityPayload)\n      .subscribe((res: any) => {\n        this.responsibilitiesData = res?.data;\n        const pagination = this.commonService.setPagination(res?.data);\n        this.responsibilitiesData['pagination'] = pagination;\n        this.responsibilitiesData['responsibilities'] = this.mapResponsibilityData( this.responsibilitiesData)\n\n        this.responsibilityLoader = false;\n        const hasResponsibility = this.responsibilitiesData?.responsibilities?.find((responsibility: any) => responsibility.id === this.selectedResponsibilityValues?.responsibility?.id);\n        if(hasResponsibility) {\n          this.onToggleResponsibility(hasResponsibility);\n        }\n      }, (error: any) => {\n        this.responsibilityLoader = false;\n        console.log({ error }, \"Error in getting responsibility list\");\n      });\n  }\n\n  responsibilityPageChange(pageNumber: number) {\n    this.responsibilityCurrentPage = pageNumber;\n    this.responsibilityPayload.pageNo = this.responsibilityCurrentPage;\n    this.responsibilityPayload.searchTerm = this.responsibilitySearchText;\n    this.getResponsibilityList();\n  }\n\n\n  deleteItem(item: any) {\n    this.selectedResponsibilityValues = {};\n    this.isValidObj = false;\n    this.selectedResponsibilityId = [];\n  }\n  save(event: any) {\n    this.backButton.emit('backToOnCompletion');\n    this.selectedResponsibility.emit(this.selectedResponsibilityValues);\n  }\n\n\n  search() {\n    this.responsibilityPayload.searchTerm = this.responsibilitySearchText;\n    this.responsibilityCurrentPage = 1;\n    this.responsibilityPayload.pageNo = this.responsibilityCurrentPage;\n    this.getResponsibilityList();\n  }\n\n \n  \n  onToggleResponsibility(responsibility: any) {\n    if(this.openedResponsibility.includes(responsibility.id)) {\n      this.openedResponsibility = this.openedResponsibility.filter((id: any) => id !== responsibility.id);\n    } else {\n      this.openedResponsibility.push(responsibility.id);\n    }\n  }\n\n\n    // Main method exposed outside\n    public mapResponsibilityData(responsibility: any): any[] {\n      if (!responsibility) return [];\n  \n      const users = this.mapShortNames(responsibility.users, this.mapShortName);\n      const userMap = this.buildMap(users);\n      const rcMap = this.buildMap(responsibility.responsibilityCenters);\n  \n      return (responsibility.responsibilities || []).map((item: any) =>\n        this.mapResponsibilityItem(item, userMap, rcMap)\n      );\n    }\n  \n    // Helper methods below:\n  \n    private mapShortNames(users: any[], mapShortName: (name: string) => string): any[] {\n      return (users || []).map(user => ({\n        ...user,\n        shortName: mapShortName(user.name),\n      }));\n    }\n  \n    private buildMap(arr: any[]): Map<string, any> {\n      return new Map((arr || []).map(item => [item.id, item]));\n    }\n  \n    private mapAssigneeUsers(assignee: any, activeUserIds: string[], userMap: Map<string, any>): any[] {\n      if (!assignee.assignee) {\n        return (activeUserIds || []).map(id => userMap.get(id)).filter(Boolean);\n      }\n      const ids = Array.isArray(assignee.assignee) ? assignee.assignee : [assignee.assignee];\n      return ids.map((id: any) => userMap.get((id))).filter(Boolean);\n    }\n  \n    private mapResponsibilityCenters(assignee: any, itemRCIds: string[], rcMap: Map<string, any>): any[] {\n      if (!assignee.responsibilityCenter) {\n        return (itemRCIds || []).map(id => rcMap.get(id)).filter(Boolean);\n      }\n      const ids = Array.isArray(assignee.responsibilityCenter) ? assignee.responsibilityCenter : [assignee.responsibilityCenter];\n      return ids.map((id: any) => rcMap.get(id)).filter(Boolean);\n    }\n  \n    private mapResponsibilityItem(item: any, userMap: Map<string, any>, rcMap: Map<string, any>): any {\n      const assigneeDetails = (item.assigneeDetails || [])\n        .filter((ad: any) => ad.status && ad.status.toLowerCase() === 'active')\n        .map((ad: any) => ({\n          ...ad,\n          assigneeInfo: this.mapAssigneeUsers(ad, item.assignees?.activeUserId || [], userMap),\n          responsibilityCenterInfo: this.mapResponsibilityCenters(ad, item.responsibilityCenters || [], rcMap),\n        }));\n        const allAssignee = this.removeDuplicateAssignee(assigneeDetails).map((ad: any) => ad.assigneeInfo[0]);\n        const allRc = this.mapRcs(item.responsibilityCenters);\n      return {\n        id: item.id,\n        title: item.title,\n        controlId: item?.controlId ? '[CID-' + (item?.controlId?.slice(4)) + '] ' : '',\n        assigneeDetails,\n         allAssignee,\n         allRc\n      };\n    }\n\n    removeDuplicateAssignee(assigneeDetails: any) {\n      const uniqueMap = new Map();\n      assigneeDetails.forEach((obj: any) => {\n        uniqueMap.set(obj.assignee, obj);\n      });\n      const uniqueArray = Array.from(uniqueMap.values());\n          return uniqueArray;\n        }\n\n      mapRcs(rcs: any) {\n        return this.responsibilitiesData?.responsibilityCenters?.filter((rc: any) => rcs?.includes(rc?.id));\n      }\n  \n  mapShortName(name: string) {\n    const nameArray = name?.split(' ');\n    if(nameArray?.length > 1) {\n      return nameArray[0]?.charAt(0) + nameArray[nameArray?.length - 1]?.charAt(0);\n    }\n    return nameArray[0]?.charAt(0) + nameArray[0]?.charAt(1)?.toUpperCase();\n  }\n\n  populateResponsibility() {\n    if(!this.selectedResponsibilityDetails?.assignee) {\n      return;\n    }\n    this.selectedResponsibilityValues =  {\n      eachAssignee: {\n        assignee: this.selectedResponsibilityDetails.assignee,\n        responsibilityCenter: this.selectedResponsibilityDetails.responsibilityCenter,\n      },\n      responsibility: {\n        title: this.selectedResponsibilityDetails.title,\n        id: this.selectedResponsibilityDetails.id,\n        allRC: [],\n        allAssignee: [],\n        assigneeDetails: [{\n          assignee: this.selectedResponsibilityDetails.assignee,\n          responsibilityCenter: this.selectedResponsibilityDetails.responsibilityCenter,\n        }],\n        eachAssignee: {},\n      }\n    }\n  }\n\n  onCompletionChange(event: any) {\n    this.selectedResponsibilityValues = event\n    console.log(this.selectedResponsibilityValues, 'selectedResponsibilityValues');\n  }\n}\n","<div class=\"frequency-responsibility-list\" [class.animate]=\"animation\">\n  <div class=\"frequency-responsibility-list-head vx-p-3 vx-d-flex vx-align-center vx-justify-between\">\n    <div class=\"vx-d-flex vx-align-center\">\n      <i class=\"icons arrow vx-fs-16 vx-label-txt vx-mr-1\" (click)=\"back()\">&#xe91d;</i>\n      <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Select a Responsibility</div>\n    </div>\n  </div>\n  <div class=\"frequency-responsibility-list-body\">\n    <!-- <app-loader-inline *ngIf=\"othersCount === 0\"></app-loader-inline> -->\n\n    <div class=\"frequency-responsibility-list-search vx-mb-2\">\n      <i class=\"icons vx-fs-12\">&#xe90b;</i>\n      <input type=\"text\" [(ngModel)]=\"responsibilitySearchText\" (keyup.enter)=\"search()\"\n        placeholder=\"Search Responsibilities\" />\n    </div>\n    <ng-container *ngIf=\"responsibilitiesData?.pagination as pagination\">\n      <app-pagination *ngIf=\"pagination?.total_pages > 1\" [start]=\"pagination?.responsibilities_from\"\n        [end]=\"pagination?.responsibilities_to\" [total]=\"pagination?.total_responsibilities\"\n        [pageCount]=\"pagination?.total_pages\" [currentPage]=\"responsibilityCurrentPage\"\n        (selectedPage)=\"responsibilityPageChange($event)\">\n      </app-pagination>\n    </ng-container>\n\n    <app-loader-inline *ngIf=\"responsibilityLoader\"></app-loader-inline>\n    <div class=\"frequency-responsibility-list-mid vx-mb-4\" [class.with-pagination]=\"\n        !responsibilityLoader && responsibilitiesData?.total_pages > 1\n      \">\n      <app-no-data *ngIf=\"\n          responsibilitiesData?.responsibilities?.length === 0 &&\n          !responsibilityLoader\n        \" [noDataImage]=\"ASSETS.search_data\" [noDataText]=\"'No Data to Display'\"></app-no-data>\n      <ng-container *ngIf=\"\n          responsibilitiesData?.responsibilities?.length > 0 &&\n          !responsibilityLoader\n        \">\n        <div class=\"table-header\">\n          <div class=\"table-row\">\n            <div\n              class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\">\n              #\n            </div>\n            <div\n              class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility\">\n              RESPONSIBILITIES\n            </div>\n            <div\n              class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility-center\">\n              RESPONSIBILITY CENTER\n            </div>\n            <div\n              class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center action\">\n            </div>\n          </div>\n        </div>\n        <div class=\"table-body\">\n          <!-- when click on radio then active class should be true -->\n          <ng-container *ngFor=\"\n              let responsibility of responsibilitiesData?.responsibilities;\n              let i = index\n            \">\n            <ng-container *ngIf=\"(responsibilitiesData?.page * responsibilitiesData?.limit -\n            responsibilitiesData?.limit +\n            i +\n            1) as srNo\">\n              <div class=\"table-row\" [class.resp]=\"responsibility?.assigneeDetails?.length === 1\" [class.active]=\"\n                selectedResponsibilityValues?.responsibility?.id === responsibility?.id && responsibility?.assigneeDetails?.length === 1\n              \" [class.with-sub-responsibility]=\"openedResponsibility.includes(responsibility?.id)\">\n                <ng-container *ngIf=\"responsibility?.assigneeDetails as assigneeDetails\">\n                  <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\">\n                    <div class=\"sr-no\" [appTooltip]=\"\n                      srNo  \n                    \" placement=\"bottom\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">\n                      {{srNo}}\n                    </div>\n                    <app-cs-radio *ngIf=\"assigneeDetails?.length === 1\" [name]=\"'onCompletion'\" [checked]=\"\n                      selectedResponsibilityValues?.responsibility?.id === responsibility?.id\n                    \"\n                      (checkedEvent)=\"onCompletionChange({eachAssignee: assigneeDetails[0], responsibility})\"></app-cs-radio>\n                  </div>\n\n                  <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility with-rc\">\n\n                    <div class=\"value vx-fs-12 vx-label-txt vx-pr-5  vx-d-flex vx-align-center\">\n                      <div class=\"avatar-list vx-d-flex vx-align-center\">\n                        <lib-avatar-v2 [avatarList]=\"responsibility?.allAssignee\"\n                          [type]=\"'SINGLE_AVATAR'\"></lib-avatar-v2>\n                      </div>\n\n                      <span class=\"value-text vx-ml-1 resp-name\" [appTooltip]=\"responsibility?.title\"\n                        placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">{{\n                        responsibility?.controlId }} {{\n                        responsibility?.title\n                        }}</span>\n                    </div>\n                  </div>\n\n                  <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility-center\">\n                    <ng-container *ngIf=\"responsibility?.allRc as rc\">\n                      <div class=\"program-inner vx-d-block\">\n                        <div class=\"program-value vx-fs-11 vx-label-txt vx-pr-5\" [appTooltip]=\"\n                        rc?.length\n                          ? rc[0]?.name\n                          : '--'\n                      \" placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">\n                          {{\n                          rc?.length\n                          ? rc[0]?.name\n                          : \"--\"\n                          }}\n                        </div>\n                        <ng-container *ngIf=\"\n                        rc?.length \n                      \">\n                        </ng-container>\n                      </div>\n                      <button *ngIf=\"rc?.length > 1\" appPopover (click)=\"rcPopup.popover()\" placement=\"right\"\n                        class=\"program-count vx-fs-11 vx-fw-500 vx-txt-white vx-p-0 vx-pl-1 vx-pr-1 vx-m-0 vx-d-flex vx-align-center vx-justify-center\">\n                        +{{ rc?.length - 1 }}\n                      </button>\n                      <app-popover #rcPopup>\n                        <div class=\"wf-action-list\">\n                          <ul class=\"action-item\">\n                            <li *ngFor=\"\n                            let data of rc?.slice(\n                              1,\n                              rc?.length\n                            )\n                          \">\n                              <div class=\"avatar-card\">\n                                <div class=\"vx-d-block vx-w-100\">\n                                  <span class=\"value\" [appTooltip]=\"data?.name\" placement=\"bottom-left\" delay=\"0\"\n                                    type=\"black\" [tooltipMandatory]=\"true\">{{ data?.name }}</span>\n                                </div>\n                              </div>\n                            </li>\n                          </ul>\n                        </div>\n                      </app-popover>\n                    </ng-container>\n                  </div>\n                  <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center action\"\n                    (click)=\"onToggleResponsibility(responsibility)\">\n                    <ng-container *ngIf=\"assigneeDetails?.length > 1; else closeIcon\">\n                      <i *ngIf=\"\n                        openedResponsibility.includes(responsibility.id);\n                        else closeIcon\n                      \" class=\"icons vx-fs-10\">&#xe9e7;</i>\n                      <ng-template #closeIcon>\n                        <i class=\"icons vx-fs-10\"> &#xe9e8;</i>\n                      </ng-template>\n                    </ng-container>\n                  </div>\n                </ng-container>\n              </div>\n              <lib-sub-responsibility *ngIf=\"openedResponsibility.includes(responsibility.id)\"\n                [responsibility]=\"responsibility\" [srNo]=\"srNo\" [selectedResponsibility]=\"selectedResponsibilityValues\"\n                (onCompletionChange)=\"onCompletionChange($event)\"></lib-sub-responsibility>\n            </ng-container>\n          </ng-container>\n        </div>\n      </ng-container>\n    </div>\n    <app-floating-bar [selectedData]=\"[selectedResponsibilityValues?.responsibility]\" [displayElementKey]=\"'title'\"\n      (closeList)=\"back()\" (closeEvent)=\"save($event)\" (deleteEvent)=\"deleteItem($event)\"\n      [isDisabled]=\"!selectedResponsibilityValues?.responsibility?.id\"></app-floating-bar>\n  </div>\n</div>"]}
225
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"frequency-responsibility-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency/frequency-responsibility-list/frequency-responsibility-list.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency/frequency-responsibility-list/frequency-responsibility-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { FrequencyService } from '../frequency.service';\nimport { ASSETS } from '../../../constants/assets.constants';\nimport { CommonService } from '../../../services/common.service';\nimport { slice } from 'lodash';\n\n@Component({\n  selector: 'app-frequency-responsibility-list',\n  templateUrl: './frequency-responsibility-list.component.html',\n  styleUrls: ['./frequency-responsibility-list.component.less'],\n})\nexport class FrequencyResponsibilityListComponent implements OnInit {\n  @Input() selectedResponsibilityDetails: any = {};\n\n  @Output() backButton = new EventEmitter();\n  @Output() selectedResponsibility = new EventEmitter();\n  \n  animation = false;\n  ASSETS = ASSETS;\n  responsibilitiesData: any = {};\n  responsibilityLoader: boolean = false;\n  selectedResponsibilityId: any = [];\n  selectedResponsibilityValues: any;\n  \n  responsibilitySearchText: string = '';\n  responsibilityCurrentPage: number = 1;\n  isValidObj = false;\n\n  responsibilityPayload = {\n    type: 'active',\n    paginationType: 'large',\n    a: '',\n    searchTerm: '',\n    filterData: {\n      appList: [],\n      riskIds: [],\n      reviewerId: [],\n      responsibilityCenter: [],\n      entrustedBy: [],\n      entrustedTo: [],\n      responsibilityCategory: [],\n      complianceType: [1],\n    },\n    pageNo: 1,\n    sortObj: {\n      sortBy: '',\n      type: '',\n    },\n    pageName: 'overview',\n  };\n  responsibilityList: any;\n  close: any;\n  openedResponsibility: any[] = [];\n\n\n  constructor(\n    private frequencyService: FrequencyService,\n    private commonService: CommonService\n  ) { }\n\n  ngOnInit(): void {\n    this.animation = true;\n    setTimeout(() => {\n      this.animation = false;\n    }, 300);\n    this.getResponsibilityList();\n    this.populateResponsibility();\n  }\n\n  back() {\n    this.backButton.emit('backToOnCompletion');\n  }\n\n\n  getResponsibilityList() {\n    this.responsibilityLoader = true;\n    this.frequencyService\n      ?.getResponsibilityList(this.responsibilityPayload)\n      .subscribe((res: any) => {\n        this.responsibilitiesData = res?.data;\n        const pagination = this.commonService.setPagination(res?.data);\n        this.responsibilitiesData['pagination'] = pagination;\n        this.responsibilitiesData['responsibilities'] = this.mapResponsibilityData( this.responsibilitiesData)\n\n        this.responsibilityLoader = false;\n        const hasResponsibility = this.responsibilitiesData?.responsibilities?.find((responsibility: any) => responsibility.id === this.selectedResponsibilityValues?.responsibility?.id);\n        if(hasResponsibility) {\n          this.onToggleResponsibility(hasResponsibility);\n        }\n      }, (error: any) => {\n        this.responsibilityLoader = false;\n        console.log({ error }, \"Error in getting responsibility list\");\n      });\n  }\n\n  responsibilityPageChange(pageNumber: number) {\n    this.responsibilityCurrentPage = pageNumber;\n    this.responsibilityPayload.pageNo = this.responsibilityCurrentPage;\n    this.responsibilityPayload.searchTerm = this.responsibilitySearchText;\n    this.getResponsibilityList();\n  }\n\n\n  deleteItem(item: any) {\n    this.selectedResponsibilityValues = {};\n    this.isValidObj = false;\n    this.selectedResponsibilityId = [];\n  }\n  save(event: any) {\n    this.backButton.emit('backToOnCompletion');\n    this.selectedResponsibility.emit(this.selectedResponsibilityValues);\n  }\n\n\n  search() {\n    this.responsibilityPayload.searchTerm = this.responsibilitySearchText;\n    this.responsibilityCurrentPage = 1;\n    this.responsibilityPayload.pageNo = this.responsibilityCurrentPage;\n    this.getResponsibilityList();\n  }\n\n \n  \n  onToggleResponsibility(responsibility: any) {\n    if(this.openedResponsibility.includes(responsibility.id)) {\n      this.openedResponsibility = this.openedResponsibility.filter((id: any) => id !== responsibility.id);\n    } else {\n      this.openedResponsibility.push(responsibility.id);\n    }\n  }\n\n\n    // Main method exposed outside\n    public mapResponsibilityData(responsibility: any): any[] {\n      if (!responsibility) return [];\n  \n      const users = this.mapShortNames(responsibility.users, this.mapShortName);\n      const userMap = this.buildMap(users);\n      const rcMap = this.buildMap(responsibility.responsibilityCenters);\n  \n      return (responsibility.responsibilities || []).map((item: any) =>\n        this.mapResponsibilityItem(item, userMap, rcMap)\n      );\n    }\n  \n    // Helper methods below:\n  \n    private mapShortNames(users: any[], mapShortName: (name: string) => string): any[] {\n      return (users || []).map(user => ({\n        ...user,\n        shortName: mapShortName(user.name),\n      }));\n    }\n  \n    private buildMap(arr: any[]): Map<string, any> {\n      return new Map((arr || []).map(item => [item.id, item]));\n    }\n  \n    private mapAssigneeUsers(assignee: any, activeUserIds: string[], userMap: Map<string, any>): any[] {\n      if (!assignee.assignee) {\n        return (activeUserIds || []).map(id => userMap.get(id)).filter(Boolean);\n      }\n      const ids = Array.isArray(assignee.assignee) ? assignee.assignee : [assignee.assignee];\n      return ids.map((id: any) => userMap.get((id))).filter(Boolean);\n    }\n  \n    private mapResponsibilityCenters(assignee: any, itemRCIds: string[], rcMap: Map<string, any>): any[] {\n      if (!assignee.responsibilityCenter) {\n        return (itemRCIds || []).map(id => rcMap.get(id)).filter(Boolean);\n      }\n      const ids = Array.isArray(assignee.responsibilityCenter) ? assignee.responsibilityCenter : [assignee.responsibilityCenter];\n      return ids.map((id: any) => rcMap.get(id)).filter(Boolean);\n    }\n  \n    private mapResponsibilityItem(item: any, userMap: Map<string, any>, rcMap: Map<string, any>): any {\n      const assigneeDetails = (item.assigneeDetails || [])\n        .filter((ad: any) => ad.status && ad.status.toLowerCase() === 'active')\n        .map((ad: any) => ({\n          ...ad,\n          assigneeInfo: this.mapAssigneeUsers(ad, item.assignees?.activeUserId || [], userMap),\n          responsibilityCenterInfo: this.mapResponsibilityCenters(ad, item.responsibilityCenters || [], rcMap),\n        }));\n        const allAssignee = this.removeDuplicateAssignee(assigneeDetails).map((ad: any) => ad.assigneeInfo[0]);\n        const allRc = this.mapRcs(item.responsibilityCenters);\n      return {\n        id: item.id,\n        title: item.title,\n        controlId: item?.controlId ? '[CID-' + item?.controlId + '] ' : '',\n        assigneeDetails,\n         allAssignee,\n         allRc\n      };\n    }\n\n    removeDuplicateAssignee(assigneeDetails: any) {\n      const uniqueMap = new Map();\n      assigneeDetails.forEach((obj: any) => {\n        uniqueMap.set(obj.assignee, obj);\n      });\n      const uniqueArray = Array.from(uniqueMap.values());\n          return uniqueArray;\n        }\n\n      mapRcs(rcs: any) {\n        return this.responsibilitiesData?.responsibilityCenters?.filter((rc: any) => rcs?.includes(rc?.id));\n      }\n  \n  mapShortName(name: string) {\n    const nameArray = name?.split(' ');\n    if(nameArray?.length > 1) {\n      return nameArray[0]?.charAt(0) + nameArray[nameArray?.length - 1]?.charAt(0);\n    }\n    return nameArray[0]?.charAt(0) + nameArray[0]?.charAt(1)?.toUpperCase();\n  }\n\n  populateResponsibility() {\n    if(!this.selectedResponsibilityDetails?.assignee) {\n      return;\n    }\n    this.selectedResponsibilityValues =  {\n      eachAssignee: {\n        assignee: this.selectedResponsibilityDetails.assignee,\n        responsibilityCenter: this.selectedResponsibilityDetails.responsibilityCenter,\n      },\n      responsibility: {\n        title: this.selectedResponsibilityDetails.title,\n        id: this.selectedResponsibilityDetails.id,\n        allRC: [],\n        allAssignee: [],\n        assigneeDetails: [{\n          assignee: this.selectedResponsibilityDetails.assignee,\n          responsibilityCenter: this.selectedResponsibilityDetails.responsibilityCenter,\n        }],\n        eachAssignee: {},\n      }\n    }\n  }\n\n  onCompletionChange(event: any) {\n    this.selectedResponsibilityValues = event\n    console.log(this.selectedResponsibilityValues, 'selectedResponsibilityValues');\n  }\n}\n","<div class=\"frequency-responsibility-list\" [class.animate]=\"animation\">\n  <div class=\"frequency-responsibility-list-head vx-p-3 vx-d-flex vx-align-center vx-justify-between\">\n    <div class=\"vx-d-flex vx-align-center\">\n      <i class=\"icons arrow vx-fs-16 vx-label-txt vx-mr-1\" (click)=\"back()\">&#xe91d;</i>\n      <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Select a Responsibility</div>\n    </div>\n  </div>\n  <div class=\"frequency-responsibility-list-body\">\n    <!-- <app-loader-inline *ngIf=\"othersCount === 0\"></app-loader-inline> -->\n\n    <div class=\"frequency-responsibility-list-search vx-mb-2\">\n      <i class=\"icons vx-fs-12\">&#xe90b;</i>\n      <input type=\"text\" [(ngModel)]=\"responsibilitySearchText\" (keyup.enter)=\"search()\"\n        placeholder=\"Search Responsibilities\" />\n    </div>\n    <ng-container *ngIf=\"responsibilitiesData?.pagination as pagination\">\n      <app-pagination *ngIf=\"pagination?.total_pages > 1\" [start]=\"pagination?.responsibilities_from\"\n        [end]=\"pagination?.responsibilities_to\" [total]=\"pagination?.total_responsibilities\"\n        [pageCount]=\"pagination?.total_pages\" [currentPage]=\"responsibilityCurrentPage\"\n        (selectedPage)=\"responsibilityPageChange($event)\">\n      </app-pagination>\n    </ng-container>\n\n    <app-loader-inline *ngIf=\"responsibilityLoader\"></app-loader-inline>\n    <div class=\"frequency-responsibility-list-mid vx-mb-4\" [class.with-pagination]=\"\n        !responsibilityLoader && responsibilitiesData?.total_pages > 1\n      \">\n      <app-no-data *ngIf=\"\n          responsibilitiesData?.responsibilities?.length === 0 &&\n          !responsibilityLoader\n        \" [noDataImage]=\"ASSETS.search_data\" [noDataText]=\"'No Data to Display'\"></app-no-data>\n      <ng-container *ngIf=\"\n          responsibilitiesData?.responsibilities?.length > 0 &&\n          !responsibilityLoader\n        \">\n        <div class=\"table-header\">\n          <div class=\"table-row\">\n            <div\n              class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\">\n              #\n            </div>\n            <div\n              class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility\">\n              RESPONSIBILITIES\n            </div>\n            <div\n              class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility-center\">\n              RESPONSIBILITY CENTER\n            </div>\n            <div\n              class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center action\">\n            </div>\n          </div>\n        </div>\n        <div class=\"table-body\">\n          <!-- when click on radio then active class should be true -->\n          <ng-container *ngFor=\"\n              let responsibility of responsibilitiesData?.responsibilities;\n              let i = index\n            \">\n            <ng-container *ngIf=\"(responsibilitiesData?.page * responsibilitiesData?.limit -\n            responsibilitiesData?.limit +\n            i +\n            1) as srNo\">\n              <div class=\"table-row\" [class.resp]=\"responsibility?.assigneeDetails?.length === 1\" [class.active]=\"\n                selectedResponsibilityValues?.responsibility?.id === responsibility?.id && responsibility?.assigneeDetails?.length === 1\n              \" [class.with-sub-responsibility]=\"openedResponsibility.includes(responsibility?.id)\">\n                <ng-container *ngIf=\"responsibility?.assigneeDetails as assigneeDetails\">\n                  <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\">\n                    <div class=\"sr-no\" [appTooltip]=\"\n                      srNo  \n                    \" placement=\"bottom\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">\n                      {{srNo}}\n                    </div>\n                    <app-cs-radio *ngIf=\"assigneeDetails?.length === 1\" [name]=\"'onCompletion'\" [checked]=\"\n                      selectedResponsibilityValues?.responsibility?.id === responsibility?.id\n                    \"\n                      (checkedEvent)=\"onCompletionChange({eachAssignee: assigneeDetails[0], responsibility})\"></app-cs-radio>\n                  </div>\n\n                  <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility with-rc\">\n\n                    <div class=\"value vx-fs-12 vx-label-txt vx-pr-5  vx-d-flex vx-align-center\">\n                      <div class=\"avatar-list vx-d-flex vx-align-center\">\n                        <lib-avatar-v2 [avatarList]=\"responsibility?.allAssignee\"\n                          [type]=\"'SINGLE_AVATAR'\"></lib-avatar-v2>\n                      </div>\n\n                      <span class=\"value-text vx-ml-1 resp-name\" [appTooltip]=\"responsibility?.title\"\n                        placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">{{\n                        responsibility?.controlId }} {{\n                        responsibility?.title\n                        }}</span>\n                    </div>\n                  </div>\n\n                  <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center responsibility-center\">\n                    <ng-container *ngIf=\"responsibility?.allRc as rc\">\n                      <div class=\"program-inner vx-d-block\">\n                        <div class=\"program-value vx-fs-11 vx-label-txt vx-pr-5\" [appTooltip]=\"\n                        rc?.length\n                          ? rc[0]?.name\n                          : '--'\n                      \" placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">\n                          {{\n                          rc?.length\n                          ? rc[0]?.name\n                          : \"--\"\n                          }}\n                        </div>\n                        <ng-container *ngIf=\"\n                        rc?.length \n                      \">\n                        </ng-container>\n                      </div>\n                      <button *ngIf=\"rc?.length > 1\" appPopover (click)=\"rcPopup.popover()\" placement=\"right\"\n                        class=\"program-count vx-fs-11 vx-fw-500 vx-txt-white vx-p-0 vx-pl-1 vx-pr-1 vx-m-0 vx-d-flex vx-align-center vx-justify-center\">\n                        +{{ rc?.length - 1 }}\n                      </button>\n                      <app-popover #rcPopup>\n                        <div class=\"wf-action-list\">\n                          <ul class=\"action-item\">\n                            <li *ngFor=\"\n                            let data of rc?.slice(\n                              1,\n                              rc?.length\n                            )\n                          \">\n                              <div class=\"avatar-card\">\n                                <div class=\"vx-d-block vx-w-100\">\n                                  <span class=\"value\" [appTooltip]=\"data?.name\" placement=\"bottom-left\" delay=\"0\"\n                                    type=\"black\" [tooltipMandatory]=\"true\">{{ data?.name }}</span>\n                                </div>\n                              </div>\n                            </li>\n                          </ul>\n                        </div>\n                      </app-popover>\n                    </ng-container>\n                  </div>\n                  <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center action\"\n                    (click)=\"onToggleResponsibility(responsibility)\">\n                    <ng-container *ngIf=\"assigneeDetails?.length > 1; else closeIcon\">\n                      <i *ngIf=\"\n                        openedResponsibility.includes(responsibility.id);\n                        else closeIcon\n                      \" class=\"icons vx-fs-10\">&#xe9e7;</i>\n                      <ng-template #closeIcon>\n                        <i class=\"icons vx-fs-10\"> &#xe9e8;</i>\n                      </ng-template>\n                    </ng-container>\n                  </div>\n                </ng-container>\n              </div>\n              <lib-sub-responsibility *ngIf=\"openedResponsibility.includes(responsibility.id)\"\n                [responsibility]=\"responsibility\" [srNo]=\"srNo\" [selectedResponsibility]=\"selectedResponsibilityValues\"\n                (onCompletionChange)=\"onCompletionChange($event)\"></lib-sub-responsibility>\n            </ng-container>\n          </ng-container>\n        </div>\n      </ng-container>\n    </div>\n    <app-floating-bar [selectedData]=\"[selectedResponsibilityValues?.responsibility]\" [displayElementKey]=\"'title'\"\n      (closeList)=\"back()\" (closeEvent)=\"save($event)\" (deleteEvent)=\"deleteItem($event)\"\n      [isDisabled]=\"!selectedResponsibilityValues?.responsibility?.id\"></app-floating-bar>\n  </div>\n</div>"]}