vcomply-workflow-engine 3.2.2 → 3.2.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (38) hide show
  1. package/esm2020/lib/more-option/more-option.component.mjs +10 -11
  2. package/esm2020/lib/workflow/grc-object/grc-object-container/grc-object-container.component.mjs +78 -6
  3. package/esm2020/lib/workflow/shared/components/attributes/attributes-text-box/attributes-text-box.component.mjs +1 -1
  4. package/esm2020/lib/workflow/shared/components/attributes/attributes.component.mjs +1 -1
  5. package/esm2020/lib/workflow/shared/components/edit-mode/edit-mode.component.mjs +32 -10
  6. package/esm2020/lib/workflow/shared/components/grc-category-listing/grc-category-listing.component.mjs +18 -3
  7. package/esm2020/lib/workflow/shared/components/grc-responsibility-listing/grc-responsibility-listing.component.mjs +62 -60
  8. package/esm2020/lib/workflow/shared/components/grc-risk-listing/grc-risk-listing.component.mjs +191 -0
  9. package/esm2020/lib/workflow/shared/components/grc-sub-category-listing/grc-sub-category-listing.component.mjs +77 -11
  10. package/esm2020/lib/workflow/shared/components/list-popup/list-popup.component.mjs +24 -2
  11. package/esm2020/lib/workflow/shared/components/program-responsibility-listing/program-responsibility-listing.component.mjs +393 -0
  12. package/esm2020/lib/workflow/shared/components/risk-category-risk-listing/risk-category-risk-listing.component.mjs +5 -5
  13. package/esm2020/lib/workflow/shared/constants/field-text.constant.mjs +3 -1
  14. package/esm2020/lib/workflow/shared/constants/link-responsibility.constant.mjs +19 -0
  15. package/esm2020/lib/workflow/shared/interfaces/add-grc.mjs +1 -1
  16. package/esm2020/lib/workflow/shared/services/grc.service.mjs +83 -1
  17. package/esm2020/lib/workflow-engine.module.mjs +2 -5
  18. package/esm2020/lib/workflow-grc/workflow-grc.component.mjs +2 -2
  19. package/esm2020/lib/workflow-policy/workflow-policy.component.mjs +2 -2
  20. package/fesm2015/vcomply-workflow-engine.mjs +910 -57
  21. package/fesm2015/vcomply-workflow-engine.mjs.map +1 -1
  22. package/fesm2020/vcomply-workflow-engine.mjs +894 -55
  23. package/fesm2020/vcomply-workflow-engine.mjs.map +1 -1
  24. package/lib/workflow/grc-object/grc-object-container/grc-object-container.component.d.ts +8 -1
  25. package/lib/workflow/shared/components/attributes/attributes-text-box/attributes-text-box.component.d.ts +2 -0
  26. package/lib/workflow/shared/components/edit-mode/edit-mode.component.d.ts +2 -1
  27. package/lib/workflow/shared/components/grc-category-listing/grc-category-listing.component.d.ts +5 -1
  28. package/lib/workflow/shared/components/grc-responsibility-listing/grc-responsibility-listing.component.d.ts +11 -9
  29. package/lib/workflow/shared/components/grc-risk-listing/grc-risk-listing.component.d.ts +35 -0
  30. package/lib/workflow/shared/components/grc-sub-category-listing/grc-sub-category-listing.component.d.ts +17 -2
  31. package/lib/workflow/shared/components/program-responsibility-listing/program-responsibility-listing.component.d.ts +76 -0
  32. package/lib/workflow/shared/components/risk-category-risk-listing/risk-category-risk-listing.component.d.ts +2 -2
  33. package/lib/workflow/shared/constants/field-text.constant.d.ts +2 -0
  34. package/lib/workflow/shared/constants/link-responsibility.constant.d.ts +7 -0
  35. package/lib/workflow/shared/interfaces/add-grc.d.ts +3 -1
  36. package/lib/workflow/shared/services/grc.service.d.ts +10 -0
  37. package/lib/workflow-engine.module.d.ts +32 -33
  38. package/package.json +1 -1
