vcomply-workflow-engine 7.1.4 → 7.1.6

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.
@@ -35,11 +35,8 @@ export class FrequencyOnCompletionOfComponent {
35
35
  }
36
36
  ngOnInit() {
37
37
  this.frequencyInfo = Object.assign(this.frequencyService.frequencyInfo);
38
- // If we already have a simple onCompletionResponsibility (from edit),
39
- // hydrate structures so the chip + list can use it.
40
38
  if (this.onCompletionResponsibility?.title &&
41
39
  !this.selectedResponsibilityDetails?.responsibility) {
42
- // For chip + frequency calculations we only need title/id
43
40
  this.selectedResponsibilityDetails = {
44
41
  responsibility: {
45
42
  title: this.onCompletionResponsibility.title,
@@ -56,7 +53,6 @@ export class FrequencyOnCompletionOfComponent {
56
53
  responsibilityCenter: null,
57
54
  },
58
55
  };
59
- // For list component pre-selection we must match its expected shape
60
56
  this.selectedResponsibilityListPrefill = {
61
57
  assignee: null,
62
58
  responsibilityCenter: null,
@@ -65,7 +61,6 @@ export class FrequencyOnCompletionOfComponent {
65
61
  };
66
62
  }
67
63
  this.getCompletionReports();
68
- // Pre-populate selected responsibility when editing an existing frequency
69
64
  if (!this.onCompletionResponsibility?.title &&
70
65
  this.frequencyData?.onCompletionReportDetails) {
71
66
  const details = this.frequencyData.onCompletionReportDetails;
@@ -109,7 +104,6 @@ export class FrequencyOnCompletionOfComponent {
109
104
  }
110
105
  onResponsibilitySelection(event) {
111
106
  this.selectedResponsibilityDetails = event;
112
- // Build flat prefill object for list on subsequent edits
113
107
  if (event?.eachAssignee && event?.responsibility) {
114
108
  this.selectedResponsibilityListPrefill = {
115
109
  assignee: event.eachAssignee.assignee,
@@ -194,7 +188,10 @@ export class FrequencyOnCompletionOfComponent {
194
188
  ? Object.keys(this.selectedResponsibilityDetails)?.length > 0
195
189
  : false;
196
190
  this.frequencyInfo.reportId = 0;
197
- // Reset placeholder text since no responsibility is selected
191
+ this.frequencyInfo.onCompletionResponsibility = null;
192
+ this.frequencyInfo.onCompletion = {};
193
+ this.frequencyInfo.pattern = '';
194
+ this.frequencyInfo.case = '';
198
195
  this.frequencyInfo.placeholder =
199
196
  this.onCompletionOfInput +
200
197
  ' ' +
@@ -227,4 +224,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
227
224
  }], radioForm: [{
228
225
  type: Output
229
226
  }] } });
230
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"frequency-on-completion-of.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency/frequency-on-completion-of/frequency-on-completion-of.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency/frequency-on-completion-of/frequency-on-completion-of.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Output, EventEmitter } from '@angular/core';\nimport { FrequencyService } from '../frequency.service';\nimport moment from 'moment/moment';\nimport { elementAt } from 'rxjs/operators';\nimport { DEFAULT_TIME } from '../../../constants/time.constants';\n\n@Component({\n  selector: 'app-frequency-on-completion-of',\n  templateUrl: './frequency-on-completion-of.component.html',\n  styleUrls: ['./frequency-on-completion-of.component.less'],\n})\nexport class FrequencyOnCompletionOfComponent implements OnInit {\n  @Input() mode: any = '';\n  @Input() feature: any;\n  @Input() onCompletionResponsibility: any;\n  DEFAULT_TIME: string = DEFAULT_TIME;\n  onCompletionOfInput = 1;\n  onCompletionOfWindow = 3;\n  onCompletionOfFailed = 5;\n  onCompletionOfTime = DEFAULT_TIME;\n  onCompletionOfResponsibility: Array<any> = [];\n  isLifecycleModified = false;\n  selectedResponsibility = 0;\n  placeholder = 'Loading...';\n  frequencyInfo: any;\n  selectedResponsibilityDetails: any = {};\n  selectedResponsibilityListPrefill: any = {};\n\n  @Input() startDate = Math.floor(Date.now() / 1000);\n  @Input() frequencyData: any;\n  lifecycleDetails: any = '0000-00-00~~0';\n\n  @Output() frequencyDetails = new EventEmitter<any>();\n  @Output() radioForm = new EventEmitter<any>();\n  openRadio: boolean = false;\n  backButton: boolean = false;\n  isSelectedData: boolean = false;\n\n  constructor(private frequencyService: FrequencyService) {}\n\n  ngOnInit(): void {\n    this.frequencyInfo = Object.assign(this.frequencyService.frequencyInfo);\n\n    // If we already have a simple onCompletionResponsibility (from edit),\n    // hydrate structures so the chip + list can use it.\n    if (\n      this.onCompletionResponsibility?.title &&\n      !this.selectedResponsibilityDetails?.responsibility\n    ) {\n      // For chip + frequency calculations we only need title/id\n      this.selectedResponsibilityDetails = {\n        responsibility: {\n          title: this.onCompletionResponsibility.title,\n          id: this.onCompletionResponsibility.id,\n          assigneeDetails: [\n            {\n              assignee: null,\n              responsibilityCenter: null,\n            },\n          ],\n        },\n        eachAssignee: {\n          assignee: null,\n          responsibilityCenter: null,\n        },\n      };\n\n      // For list component pre-selection we must match its expected shape\n      this.selectedResponsibilityListPrefill = {\n        assignee: null,\n        responsibilityCenter: null,\n        title: this.onCompletionResponsibility.title,\n        id: this.onCompletionResponsibility.id,\n      };\n    }\n    this.getCompletionReports();\n    // Pre-populate selected responsibility when editing an existing frequency\n    if (\n      !this.onCompletionResponsibility?.title &&\n      this.frequencyData?.onCompletionReportDetails\n    ) {\n      const details = this.frequencyData.onCompletionReportDetails;\n      if (details && Object.keys(details).length > 0) {\n        this.onCompletionResponsibility = {\n          title: details.report_name,\n          id: details.ReportId,\n        };\n      }\n    }\n    this.getOnCompletionFrequency();\n    this.isSelectedData = this.selectedResponsibilityDetails\n      ? Object.keys(this.selectedResponsibilityDetails)?.length > 0\n      : false;\n  }\n\n  populateFrequency() {\n    const frequencySelected = this.frequencyData.pattern.split('~');\n    this.onCompletionOfInput = parseInt(frequencySelected[3]);\n    this.onCompletionOfFailed = this.frequencyData.failed;\n    this.onCompletionOfWindow = this.frequencyData.window;\n    this.onCompletionOfTime = this.frequencyData.failedTime;\n    this.selectedResponsibilityDetails =\n      this.frequencyData.onCompletionResponsibility;\n    this.getOnCompletionFrequency();\n    this.isSelectedData = this.selectedResponsibilityDetails\n      ? Object.keys(this.selectedResponsibilityDetails)?.length > 0\n      : false;\n  }\n\n  onTimeChanged(event: string) {\n    this.onCompletionOfTime = event;\n    this.getOnCompletionFrequency();\n  }\n\n  onValueChange(event: any) {\n    if (event.type === 'completed') {\n      this.onCompletionOfWindow = event.value;\n    } else {\n      this.onCompletionOfFailed = event.value;\n    }\n    this.getOnCompletionFrequency();\n  }\n\n  onResponsibilitySelection(event: any) {\n    this.selectedResponsibilityDetails = event;\n    // Build flat prefill object for list on subsequent edits\n    if (event?.eachAssignee && event?.responsibility) {\n      this.selectedResponsibilityListPrefill = {\n        assignee: event.eachAssignee.assignee,\n        responsibilityCenter: event.eachAssignee.responsibilityCenter,\n        title: event.responsibility.title,\n        id: event.responsibility.id,\n      };\n    }\n    this.onCompletionResponsibility = event?.responsibility;\n    this.getOnCompletionFrequency();\n  }\n\n  getCompletionReports() {\n    this.selectedResponsibility = 0;\n    this.placeholder = 'Select a Responsibility';\n    this.onCompletionOfResponsibility = [];\n\n    if (this.frequencyData?.onCompletionReportDetails) {\n      this.onCompletionOfResponsibility.push(\n        this.frequencyData?.onCompletionReportDetails\n      );\n    }\n\n    if (\n      this.frequencyData.pattern != '' &&\n      parseInt(this.frequencyData.pattern.split('~')[0]) === 6\n    ) {\n      this.populateFrequency();\n    }\n  }\n\n  inputValueChange(event: any) {\n    this.onCompletionOfInput = Number(event.target.value);\n    if (this.onCompletionOfInput < 1) {\n      this.onCompletionOfInput = 1;\n    }\n    this.getOnCompletionFrequency();\n  }\n\n  getOnCompletionFrequency() {\n    const responsibilityTitle =\n      this.selectedResponsibilityDetails?.responsibility?.title ||\n      this.onCompletionResponsibility?.title ||\n      '';\n\n    const responsibilityId =\n      this.selectedResponsibilityDetails?.responsibility?.id ||\n      this.onCompletionResponsibility?.id ||\n      null;\n\n    const firstAssigneeDetail =\n      this.selectedResponsibilityDetails?.responsibility?.assigneeDetails?.[0] ||\n      {};\n\n    this.frequencyInfo.placeholder =\n      this.onCompletionOfInput +\n      ' ' +\n      (this.onCompletionOfInput > 1 ? 'days' : 'day') +\n      ' after completion of ' +\n      responsibilityTitle;\n    this.frequencyInfo.pattern =\n      6 + '~' + '0' + '~' + '0' + '~' + this.onCompletionOfInput;\n    this.frequencyInfo.case = 'on_complete';\n    this.frequencyInfo.failedAfter = this.onCompletionOfFailed;\n    this.frequencyInfo.window = this.onCompletionOfWindow;\n    this.frequencyInfo.timeIn12hr = this.onCompletionOfTime;\n    this.frequencyInfo.timeIn24Hr = this.frequencyService.timeFrom12hTo24h(\n      this.onCompletionOfTime\n    );\n    this.frequencyInfo.failed_time_utc = 0;\n    this.frequencyInfo.onCompletionResponsibility = {\n      title: responsibilityTitle,\n      id: responsibilityId,\n    };\n    this.frequencyInfo.onCompletion = {\n      dueAfter: this.onCompletionOfInput,\n      responsibility: responsibilityId,\n      assignee: firstAssigneeDetail.assignee ?? null,\n      responsibilityCenter: firstAssigneeDetail.responsibilityCenter ?? null,\n    };\n    this.frequencyDetails.emit(this.frequencyInfo);\n  }\n\n  openRadioResponsibility(event: any) {\n    if (event === 'backToOnCompletion') {\n      this.backButton = true;\n      this.openRadio = false;\n    } else {\n      this.openRadio = true;\n      this.backButton = false;\n    }\n    this.radioForm.emit(this.openRadio);\n  }\n\n  remove() {\n    this.selectedResponsibilityDetails = {};\n    this.selectedResponsibilityListPrefill = {};\n    this.onCompletionResponsibility = null;\n    this.isSelectedData = this.selectedResponsibilityDetails\n      ? Object.keys(this.selectedResponsibilityDetails)?.length > 0\n      : false;\n    this.frequencyInfo.reportId = 0;\n    // Reset placeholder text since no responsibility is selected\n    this.frequencyInfo.placeholder =\n      this.onCompletionOfInput +\n      ' ' +\n      (this.onCompletionOfInput > 1 ? 'days' : 'day') +\n      ' after completion of ';\n    this.frequencyDetails.emit(this.frequencyInfo);\n  }\n\n  timeSelection(event: any) {\n    const selectedValue = event.selectedValue;\n    this.onTimeChanged(selectedValue);\n  }\n}\n","<div class=\"frequency-completion\" *ngIf=\"mode !== 'policy' || backButton\">\n  <div class=\"vx-fs-11 vx-fw-500 vx-label-txt vx-tt-uppercase vx-mb-1\">\n    DUE DATE FREQUENCY:\n  </div>\n  <div class=\"frequency-completion-inner\">\n    <div class=\"frequency-completion-top vx-p-3 vx-d-flex vx-align-center\">\n      <input class=\"countNum\" type=\"number\" [(ngModel)]=\"onCompletionOfInput\" (change)=\"inputValueChange($event)\"\n        onkeydown=\"return event.keyCode !== 190\" min=\"0\" oninput=\"this.value = Math.abs(this.value)\" />\n      <div class=\"vx-fs-13 vx-paragraph-txt\">day after completion of</div>\n    </div>\n    <div class=\"frequency-completion-bottom vx-p-3\">\n      <div class=\"vx-fs-11 vx-fw-500 vx-label-txt vx-tt-uppercase vx-mb-1\">\n        RESPONSIBILITY\n      </div>\n      <div class=\"vx-d-flex vx-align-center\">\n        <ng-container>\n          <div *ngIf=\"!onCompletionResponsibility?.title\" [class.disabled]=\"placeholder === 'Loading...'\"\n            class=\"select-box vx-fs-11 vx-paragraph-txt vx-p-2 vx-pl-3 vx-pr-3 vx-mr-3 vx-d-flex vx-align-center vx-justify-between vx-w-100\"\n            (click)=\"openRadioResponsibility($event)\">\n            {{\n            placeholder === \"Loading...\"\n            ? \"Loading...\"\n            : \"Select a Responsibility\"\n            }}\n            <i class=\"icons vx-fs-10\">&#xe9e8;</i>\n          </div>\n          <div *ngIf=\"onCompletionResponsibility?.title as respName\"\n            class=\"after-select-box vx-p-1 vx-mr-3 vx-d-flex vx-align-center vx-justify-between vx-w-100\">\n            <div class=\"select-chip vx-fs-12 vx-paragraph-txt vx-p-1 vx-pl-2 vx-pr-2 vx-d-flex vx-align-center\">\n              <i class=\"icons cross vx-fs-14 vx-mr-1\" (click)=\"remove()\">&#xe9ae;</i>\n              <span [appTooltip]=\"respName\" placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">{{\n                respName }}</span>\n            </div>\n            <button\n              class=\"edit-btn vx-fs-11 vx-fw-500 vx-txt-blue vx-tt-uppercase vx-p-0 vx-pl-1 vx-pr-1 vx-m-0 vx-d-flex vx-align-center\"\n              (click)=\"openRadioResponsibility($event)\">\n              <i class=\"icons vx-mr-1\" (click)=\"openRadioResponsibility($event)\">&#xe90c;</i>\n              EDIT\n            </button>\n          </div>\n          <app-frequency-responsibility-list *ngIf=\"openRadio\" [feature]=\"feature\"\n            [selectedResponsibilityDetails]=\"selectedResponsibilityListPrefill\"\n            (backButton)=\"openRadioResponsibility($event)\"\n            (selectedResponsibility)=\"onResponsibilitySelection($event)\"></app-frequency-responsibility-list>\n        </ng-container>\n\n        <div class=\"time-picker-group vx-d-flex\" *ngIf=\"!openRadio\">\n          <div class=\"time-field\" appPopover (click)=\"timePicker.popover()\" placement=\"right\">\n            <input class=\"input\" [placeholder]=\"onCompletionOfTime | uppercase\" readonly />\n            <div class=\"clock-icon vx-d-flex vx-align-center vx-justify-center\">\n              <i class=\"icons vx-fs-12 vx-paragraph-txt\">&#xe955;</i>\n            </div>\n          </div>\n          <app-popover #timePicker [dontCloseonClick]=\"true\">\n            <app-time-picker [time]=\"onCompletionOfTime\" (onTimeSelection)=\"\n                timeSelection($event); timePicker.closePopover('top')\n              \"></app-time-picker>\n          </app-popover>\n        </div>\n      </div>\n    </div>\n  </div>\n  <app-frequency-due-date [id]=\"3\" [pageName]=\"'onCompletion'\" [mode]=\"mode\" [isDeactivated]=\"false\"\n    [completedValue]=\"onCompletionOfWindow\" [notCompletedValue]=\"onCompletionOfFailed\"\n    (valueChange)=\"onValueChange($event)\"></app-frequency-due-date>\n</div>"]}
227
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"frequency-on-completion-of.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency/frequency-on-completion-of/frequency-on-completion-of.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency/frequency-on-completion-of/frequency-on-completion-of.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Output, EventEmitter } from '@angular/core';\nimport { FrequencyService } from '../frequency.service';\nimport moment from 'moment/moment';\nimport { elementAt } from 'rxjs/operators';\nimport { DEFAULT_TIME } from '../../../constants/time.constants';\n\n@Component({\n  selector: 'app-frequency-on-completion-of',\n  templateUrl: './frequency-on-completion-of.component.html',\n  styleUrls: ['./frequency-on-completion-of.component.less'],\n})\nexport class FrequencyOnCompletionOfComponent implements OnInit {\n  @Input() mode: any = '';\n  @Input() feature: any;\n  @Input() onCompletionResponsibility: any;\n  DEFAULT_TIME: string = DEFAULT_TIME;\n  onCompletionOfInput = 1;\n  onCompletionOfWindow = 3;\n  onCompletionOfFailed = 5;\n  onCompletionOfTime = DEFAULT_TIME;\n  onCompletionOfResponsibility: Array<any> = [];\n  isLifecycleModified = false;\n  selectedResponsibility = 0;\n  placeholder = 'Loading...';\n  frequencyInfo: any;\n  selectedResponsibilityDetails: any = {};\n  selectedResponsibilityListPrefill: any = {};\n\n  @Input() startDate = Math.floor(Date.now() / 1000);\n  @Input() frequencyData: any;\n  lifecycleDetails: any = '0000-00-00~~0';\n\n  @Output() frequencyDetails = new EventEmitter<any>();\n  @Output() radioForm = new EventEmitter<any>();\n  openRadio: boolean = false;\n  backButton: boolean = false;\n  isSelectedData: boolean = false;\n\n  constructor(private frequencyService: FrequencyService) {}\n\n  ngOnInit(): void {\n    this.frequencyInfo = Object.assign(this.frequencyService.frequencyInfo);\n    if (\n      this.onCompletionResponsibility?.title &&\n      !this.selectedResponsibilityDetails?.responsibility\n    ) {\n      this.selectedResponsibilityDetails = {\n        responsibility: {\n          title: this.onCompletionResponsibility.title,\n          id: this.onCompletionResponsibility.id,\n          assigneeDetails: [\n            {\n              assignee: null,\n              responsibilityCenter: null,\n            },\n          ],\n        },\n        eachAssignee: {\n          assignee: null,\n          responsibilityCenter: null,\n        },\n      };\n\n      this.selectedResponsibilityListPrefill = {\n        assignee: null,\n        responsibilityCenter: null,\n        title: this.onCompletionResponsibility.title,\n        id: this.onCompletionResponsibility.id,\n      };\n    }\n    this.getCompletionReports();\n    if (\n      !this.onCompletionResponsibility?.title &&\n      this.frequencyData?.onCompletionReportDetails\n    ) {\n      const details = this.frequencyData.onCompletionReportDetails;\n      if (details && Object.keys(details).length > 0) {\n        this.onCompletionResponsibility = {\n          title: details.report_name,\n          id: details.ReportId,\n        };\n      }\n    }\n    this.getOnCompletionFrequency();\n    this.isSelectedData = this.selectedResponsibilityDetails\n      ? Object.keys(this.selectedResponsibilityDetails)?.length > 0\n      : false;\n  }\n\n  populateFrequency() {\n    const frequencySelected = this.frequencyData.pattern.split('~');\n    this.onCompletionOfInput = parseInt(frequencySelected[3]);\n    this.onCompletionOfFailed = this.frequencyData.failed;\n    this.onCompletionOfWindow = this.frequencyData.window;\n    this.onCompletionOfTime = this.frequencyData.failedTime;\n    this.selectedResponsibilityDetails =\n      this.frequencyData.onCompletionResponsibility;\n    this.getOnCompletionFrequency();\n    this.isSelectedData = this.selectedResponsibilityDetails\n      ? Object.keys(this.selectedResponsibilityDetails)?.length > 0\n      : false;\n  }\n\n  onTimeChanged(event: string) {\n    this.onCompletionOfTime = event;\n    this.getOnCompletionFrequency();\n  }\n\n  onValueChange(event: any) {\n    if (event.type === 'completed') {\n      this.onCompletionOfWindow = event.value;\n    } else {\n      this.onCompletionOfFailed = event.value;\n    }\n    this.getOnCompletionFrequency();\n  }\n\n  onResponsibilitySelection(event: any) {\n    this.selectedResponsibilityDetails = event;\n    if (event?.eachAssignee && event?.responsibility) {\n      this.selectedResponsibilityListPrefill = {\n        assignee: event.eachAssignee.assignee,\n        responsibilityCenter: event.eachAssignee.responsibilityCenter,\n        title: event.responsibility.title,\n        id: event.responsibility.id,\n      };\n    }\n    this.onCompletionResponsibility = event?.responsibility;\n    this.getOnCompletionFrequency();\n  }\n\n  getCompletionReports() {\n    this.selectedResponsibility = 0;\n    this.placeholder = 'Select a Responsibility';\n    this.onCompletionOfResponsibility = [];\n\n    if (this.frequencyData?.onCompletionReportDetails) {\n      this.onCompletionOfResponsibility.push(\n        this.frequencyData?.onCompletionReportDetails\n      );\n    }\n\n    if (\n      this.frequencyData.pattern != '' &&\n      parseInt(this.frequencyData.pattern.split('~')[0]) === 6\n    ) {\n      this.populateFrequency();\n    }\n  }\n\n  inputValueChange(event: any) {\n    this.onCompletionOfInput = Number(event.target.value);\n    if (this.onCompletionOfInput < 1) {\n      this.onCompletionOfInput = 1;\n    }\n    this.getOnCompletionFrequency();\n  }\n\n  getOnCompletionFrequency() {\n    const responsibilityTitle =\n      this.selectedResponsibilityDetails?.responsibility?.title ||\n      this.onCompletionResponsibility?.title ||\n      '';\n\n    const responsibilityId =\n      this.selectedResponsibilityDetails?.responsibility?.id ||\n      this.onCompletionResponsibility?.id ||\n      null;\n\n    const firstAssigneeDetail =\n      this.selectedResponsibilityDetails?.responsibility?.assigneeDetails?.[0] ||\n      {};\n\n    this.frequencyInfo.placeholder =\n      this.onCompletionOfInput +\n      ' ' +\n      (this.onCompletionOfInput > 1 ? 'days' : 'day') +\n      ' after completion of ' +\n      responsibilityTitle;\n    this.frequencyInfo.pattern =\n      6 + '~' + '0' + '~' + '0' + '~' + this.onCompletionOfInput;\n    this.frequencyInfo.case = 'on_complete';\n    this.frequencyInfo.failedAfter = this.onCompletionOfFailed;\n    this.frequencyInfo.window = this.onCompletionOfWindow;\n    this.frequencyInfo.timeIn12hr = this.onCompletionOfTime;\n    this.frequencyInfo.timeIn24Hr = this.frequencyService.timeFrom12hTo24h(\n      this.onCompletionOfTime\n    );\n    this.frequencyInfo.failed_time_utc = 0;\n    this.frequencyInfo.onCompletionResponsibility = {\n      title: responsibilityTitle,\n      id: responsibilityId,\n    };\n    this.frequencyInfo.onCompletion = {\n      dueAfter: this.onCompletionOfInput,\n      responsibility: responsibilityId,\n      assignee: firstAssigneeDetail.assignee ?? null,\n      responsibilityCenter: firstAssigneeDetail.responsibilityCenter ?? null,\n    };\n    this.frequencyDetails.emit(this.frequencyInfo);\n  }\n\n  openRadioResponsibility(event: any) {\n    if (event === 'backToOnCompletion') {\n      this.backButton = true;\n      this.openRadio = false;\n    } else {\n      this.openRadio = true;\n      this.backButton = false;\n    }\n    this.radioForm.emit(this.openRadio);\n  }\n\n  remove() {\n    this.selectedResponsibilityDetails = {};\n    this.selectedResponsibilityListPrefill = {};\n    this.onCompletionResponsibility = null;\n    this.isSelectedData = this.selectedResponsibilityDetails\n      ? Object.keys(this.selectedResponsibilityDetails)?.length > 0\n      : false;\n    this.frequencyInfo.reportId = 0;\n    this.frequencyInfo.onCompletionResponsibility = null;\n    this.frequencyInfo.onCompletion = {};\n    this.frequencyInfo.pattern = '';\n    this.frequencyInfo.case = '';\n    this.frequencyInfo.placeholder =\n      this.onCompletionOfInput +\n      ' ' +\n      (this.onCompletionOfInput > 1 ? 'days' : 'day') +\n      ' after completion of ';\n    this.frequencyDetails.emit(this.frequencyInfo);\n  }\n\n  timeSelection(event: any) {\n    const selectedValue = event.selectedValue;\n    this.onTimeChanged(selectedValue);\n  }\n}\n","<div class=\"frequency-completion\" *ngIf=\"mode !== 'policy' || backButton\">\n  <div class=\"vx-fs-11 vx-fw-500 vx-label-txt vx-tt-uppercase vx-mb-1\">\n    DUE DATE FREQUENCY:\n  </div>\n  <div class=\"frequency-completion-inner\">\n    <div class=\"frequency-completion-top vx-p-3 vx-d-flex vx-align-center\">\n      <input class=\"countNum\" type=\"number\" [(ngModel)]=\"onCompletionOfInput\" (change)=\"inputValueChange($event)\"\n        onkeydown=\"return event.keyCode !== 190\" min=\"0\" oninput=\"this.value = Math.abs(this.value)\" />\n      <div class=\"vx-fs-13 vx-paragraph-txt\">day after completion of</div>\n    </div>\n    <div class=\"frequency-completion-bottom vx-p-3\">\n      <div class=\"vx-fs-11 vx-fw-500 vx-label-txt vx-tt-uppercase vx-mb-1\">\n        RESPONSIBILITY\n      </div>\n      <div class=\"vx-d-flex vx-align-center\">\n        <ng-container>\n          <div *ngIf=\"!onCompletionResponsibility?.title\" [class.disabled]=\"placeholder === 'Loading...'\"\n            class=\"select-box vx-fs-11 vx-paragraph-txt vx-p-2 vx-pl-3 vx-pr-3 vx-mr-3 vx-d-flex vx-align-center vx-justify-between vx-w-100\"\n            (click)=\"openRadioResponsibility($event)\">\n            {{\n            placeholder === \"Loading...\"\n            ? \"Loading...\"\n            : \"Select a Responsibility\"\n            }}\n            <i class=\"icons vx-fs-10\">&#xe9e8;</i>\n          </div>\n          <div *ngIf=\"onCompletionResponsibility?.title as respName\"\n            class=\"after-select-box vx-p-1 vx-mr-3 vx-d-flex vx-align-center vx-justify-between vx-w-100\">\n            <div class=\"select-chip vx-fs-12 vx-paragraph-txt vx-p-1 vx-pl-2 vx-pr-2 vx-d-flex vx-align-center\">\n              <i class=\"icons cross vx-fs-14 vx-mr-1\" (click)=\"remove()\">&#xe9ae;</i>\n              <span [appTooltip]=\"respName\" placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">{{\n                respName }}</span>\n            </div>\n            <button\n              class=\"edit-btn vx-fs-11 vx-fw-500 vx-txt-blue vx-tt-uppercase vx-p-0 vx-pl-1 vx-pr-1 vx-m-0 vx-d-flex vx-align-center\"\n              (click)=\"openRadioResponsibility($event)\">\n              <i class=\"icons vx-mr-1\" (click)=\"openRadioResponsibility($event)\">&#xe90c;</i>\n              EDIT\n            </button>\n          </div>\n          <app-frequency-responsibility-list *ngIf=\"openRadio\" [feature]=\"feature\"\n            [selectedResponsibilityDetails]=\"selectedResponsibilityListPrefill\"\n            (backButton)=\"openRadioResponsibility($event)\"\n            (selectedResponsibility)=\"onResponsibilitySelection($event)\"></app-frequency-responsibility-list>\n        </ng-container>\n\n        <div class=\"time-picker-group vx-d-flex\" *ngIf=\"!openRadio\">\n          <div class=\"time-field\" appPopover (click)=\"timePicker.popover()\" placement=\"right\">\n            <input class=\"input\" [placeholder]=\"onCompletionOfTime | uppercase\" readonly />\n            <div class=\"clock-icon vx-d-flex vx-align-center vx-justify-center\">\n              <i class=\"icons vx-fs-12 vx-paragraph-txt\">&#xe955;</i>\n            </div>\n          </div>\n          <app-popover #timePicker [dontCloseonClick]=\"true\">\n            <app-time-picker [time]=\"onCompletionOfTime\" (onTimeSelection)=\"\n                timeSelection($event); timePicker.closePopover('top')\n              \"></app-time-picker>\n          </app-popover>\n        </div>\n      </div>\n    </div>\n  </div>\n  <app-frequency-due-date [id]=\"3\" [pageName]=\"'onCompletion'\" [mode]=\"mode\" [isDeactivated]=\"false\"\n    [completedValue]=\"onCompletionOfWindow\" [notCompletedValue]=\"onCompletionOfFailed\"\n    (valueChange)=\"onValueChange($event)\"></app-frequency-due-date>\n</div>"]}
@@ -195,7 +195,6 @@ export class FrequencyResponsibilityListComponent {
195
195
  return nameArray[0]?.charAt(0) + nameArray[0]?.charAt(1)?.toUpperCase();
196
196
  }
