vcomply-workflow-engine 3.1.18 → 3.1.20

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.
@@ -124,7 +124,12 @@ export class GrcResponsibilityListingComponent {
124
124
  let categoryIndex = -1;
125
125
  for (let i = 0; i < this.selectedCatAndRisk.length; i++) {
126
126
  let category = this.selectedCatAndRisk[i];
127
- let foundCategory = Object.entries(category.category).find(([key, value]) => value === categoryId);
127
+ let foundCategory = Object.entries(category.category).find(([key, value]) => {
128
+ if (key === '_id' && value === 'uncategorized') {
129
+ return true;
130
+ }
131
+ return value === categoryId;
132
+ });
128
133
  if (foundCategory) {
129
134
  categoryIndex = i;
130
135
  break;
@@ -184,4 +189,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
184
189
  }], changeSelectedCatAndRisk: [{
185
190
  type: Output
186
191
  }] } });
187
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grc-responsibility-listing.component.js","sourceRoot":"","sources":["../../../../../../../../projects/vx-workflow-engine/src/lib/workflow/shared/components/grc-responsibility-listing/grc-responsibility-listing.component.ts","../../../../../../../../projects/vx-workflow-engine/src/lib/workflow/shared/components/grc-responsibility-listing/grc-responsibility-listing.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Optional,\r\n  Output,\r\n} from '@angular/core';\r\nimport { FloatingBarModule } from '../../../../sharedComponents/floating-bar/floating-bar.module';\r\nimport { FormgroupModule } from '../../../../ui-kit/formgroup/formgroup.module';\r\nimport { PaginationModule } from '../../../../ui-kit/pagination/pagination.module';\r\nimport { PopoverModule } from '../../../../ui-kit/popover/popover.module';\r\nimport { TooltipModule } from '../../../../ui-kit/tooltip/tooltip.module';\r\nimport { Configurations } from '../../../../configurations';\r\n\r\n@Component({\r\n  selector: 'app-grc-responsibility-listing',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    PopoverModule,\r\n    FormgroupModule,\r\n    TooltipModule,\r\n    FloatingBarModule,\r\n    PaginationModule,\r\n  ],\r\n  templateUrl: './grc-responsibility-listing.component.html',\r\n  styleUrls: ['./grc-responsibility-listing.component.less'],\r\n  inputs: [\r\n    'tableCard',\r\n    'activeCategory',\r\n    'headerText',\r\n    'currentPage',\r\n    'perPageLimit',\r\n    'totalListData',\r\n    'totalPages',\r\n    'selectedListData',\r\n    'selectedListDataIds',\r\n    'selectedCatAndRisk',\r\n  ],\r\n})\r\nexport class GrcResponsibilityListingComponent implements OnInit {\r\n  profilePic = '';\r\n  env: any;\r\n  dataList: any = [];\r\n  headerText: string = 'Name';\r\n  selectedListData: any = [];\r\n  selectedListDataIds: any = [];\r\n  perPageLimit: number = 30;\r\n  currentPage: number = 1;\r\n  totalPages: number = 1;\r\n  totalListData: number = 0;\r\n  selectedCatAndRisk: any = [];\r\n  activeCategory: any = {};\r\n\r\n  @Input('dataList') set risksList(value: any) {\r\n    this.dataList = value;\r\n  }\r\n\r\n  @Input('selectedCatAndRisk') set getSelectedCatAndRisk(value: any) {\r\n    this.selectedCatAndRisk = value;\r\n    this.getSelectedDataAndIds(value);\r\n  }\r\n\r\n  @Output() getUpdatedDataList: EventEmitter<any> = new EventEmitter();\r\n  @Output() changeSelectedCatAndRisk: EventEmitter<any> = new EventEmitter();\r\n\r\n  constructor(@Optional() config?: Configurations) {\r\n    this.env = config?.envConfig;\r\n    this.profilePic = this.env.s3Url + this.env.s3Bucket + this.env.profile;\r\n  }\r\n\r\n  ngOnInit(): void {}\r\n\r\n  getSelectedData(responsibility: any, event: any) {\r\n    if (event) {\r\n      this.selectedListData.push(responsibility);\r\n      this.selectedListDataIds.push(responsibility?._id);\r\n    } else {\r\n      this.deleteEvent(responsibility);\r\n    }\r\n    this.updateOrCreateCategory(\r\n      this.activeCategory?.category_id,\r\n      this.activeCategory\r\n    );\r\n  }\r\n\r\n  deleteEvent(responsibility: any) {\r\n    this.selectedListData = this.selectedListData?.filter(\r\n      (selected: any) => selected?._id !== responsibility?._id\r\n    );\r\n    this.selectedListDataIds = this.selectedListDataIds?.filter(\r\n      (selectedListDataId: any) => selectedListDataId !== responsibility?._id\r\n    );\r\n  }\r\n\r\n  selectAll(event: any) {\r\n    this.dataList?.forEach((data: any) => {\r\n      if (event) {\r\n        if (!this.selectedListDataIds.includes(data?._id)) {\r\n          this.selectedListData.push(data);\r\n          this.selectedListDataIds.push(data?._id);\r\n        }\r\n      } else {\r\n        this.deleteEvent(data);\r\n      }\r\n    });\r\n    this.updateOrCreateCategory(\r\n      this.activeCategory?.category_id,\r\n      this.activeCategory\r\n    );\r\n  }\r\n\r\n  isAllSelected(): boolean {\r\n    if (\r\n      this.selectedListDataIds &&\r\n      this.selectedListDataIds.length >= this.selectedListData?.length &&\r\n      this.selectedListDataIds.length > 0\r\n    ) {\r\n      for (const grc of this.dataList) {\r\n        if (!this.selectedListDataIds.includes(grc?._id)) {\r\n          return false;\r\n        }\r\n      }\r\n      return true;\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  changePage(event: number) {\r\n    this.currentPage = event;\r\n    this.getUpdatedDataList.emit({\r\n      pageNo: this.currentPage,\r\n    });\r\n  }\r\n\r\n  updateOrCreateCategory(categoryId: number, category: any) {\r\n    const categoryIndex = this.findCheckedCategoryIndex(categoryId);\r\n    if (categoryIndex !== -1) {\r\n      // Category exists, update risk value\r\n      this.selectedCatAndRisk[categoryIndex].risks =\r\n        this.selectedListData ?? [];\r\n      if (this.selectedListData.length === 0) {\r\n        // Remove category if selectedListData is empty\r\n        this.selectedCatAndRisk.splice(categoryIndex, 1);\r\n      }\r\n    } else {\r\n      // Category doesn't exist, create new category with subcategory\r\n      this.selectedCatAndRisk.push({\r\n        category: category ?? {},\r\n        risks: this.selectedListData ?? [],\r\n      });\r\n    }\r\n    this.changeSelectedCatAndRisk.emit(this.selectedCatAndRisk);\r\n  }\r\n\r\n  getSelectedDataAndIds(selectedData: any) {\r\n    const categoryIndex = this.findCheckedCategoryIndex(\r\n      this.activeCategory?.category_id\r\n    );\r\n    this.selectedListData = [];\r\n    this.selectedListDataIds = [];\r\n    if (categoryIndex !== -1) {\r\n      this.selectedListData = selectedData[categoryIndex]?.risks ?? [];\r\n      this.selectedListData?.forEach((data: any) => {\r\n        this.selectedListDataIds.push(data?._id);\r\n      });\r\n    }\r\n  }\r\n\r\n  findCheckedCategoryIndex(categoryId: number) {\r\n    let categoryIndex = -1;\r\n    for (let i = 0; i < this.selectedCatAndRisk.length; i++) {\r\n      let category = this.selectedCatAndRisk[i];\r\n      let foundCategory = Object.entries(category.category).find(\r\n        ([key, value]) => value === categoryId\r\n      );\r\n      if (foundCategory) {\r\n        categoryIndex = i;\r\n        break;\r\n      }\r\n    }\r\n    return categoryIndex;\r\n  }\r\n\r\n  deleteSelectedRisk(categoryId: number, risk: any) {\r\n    const categoryIndex = this.findCheckedCategoryIndex(categoryId);\r\n    if (categoryIndex !== -1) {\r\n      // Category exists, update risk value\r\n      const riskIndex = this.selectedCatAndRisk[\r\n        categoryIndex\r\n      ]?.risks?.findIndex((item: any) => item?._id === risk?._id);\r\n      if (riskIndex !== -1) {\r\n        this.selectedCatAndRisk[categoryIndex]?.risks.splice(riskIndex, 1);\r\n      }\r\n\r\n      if (this.selectedCatAndRisk[categoryIndex]?.risks?.length === 0) {\r\n        // Remove category if selectedListData is empty\r\n        this.selectedCatAndRisk.splice(categoryIndex, 1);\r\n      }\r\n    }\r\n    this.changeSelectedCatAndRisk.emit(this.selectedCatAndRisk);\r\n  }\r\n}\r\n","<div class=\"grc-responsibility-listing\">\r\n    <div class=\"top-heading vx-pl-2 vx-mb-2 vx-d-flex vx-align-center\">\r\n        <app-cs-checkbox *ngIf=\"isAllSelected() || selectedListDataIds?.length === 0\"  [ngValue]=\"isAllSelected()\" (ngValueChange)=\"selectAll($event)\"></app-cs-checkbox>\r\n        <app-cs-checkbox-indeterminate *ngIf=\"!isAllSelected() && selectedListDataIds?.length\" [ngValue]=\"true\" (ngValueChange)=\"selectAll(false)\"></app-cs-checkbox-indeterminate>\r\n        <div class=\"vx-fs-11 vx-fw-500 vx-label-txt vx-tt-uppercase vx-ml-2 vx-lh-4\">{{headerText}}</div>\r\n    </div>\r\n    <div class=\"grc-responsibility-listing-inner\">\r\n        <div class=\"grc-responsibility-table-body\" [class.with-pagination]=\"totalPages > 1\">\r\n            <div class=\"grc-responsibility-table-row\" *ngFor=\"let list of dataList; let i = index\" [class.active]=\"selectedListDataIds?.includes(list?._id)\">\r\n                <div class=\"grc-responsibility-table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\">\r\n                    <div class=\"sr-no\" [appTooltip]=\"(perPageLimit * (currentPage - 1)) + i + 1\" placement=\"bottom\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">{{(perPageLimit * (currentPage - 1)) + i + 1}}</div>\r\n                    <app-cs-checkbox [ngValue]=\"selectedListDataIds?.includes(list?._id)\" (ngValueChange)=\"getSelectedData(list,$event)\"></app-cs-checkbox>\r\n                </div>\r\n                <div class=\"grc-responsibility-table-column vx-pr-1 vx-d-flex vx-align-center responsibility-name\">\r\n                    <div class=\"vx-avatar-group vx-mr-1\">\r\n                        <div class=\"vx-avatar md\" [appTooltip]=\"list?.entrustedBy?.name\" placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">\r\n                            <span *ngIf=\"list?.entrustedBy?.profilePic?.length === ''\" class=\"blue\">{{list.entrustedBy?.shortName}}</span>\r\n                            <img *ngIf=\"list?.entrustedBy?.profilePic?.length !== ''\" src=\"{{profilePic + list?.entrustedBy?.profilePic}}\" alt=\"\">\r\n                        </div>\r\n                        <div *ngIf=\"false\" class=\"vx-avatar md\" [appTooltip]=\"'Harshvardhan Kariwala'\" placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">\r\n                            <span class=\"blue\">hk</span>\r\n                            <img *ngIf=\"false\" src=\"https://s3-eu-west-1.amazonaws.com/eu.v-comply.com/profile_pic/thumb/1672222891690_ProfilePicture.png\" alt=\"\">\r\n                        </div>\r\n                        <div *ngIf=\"false\" class=\"vx-avatar md counter\" appPopover (click)=\"multiUser.popover()\" placement=\"left\">\r\n                            <span class=\"green\">+99</span>\r\n                        </div>\r\n                        <app-popover #multiUser>\r\n                            <div class=\"wf-action-list\">\r\n                                <ul class=\"action-item\">\r\n                                    <li *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\r\n                                        <div class=\"avatar-card\">\r\n                                            <div class=\"avatar\">hk</div>\r\n                                            <div *ngIf=\"false\" class=\"avatar\"><img src=\"https://s3-eu-west-1.amazonaws.com/eu.v-comply.com/profile_pic/thumb/1672222891690_ProfilePicture.png\" alt=\"\"></div>\r\n                                            <span class=\"value\" [appTooltip]=\"'Harshvardhan Kariwala'\" placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"false\">Harshvardhan Kariwala</span>\r\n                                        </div>\r\n                                    </li>\r\n                                </ul>\r\n                            </div>\r\n                        </app-popover>\r\n                    </div>\r\n                    <!-- <i class=\"icons star vx-fs-10 vx-mr-1\" [class.active]=\"true\">&#xea70;</i> -->\r\n                    <div class=\"name-inner\">\r\n                        <div class=\"vx-d-flex vx-align-center\">\r\n                            <div class=\"id vx-fs-10 vx-fw-500 vx-label-txt vx-tt-uppercase vx-mr-1\">{{list?.controlId}}</div>\r\n                            <div class=\"name vx-fs-13 vx-label-txt\" [appTooltip]=\"list?.name\" placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"false\">{{list?.name}}</div>\r\n                        </div>\r\n                        <div class=\"vx-d-flex vx-align-center\" *ngIf=\"list?.withinData?.name\">\r\n                            <div class=\"vx-fs-10 vx-fw-500 vx-label-txt vx-tt-uppercase vx-mr-1\">RESPONSIBILITY CENTER:</div>\r\n                            <div class=\"within-part vx-d-flex vx-align-center vx-pr-3\">\r\n                                <div class=\"within-box vx-fs-9 vx-fw-600 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mr-2 vx-lh-3\">Within</div>\r\n                                <div class=\"within-value vx-fs-11 vx-paragraph-txt\" [appTooltip]=\"'Management direction for information > Information Security'\" placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"false\">Management direction for information > Information Security</div>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n        <app-pagination *ngIf=\"totalPages > 1\" [start]=\"perPageLimit * (currentPage - 1) + 1\" [end]=\"perPageLimit * currentPage\" [total]=\"totalListData\" [pageCount]=\"totalPages\" [currentPage]=\"currentPage\" (selectedPage)=\"changePage($event)\"></app-pagination>\r\n    </div>\r\n</div>"]}
192
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grc-responsibility-listing.component.js","sourceRoot":"","sources":["../../../../../../../../projects/vx-workflow-engine/src/lib/workflow/shared/components/grc-responsibility-listing/grc-responsibility-listing.component.ts","../../../../../../../../projects/vx-workflow-engine/src/lib/workflow/shared/components/grc-responsibility-listing/grc-responsibility-listing.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Optional,\r\n  Output,\r\n} from '@angular/core';\r\nimport { FloatingBarModule } from '../../../../sharedComponents/floating-bar/floating-bar.module';\r\nimport { FormgroupModule } from '../../../../ui-kit/formgroup/formgroup.module';\r\nimport { PaginationModule } from '../../../../ui-kit/pagination/pagination.module';\r\nimport { PopoverModule } from '../../../../ui-kit/popover/popover.module';\r\nimport { TooltipModule } from '../../../../ui-kit/tooltip/tooltip.module';\r\nimport { Configurations } from '../../../../configurations';\r\n\r\n@Component({\r\n  selector: 'app-grc-responsibility-listing',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    PopoverModule,\r\n    FormgroupModule,\r\n    TooltipModule,\r\n    FloatingBarModule,\r\n    PaginationModule,\r\n  ],\r\n  templateUrl: './grc-responsibility-listing.component.html',\r\n  styleUrls: ['./grc-responsibility-listing.component.less'],\r\n  inputs: [\r\n    'tableCard',\r\n    'activeCategory',\r\n    'headerText',\r\n    'currentPage',\r\n    'perPageLimit',\r\n    'totalListData',\r\n    'totalPages',\r\n    'selectedListData',\r\n    'selectedListDataIds',\r\n    'selectedCatAndRisk',\r\n  ],\r\n})\r\nexport class GrcResponsibilityListingComponent implements OnInit {\r\n  profilePic = '';\r\n  env: any;\r\n  dataList: any = [];\r\n  headerText: string = 'Name';\r\n  selectedListData: any = [];\r\n  selectedListDataIds: any = [];\r\n  perPageLimit: number = 30;\r\n  currentPage: number = 1;\r\n  totalPages: number = 1;\r\n  totalListData: number = 0;\r\n  selectedCatAndRisk: any = [];\r\n  activeCategory: any = {};\r\n\r\n  @Input('dataList') set risksList(value: any) {\r\n    this.dataList = value;\r\n  }\r\n\r\n  @Input('selectedCatAndRisk') set getSelectedCatAndRisk(value: any) {\r\n    this.selectedCatAndRisk = value;\r\n    this.getSelectedDataAndIds(value);\r\n  }\r\n\r\n  @Output() getUpdatedDataList: EventEmitter<any> = new EventEmitter();\r\n  @Output() changeSelectedCatAndRisk: EventEmitter<any> = new EventEmitter();\r\n\r\n  constructor(@Optional() config?: Configurations) {\r\n    this.env = config?.envConfig;\r\n    this.profilePic = this.env.s3Url + this.env.s3Bucket + this.env.profile;\r\n  }\r\n\r\n  ngOnInit(): void {}\r\n\r\n  getSelectedData(responsibility: any, event: any) {\r\n    if (event) {\r\n      this.selectedListData.push(responsibility);\r\n      this.selectedListDataIds.push(responsibility?._id);\r\n    } else {\r\n      this.deleteEvent(responsibility);\r\n    }\r\n    this.updateOrCreateCategory(\r\n      this.activeCategory?.category_id,\r\n      this.activeCategory\r\n    );\r\n  }\r\n\r\n  deleteEvent(responsibility: any) {\r\n    this.selectedListData = this.selectedListData?.filter(\r\n      (selected: any) => selected?._id !== responsibility?._id\r\n    );\r\n    this.selectedListDataIds = this.selectedListDataIds?.filter(\r\n      (selectedListDataId: any) => selectedListDataId !== responsibility?._id\r\n    );\r\n  }\r\n\r\n  selectAll(event: any) {\r\n    this.dataList?.forEach((data: any) => {\r\n      if (event) {\r\n        if (!this.selectedListDataIds.includes(data?._id)) {\r\n          this.selectedListData.push(data);\r\n          this.selectedListDataIds.push(data?._id);\r\n        }\r\n      } else {\r\n        this.deleteEvent(data);\r\n      }\r\n    });\r\n    this.updateOrCreateCategory(\r\n      this.activeCategory?.category_id,\r\n      this.activeCategory\r\n    );\r\n  }\r\n\r\n  isAllSelected(): boolean {\r\n    if (\r\n      this.selectedListDataIds &&\r\n      this.selectedListDataIds.length >= this.selectedListData?.length &&\r\n      this.selectedListDataIds.length > 0\r\n    ) {\r\n      for (const grc of this.dataList) {\r\n        if (!this.selectedListDataIds.includes(grc?._id)) {\r\n          return false;\r\n        }\r\n      }\r\n      return true;\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  changePage(event: number) {\r\n    this.currentPage = event;\r\n    this.getUpdatedDataList.emit({\r\n      pageNo: this.currentPage,\r\n    });\r\n  }\r\n\r\n  updateOrCreateCategory(categoryId: number, category: any) {\r\n    const categoryIndex = this.findCheckedCategoryIndex(categoryId);\r\n    if (categoryIndex !== -1) {\r\n      // Category exists, update risk value\r\n      this.selectedCatAndRisk[categoryIndex].risks =\r\n        this.selectedListData ?? [];\r\n      if (this.selectedListData.length === 0) {\r\n        // Remove category if selectedListData is empty\r\n        this.selectedCatAndRisk.splice(categoryIndex, 1);\r\n      }\r\n    } else {\r\n      // Category doesn't exist, create new category with subcategory\r\n      this.selectedCatAndRisk.push({\r\n        category: category ?? {},\r\n        risks: this.selectedListData ?? [],\r\n      });\r\n    }\r\n    this.changeSelectedCatAndRisk.emit(this.selectedCatAndRisk);\r\n  }\r\n\r\n  getSelectedDataAndIds(selectedData: any) {\r\n    const categoryIndex = this.findCheckedCategoryIndex(\r\n      this.activeCategory?.category_id\r\n    );\r\n    this.selectedListData = [];\r\n    this.selectedListDataIds = [];\r\n    if (categoryIndex !== -1) {\r\n      this.selectedListData = selectedData[categoryIndex]?.risks ?? [];\r\n      this.selectedListData?.forEach((data: any) => {\r\n        this.selectedListDataIds.push(data?._id);\r\n      });\r\n    }\r\n  }\r\n\r\n  findCheckedCategoryIndex(categoryId: number) {\r\n    let categoryIndex = -1;\r\n    for (let i = 0; i < this.selectedCatAndRisk.length; i++) {\r\n      let category = this.selectedCatAndRisk[i];\r\n      let foundCategory = Object.entries(category.category).find(\r\n        ([key, value]) => {\r\n          if (key === '_id' && value === 'uncategorized') {\r\n            return true;\r\n          }\r\n          return value === categoryId;\r\n        }\r\n      );\r\n      if (foundCategory) {\r\n        categoryIndex = i;\r\n        break;\r\n      }\r\n    }\r\n    return categoryIndex;\r\n  }\r\n\r\n  deleteSelectedRisk(categoryId: number, risk: any) {\r\n    const categoryIndex = this.findCheckedCategoryIndex(categoryId);\r\n    if (categoryIndex !== -1) {\r\n      // Category exists, update risk value\r\n      const riskIndex = this.selectedCatAndRisk[\r\n        categoryIndex\r\n      ]?.risks?.findIndex((item: any) => item?._id === risk?._id);\r\n      if (riskIndex !== -1) {\r\n        this.selectedCatAndRisk[categoryIndex]?.risks.splice(riskIndex, 1);\r\n      }\r\n\r\n      if (this.selectedCatAndRisk[categoryIndex]?.risks?.length === 0) {\r\n        // Remove category if selectedListData is empty\r\n        this.selectedCatAndRisk.splice(categoryIndex, 1);\r\n      }\r\n    }\r\n    this.changeSelectedCatAndRisk.emit(this.selectedCatAndRisk);\r\n  }\r\n}\r\n","<div class=\"grc-responsibility-listing\">\r\n    <div class=\"top-heading vx-pl-2 vx-mb-2 vx-d-flex vx-align-center\">\r\n        <app-cs-checkbox *ngIf=\"isAllSelected() || selectedListDataIds?.length === 0\"  [ngValue]=\"isAllSelected()\" (ngValueChange)=\"selectAll($event)\"></app-cs-checkbox>\r\n        <app-cs-checkbox-indeterminate *ngIf=\"!isAllSelected() && selectedListDataIds?.length\" [ngValue]=\"true\" (ngValueChange)=\"selectAll(false)\"></app-cs-checkbox-indeterminate>\r\n        <div class=\"vx-fs-11 vx-fw-500 vx-label-txt vx-tt-uppercase vx-ml-2 vx-lh-4\">{{headerText}}</div>\r\n    </div>\r\n    <div class=\"grc-responsibility-listing-inner\">\r\n        <div class=\"grc-responsibility-table-body\" [class.with-pagination]=\"totalPages > 1\">\r\n            <div class=\"grc-responsibility-table-row\" *ngFor=\"let list of dataList; let i = index\" [class.active]=\"selectedListDataIds?.includes(list?._id)\">\r\n                <div class=\"grc-responsibility-table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\">\r\n                    <div class=\"sr-no\" [appTooltip]=\"(perPageLimit * (currentPage - 1)) + i + 1\" placement=\"bottom\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">{{(perPageLimit * (currentPage - 1)) + i + 1}}</div>\r\n                    <app-cs-checkbox [ngValue]=\"selectedListDataIds?.includes(list?._id)\" (ngValueChange)=\"getSelectedData(list,$event)\"></app-cs-checkbox>\r\n                </div>\r\n                <div class=\"grc-responsibility-table-column vx-pr-1 vx-d-flex vx-align-center responsibility-name\">\r\n                    <div class=\"vx-avatar-group vx-mr-1\">\r\n                        <div class=\"vx-avatar md\" [appTooltip]=\"list?.entrustedBy?.name\" placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">\r\n                            <span *ngIf=\"list?.entrustedBy?.profilePic?.length === ''\" class=\"blue\">{{list.entrustedBy?.shortName}}</span>\r\n                            <img *ngIf=\"list?.entrustedBy?.profilePic?.length !== ''\" src=\"{{profilePic + list?.entrustedBy?.profilePic}}\" alt=\"\">\r\n                        </div>\r\n                        <div *ngIf=\"false\" class=\"vx-avatar md\" [appTooltip]=\"'Harshvardhan Kariwala'\" placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"true\">\r\n                            <span class=\"blue\">hk</span>\r\n                            <img *ngIf=\"false\" src=\"https://s3-eu-west-1.amazonaws.com/eu.v-comply.com/profile_pic/thumb/1672222891690_ProfilePicture.png\" alt=\"\">\r\n                        </div>\r\n                        <div *ngIf=\"false\" class=\"vx-avatar md counter\" appPopover (click)=\"multiUser.popover()\" placement=\"left\">\r\n                            <span class=\"green\">+99</span>\r\n                        </div>\r\n                        <app-popover #multiUser>\r\n                            <div class=\"wf-action-list\">\r\n                                <ul class=\"action-item\">\r\n                                    <li *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\r\n                                        <div class=\"avatar-card\">\r\n                                            <div class=\"avatar\">hk</div>\r\n                                            <div *ngIf=\"false\" class=\"avatar\"><img src=\"https://s3-eu-west-1.amazonaws.com/eu.v-comply.com/profile_pic/thumb/1672222891690_ProfilePicture.png\" alt=\"\"></div>\r\n                                            <span class=\"value\" [appTooltip]=\"'Harshvardhan Kariwala'\" placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"false\">Harshvardhan Kariwala</span>\r\n                                        </div>\r\n                                    </li>\r\n                                </ul>\r\n                            </div>\r\n                        </app-popover>\r\n                    </div>\r\n                    <!-- <i class=\"icons star vx-fs-10 vx-mr-1\" [class.active]=\"true\">&#xea70;</i> -->\r\n                    <div class=\"name-inner\">\r\n                        <div class=\"vx-d-flex vx-align-center\">\r\n                            <div class=\"id vx-fs-10 vx-fw-500 vx-label-txt vx-tt-uppercase vx-mr-1\">{{list?.controlId}}</div>\r\n                            <div class=\"name vx-fs-13 vx-label-txt\" [appTooltip]=\"list?.name\" placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"false\">{{list?.name}}</div>\r\n                        </div>\r\n                        <div class=\"vx-d-flex vx-align-center\" *ngIf=\"list?.withinData?.name\">\r\n                            <div class=\"vx-fs-10 vx-fw-500 vx-label-txt vx-tt-uppercase vx-mr-1\">RESPONSIBILITY CENTER:</div>\r\n                            <div class=\"within-part vx-d-flex vx-align-center vx-pr-3\">\r\n                                <div class=\"within-box vx-fs-9 vx-fw-600 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mr-2 vx-lh-3\">Within</div>\r\n                                <div class=\"within-value vx-fs-11 vx-paragraph-txt\" [appTooltip]=\"'Management direction for information > Information Security'\" placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"false\">Management direction for information > Information Security</div>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n        <app-pagination *ngIf=\"totalPages > 1\" [start]=\"perPageLimit * (currentPage - 1) + 1\" [end]=\"perPageLimit * currentPage\" [total]=\"totalListData\" [pageCount]=\"totalPages\" [currentPage]=\"currentPage\" (selectedPage)=\"changePage($event)\"></app-pagination>\r\n    </div>\r\n</div>"]}