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.
- package/esm2020/lib/more-option/more-option.component.mjs +10 -11
- package/esm2020/lib/workflow/grc-object/grc-object-container/grc-object-container.component.mjs +78 -6
- package/esm2020/lib/workflow/shared/components/attributes/attributes-text-box/attributes-text-box.component.mjs +1 -1
- package/esm2020/lib/workflow/shared/components/attributes/attributes.component.mjs +1 -1
- package/esm2020/lib/workflow/shared/components/edit-mode/edit-mode.component.mjs +32 -10
- package/esm2020/lib/workflow/shared/components/grc-category-listing/grc-category-listing.component.mjs +18 -3
- package/esm2020/lib/workflow/shared/components/grc-responsibility-listing/grc-responsibility-listing.component.mjs +62 -60
- package/esm2020/lib/workflow/shared/components/grc-risk-listing/grc-risk-listing.component.mjs +191 -0
- package/esm2020/lib/workflow/shared/components/grc-sub-category-listing/grc-sub-category-listing.component.mjs +77 -11
- package/esm2020/lib/workflow/shared/components/list-popup/list-popup.component.mjs +24 -2
- package/esm2020/lib/workflow/shared/components/program-responsibility-listing/program-responsibility-listing.component.mjs +393 -0
- package/esm2020/lib/workflow/shared/components/risk-category-risk-listing/risk-category-risk-listing.component.mjs +5 -5
- package/esm2020/lib/workflow/shared/constants/field-text.constant.mjs +3 -1
- package/esm2020/lib/workflow/shared/constants/link-responsibility.constant.mjs +19 -0
- package/esm2020/lib/workflow/shared/interfaces/add-grc.mjs +1 -1
- package/esm2020/lib/workflow/shared/services/grc.service.mjs +83 -1
- package/esm2020/lib/workflow-engine.module.mjs +2 -5
- package/esm2020/lib/workflow-grc/workflow-grc.component.mjs +2 -2
- package/esm2020/lib/workflow-policy/workflow-policy.component.mjs +2 -2
- package/fesm2015/vcomply-workflow-engine.mjs +910 -57
- package/fesm2015/vcomply-workflow-engine.mjs.map +1 -1
- package/fesm2020/vcomply-workflow-engine.mjs +894 -55
- package/fesm2020/vcomply-workflow-engine.mjs.map +1 -1
- package/lib/workflow/grc-object/grc-object-container/grc-object-container.component.d.ts +8 -1
- package/lib/workflow/shared/components/attributes/attributes-text-box/attributes-text-box.component.d.ts +2 -0
- package/lib/workflow/shared/components/edit-mode/edit-mode.component.d.ts +2 -1
- package/lib/workflow/shared/components/grc-category-listing/grc-category-listing.component.d.ts +5 -1
- package/lib/workflow/shared/components/grc-responsibility-listing/grc-responsibility-listing.component.d.ts +11 -9
- package/lib/workflow/shared/components/grc-risk-listing/grc-risk-listing.component.d.ts +35 -0
- package/lib/workflow/shared/components/grc-sub-category-listing/grc-sub-category-listing.component.d.ts +17 -2
- package/lib/workflow/shared/components/program-responsibility-listing/program-responsibility-listing.component.d.ts +76 -0
- package/lib/workflow/shared/components/risk-category-risk-listing/risk-category-risk-listing.component.d.ts +2 -2
- package/lib/workflow/shared/constants/field-text.constant.d.ts +2 -0
- package/lib/workflow/shared/constants/link-responsibility.constant.d.ts +7 -0
- package/lib/workflow/shared/interfaces/add-grc.d.ts +3 -1
- package/lib/workflow/shared/services/grc.service.d.ts +10 -0
- package/lib/workflow-engine.module.d.ts +32 -33
- 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\"></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\"></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":"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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  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>"]}
|