197
197
  populateResponsibility() {
198
- // Allow pre-selection even if assignee / RC are not known.
199
198
  if (!this.selectedResponsibilityDetails || !this.selectedResponsibilityDetails.id) {
200
199
  return;
201
200
  }
@@ -235,4 +234,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
235
234
  }], selectedResponsibility: [{
236
235
  type: Output
237
236
  }] } });
238
- //# 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\n      let  assigneeDetails = (item.assigneeDetails || [])\n        .filter((ad: any) => ad.status && ad.status.toLowerCase() === 'active')\n        if(assigneeDetails?.length === 0 && item?.assigneeType === 'any' && [null, 'any'].includes(item?.rcType)) {\n\n          assigneeDetails =  item.assignees?.activeUserId?.map((id: any) => {\n            return {\n              ...item.assigneeDetails[0],\n              status: 'active',\n              assignee: id,\n            }\n          });\n        }\n        assigneeDetails =  assigneeDetails.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        assigneeType: item?.assigneeType,\n        rcType: item?.rcType,\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    // Allow pre-selection even if assignee / RC are not known.\n    if (!this.selectedResponsibilityDetails || !this.selectedResponsibilityDetails.id) {\n      return;\n    }\n\n    this.selectedResponsibilityValues = {\n      eachAssignee: {\n        assignee: this.selectedResponsibilityDetails.assignee ?? null,\n        responsibilityCenter: this.selectedResponsibilityDetails.responsibilityCenter ?? null,\n      },\n      responsibility: {\n        title: this.selectedResponsibilityDetails.title,\n        id: this.selectedResponsibilityDetails.id,\n        allRC: [],\n        allAssignee: [],\n        assigneeDetails: [\n          {\n            assignee: this.selectedResponsibilityDetails.assignee ?? null,\n            responsibilityCenter: this.selectedResponsibilityDetails.responsibilityCenter ?? null,\n          },\n        ],\n        eachAssignee: {},\n      },\n    };\n  }\n\n  onCompletionChange(event: any) {\n    this.selectedResponsibilityValues = event\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\"\n                [class.resp]=\"responsibility?.assigneeDetails?.length === 1 || (responsibility?.assigneeType === 'any' && [null, 'any'].includes(responsibility?.rcType))\"\n                [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\n                      *ngIf=\"assigneeDetails?.length === 1 || (responsibility?.assigneeType === 'any' && [null, 'any'].includes(responsibility?.rcType))\"\n                      [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\n                      *ngIf=\"assigneeDetails?.length > 1 && !(responsibility?.assigneeType === 'any' && [null, 'any'].includes(responsibility?.rcType)); 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>"]}
237
+ //# 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;QAEzF,IAAK,eAAe,GAAG,CAAC,IAAI,CAAC,eAAe,IAAI,EAAE,CAAC;aAChD,MAAM,CAAC,CAAC,EAAO,EAAE,EAAE,CAAC,EAAE,CAAC,MAAM,IAAI,EAAE,CAAC,MAAM,CAAC,WAAW,EAAE,KAAK,QAAQ,CAAC,CAAA;QACvE,IAAG,eAAe,EAAE,MAAM,KAAK,CAAC,IAAI,IAAI,EAAE,YAAY,KAAK,KAAK,IAAI,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC,EAAE;YAExG,eAAe,GAAI,IAAI,CAAC,SAAS,EAAE,YAAY,EAAE,GAAG,CAAC,CAAC,EAAO,EAAE,EAAE;gBAC/D,OAAO;oBACL,GAAG,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC;oBAC1B,MAAM,EAAE,QAAQ;oBAChB,QAAQ,EAAE,EAAE;iBACb,CAAA;YACH,CAAC,CAAC,CAAC;SACJ;QACD,eAAe,GAAI,eAAe,CAAC,GAAG,CAAC,CAAC,EAAO,EAAE,EAAE,CAAC,CAAC;YACnD,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,IAAI,EAAE,SAAS,GAAG,IAAI,CAAC,CAAC,CAAC,EAAE;YAClE,YAAY,EAAE,IAAI,EAAE,YAAY;YAChC,MAAM,EAAE,IAAI,EAAE,MAAM;YACpB,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,IAAI,CAAC,IAAI,CAAC,6BAA6B,IAAI,CAAC,IAAI,CAAC,6BAA6B,CAAC,EAAE,EAAE;YACjF,OAAO;SACR;QACD,IAAI,CAAC,4BAA4B,GAAI;YACnC,YAAY,EAAE;gBACZ,QAAQ,EAAE,IAAI,CAAC,6BAA6B,CAAC,QAAQ,IAAI,IAAI;gBAC7D,oBAAoB,EAAE,IAAI,CAAC,6BAA6B,CAAC,oBAAoB,IAAI,IAAI;aACtF;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;oBACf;wBACE,QAAQ,EAAE,IAAI,CAAC,6BAA6B,CAAC,QAAQ,IAAI,IAAI;wBAC7D,oBAAoB,EAAE,IAAI,CAAC,6BAA6B,CAAC,oBAAoB,IAAI,IAAI;qBACtF;iBACF;gBACD,YAAY,EAAE,EAAE;aACjB;SACF,CAAC;IACJ,CAAC;IAED,kBAAkB,CAAC,KAAU;QAC3B,IAAI,CAAC,4BAA4B,GAAG,KAAK,CAAA;IAC3C,CAAC;+GApPU,oCAAoC;mGAApC,oCAAoC,8OCXjD,43SA2KM;;4FDhKO,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\n      let  assigneeDetails = (item.assigneeDetails || [])\n        .filter((ad: any) => ad.status && ad.status.toLowerCase() === 'active')\n        if(assigneeDetails?.length === 0 && item?.assigneeType === 'any' && [null, 'any'].includes(item?.rcType)) {\n\n          assigneeDetails =  item.assignees?.activeUserId?.map((id: any) => {\n            return {\n              ...item.assigneeDetails[0],\n              status: 'active',\n              assignee: id,\n            }\n          });\n        }\n        assigneeDetails =  assigneeDetails.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        assigneeType: item?.assigneeType,\n        rcType: item?.rcType,\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 || !this.selectedResponsibilityDetails.id) {\n      return;\n    }\n    this.selectedResponsibilityValues =  {\n      eachAssignee: {\n        assignee: this.selectedResponsibilityDetails.assignee ?? null,\n        responsibilityCenter: this.selectedResponsibilityDetails.responsibilityCenter ?? null,\n      },\n      responsibility: {\n        title: this.selectedResponsibilityDetails.title,\n        id: this.selectedResponsibilityDetails.id,\n        allRC: [],\n        allAssignee: [],\n        assigneeDetails: [\n          {\n            assignee: this.selectedResponsibilityDetails.assignee ?? null,\n            responsibilityCenter: this.selectedResponsibilityDetails.responsibilityCenter ?? null,\n          },\n        ],\n        eachAssignee: {},\n      },\n    };\n  }\n\n  onCompletionChange(event: any) {\n    this.selectedResponsibilityValues = event\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\"\n                [class.resp]=\"responsibility?.assigneeDetails?.length === 1 || (responsibility?.assigneeType === 'any' && [null, 'any'].includes(responsibility?.rcType))\"\n                [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\n                      *ngIf=\"assigneeDetails?.length === 1 || (responsibility?.assigneeType === 'any' && [null, 'any'].includes(responsibility?.rcType))\"\n                      [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\n                      *ngIf=\"assigneeDetails?.length > 1 && !(responsibility?.assigneeType === 'any' && [null, 'any'].includes(responsibility?.rcType)); 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>"]}