@@ -0,0 +1,393 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { Component, EventEmitter, Input, ViewChild, } from '@angular/core';
3
+ import { FloatingBarModule } from '../../../../sharedComponents/floating-bar/floating-bar.module';
4
+ import { FormgroupModule } from '../../../../ui-kit/formgroup/formgroup.module';
5
+ import { PaginationModule } from '../../../../ui-kit/pagination/pagination.module';
6
+ import { PopoverModule } from '../../../../ui-kit/popover/popover.module';
7
+ import { TooltipModule } from '../../../../ui-kit/tooltip/tooltip.module';
8
+ import { TableCardComponent } from '../table-card/table-card.component';
9
+ import { GrcCategoryListingComponent } from '../grc-category-listing/grc-category-listing.component';
10
+ import { GrcResponsibilityListingComponent } from '../grc-responsibility-listing/grc-responsibility-listing.component';
11
+ import { NoDataModule } from '../../../../ui-kit/no-data/no-data.module';
12
+ import { ListLoaderModule } from '../../../../sharedComponents/list-loader/list-loader.module';
13
+ import { GrcSubCategoryListingComponent } from '../grc-sub-category-listing/grc-sub-category-listing.component';
14
+ import { RESPONSIBILITY_TABLE_CARD } from '../../constants/link-responsibility.constant';
15
+ import { TableCardLoaderComponent } from '../../../../sharedComponents/table-card-loader/table-card-loader.component';
16
+ import { HttpParams } from '@angular/common/http';
17
+ import { LINKS } from '../../constants/cdn-link.constant';
18
+ import * as i0 from "@angular/core";
19
+ import * as i1 from "../../services/grc.service";
20
+ import * as i2 from "@angular/common";
21
+ import * as i3 from "../../../../sharedComponents/floating-bar/floating-bar.component";
22
+ import * as i4 from "../../../../sharedComponents/list-loader/list-loader.component";
23
+ import * as i5 from "../../../../ui-kit/no-data/no-data.component";
24
+ export class ProgramResponsibilityListingComponent {
25
+ constructor(grcService) {
26
+ this.grcService = grcService;
27
+ this.programTypes = RESPONSIBILITY_TABLE_CARD;
28
+ this.CDN_LINK = LINKS;
29
+ this.selectedTab = 1;
30
+ this.animation = false;
31
+ this.programLoader = false;
32
+ this.programCountLoader = false;
33
+ this.responsibilityLoader = false;
34
+ this.categoryLoader = false;
35
+ this.selectedProgramAndResp = [];
36
+ this.preSelectedProgramAndResp = [];
37
+ this.searchString = '';
38
+ this.programCurrentPage = 1;
39
+ this.categoryCurrentPage = 1;
40
+ this.responsibilityCurrentPage = 1;
41
+ this.responsibilityData = {
42
+ data: [],
43
+ };
44
+ this.selectedProgramIds = [];
45
+ this.selectedCategoryIds = [];
46
+ this.selectedResponsibilities = [];
47
+ this.closeList = new EventEmitter();
48
+ this.currentBusinessCycle = this.grcService?.getBusinessCycle();
49
+ }
50
+ set getSelectedProgramAndResp(data) {
51
+ this.selectedProgramAndResp = data || [];
52
+ this.preSelectedProgramAndResp = JSON.parse(JSON.stringify(data));
53
+ this.getSelectedProgramIds(this.selectedProgramAndResp);
54
+ this.getAllSelectedResponsibilities(this.selectedProgramAndResp);
55
+ }
56
+ ngOnInit() {
57
+ this.animation = true;
58
+ setTimeout(() => {
59
+ this.animation = false;
60
+ }, 300);
61
+ this.getProgramsList();
62
+ this.getProgramsCount();
63
+ }
64
+ close() {
65
+ this.closeList.emit(this.preSelectedProgramAndResp);
66
+ }
67
+ save() {
68
+ this.closeList.emit(this.selectedProgramAndResp);
69
+ }
70
+ getProgramsList(event) {
71
+ if (this.programCall) {
72
+ this.programCall.unsubscribe();
73
+ }
74
+ this.programLoader = true;
75
+ const request = {
76
+ headers: {
77
+ type: '',
78
+ paginationType: 'small',
79
+ a: '',
80
+ searchText: this.searchString,
81
+ filterData: {
82
+ appList: [],
83
+ riskIds: [],
84
+ reviewerId: [],
85
+ responsibilityCenter: [],
86
+ entrustedBy: [],
87
+ entrustedTo: [],
88
+ responsibilityCategory: [],
89
+ },
90
+ pageNo: this.programCurrentPage || 1,
91
+ sortObj: { sortBy: '', type: -1 },
92
+ pageName: 'category',
93
+ typeArr: [this.selectedTab],
94
+ start_date: this.currentBusinessCycle?.start_date,
95
+ end_date: this.currentBusinessCycle?.end_date,
96
+ selected_cycle_arr: this.currentBusinessCycle?.selected_cycle_arr,
97
+ selected_cycle: this.currentBusinessCycle?.selected_cycle,
98
+ time_filter_type: '',
99
+ state: [2, 3],
100
+ },
101
+ };
102
+ this.programCall = this.grcService.getProgramsList(request).subscribe({
103
+ next: (res) => {
104
+ this.programLoader = false;
105
+ // this.programData.data = res.data ?? [];
106
+ this.programData = { ...res };
107
+ this.onSelectedProgramChange();
108
+ this.getCategoryByProgramId(res?.data[0]);
109
+ },
110
+ error: (err) => {
111
+ this.programLoader = false;
112
+ },
113
+ });
114
+ }
115
+ onProgramPageChange(event) {
116
+ this.programCurrentPage = event?.pageNo || 1;
117
+ this.getProgramsList();
118
+ }
119
+ onSubCategoryPageChange(event) {
120
+ this.categoryCurrentPage = event?.pageNo || 1;
121
+ this.getCategoryByProgramId(this.selectedProgram);
122
+ }
123
+ deleteEvent(event) {
124
+ this.responsibilityListingComponent.deleteSelectedResponsibility(event);
125
+ }
126
+ setSelectedTab(event) {
127
+ this.programCurrentPage = 1;
128
+ this.selectedTab = event?.type;
129
+ this.getProgramsList();
130
+ }
131
+ handleSearch(event) {
132
+ if (this.searchString != event) {
133
+ this.programCurrentPage = 1;
134
+ this.searchString = event;
135
+ this.onSelectedProgramChange();
136
+ this.getProgramsList();
137
+ this.getProgramsCount();
138
+ }
139
+ }
140
+ getProgramsCount(paramsObject) {
141
+ this.programCountLoader = true;
142
+ const request = {
143
+ headers: {
144
+ type: '',
145
+ paginationType: 'small',
146
+ a: '',
147
+ searchText: this.searchString,
148
+ filterData: {
149
+ appList: [],
150
+ riskIds: [],
151
+ reviewerId: [],
152
+ responsibilityCenter: [],
153
+ entrustedBy: [],
154
+ entrustedTo: [],
155
+ responsibilityCategory: [],
156
+ },
157
+ pageNo: 1,
158
+ sortObj: { sortBy: '', type: '' },
159
+ pageName: 'category',
160
+ typeArr: [1, 2, 3, 0],
161
+ start_date: this.currentBusinessCycle?.start_date,
162
+ end_date: this.currentBusinessCycle?.end_date,
163
+ selected_cycle_arr: this.currentBusinessCycle?.selected_cycle_arr,
164
+ selected_cycle: this.currentBusinessCycle?.selected_cycle,
165
+ time_filter_type: '',
166
+ state: [2, 3],
167
+ },
168
+ };
169
+ this.grcService.getProgramsListCount(request).subscribe({
170
+ next: (res) => {
171
+ this.programCountLoader = false;
172
+ this.programTypes[0].count =
173
+ res?.regulationCount?.active + res?.regulationCount?.completed;
174
+ this.programTypes[1].count =
175
+ res?.standardCount?.active + res?.standardCount?.completed;
176
+ this.programTypes[2].count =
177
+ res?.internalCount?.active + res?.internalCount?.completed;
178
+ this.programTypes[3].count =
179
+ res?.otherCount?.active + res?.otherCount?.completed;
180
+ // }
181
+ },
182
+ });
183
+ }
184
+ getCategoryByProgramId(program) {
185
+ if (this.categoryCall) {
186
+ this.categoryCall.unsubscribe();
187
+ }
188
+ this.selectedProgram = program;
189
+ this.categoryLoader = true;
190
+ // this.resetControlVariable();
191
+ const headers = {
192
+ id: program?._id,
193
+ scopeType: 'risk',
194
+ paginationType: 'small',
195
+ searchText: this.searchString,
196
+ filterData: {
197
+ appList: [],
198
+ riskIds: [],
199
+ reviewerId: [],
200
+ responsibilityCenter: [],
201
+ entrustedBy: [],
202
+ entrustedTo: [],
203
+ responsibilityCategory: [],
204
+ },
205
+ page: this.categoryCurrentPage || 1,
206
+ // sortingCount: this.categorySortValue,
207
+ name: 'name',
208
+ businessCycle: {
209
+ start_date: this.currentBusinessCycle?.start_date,
210
+ end_date: this.currentBusinessCycle?.end_date,
211
+ selected_cycle_arr: this.currentBusinessCycle?.selected_cycle_arr,
212
+ selected_cycle: this.currentBusinessCycle?.selected_cycle,
213
+ time_filter_type: '',
214
+ // "scopeType": 'risk',
215
+ type: 'risk',
216
+ filterData: {
217
+ appList: [],
218
+ riskIds: [],
219
+ reviewerId: [],
220
+ responsibilityCenter: [],
221
+ entrustedBy: [],
222
+ entrustedTo: [],
223
+ responsibilityCategory: [],
224
+ },
225
+ },
226
+ };
227
+ this.categoryCall = this.grcService.getSubCategoryList(headers).subscribe({
228
+ next: (res) => {
229
+ this.categoryLoader = false;
230
+ this.categoryData = { ...res };
231
+ this.selectedCategory = res?.data[0];
232
+ this.responsibilityCurrentPage = 1;
233
+ this.getResponsibilitiesList();
234
+ },
235
+ error: (err) => {
236
+ console.error(err);
237
+ this.categoryLoader = false;
238
+ },
239
+ });
240
+ }
241
+ activeSelectedProgram(event) {
242
+ this.selectedProgram = event?.category;
243
+ this.onSelectedProgramChange();
244
+ this.getCategoryByProgramId(this.selectedProgram);
245
+ // this.getSelectedCategoryIds(this.selectedProgramAndResp);
246
+ }
247
+ activeSelectedSubCategory(event) {
248
+ this.selectedCategory = event?.category;
249
+ this.getResponsibilitiesList();
250
+ }
251
+ getResponsibilitiesList(event) {
252
+ if (this.responsibilityCall) {
253
+ this.responsibilityCall.unsubscribe();
254
+ }
255
+ // this.respCount = event.sortValue;
256
+ this.responsibilityLoader = true;
257
+ let params = new HttpParams();
258
+ params = params.append('isBusinessCycle', 'true');
259
+ params = params.append('parentId', this.selectedProgram?.category_id);
260
+ params = params.append('catId', this.selectedCategory?.category_id);
261
+ params = params.append('pageNo', this.responsibilityCurrentPage ?? 1);
262
+ // if ([1, -1].includes(this.controlSortValue)) {
263
+ // params = params.append('sortValue', this.controlSortValue);
264
+ // params = params.append('sortBy', 'Data.ReportName');
265
+ // }
266
+ params = params.append('paginationType', 'small');
267
+ params = params.append('pageType', 'risk');
268
+ let businessCycle = {
269
+ start_date: this.currentBusinessCycle?.start_date,
270
+ end_date: this.currentBusinessCycle?.end_date,
271
+ selected_cycle_arr: this.currentBusinessCycle?.selected_cycle_arr,
272
+ selected_cycle: this.currentBusinessCycle?.selected_cycle,
273
+ time_filter_type: '',
274
+ pageType: 'risk',
275
+ filterData: {
276
+ appList: [],
277
+ riskIds: [],
278
+ reviewerId: [],
279
+ responsibilityCenter: [],
280
+ entrustedBy: [],
281
+ entrustedTo: [],
282
+ responsibilityCategory: [],
283
+ },
284
+ };
285
+ this.responsibilityCall = this.grcService
286
+ .getResponsibilityByCategoryId(params, businessCycle)
287
+ .subscribe({
288
+ next: (res) => {
289
+ this.categoryLoader = false;
290
+ this.responsibilityData = res;
291
+ this.responsibilityData['data'] = this.setDataListStructure(res?.data);
292
+ this.responsibilityLoader = false;
293
+ },
294
+ error: (err) => {
295
+ this.responsibilityLoader = false;
296
+ },
297
+ });
298
+ }
299
+ getUpdatedDataList(event) {
300
+ this.responsibilityCurrentPage = event?.pageNo;
301
+ this.getResponsibilitiesList();
302
+ }
303
+ setDataListStructure(res) {
304
+ const data = res?.map((responsibility) => {
305
+ return {
306
+ ...responsibility,
307
+ name: responsibility?.ReportName,
308
+ controlId: responsibility?.ControlId,
309
+ _id: responsibility?.EncryptedReportId,
310
+ entrustedBy: {
311
+ name: responsibility?.AssignBy,
312
+ email: responsibility?.AssignByEmail,
313
+ profilePic: responsibility?.member_pic ?? '',
314
+ shortName: responsibility?.member_short_name,
315
+ },
316
+ entrustedTo: {
317
+ name: responsibility?.AssignTo,
318
+ email: responsibility?.AssignTo,
319
+ profilePic: responsibility?.employee_pic ?? '',
320
+ shortName: responsibility?.employee_short_name,
321
+ EntrustedToMembers: responsibility?.EntrustedToMembers,
322
+ },
323
+ withinData: responsibility?.RC_details_array?.map((within) => {
324
+ return {
325
+ name: within?.rc_name,
326
+ };
327
+ }),
328
+ };
329
+ });
330
+ return data;
331
+ }
332
+ onSelectedProgramChange() {
333
+ this.categoryCurrentPage = 1;
334
+ this.responsibilityCurrentPage = 1;
335
+ }
336
+ changeSelectedProgramAndResp(event) {
337
+ this.selectedProgramAndResp = event;
338
+ this.getSelectedProgramIds(this.selectedProgramAndResp);
339
+ this.getAllSelectedResponsibilities(this.selectedProgramAndResp);
340
+ // this.getSelectedCategoryIds(this.selectedProgramAndResp);
341
+ }
342
+ getSelectedProgramIds(selectedData) {
343
+ this.selectedProgramIds = [];
344
+ selectedData?.forEach((selected) => {
345
+ this.selectedCategoryIds = selected?.category;
346
+ this.selectedProgramIds.push(selected?.program?.programId);
347
+ });
348
+ }
349
+ getSelectedCategoryIds(selectedData) {
350
+ this.selectedCategoryIds = [];
351
+ let programIndex = -1;
352
+ programIndex = selectedData.findIndex((cat) => cat?.program?.programId === this.selectedProgram?.programId);
353
+ if (programIndex !== -1) {
354
+ this.selectedCategoryIds = selectedData[programIndex]?.category;
355
+ }
356
+ else {
357
+ this.selectedCategoryIds = [];
358
+ }
359
+ }
360
+ getAllSelectedResponsibilities(selectedData) {
361
+ this.selectedResponsibilities = [];
362
+ selectedData.forEach((item) => {
363
+ this.selectedResponsibilities.push(...item?.responsibility);
364
+ });
365
+ }
366
+ }
367
+ ProgramResponsibilityListingComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ProgramResponsibilityListingComponent, deps: [{ token: i1.GrcService }], target: i0.ɵɵFactoryTarget.Component });
368
+ ProgramResponsibilityListingComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ProgramResponsibilityListingComponent, isStandalone: true, selector: "app-program-responsibility-listing", inputs: { getSelectedProgramAndResp: ["selectedProgramAndResp", "getSelectedProgramAndResp"] }, outputs: { closeList: "closeList" }, viewQueries: [{ propertyName: "responsibilityListingComponent", first: true, predicate: ["dataListing"], descendants: true }], ngImport: i0, template: "<div class=\"program-responsibility-listing\" [class.animate]=\"animation\">\r\n <div class=\"program-responsibility-listing-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\">\r\n <h3 class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Select Responsibilities</h3></div>\r\n <div class=\"program-responsibility-listing-body\">\r\n <app-table-card-loader *ngIf=\"programCountLoader\"></app-table-card-loader>\r\n <app-table-card\r\n *ngIf=\"!programCountLoader\"\r\n class=\"vx-w-100\"\r\n [tableCard]=\"programTypes\"\r\n [singleSelectedText]=\"'Responsibility Selected'\"\r\n [selectedTab]=\"selectedTab\"\r\n [multipleSelectedText]=\"'Responsibilities Selected'\"\r\n (setSelectedTab)=\"setSelectedTab($event)\">\r\n </app-table-card>\r\n <div class=\"search-block vx-mb-2\">\r\n <i class=\"icons\">&#xe90b;</i>\r\n <input type=\"text\" #searchRiskCategory (keyup.enter)=\"handleSearch($event.target.value)\" placeholder=\"Search Programs\" />\r\n </div>\r\n <div class=\"program-responsibility-listing-body-inner vx-mb-2 vx-d-flex\" [class.vx-justify-center]=\"(!programLoader && !programData?.data?.length)\">\r\n <ng-container *ngIf=\"(programLoader || programData?.data?.length)\">\r\n <div class=\"inner-item-left vx-pr-2\">\r\n\r\n <app-grc-category-listing *ngIf=\"!programLoader\" [headerText]=\"'Programs'\" [programData]=\"programData\" [selectedCatAndRisk]=\"selectedCatAndRisk\" [nameDisplayKey]=\"'item_name'\" [currentPage]=\"programCurrentPage\" [selectedTabIndex]=\"selectedTab\" [selectedCategoryIds]=\"selectedProgramIds\" (activeSelectedCategory)=\"activeSelectedProgram($event)\" (onCategoryPageChange)=\"onProgramPageChange($event)\"></app-grc-category-listing>\r\n \r\n <app-list-loader *ngIf=\"programLoader\"></app-list-loader>\r\n\r\n </div>\r\n\r\n <div class=\"inner-item-mid vx-pr-2\">\r\n <app-grc-sub-category-listing *ngIf=\"!categoryLoader && !programLoader\" [headerText]=\"'Programs'\" [categories]=\"categoryData\" [nameDisplayKey]=\"'item_name'\" [currentPage]=\"categoryCurrentPage\" [selectedCategoryIds]=\"selectedCategoryIds\" [activeProgram]=\"selectedProgram\" [selectedProgramAndResp]=\"selectedProgramAndResp\" (activeSelectedCategory)=\"activeSelectedSubCategory($event)\" (onCategoryPageChange)=\"onSubCategoryPageChange($event)\"></app-grc-sub-category-listing>\r\n <app-list-loader *ngIf=\"categoryLoader || programLoader\"></app-list-loader>\r\n </div>\r\n\r\n <div class=\"inner-item-right\">\r\n <!-- <app-grc-responsibility-listing></app-grc-responsibility-listing> -->\r\n\r\n <app-grc-responsibility-listing #dataListing *ngIf=\"!responsibilityLoader && !categoryLoader && !programLoader && responsibilityData?.data?.length !== 0\" [headerText]=\"'Responsibilities'\" [responsibilityData]=\"responsibilityData\" [activeProgram]=\"selectedProgram\" [activeCategory]=\"selectedCategory\" [selectedProgramAndResp]=\"selectedProgramAndResp\" (changeSelectedProgramAndResp)=\"changeSelectedProgramAndResp($event)\" [currentPage]=\"responsibilityCurrentPage\" [perPageLimit]=\"30\" [totalListData]=\"responsibilityData?.total_items\" [totalPages]=\"responsibilityData?.total_pages\" (getUpdatedDataList)=\"getUpdatedDataList($event)\" ></app-grc-responsibility-listing>\r\n \r\n <app-list-loader *ngIf=\"responsibilityLoader || categoryLoader || programLoader\"></app-list-loader>\r\n \r\n <app-no-data *ngIf=\"responsibilityData?.data?.length === 0 && !(responsibilityLoader || categoryLoader || programLoader)\" [noDataImage]=\"CDN_LINK?.noData\" [noDataText]=\"'No data to display'\"></app-no-data>\r\n </div>\r\n </ng-container>\r\n <app-no-data *ngIf=\"(!programLoader && !programData?.data?.length)\" [noDataImage]=\"CDN_LINK?.noData\" [noDataText]=\"'No data to display'\"></app-no-data>\r\n </div>\r\n <app-floating-bar [selectedData]=\"selectedResponsibilities?.length ? selectedResponsibilities : []\" (closeList)=\"close()\" (closeEvent)=\"save()\" [displayElementKey]=\"'ReportName'\" [singularText]=\"'Responsibility selected'\" [pluralText]=\"'Responsibilities selected'\" (deleteEvent)=\"deleteEvent($event)\"></app-floating-bar>\r\n </div>\r\n</div>", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";::ng-deep .program-responsibility-listing{position:fixed;inset:0 30px 0 0}::ng-deep .program-responsibility-listing:before{background:#1E5DD3;content:\"\";position:absolute;top:0;left:0;right:0;width:100%;height:3px}::ng-deep .program-responsibility-listing.animate{animation:animate-right .2s cubic-bezier(.25,.46,.45,.94) both;z-index:-1}::ng-deep .program-responsibility-listing-head{background:#fbfbfb;height:2.75rem;border-bottom:1px solid #f1f1f1}::ng-deep .program-responsibility-listing-body{background:#fff;height:calc(100vh - 2.75rem);padding:2rem}::ng-deep .program-responsibility-listing-body .search-block{position:relative}::ng-deep .program-responsibility-listing-body .search-block input{height:2.75rem;line-height:1.5rem;padding:.5rem 1rem .5rem 2.5rem;outline:none;border:1px solid #7475763f;border-radius:.25rem;width:100%;font-size:14px;color:#747576}::ng-deep .program-responsibility-listing-body .search-block input:focus{border-color:#1e5dd3}::ng-deep .program-responsibility-listing-body .search-block input::placeholder{color:#747576}::ng-deep .program-responsibility-listing-body .search-block i{position:absolute;left:1rem;font-size:12px;font-weight:400;top:1rem;pointer-events:none;color:#f1f1f1}::ng-deep .program-responsibility-listing-body-inner{height:calc(100vh - 17.5rem)}::ng-deep .program-responsibility-listing-body-inner .inner-item-left{width:25%}::ng-deep .program-responsibility-listing-body-inner .inner-item-mid{width:25%}::ng-deep .program-responsibility-listing-body-inner .inner-item-right{width:50%}@keyframes animate-right{0%{transform:translate(100%)}to{transform:translate(0)}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: PopoverModule }, { kind: "ngmodule", type: FormgroupModule }, { kind: "ngmodule", type: TooltipModule }, { kind: "ngmodule", type: FloatingBarModule }, { kind: "component", type: i3.FloatingBarComponent, selector: "app-floating-bar", inputs: ["selectedData", "selectedGroups", "displayElementKey", "elementId", "singularText", "pluralText", "showNextButton", "showFrequencyText", "showWorkflow", "workflowText", "currentFrequency", "isDisabled", "workflowList", "selectedWorkflow", "workflowPlaceHolder", "mode", "defaultSelected", "groupsEnabled", "nonRemovableUsersList", "removePosition"], outputs: ["closeEvent", "deleteEvent", "closeList", "deleteGroupEvent", "workflowTypeChanged"] }, { kind: "ngmodule", type: PaginationModule }, { kind: "component", type: TableCardComponent, selector: "app-table-card", inputs: ["singleSelectedText", "multipleSelectedText", "selectedTab", "tableCard"], outputs: ["setSelectedTab"] }, { kind: "component", type: GrcCategoryListingComponent, selector: "app-grc-category-listing", inputs: ["tableCard", "headerText", "currentPage", "selectedTabIndex", "selectedCatAndRisk", "selectedCategoryIds", "categories", "programData"], outputs: ["activeSelectedCategory", "onCategoryPageChange"] }, { kind: "component", type: GrcResponsibilityListingComponent, selector: "app-grc-responsibility-listing", inputs: ["tableCard", "activeProgram", "headerText", "currentPage", "perPageLimit", "totalListData", "totalPages", "selectedListData", "selectedListDataIds", "responsibilityData", "selectedProgramAndResp"], outputs: ["getUpdatedDataList", "changeSelectedProgramAndResp"] }, { kind: "component", type: GrcSubCategoryListingComponent, selector: "app-grc-sub-category-listing", inputs: ["currentPage", "nameDisplayKey", "selectedCategoryIds", "activeProgram", "categories", "selectedProgramAndResp"], outputs: ["activeSelectedCategory", "onCategoryPageChange"] }, { kind: "ngmodule", type: ListLoaderModule }, { kind: "component", type: i4.ListLoaderComponent, selector: "app-list-loader" }, { kind: "ngmodule", type: NoDataModule }, { kind: "component", type: i5.NoDataComponent, selector: "app-no-data", inputs: ["action", "secondaryAction", "noDataImage", "noDataText", "noDataButton", "secondaryButton", "noDataSecButton", "altText", "smallButton"], outputs: ["buttonAction", "secondaryActionButton"] }, { kind: "component", type: TableCardLoaderComponent, selector: "app-table-card-loader" }] });
369
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ProgramResponsibilityListingComponent, decorators: [{
370
+ type: Component,
371
+ args: [{ selector: 'app-program-responsibility-listing', standalone: true, imports: [
372
+ CommonModule,
373
+ PopoverModule,
374
+ FormgroupModule,
375
+ TooltipModule,
376
+ FloatingBarModule,
377
+ PaginationModule,
378
+ TableCardComponent,
379
+ GrcCategoryListingComponent,
380
+ GrcResponsibilityListingComponent,
381
+ GrcSubCategoryListingComponent,
382
+ ListLoaderModule,
383
+ NoDataModule,
384
+ TableCardLoaderComponent,
385
+ ], outputs: ['closeList'], template: "<div class=\"program-responsibility-listing\" [class.animate]=\"animation\">\r\n <div class=\"program-responsibility-listing-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\">\r\n <h3 class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Select Responsibilities</h3></div>\r\n <div class=\"program-responsibility-listing-body\">\r\n <app-table-card-loader *ngIf=\"programCountLoader\"></app-table-card-loader>\r\n <app-table-card\r\n *ngIf=\"!programCountLoader\"\r\n class=\"vx-w-100\"\r\n [tableCard]=\"programTypes\"\r\n [singleSelectedText]=\"'Responsibility Selected'\"\r\n [selectedTab]=\"selectedTab\"\r\n [multipleSelectedText]=\"'Responsibilities Selected'\"\r\n (setSelectedTab)=\"setSelectedTab($event)\">\r\n </app-table-card>\r\n <div class=\"search-block vx-mb-2\">\r\n <i class=\"icons\">&#xe90b;</i>\r\n <input type=\"text\" #searchRiskCategory (keyup.enter)=\"handleSearch($event.target.value)\" placeholder=\"Search Programs\" />\r\n </div>\r\n <div class=\"program-responsibility-listing-body-inner vx-mb-2 vx-d-flex\" [class.vx-justify-center]=\"(!programLoader && !programData?.data?.length)\">\r\n <ng-container *ngIf=\"(programLoader || programData?.data?.length)\">\r\n <div class=\"inner-item-left vx-pr-2\">\r\n\r\n <app-grc-category-listing *ngIf=\"!programLoader\" [headerText]=\"'Programs'\" [programData]=\"programData\" [selectedCatAndRisk]=\"selectedCatAndRisk\" [nameDisplayKey]=\"'item_name'\" [currentPage]=\"programCurrentPage\" [selectedTabIndex]=\"selectedTab\" [selectedCategoryIds]=\"selectedProgramIds\" (activeSelectedCategory)=\"activeSelectedProgram($event)\" (onCategoryPageChange)=\"onProgramPageChange($event)\"></app-grc-category-listing>\r\n \r\n <app-list-loader *ngIf=\"programLoader\"></app-list-loader>\r\n\r\n </div>\r\n\r\n <div class=\"inner-item-mid vx-pr-2\">\r\n <app-grc-sub-category-listing *ngIf=\"!categoryLoader && !programLoader\" [headerText]=\"'Programs'\" [categories]=\"categoryData\" [nameDisplayKey]=\"'item_name'\" [currentPage]=\"categoryCurrentPage\" [selectedCategoryIds]=\"selectedCategoryIds\" [activeProgram]=\"selectedProgram\" [selectedProgramAndResp]=\"selectedProgramAndResp\" (activeSelectedCategory)=\"activeSelectedSubCategory($event)\" (onCategoryPageChange)=\"onSubCategoryPageChange($event)\"></app-grc-sub-category-listing>\r\n <app-list-loader *ngIf=\"categoryLoader || programLoader\"></app-list-loader>\r\n </div>\r\n\r\n <div class=\"inner-item-right\">\r\n <!-- <app-grc-responsibility-listing></app-grc-responsibility-listing> -->\r\n\r\n <app-grc-responsibility-listing #dataListing *ngIf=\"!responsibilityLoader && !categoryLoader && !programLoader && responsibilityData?.data?.length !== 0\" [headerText]=\"'Responsibilities'\" [responsibilityData]=\"responsibilityData\" [activeProgram]=\"selectedProgram\" [activeCategory]=\"selectedCategory\" [selectedProgramAndResp]=\"selectedProgramAndResp\" (changeSelectedProgramAndResp)=\"changeSelectedProgramAndResp($event)\" [currentPage]=\"responsibilityCurrentPage\" [perPageLimit]=\"30\" [totalListData]=\"responsibilityData?.total_items\" [totalPages]=\"responsibilityData?.total_pages\" (getUpdatedDataList)=\"getUpdatedDataList($event)\" ></app-grc-responsibility-listing>\r\n \r\n <app-list-loader *ngIf=\"responsibilityLoader || categoryLoader || programLoader\"></app-list-loader>\r\n \r\n <app-no-data *ngIf=\"responsibilityData?.data?.length === 0 && !(responsibilityLoader || categoryLoader || programLoader)\" [noDataImage]=\"CDN_LINK?.noData\" [noDataText]=\"'No data to display'\"></app-no-data>\r\n </div>\r\n </ng-container>\r\n <app-no-data *ngIf=\"(!programLoader && !programData?.data?.length)\" [noDataImage]=\"CDN_LINK?.noData\" [noDataText]=\"'No data to display'\"></app-no-data>\r\n </div>\r\n <app-floating-bar [selectedData]=\"selectedResponsibilities?.length ? selectedResponsibilities : []\" (closeList)=\"close()\" (closeEvent)=\"save()\" [displayElementKey]=\"'ReportName'\" [singularText]=\"'Responsibility selected'\" [pluralText]=\"'Responsibilities selected'\" (deleteEvent)=\"deleteEvent($event)\"></app-floating-bar>\r\n </div>\r\n</div>", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";::ng-deep .program-responsibility-listing{position:fixed;inset:0 30px 0 0}::ng-deep .program-responsibility-listing:before{background:#1E5DD3;content:\"\";position:absolute;top:0;left:0;right:0;width:100%;height:3px}::ng-deep .program-responsibility-listing.animate{animation:animate-right .2s cubic-bezier(.25,.46,.45,.94) both;z-index:-1}::ng-deep .program-responsibility-listing-head{background:#fbfbfb;height:2.75rem;border-bottom:1px solid #f1f1f1}::ng-deep .program-responsibility-listing-body{background:#fff;height:calc(100vh - 2.75rem);padding:2rem}::ng-deep .program-responsibility-listing-body .search-block{position:relative}::ng-deep .program-responsibility-listing-body .search-block input{height:2.75rem;line-height:1.5rem;padding:.5rem 1rem .5rem 2.5rem;outline:none;border:1px solid #7475763f;border-radius:.25rem;width:100%;font-size:14px;color:#747576}::ng-deep .program-responsibility-listing-body .search-block input:focus{border-color:#1e5dd3}::ng-deep .program-responsibility-listing-body .search-block input::placeholder{color:#747576}::ng-deep .program-responsibility-listing-body .search-block i{position:absolute;left:1rem;font-size:12px;font-weight:400;top:1rem;pointer-events:none;color:#f1f1f1}::ng-deep .program-responsibility-listing-body-inner{height:calc(100vh - 17.5rem)}::ng-deep .program-responsibility-listing-body-inner .inner-item-left{width:25%}::ng-deep .program-responsibility-listing-body-inner .inner-item-mid{width:25%}::ng-deep .program-responsibility-listing-body-inner .inner-item-right{width:50%}@keyframes animate-right{0%{transform:translate(100%)}to{transform:translate(0)}}\n"] }]
386
+ }], ctorParameters: function () { return [{ type: i1.GrcService }]; }, propDecorators: { getSelectedProgramAndResp: [{
387
+ type: Input,
388
+ args: ['selectedProgramAndResp']
389
+ }], responsibilityListingComponent: [{
390
+ type: ViewChild,
391
+ args: ['dataListing']
392
+ }] } });
393
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"program-responsibility-listing.component.js","sourceRoot":"","sources":["../../../../../../../../projects/vx-workflow-engine/src/lib/workflow/shared/components/program-responsibility-listing/program-responsibility-listing.component.ts","../../../../../../../../projects/vx-workflow-engine/src/lib/workflow/shared/components/program-responsibility-listing/program-responsibility-listing.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EACL,SAAS,EACT,YAAY,EACZ,KAAK,EAEL,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,iBAAiB,EAAE,MAAM,+DAA+D,CAAC;AAClG,OAAO,EAAE,eAAe,EAAE,MAAM,+CAA+C,CAAC;AAChF,OAAO,EAAE,gBAAgB,EAAE,MAAM,iDAAiD,CAAC;AACnF,OAAO,EAAE,aAAa,EAAE,MAAM,2CAA2C,CAAC;AAC1E,OAAO,EAAE,aAAa,EAAE,MAAM,2CAA2C,CAAC;AAC1E,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAC;AACxE,OAAO,EAAE,2BAA2B,EAAE,MAAM,wDAAwD,CAAC;AACrG,OAAO,EAAE,iCAAiC,EAAE,MAAM,oEAAoE,CAAC;AACvH,OAAO,EAAE,YAAY,EAAE,MAAM,2CAA2C,CAAC;AACzE,OAAO,EAAE,gBAAgB,EAAE,MAAM,6DAA6D,CAAC;AAC/F,OAAO,EAAE,8BAA8B,EAAE,MAAM,gEAAgE,CAAC;AAEhH,OAAO,EAAE,yBAAyB,EAAE,MAAM,8CAA8C,CAAC;AAEzF,OAAO,EAAE,wBAAwB,EAAE,MAAM,4EAA4E,CAAC;AACtH,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,KAAK,EAAE,MAAM,mCAAmC,CAAC;;;;;;;AAwB1D,MAAM,OAAO,qCAAqC;IA6ChD,YAAoB,UAAsB;QAAtB,eAAU,GAAV,UAAU,CAAY;QA5C1C,iBAAY,GAAG,yBAAyB,CAAC;QACzC,aAAQ,GAAG,KAAK,CAAC;QACjB,gBAAW,GAAkB,CAAC,CAAC;QAE/B,cAAS,GAAG,KAAK,CAAC;QAElB,kBAAa,GAAY,KAAK,CAAC;QAC/B,uBAAkB,GAAY,KAAK,CAAC;QACpC,yBAAoB,GAAY,KAAK,CAAC;QACtC,mBAAc,GAAY,KAAK,CAAC;QAChC,2BAAsB,GAAU,EAAE,CAAC;QACnC,8BAAyB,GAAU,EAAE,CAAC;QACtC,iBAAY,GAAW,EAAE,CAAC;QAI1B,uBAAkB,GAAW,CAAC,CAAC;QAC/B,wBAAmB,GAAW,CAAC,CAAC;QAChC,8BAAyB,GAAW,CAAC,CAAC;QAGtC,uBAAkB,GAAQ;YACxB,IAAI,EAAE,EAAE;SACT,CAAC;QACF,uBAAkB,GAAU,EAAE,CAAC;QAC/B,wBAAmB,GAAU,EAAE,CAAC;QAChC,6BAAwB,GAAU,EAAE,CAAC;QAarC,cAAS,GAAsB,IAAI,YAAY,EAAE,CAAC;QAMhD,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,UAAU,EAAE,gBAAgB,EAAE,CAAC;IAClE,CAAC;IAdD,IAAqC,yBAAyB,CAAC,IAAS;QACtE,IAAI,CAAC,sBAAsB,GAAG,IAAI,IAAI,EAAE,CAAC;QACzC,IAAI,CAAC,yBAAyB,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC;QAClE,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;QACxD,IAAI,CAAC,8BAA8B,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;IACnE,CAAC;IAWD,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;QAER,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAED,KAAK;QACH,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC;IACtD,CAAC;IAED,IAAI;QACF,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;IACnD,CAAC;IAED,eAAe,CAAC,KAAW;QACzB,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,CAAC;SAChC;QACD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAC1B,MAAM,OAAO,GAAG;YACd,OAAO,EAAE;gBACP,IAAI,EAAE,EAAE;gBACR,cAAc,EAAE,OAAO;gBACvB,CAAC,EAAE,EAAE;gBACL,UAAU,EAAE,IAAI,CAAC,YAAY;gBAC7B,UAAU,EAAE;oBACV,OAAO,EAAE,EAAE;oBACX,OAAO,EAAE,EAAE;oBACX,UAAU,EAAE,EAAE;oBACd,oBAAoB,EAAE,EAAE;oBACxB,WAAW,EAAE,EAAE;oBACf,WAAW,EAAE,EAAE;oBACf,sBAAsB,EAAE,EAAE;iBAC3B;gBACD,MAAM,EAAE,IAAI,CAAC,kBAAkB,IAAI,CAAC;gBACpC,OAAO,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE;gBACjC,QAAQ,EAAE,UAAU;gBACpB,OAAO,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC;gBAC3B,UAAU,EAAE,IAAI,CAAC,oBAAoB,EAAE,UAAU;gBACjD,QAAQ,EAAE,IAAI,CAAC,oBAAoB,EAAE,QAAQ;gBAC7C,kBAAkB,EAAE,IAAI,CAAC,oBAAoB,EAAE,kBAAkB;gBACjE,cAAc,EAAE,IAAI,CAAC,oBAAoB,EAAE,cAAc;gBACzD,gBAAgB,EAAE,EAAE;gBACpB,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;aACd;SACF,CAAC;QACF,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC;YACpE,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;gBAC3B,0CAA0C;gBAC1C,IAAI,CAAC,WAAW,GAAG,EAAE,GAAG,GAAG,EAAE,CAAC;gBAC9B,IAAI,CAAC,uBAAuB,EAAE,CAAC;gBAC/B,IAAI,CAAC,sBAAsB,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;YAC5C,CAAC;YACD,KAAK,EAAE,CAAC,GAAQ,EAAE,EAAE;gBAClB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;YAC7B,CAAC;SACF,CAAC,CAAC;IACL,CAAC;IAED,mBAAmB,CAAC,KAAU;QAC5B,IAAI,CAAC,kBAAkB,GAAG,KAAK,EAAE,MAAM,IAAI,CAAC,CAAC;QAC7C,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAED,uBAAuB,CAAC,KAAU;QAChC,IAAI,CAAC,mBAAmB,GAAG,KAAK,EAAE,MAAM,IAAI,CAAC,CAAC;QAC9C,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IACpD,CAAC;IAED,WAAW,CAAC,KAAU;QACpB,IAAI,CAAC,8BAA8B,CAAC,4BAA4B,CAAC,KAAK,CAAC,CAAC;IAC1E,CAAC;IAED,cAAc,CAAC,KAAU;QACvB,IAAI,CAAC,kBAAkB,GAAG,CAAC,CAAC;QAC5B,IAAI,CAAC,WAAW,GAAG,KAAK,EAAE,IAAI,CAAC;QAC/B,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAED,YAAY,CAAC,KAAU;QACrB,IAAI,IAAI,CAAC,YAAY,IAAI,KAAK,EAAE;YAC9B,IAAI,CAAC,kBAAkB,GAAG,CAAC,CAAC;YAC5B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;YAC1B,IAAI,CAAC,uBAAuB,EAAE,CAAC;YAC/B,IAAI,CAAC,eAAe,EAAE,CAAC;YACvB,IAAI,CAAC,gBAAgB,EAAE,CAAC;SACzB;IACH,CAAC;IAED,gBAAgB,CAAC,YAAkB;QACjC,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;QAC/B,MAAM,OAAO,GAAG;YACd,OAAO,EAAE;gBACP,IAAI,EAAE,EAAE;gBACR,cAAc,EAAE,OAAO;gBACvB,CAAC,EAAE,EAAE;gBACL,UAAU,EAAE,IAAI,CAAC,YAAY;gBAC7B,UAAU,EAAE;oBACV,OAAO,EAAE,EAAE;oBACX,OAAO,EAAE,EAAE;oBACX,UAAU,EAAE,EAAE;oBACd,oBAAoB,EAAE,EAAE;oBACxB,WAAW,EAAE,EAAE;oBACf,WAAW,EAAE,EAAE;oBACf,sBAAsB,EAAE,EAAE;iBAC3B;gBACD,MAAM,EAAE,CAAC;gBACT,OAAO,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE;gBACjC,QAAQ,EAAE,UAAU;gBACpB,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;gBACrB,UAAU,EAAE,IAAI,CAAC,oBAAoB,EAAE,UAAU;gBACjD,QAAQ,EAAE,IAAI,CAAC,oBAAoB,EAAE,QAAQ;gBAC7C,kBAAkB,EAAE,IAAI,CAAC,oBAAoB,EAAE,kBAAkB;gBACjE,cAAc,EAAE,IAAI,CAAC,oBAAoB,EAAE,cAAc;gBACzD,gBAAgB,EAAE,EAAE;gBACpB,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;aACd;SACF,CAAC;QACF,IAAI,CAAC,UAAU,CAAC,oBAAoB,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC;YACtD,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;gBAChC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,KAAK;oBACxB,GAAG,EAAE,eAAe,EAAE,MAAM,GAAG,GAAG,EAAE,eAAe,EAAE,SAAS,CAAC;gBACjE,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,KAAK;oBACxB,GAAG,EAAE,aAAa,EAAE,MAAM,GAAG,GAAG,EAAE,aAAa,EAAE,SAAS,CAAC;gBAC7D,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,KAAK;oBACxB,GAAG,EAAE,aAAa,EAAE,MAAM,GAAG,GAAG,EAAE,aAAa,EAAE,SAAS,CAAC;gBAC7D,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,KAAK;oBACxB,GAAG,EAAE,UAAU,EAAE,MAAM,GAAG,GAAG,EAAE,UAAU,EAAE,SAAS,CAAC;gBACvD,IAAI;YACN,CAAC;SACF,CAAC,CAAC;IACL,CAAC;IAED,sBAAsB,CAAC,OAAY;QACjC,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;SACjC;QACD,IAAI,CAAC,eAAe,GAAG,OAAO,CAAC;QAC/B,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,+BAA+B;QAC/B,MAAM,OAAO,GAAG;YACd,EAAE,EAAE,OAAO,EAAE,GAAG;YAChB,SAAS,EAAE,MAAM;YACjB,cAAc,EAAE,OAAO;YACvB,UAAU,EAAE,IAAI,CAAC,YAAY;YAC7B,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;aAC3B;YACD,IAAI,EAAE,IAAI,CAAC,mBAAmB,IAAI,CAAC;YACnC,wCAAwC;YACxC,IAAI,EAAE,MAAM;YACZ,aAAa,EAAE;gBACb,UAAU,EAAE,IAAI,CAAC,oBAAoB,EAAE,UAAU;gBACjD,QAAQ,EAAE,IAAI,CAAC,oBAAoB,EAAE,QAAQ;gBAC7C,kBAAkB,EAAE,IAAI,CAAC,oBAAoB,EAAE,kBAAkB;gBACjE,cAAc,EAAE,IAAI,CAAC,oBAAoB,EAAE,cAAc;gBACzD,gBAAgB,EAAE,EAAE;gBACpB,uBAAuB;gBACvB,IAAI,EAAE,MAAM;gBACZ,UAAU,EAAE;oBACV,OAAO,EAAE,EAAE;oBACX,OAAO,EAAE,EAAE;oBACX,UAAU,EAAE,EAAE;oBACd,oBAAoB,EAAE,EAAE;oBACxB,WAAW,EAAE,EAAE;oBACf,WAAW,EAAE,EAAE;oBACf,sBAAsB,EAAE,EAAE;iBAC3B;aACF;SACF,CAAC;QACF,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC;YACxE,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;gBAC5B,IAAI,CAAC,YAAY,GAAG,EAAE,GAAG,GAAG,EAAE,CAAC;gBAC/B,IAAI,CAAC,gBAAgB,GAAG,GAAG,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;gBACrC,IAAI,CAAC,yBAAyB,GAAG,CAAC,CAAC;gBACnC,IAAI,CAAC,uBAAuB,EAAE,CAAC;YACjC,CAAC;YACD,KAAK,EAAE,CAAC,GAAG,EAAE,EAAE;gBACb,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;gBACnB,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;YAC9B,CAAC;SACF,CAAC,CAAC;IACL,CAAC;IAED,qBAAqB,CAAC,KAAU;QAC9B,IAAI,CAAC,eAAe,GAAG,KAAK,EAAE,QAAQ,CAAC;QACvC,IAAI,CAAC,uBAAuB,EAAE,CAAC;QAC/B,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QAClD,4DAA4D;IAC9D,CAAC;IAED,yBAAyB,CAAC,KAAU;QAClC,IAAI,CAAC,gBAAgB,GAAG,KAAK,EAAE,QAAQ,CAAC;QACxC,IAAI,CAAC,uBAAuB,EAAE,CAAC;IACjC,CAAC;IAED,uBAAuB,CAAC,KAAW;QACjC,IAAI,IAAI,CAAC,kBAAkB,EAAE;YAC3B,IAAI,CAAC,kBAAkB,CAAC,WAAW,EAAE,CAAC;SACvC;QACD,oCAAoC;QACpC,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC;QACjC,IAAI,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;QAC9B,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,iBAAiB,EAAE,MAAM,CAAC,CAAC;QAClD,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,UAAU,EAAE,IAAI,CAAC,eAAe,EAAE,WAAW,CAAC,CAAC;QACtE,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,gBAAgB,EAAE,WAAW,CAAC,CAAC;QACpE,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,QAAQ,EAAE,IAAI,CAAC,yBAAyB,IAAI,CAAC,CAAC,CAAC;QACtE,iDAAiD;QACjD,gEAAgE;QAChE,yDAAyD;QACzD,IAAI;QACJ,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,gBAAgB,EAAE,OAAO,CAAC,CAAC;QAClD,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;QAC3C,IAAI,aAAa,GAAG;YAClB,UAAU,EAAE,IAAI,CAAC,oBAAoB,EAAE,UAAU;YACjD,QAAQ,EAAE,IAAI,CAAC,oBAAoB,EAAE,QAAQ;YAC7C,kBAAkB,EAAE,IAAI,CAAC,oBAAoB,EAAE,kBAAkB;YACjE,cAAc,EAAE,IAAI,CAAC,oBAAoB,EAAE,cAAc;YACzD,gBAAgB,EAAE,EAAE;YACpB,QAAQ,EAAE,MAAM;YAChB,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;aAC3B;SACF,CAAC;QAEF,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,UAAU;aACtC,6BAA6B,CAAC,MAAM,EAAE,aAAa,CAAC;aACpD,SAAS,CAAC;YACT,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;gBAC5B,IAAI,CAAC,kBAAkB,GAAG,GAAG,CAAC;gBAC9B,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,oBAAoB,CACzD,GAAG,EAAE,IAAI,CACV,CAAC;gBACF,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;YACpC,CAAC;YACD,KAAK,EAAE,CAAC,GAAQ,EAAE,EAAE;gBAClB,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;YACpC,CAAC;SACF,CAAC,CAAC;IACP,CAAC;IAED,kBAAkB,CAAC,KAAU;QAC3B,IAAI,CAAC,yBAAyB,GAAG,KAAK,EAAE,MAAM,CAAC;QAC/C,IAAI,CAAC,uBAAuB,EAAE,CAAC;IACjC,CAAC;IAED,oBAAoB,CAAC,GAAQ;QAC3B,MAAM,IAAI,GAAG,GAAG,EAAE,GAAG,CAAC,CAAC,cAAmB,EAAE,EAAE;YAC5C,OAAO;gBACL,GAAG,cAAc;gBACjB,IAAI,EAAE,cAAc,EAAE,UAAU;gBAChC,SAAS,EAAE,cAAc,EAAE,SAAS;gBACpC,GAAG,EAAE,cAAc,EAAE,iBAAiB;gBACtC,WAAW,EAAE;oBACX,IAAI,EAAE,cAAc,EAAE,QAAQ;oBAC9B,KAAK,EAAE,cAAc,EAAE,aAAa;oBACpC,UAAU,EAAE,cAAc,EAAE,UAAU,IAAI,EAAE;oBAC5C,SAAS,EAAE,cAAc,EAAE,iBAAiB;iBAC7C;gBACD,WAAW,EAAE;oBACX,IAAI,EAAE,cAAc,EAAE,QAAQ;oBAC9B,KAAK,EAAE,cAAc,EAAE,QAAQ;oBAC/B,UAAU,EAAE,cAAc,EAAE,YAAY,IAAI,EAAE;oBAC9C,SAAS,EAAE,cAAc,EAAE,mBAAmB;oBAC9C,kBAAkB,EAAE,cAAc,EAAE,kBAAkB;iBACvD;gBACD,UAAU,EAAE,cAAc,EAAE,gBAAgB,EAAE,GAAG,CAAC,CAAC,MAAW,EAAE,EAAE;oBAChE,OAAO;wBACL,IAAI,EAAE,MAAM,EAAE,OAAO;qBACtB,CAAC;gBACJ,CAAC,CAAC;aACH,CAAC;QACJ,CAAC,CAAC,CAAC;QACH,OAAO,IAAI,CAAC;IACd,CAAC;IAED,uBAAuB;QACrB,IAAI,CAAC,mBAAmB,GAAG,CAAC,CAAC;QAC7B,IAAI,CAAC,yBAAyB,GAAG,CAAC,CAAC;IACrC,CAAC;IAED,4BAA4B,CAAC,KAAU;QACrC,IAAI,CAAC,sBAAsB,GAAG,KAAK,CAAC;QACpC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;QACxD,IAAI,CAAC,8BAA8B,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;QACjE,4DAA4D;IAC9D,CAAC;IAED,qBAAqB,CAAC,YAAiB;QACrC,IAAI,CAAC,kBAAkB,GAAG,EAAE,CAAC;QAC7B,YAAY,EAAE,OAAO,CAAC,CAAC,QAAa,EAAE,EAAE;YACtC,IAAI,CAAC,mBAAmB,GAAG,QAAQ,EAAE,QAAQ,CAAC;YAC9C,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,QAAQ,EAAE,OAAO,EAAE,SAAS,CAAC,CAAC;QAC7D,CAAC,CAAC,CAAC;IACL,CAAC;IAED,sBAAsB,CAAC,YAAiB;QACtC,IAAI,CAAC,mBAAmB,GAAG,EAAE,CAAC;QAC9B,IAAI,YAAY,GAAG,CAAC,CAAC,CAAC;QACtB,YAAY,GAAG,YAAY,CAAC,SAAS,CACnC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,OAAO,EAAE,SAAS,KAAK,IAAI,CAAC,eAAe,EAAE,SAAS,CAC1E,CAAC;QACF,IAAI,YAAY,KAAK,CAAC,CAAC,EAAE;YACvB,IAAI,CAAC,mBAAmB,GAAG,YAAY,CAAC,YAAY,CAAC,EAAE,QAAQ,CAAC;SACjE;aAAM;YACL,IAAI,CAAC,mBAAmB,GAAG,EAAE,CAAC;SAC/B;IACH,CAAC;IAED,8BAA8B,CAAC,YAAiB;QAC9C,IAAI,CAAC,wBAAwB,GAAG,EAAE,CAAC;QACnC,YAAY,CAAC,OAAO,CAAC,CAAC,IAAS,EAAE,EAAE;YACjC,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,GAAG,IAAI,EAAE,cAAc,CAAC,CAAC;QAC9D,CAAC,CAAC,CAAC;IACL,CAAC;;kIA/XU,qCAAqC;sHAArC,qCAAqC,kWChDlD,iiJA+CM,syDDjBF,YAAY,kIACZ,aAAa,8BACb,eAAe,8BACf,aAAa,8BACb,iBAAiB,yjBACjB,gBAAgB,+BAChB,kBAAkB,4KAClB,2BAA2B,oRAC3B,iCAAiC,2VACjC,8BAA8B,gQAC9B,gBAAgB,gHAChB,YAAY,iTACZ,wBAAwB;2FAMf,qCAAqC;kBAtBjD,SAAS;+BACE,oCAAoC,cAClC,IAAI,WACP;wBACP,YAAY;wBACZ,aAAa;wBACb,eAAe;wBACf,aAAa;wBACb,iBAAiB;wBACjB,gBAAgB;wBAChB,kBAAkB;wBAClB,2BAA2B;wBAC3B,iCAAiC;wBACjC,8BAA8B;wBAC9B,gBAAgB;wBAChB,YAAY;wBACZ,wBAAwB;qBACzB,WAGQ,CAAC,WAAW,CAAC;iGAmCe,yBAAyB;sBAA7D,KAAK;uBAAC,wBAAwB;gBAU/B,8BAA8B;sBAD7B,SAAS;uBAAC,aAAa","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  ViewChild,\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 { TableCardComponent } from '../table-card/table-card.component';\r\nimport { GrcCategoryListingComponent } from '../grc-category-listing/grc-category-listing.component';\r\nimport { GrcResponsibilityListingComponent } from '../grc-responsibility-listing/grc-responsibility-listing.component';\r\nimport { NoDataModule } from '../../../../ui-kit/no-data/no-data.module';\r\nimport { ListLoaderModule } from '../../../../sharedComponents/list-loader/list-loader.module';\r\nimport { GrcSubCategoryListingComponent } from '../grc-sub-category-listing/grc-sub-category-listing.component';\r\nimport { Subscription } from 'rxjs';\r\nimport { RESPONSIBILITY_TABLE_CARD } from '../../constants/link-responsibility.constant';\r\nimport { GrcService } from '../../services/grc.service';\r\nimport { TableCardLoaderComponent } from '../../../../sharedComponents/table-card-loader/table-card-loader.component';\r\nimport { HttpParams } from '@angular/common/http';\r\nimport { LINKS } from '../../constants/cdn-link.constant';\r\n\r\n@Component({\r\n  selector: 'app-program-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    TableCardComponent,\r\n    GrcCategoryListingComponent,\r\n    GrcResponsibilityListingComponent,\r\n    GrcSubCategoryListingComponent,\r\n    ListLoaderModule,\r\n    NoDataModule,\r\n    TableCardLoaderComponent,\r\n  ],\r\n  templateUrl: './program-responsibility-listing.component.html',\r\n  styleUrls: ['./program-responsibility-listing.component.less'],\r\n  outputs: ['closeList'],\r\n})\r\nexport class ProgramResponsibilityListingComponent implements OnInit {\r\n  programTypes = RESPONSIBILITY_TABLE_CARD;\r\n  CDN_LINK = LINKS;\r\n  selectedTab: 0 | 1 | 2 | 3 = 1;\r\n\r\n  animation = false;\r\n\r\n  programLoader: boolean = false;\r\n  programCountLoader: boolean = false;\r\n  responsibilityLoader: boolean = false;\r\n  categoryLoader: boolean = false;\r\n  selectedProgramAndResp: any[] = [];\r\n  preSelectedProgramAndResp: any[] = [];\r\n  searchString: string = '';\r\n  currentBusinessCycle!: any;\r\n  selectedProgram: any;\r\n  selectedCategory: any;\r\n  programCurrentPage: number = 1;\r\n  categoryCurrentPage: number = 1;\r\n  responsibilityCurrentPage: number = 1;\r\n  programData: any;\r\n  categoryData: any;\r\n  responsibilityData: any = {\r\n    data: [],\r\n  };\r\n  selectedProgramIds: any[] = [];\r\n  selectedCategoryIds: any[] = [];\r\n  selectedResponsibilities: any[] = [];\r\n\r\n  programCall!: Subscription;\r\n  categoryCall!: Subscription;\r\n  responsibilityCall!: Subscription;\r\n\r\n  @Input('selectedProgramAndResp') set getSelectedProgramAndResp(data: any) {\r\n    this.selectedProgramAndResp = data || [];\r\n    this.preSelectedProgramAndResp = JSON.parse(JSON.stringify(data));\r\n    this.getSelectedProgramIds(this.selectedProgramAndResp);\r\n    this.getAllSelectedResponsibilities(this.selectedProgramAndResp);\r\n  }\r\n\r\n  closeList: EventEmitter<any> = new EventEmitter();\r\n\r\n  @ViewChild('dataListing')\r\n  responsibilityListingComponent!: GrcResponsibilityListingComponent;\r\n\r\n  constructor(private grcService: GrcService) {\r\n    this.currentBusinessCycle = this.grcService?.getBusinessCycle();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.animation = true;\r\n    setTimeout(() => {\r\n      this.animation = false;\r\n    }, 300);\r\n\r\n    this.getProgramsList();\r\n    this.getProgramsCount();\r\n  }\r\n\r\n  close() {\r\n    this.closeList.emit(this.preSelectedProgramAndResp);\r\n  }\r\n\r\n  save() {\r\n    this.closeList.emit(this.selectedProgramAndResp);\r\n  }\r\n\r\n  getProgramsList(event?: any) {\r\n    if (this.programCall) {\r\n      this.programCall.unsubscribe();\r\n    }\r\n    this.programLoader = true;\r\n    const request = {\r\n      headers: {\r\n        type: '',\r\n        paginationType: 'small',\r\n        a: '',\r\n        searchText: this.searchString,\r\n        filterData: {\r\n          appList: [],\r\n          riskIds: [],\r\n          reviewerId: [],\r\n          responsibilityCenter: [],\r\n          entrustedBy: [],\r\n          entrustedTo: [],\r\n          responsibilityCategory: [],\r\n        },\r\n        pageNo: this.programCurrentPage || 1,\r\n        sortObj: { sortBy: '', type: -1 },\r\n        pageName: 'category',\r\n        typeArr: [this.selectedTab],\r\n        start_date: this.currentBusinessCycle?.start_date,\r\n        end_date: this.currentBusinessCycle?.end_date,\r\n        selected_cycle_arr: this.currentBusinessCycle?.selected_cycle_arr,\r\n        selected_cycle: this.currentBusinessCycle?.selected_cycle,\r\n        time_filter_type: '',\r\n        state: [2, 3],\r\n      },\r\n    };\r\n    this.programCall = this.grcService.getProgramsList(request).subscribe({\r\n      next: (res: any) => {\r\n        this.programLoader = false;\r\n        // this.programData.data = res.data ?? [];\r\n        this.programData = { ...res };\r\n        this.onSelectedProgramChange();\r\n        this.getCategoryByProgramId(res?.data[0]);\r\n      },\r\n      error: (err: any) => {\r\n        this.programLoader = false;\r\n      },\r\n    });\r\n  }\r\n\r\n  onProgramPageChange(event: any) {\r\n    this.programCurrentPage = event?.pageNo || 1;\r\n    this.getProgramsList();\r\n  }\r\n\r\n  onSubCategoryPageChange(event: any) {\r\n    this.categoryCurrentPage = event?.pageNo || 1;\r\n    this.getCategoryByProgramId(this.selectedProgram);\r\n  }\r\n\r\n  deleteEvent(event: any) {\r\n    this.responsibilityListingComponent.deleteSelectedResponsibility(event);\r\n  }\r\n\r\n  setSelectedTab(event: any) {\r\n    this.programCurrentPage = 1;\r\n    this.selectedTab = event?.type;\r\n    this.getProgramsList();\r\n  }\r\n\r\n  handleSearch(event: any) {\r\n    if (this.searchString != event) {\r\n      this.programCurrentPage = 1;\r\n      this.searchString = event;\r\n      this.onSelectedProgramChange();\r\n      this.getProgramsList();\r\n      this.getProgramsCount();\r\n    }\r\n  }\r\n\r\n  getProgramsCount(paramsObject?: any) {\r\n    this.programCountLoader = true;\r\n    const request = {\r\n      headers: {\r\n        type: '',\r\n        paginationType: 'small',\r\n        a: '',\r\n        searchText: this.searchString,\r\n        filterData: {\r\n          appList: [],\r\n          riskIds: [],\r\n          reviewerId: [],\r\n          responsibilityCenter: [],\r\n          entrustedBy: [],\r\n          entrustedTo: [],\r\n          responsibilityCategory: [],\r\n        },\r\n        pageNo: 1,\r\n        sortObj: { sortBy: '', type: '' },\r\n        pageName: 'category',\r\n        typeArr: [1, 2, 3, 0],\r\n        start_date: this.currentBusinessCycle?.start_date,\r\n        end_date: this.currentBusinessCycle?.end_date,\r\n        selected_cycle_arr: this.currentBusinessCycle?.selected_cycle_arr,\r\n        selected_cycle: this.currentBusinessCycle?.selected_cycle,\r\n        time_filter_type: '',\r\n        state: [2, 3],\r\n      },\r\n    };\r\n    this.grcService.getProgramsListCount(request).subscribe({\r\n      next: (res: any) => {\r\n        this.programCountLoader = false;\r\n        this.programTypes[0].count =\r\n          res?.regulationCount?.active + res?.regulationCount?.completed;\r\n        this.programTypes[1].count =\r\n          res?.standardCount?.active + res?.standardCount?.completed;\r\n        this.programTypes[2].count =\r\n          res?.internalCount?.active + res?.internalCount?.completed;\r\n        this.programTypes[3].count =\r\n          res?.otherCount?.active + res?.otherCount?.completed;\r\n        // }\r\n      },\r\n    });\r\n  }\r\n\r\n  getCategoryByProgramId(program: any) {\r\n    if (this.categoryCall) {\r\n      this.categoryCall.unsubscribe();\r\n    }\r\n    this.selectedProgram = program;\r\n    this.categoryLoader = true;\r\n    // this.resetControlVariable();\r\n    const headers = {\r\n      id: program?._id,\r\n      scopeType: 'risk',\r\n      paginationType: 'small',\r\n      searchText: this.searchString,\r\n      filterData: {\r\n        appList: [],\r\n        riskIds: [],\r\n        reviewerId: [],\r\n        responsibilityCenter: [],\r\n        entrustedBy: [],\r\n        entrustedTo: [],\r\n        responsibilityCategory: [],\r\n      },\r\n      page: this.categoryCurrentPage || 1,\r\n      // sortingCount: this.categorySortValue,\r\n      name: 'name',\r\n      businessCycle: {\r\n        start_date: this.currentBusinessCycle?.start_date,\r\n        end_date: this.currentBusinessCycle?.end_date,\r\n        selected_cycle_arr: this.currentBusinessCycle?.selected_cycle_arr,\r\n        selected_cycle: this.currentBusinessCycle?.selected_cycle,\r\n        time_filter_type: '',\r\n        // \"scopeType\": 'risk',\r\n        type: 'risk',\r\n        filterData: {\r\n          appList: [],\r\n          riskIds: [],\r\n          reviewerId: [],\r\n          responsibilityCenter: [],\r\n          entrustedBy: [],\r\n          entrustedTo: [],\r\n          responsibilityCategory: [],\r\n        },\r\n      },\r\n    };\r\n    this.categoryCall = this.grcService.getSubCategoryList(headers).subscribe({\r\n      next: (res: any) => {\r\n        this.categoryLoader = false;\r\n        this.categoryData = { ...res };\r\n        this.selectedCategory = res?.data[0];\r\n        this.responsibilityCurrentPage = 1;\r\n        this.getResponsibilitiesList();\r\n      },\r\n      error: (err) => {\r\n        console.error(err);\r\n        this.categoryLoader = false;\r\n      },\r\n    });\r\n  }\r\n\r\n  activeSelectedProgram(event: any) {\r\n    this.selectedProgram = event?.category;\r\n    this.onSelectedProgramChange();\r\n    this.getCategoryByProgramId(this.selectedProgram);\r\n    // this.getSelectedCategoryIds(this.selectedProgramAndResp);\r\n  }\r\n\r\n  activeSelectedSubCategory(event: any) {\r\n    this.selectedCategory = event?.category;\r\n    this.getResponsibilitiesList();\r\n  }\r\n\r\n  getResponsibilitiesList(event?: any) {\r\n    if (this.responsibilityCall) {\r\n      this.responsibilityCall.unsubscribe();\r\n    }\r\n    // this.respCount = event.sortValue;\r\n    this.responsibilityLoader = true;\r\n    let params = new HttpParams();\r\n    params = params.append('isBusinessCycle', 'true');\r\n    params = params.append('parentId', this.selectedProgram?.category_id);\r\n    params = params.append('catId', this.selectedCategory?.category_id);\r\n    params = params.append('pageNo', this.responsibilityCurrentPage ?? 1);\r\n    // if ([1, -1].includes(this.controlSortValue)) {\r\n    //   params = params.append('sortValue', this.controlSortValue);\r\n    //   params = params.append('sortBy', 'Data.ReportName');\r\n    // }\r\n    params = params.append('paginationType', 'small');\r\n    params = params.append('pageType', 'risk');\r\n    let businessCycle = {\r\n      start_date: this.currentBusinessCycle?.start_date,\r\n      end_date: this.currentBusinessCycle?.end_date,\r\n      selected_cycle_arr: this.currentBusinessCycle?.selected_cycle_arr,\r\n      selected_cycle: this.currentBusinessCycle?.selected_cycle,\r\n      time_filter_type: '',\r\n      pageType: 'risk',\r\n      filterData: {\r\n        appList: [],\r\n        riskIds: [],\r\n        reviewerId: [],\r\n        responsibilityCenter: [],\r\n        entrustedBy: [],\r\n        entrustedTo: [],\r\n        responsibilityCategory: [],\r\n      },\r\n    };\r\n\r\n    this.responsibilityCall = this.grcService\r\n      .getResponsibilityByCategoryId(params, businessCycle)\r\n      .subscribe({\r\n        next: (res: any) => {\r\n          this.categoryLoader = false;\r\n          this.responsibilityData = res;\r\n          this.responsibilityData['data'] = this.setDataListStructure(\r\n            res?.data\r\n          );\r\n          this.responsibilityLoader = false;\r\n        },\r\n        error: (err: any) => {\r\n          this.responsibilityLoader = false;\r\n        },\r\n      });\r\n  }\r\n\r\n  getUpdatedDataList(event: any) {\r\n    this.responsibilityCurrentPage = event?.pageNo;\r\n    this.getResponsibilitiesList();\r\n  }\r\n\r\n  setDataListStructure(res: any) {\r\n    const data = res?.map((responsibility: any) => {\r\n      return {\r\n        ...responsibility,\r\n        name: responsibility?.ReportName,\r\n        controlId: responsibility?.ControlId,\r\n        _id: responsibility?.EncryptedReportId,\r\n        entrustedBy: {\r\n          name: responsibility?.AssignBy,\r\n          email: responsibility?.AssignByEmail,\r\n          profilePic: responsibility?.member_pic ?? '',\r\n          shortName: responsibility?.member_short_name,\r\n        },\r\n        entrustedTo: {\r\n          name: responsibility?.AssignTo,\r\n          email: responsibility?.AssignTo,\r\n          profilePic: responsibility?.employee_pic ?? '',\r\n          shortName: responsibility?.employee_short_name,\r\n          EntrustedToMembers: responsibility?.EntrustedToMembers,\r\n        },\r\n        withinData: responsibility?.RC_details_array?.map((within: any) => {\r\n          return {\r\n            name: within?.rc_name,\r\n          };\r\n        }),\r\n      };\r\n    });\r\n    return data;\r\n  }\r\n\r\n  onSelectedProgramChange() {\r\n    this.categoryCurrentPage = 1;\r\n    this.responsibilityCurrentPage = 1;\r\n  }\r\n\r\n  changeSelectedProgramAndResp(event: any) {\r\n    this.selectedProgramAndResp = event;\r\n    this.getSelectedProgramIds(this.selectedProgramAndResp);\r\n    this.getAllSelectedResponsibilities(this.selectedProgramAndResp);\r\n    // this.getSelectedCategoryIds(this.selectedProgramAndResp);\r\n  }\r\n\r\n  getSelectedProgramIds(selectedData: any) {\r\n    this.selectedProgramIds = [];\r\n    selectedData?.forEach((selected: any) => {\r\n      this.selectedCategoryIds = selected?.category;\r\n      this.selectedProgramIds.push(selected?.program?.programId);\r\n    });\r\n  }\r\n\r\n  getSelectedCategoryIds(selectedData: any) {\r\n    this.selectedCategoryIds = [];\r\n    let programIndex = -1;\r\n    programIndex = selectedData.findIndex(\r\n      (cat: any) => cat?.program?.programId === this.selectedProgram?.programId\r\n    );\r\n    if (programIndex !== -1) {\r\n      this.selectedCategoryIds = selectedData[programIndex]?.category;\r\n    } else {\r\n      this.selectedCategoryIds = [];\r\n    }\r\n  }\r\n\r\n  getAllSelectedResponsibilities(selectedData: any) {\r\n    this.selectedResponsibilities = [];\r\n    selectedData.forEach((item: any) => {\r\n      this.selectedResponsibilities.push(...item?.responsibility);\r\n    });\r\n  }\r\n}\r\n","<div class=\"program-responsibility-listing\" [class.animate]=\"animation\">\r\n    <div class=\"program-responsibility-listing-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\">\r\n        <h3 class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Select Responsibilities</h3></div>\r\n    <div class=\"program-responsibility-listing-body\">\r\n        <app-table-card-loader *ngIf=\"programCountLoader\"></app-table-card-loader>\r\n        <app-table-card\r\n            *ngIf=\"!programCountLoader\"\r\n            class=\"vx-w-100\"\r\n            [tableCard]=\"programTypes\"\r\n            [singleSelectedText]=\"'Responsibility Selected'\"\r\n            [selectedTab]=\"selectedTab\"\r\n            [multipleSelectedText]=\"'Responsibilities Selected'\"\r\n            (setSelectedTab)=\"setSelectedTab($event)\">\r\n        </app-table-card>\r\n        <div class=\"search-block vx-mb-2\">\r\n          <i class=\"icons\">&#xe90b;</i>\r\n          <input type=\"text\"  #searchRiskCategory (keyup.enter)=\"handleSearch($event.target.value)\" placeholder=\"Search Programs\" />\r\n        </div>\r\n        <div class=\"program-responsibility-listing-body-inner vx-mb-2 vx-d-flex\" [class.vx-justify-center]=\"(!programLoader && !programData?.data?.length)\">\r\n            <ng-container *ngIf=\"(programLoader || programData?.data?.length)\">\r\n                <div class=\"inner-item-left vx-pr-2\">\r\n\r\n                    <app-grc-category-listing *ngIf=\"!programLoader\" [headerText]=\"'Programs'\" [programData]=\"programData\"  [selectedCatAndRisk]=\"selectedCatAndRisk\" [nameDisplayKey]=\"'item_name'\" [currentPage]=\"programCurrentPage\" [selectedTabIndex]=\"selectedTab\" [selectedCategoryIds]=\"selectedProgramIds\" (activeSelectedCategory)=\"activeSelectedProgram($event)\" (onCategoryPageChange)=\"onProgramPageChange($event)\"></app-grc-category-listing>\r\n                        \r\n                    <app-list-loader *ngIf=\"programLoader\"></app-list-loader>\r\n\r\n                </div>\r\n\r\n                <div class=\"inner-item-mid vx-pr-2\">\r\n                    <app-grc-sub-category-listing *ngIf=\"!categoryLoader && !programLoader\"  [headerText]=\"'Programs'\" [categories]=\"categoryData\"  [nameDisplayKey]=\"'item_name'\"  [currentPage]=\"categoryCurrentPage\" [selectedCategoryIds]=\"selectedCategoryIds\" [activeProgram]=\"selectedProgram\" [selectedProgramAndResp]=\"selectedProgramAndResp\" (activeSelectedCategory)=\"activeSelectedSubCategory($event)\" (onCategoryPageChange)=\"onSubCategoryPageChange($event)\"></app-grc-sub-category-listing>\r\n                    <app-list-loader *ngIf=\"categoryLoader || programLoader\"></app-list-loader>\r\n                </div>\r\n\r\n                <div class=\"inner-item-right\">\r\n                    <!-- <app-grc-responsibility-listing></app-grc-responsibility-listing> -->\r\n\r\n                    <app-grc-responsibility-listing #dataListing *ngIf=\"!responsibilityLoader && !categoryLoader && !programLoader && responsibilityData?.data?.length !== 0\" [headerText]=\"'Responsibilities'\" [responsibilityData]=\"responsibilityData\" [activeProgram]=\"selectedProgram\" [activeCategory]=\"selectedCategory\" [selectedProgramAndResp]=\"selectedProgramAndResp\" (changeSelectedProgramAndResp)=\"changeSelectedProgramAndResp($event)\" [currentPage]=\"responsibilityCurrentPage\" [perPageLimit]=\"30\" [totalListData]=\"responsibilityData?.total_items\" [totalPages]=\"responsibilityData?.total_pages\" (getUpdatedDataList)=\"getUpdatedDataList($event)\" ></app-grc-responsibility-listing>\r\n                        \r\n                    <app-list-loader *ngIf=\"responsibilityLoader || categoryLoader || programLoader\"></app-list-loader>\r\n                    \r\n                    <app-no-data *ngIf=\"responsibilityData?.data?.length === 0 && !(responsibilityLoader || categoryLoader || programLoader)\" [noDataImage]=\"CDN_LINK?.noData\" [noDataText]=\"'No data to display'\"></app-no-data>\r\n                </div>\r\n            </ng-container>\r\n            <app-no-data *ngIf=\"(!programLoader && !programData?.data?.length)\" [noDataImage]=\"CDN_LINK?.noData\" [noDataText]=\"'No data to display'\"></app-no-data>\r\n        </div>\r\n        <app-floating-bar   [selectedData]=\"selectedResponsibilities?.length ? selectedResponsibilities : []\"  (closeList)=\"close()\" (closeEvent)=\"save()\"  [displayElementKey]=\"'ReportName'\" [singularText]=\"'Responsibility selected'\" [pluralText]=\"'Responsibilities selected'\" (deleteEvent)=\"deleteEvent($event)\"></app-floating-bar>\r\n    </div>\r\n</div>"]}