vcomply-workflow-engine 2.9.58 → 2.9.60
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/bundles/vcomply-workflow-engine.umd.js +956 -263
- package/bundles/vcomply-workflow-engine.umd.js.map +1 -1
- package/esm2015/lib/more-option/more-option.component.js +110 -59
- package/esm2015/lib/more-option/more-option.component.ngfactory.js +3 -3
- package/esm2015/lib/sharedComponents/link-program/link-program/link-program.component.js +435 -0
- package/esm2015/lib/sharedComponents/link-program/link-program/link-program.component.ngfactory.js +292 -0
- package/esm2015/lib/sharedComponents/link-program/link-program/link-program.component.ngsummary.json +1 -0
- package/esm2015/lib/sharedComponents/link-program/link-program/program-list-model.js +2 -0
- package/esm2015/lib/sharedComponents/link-program/link-program/program-list-model.ngsummary.json +1 -0
- package/esm2015/lib/sharedComponents/link-program/program-integration-interfaces.js +2 -0
- package/esm2015/lib/sharedComponents/link-program/program-integration-interfaces.ngsummary.json +1 -0
- package/esm2015/lib/sharedComponents/link-program/restapi.service.js +136 -0
- package/esm2015/lib/sharedComponents/link-program/restapi.service.ngsummary.json +1 -0
- package/esm2015/lib/sharedComponents/link-program/tooltip-validation.pipe.js +25 -0
- package/esm2015/lib/sharedComponents/link-program/tooltip-validation.pipe.ngsummary.json +1 -0
- package/esm2015/lib/workflow-engine.module.js +9 -3
- package/esm2015/lib/workflow-engine.module.ngfactory.js +1 -1
- package/esm2015/lib/workflow-interfaces/create-policy-form.js +1 -1
- package/esm2015/lib/workflow-policy/workflow-policy.component.js +65 -17
- package/esm2015/lib/workflow-policy/workflow-policy.component.ngfactory.js +171 -156
- package/esm2015/lib/workflow-policy/workflow-policy.component.ngsummary.json +1 -1
- package/esm2015/vcomply-workflow-engine.js +193 -190
- package/esm2015/vcomply-workflow-engine.ngsummary.json +1 -1
- package/fesm2015/vcomply-workflow-engine.js +758 -78
- package/fesm2015/vcomply-workflow-engine.js.map +1 -1
- package/lib/sharedComponents/link-program/link-program/link-program.component.d.ts +81 -0
- package/lib/sharedComponents/link-program/link-program/link-program.component.ngfactory.d.ts +1 -0
- package/lib/sharedComponents/link-program/link-program/program-list-model.d.ts +25 -0
- package/lib/sharedComponents/link-program/program-integration-interfaces.d.ts +9 -0
- package/lib/sharedComponents/link-program/restapi.service.d.ts +33 -0
- package/lib/sharedComponents/link-program/tooltip-validation.pipe.d.ts +4 -0
- package/lib/workflow-interfaces/create-policy-form.d.ts +5 -0
- package/lib/workflow-policy/workflow-policy.component.d.ts +2 -0
- package/package.json +1 -1
- package/vcomply-workflow-engine.d.ts +192 -189
- package/vcomply-workflow-engine.metadata.json +1 -1
|
@@ -0,0 +1,435 @@
|
|
|
1
|
+
import { HttpParams } from '@angular/common/http';
|
|
2
|
+
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
3
|
+
import { Subject } from 'rxjs';
|
|
4
|
+
import { takeUntil } from 'rxjs/operators';
|
|
5
|
+
import { RestApiService } from '../restapi.service';
|
|
6
|
+
import { SnackBarService } from '../../../ui-kit/snack-bar/snack-bar.service';
|
|
7
|
+
export class LinkProgramComponent {
|
|
8
|
+
//program
|
|
9
|
+
constructor(restApiService, snackbar) {
|
|
10
|
+
this.restApiService = restApiService;
|
|
11
|
+
this.snackbar = snackbar;
|
|
12
|
+
this.animation = false;
|
|
13
|
+
this.subCategoriesList = {
|
|
14
|
+
from: 1,
|
|
15
|
+
to: 0,
|
|
16
|
+
currentPage: 1,
|
|
17
|
+
totalPage: 0,
|
|
18
|
+
totalRecords: 0,
|
|
19
|
+
data: [],
|
|
20
|
+
};
|
|
21
|
+
this.responsibilitiesList = {
|
|
22
|
+
from: 1,
|
|
23
|
+
to: 0,
|
|
24
|
+
currentPage: 1,
|
|
25
|
+
totalPage: 0,
|
|
26
|
+
totalRecords: 0,
|
|
27
|
+
data: [],
|
|
28
|
+
};
|
|
29
|
+
this.searchText = {
|
|
30
|
+
program: '',
|
|
31
|
+
category: '',
|
|
32
|
+
responsibility: '',
|
|
33
|
+
};
|
|
34
|
+
this.selectedValues = {
|
|
35
|
+
program: {},
|
|
36
|
+
categories: [],
|
|
37
|
+
responsibilities: []
|
|
38
|
+
};
|
|
39
|
+
this.selectedIds = {
|
|
40
|
+
categories: [],
|
|
41
|
+
responsibilities: []
|
|
42
|
+
};
|
|
43
|
+
this.submissionLoader = false;
|
|
44
|
+
this.currentCategory = {};
|
|
45
|
+
this.policy = {};
|
|
46
|
+
this.mode = '';
|
|
47
|
+
this.changeTab = new EventEmitter();
|
|
48
|
+
this.updatedProgramDetails = new EventEmitter();
|
|
49
|
+
this.loader = false;
|
|
50
|
+
this.programSortBy = 'desc';
|
|
51
|
+
this.currentList = 'programs';
|
|
52
|
+
this.unsubscribe = new Subject();
|
|
53
|
+
this.save = new EventEmitter();
|
|
54
|
+
this.close = new EventEmitter();
|
|
55
|
+
this.refreshLinkedPolicies = new EventEmitter();
|
|
56
|
+
//program
|
|
57
|
+
this.subList = false;
|
|
58
|
+
this.selectedCategories = [];
|
|
59
|
+
this.previousSelectedValues = {
|
|
60
|
+
program: {},
|
|
61
|
+
categories: []
|
|
62
|
+
};
|
|
63
|
+
this.programData = {
|
|
64
|
+
data: [],
|
|
65
|
+
from: 0,
|
|
66
|
+
to: 0,
|
|
67
|
+
totalPages: 0,
|
|
68
|
+
totalRecords: 0,
|
|
69
|
+
currentPage: 1,
|
|
70
|
+
AllInternalControlsProgramsCount: 0,
|
|
71
|
+
AllOthersProgramsCount: 0,
|
|
72
|
+
AllRegulationProgramsCount: 0,
|
|
73
|
+
AllStandardProgramsCount: 0,
|
|
74
|
+
SelectedInternalControlsProgramsCount: 0,
|
|
75
|
+
SelectedOthersProgramsCount: 0,
|
|
76
|
+
SelectedRegulationProgramsCount: 0,
|
|
77
|
+
SelectedStandardProgramsCount: 0
|
|
78
|
+
};
|
|
79
|
+
this.programTypeObject = {
|
|
80
|
+
regulations: 1,
|
|
81
|
+
standards: 2,
|
|
82
|
+
internal_controls: 3,
|
|
83
|
+
others: 0,
|
|
84
|
+
};
|
|
85
|
+
this.displayConfirmationMessage = false;
|
|
86
|
+
this.activeTab = 'regulations';
|
|
87
|
+
this.getPrograms();
|
|
88
|
+
}
|
|
89
|
+
// @Input() allPrograms: any[] = [];
|
|
90
|
+
set getSelectedProgram(program) {
|
|
91
|
+
this.selectedValues = program !== null && program !== void 0 ? program : {
|
|
92
|
+
program: {},
|
|
93
|
+
categories: [],
|
|
94
|
+
responsibilities: []
|
|
95
|
+
};
|
|
96
|
+
}
|
|
97
|
+
ngOnInit() {
|
|
98
|
+
this.animation = true;
|
|
99
|
+
setTimeout(() => {
|
|
100
|
+
this.animation = false;
|
|
101
|
+
}, 300);
|
|
102
|
+
this.currentBusinessCycle = this.restApiService.getBusinessCycle();
|
|
103
|
+
}
|
|
104
|
+
getPrograms(data) {
|
|
105
|
+
this.loader = true;
|
|
106
|
+
let params = new HttpParams();
|
|
107
|
+
params = params.append('mode', 'complianceCategory/programList');
|
|
108
|
+
params = params.append('programType', this.programTypeObject[this.activeTab]);
|
|
109
|
+
params = params.append('pageName', "policyWorkroom");
|
|
110
|
+
if ((data === null || data === void 0 ? void 0 : data.search) || this.searchText.program) {
|
|
111
|
+
params = params.append('searchText', this.searchText.program);
|
|
112
|
+
}
|
|
113
|
+
else {
|
|
114
|
+
params = params.append('pageNo', this.programData.currentPage);
|
|
115
|
+
}
|
|
116
|
+
const request = {
|
|
117
|
+
method: 'get',
|
|
118
|
+
action: '/compliance/',
|
|
119
|
+
params
|
|
120
|
+
};
|
|
121
|
+
this.restApiService.apiDelegate(request).pipe(takeUntil(this.unsubscribe)).subscribe({
|
|
122
|
+
next: (res) => {
|
|
123
|
+
this.programData.data = res.data;
|
|
124
|
+
this.programData.from = res.from;
|
|
125
|
+
this.programData.to = res.to;
|
|
126
|
+
this.programData.totalPages = res.totalPages;
|
|
127
|
+
this.programData.totalRecords = res.totalRecords;
|
|
128
|
+
this.programData.AllInternalControlsProgramsCount = res.AllInternalControlsProgramsCount;
|
|
129
|
+
this.programData.AllOthersProgramsCount = res.AllOthersProgramsCount;
|
|
130
|
+
this.programData.AllRegulationProgramsCount = res.AllRegulationProgramsCount;
|
|
131
|
+
this.programData.AllStandardProgramsCount = res.AllStandardProgramsCount;
|
|
132
|
+
this.loader = false;
|
|
133
|
+
},
|
|
134
|
+
error: (err) => {
|
|
135
|
+
this.loader = false;
|
|
136
|
+
},
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
getCategories(data) {
|
|
140
|
+
var _a;
|
|
141
|
+
this.loader = true;
|
|
142
|
+
let params = new HttpParams();
|
|
143
|
+
params = params.append('parentId', (_a = this.selectedValues.program) === null || _a === void 0 ? void 0 : _a._id);
|
|
144
|
+
if (data === null || data === void 0 ? void 0 : data.search) {
|
|
145
|
+
params = params.append('q', this.searchText.category);
|
|
146
|
+
}
|
|
147
|
+
const request = {
|
|
148
|
+
method: 'get',
|
|
149
|
+
action: '/program/subCategories',
|
|
150
|
+
params
|
|
151
|
+
};
|
|
152
|
+
this.restApiService.apiDelegate(request).pipe(takeUntil(this.unsubscribe)).subscribe({
|
|
153
|
+
next: (res) => {
|
|
154
|
+
var _a, _b, _c, _d, _e;
|
|
155
|
+
this.subCategoriesList.from = (_a = res.items_from) !== null && _a !== void 0 ? _a : 1;
|
|
156
|
+
this.subCategoriesList.to = (_b = res.items_to) !== null && _b !== void 0 ? _b : 0;
|
|
157
|
+
this.subCategoriesList.totalPage = (_c = res.total_pages) !== null && _c !== void 0 ? _c : 0;
|
|
158
|
+
this.subCategoriesList.totalRecords = (_d = res.total_items) !== null && _d !== void 0 ? _d : 0;
|
|
159
|
+
this.subCategoriesList.data = (_e = res.data) !== null && _e !== void 0 ? _e : [];
|
|
160
|
+
this.loader = false;
|
|
161
|
+
},
|
|
162
|
+
error: (err) => {
|
|
163
|
+
this.loader = false;
|
|
164
|
+
},
|
|
165
|
+
});
|
|
166
|
+
}
|
|
167
|
+
changeTabProgram(type) {
|
|
168
|
+
this.activeTab = type;
|
|
169
|
+
this.programData.currentPage = 1;
|
|
170
|
+
this.searchText.program = '';
|
|
171
|
+
this.searchProgram.nativeElement.value = '';
|
|
172
|
+
this.getPrograms();
|
|
173
|
+
}
|
|
174
|
+
getResponsibilities(data) {
|
|
175
|
+
var _a, _b, _c, _d;
|
|
176
|
+
this.loader = true;
|
|
177
|
+
const request = {
|
|
178
|
+
method: 'get',
|
|
179
|
+
action: '/program/categoryResponsibilities',
|
|
180
|
+
payloadObject: {
|
|
181
|
+
"start_date": (_a = this.currentBusinessCycle) === null || _a === void 0 ? void 0 : _a.start_date,
|
|
182
|
+
"end_date": (_b = this.currentBusinessCycle) === null || _b === void 0 ? void 0 : _b.end_date,
|
|
183
|
+
"selected_cycle_arr": (_c = this.currentBusinessCycle) === null || _c === void 0 ? void 0 : _c.selected_cycle_arr,
|
|
184
|
+
"selected_cycle": (_d = this.currentBusinessCycle) === null || _d === void 0 ? void 0 : _d.selected_cycle,
|
|
185
|
+
'categoryIds': this.selectedIds.categories,
|
|
186
|
+
'pageNo': this.responsibilitiesList.currentPage,
|
|
187
|
+
'searchText': (data === null || data === void 0 ? void 0 : data.search) ? this.searchText.responsibility : ''
|
|
188
|
+
}
|
|
189
|
+
};
|
|
190
|
+
this.restApiService.apiDelegate(request).pipe(takeUntil(this.unsubscribe)).subscribe({
|
|
191
|
+
next: (res) => {
|
|
192
|
+
var _a, _b, _c, _d, _e;
|
|
193
|
+
this.loader = false;
|
|
194
|
+
this.responsibilitiesList.from = (_a = res.items_from) !== null && _a !== void 0 ? _a : 1;
|
|
195
|
+
this.responsibilitiesList.to = (_b = res.items_to) !== null && _b !== void 0 ? _b : 0;
|
|
196
|
+
this.responsibilitiesList.totalPage = (_c = res.total_pages) !== null && _c !== void 0 ? _c : 1;
|
|
197
|
+
this.responsibilitiesList.totalRecords = (_d = res.total_items) !== null && _d !== void 0 ? _d : 0;
|
|
198
|
+
this.responsibilitiesList.data = (_e = res.data) !== null && _e !== void 0 ? _e : [];
|
|
199
|
+
},
|
|
200
|
+
error: (err) => {
|
|
201
|
+
this.loader = false;
|
|
202
|
+
},
|
|
203
|
+
});
|
|
204
|
+
}
|
|
205
|
+
changePage(event, type) {
|
|
206
|
+
switch (type) {
|
|
207
|
+
case 'programs':
|
|
208
|
+
this.programData.currentPage = event;
|
|
209
|
+
this.getPrograms();
|
|
210
|
+
break;
|
|
211
|
+
case 'categories':
|
|
212
|
+
this.subCategoriesList.currentPage = event;
|
|
213
|
+
this.getCategories();
|
|
214
|
+
break;
|
|
215
|
+
case 'responsibilities':
|
|
216
|
+
this.responsibilitiesList.currentPage = event;
|
|
217
|
+
this.getResponsibilities();
|
|
218
|
+
break;
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
searchBy(event, type) {
|
|
222
|
+
switch (type) {
|
|
223
|
+
case 'programs':
|
|
224
|
+
if (this.searchText.program != event) {
|
|
225
|
+
this.searchText.program = event;
|
|
226
|
+
this.getPrograms({ search: true });
|
|
227
|
+
}
|
|
228
|
+
break;
|
|
229
|
+
case 'categories':
|
|
230
|
+
if (this.searchText.category != event) {
|
|
231
|
+
this.searchText.category = event;
|
|
232
|
+
this.getCategories({ search: true });
|
|
233
|
+
}
|
|
234
|
+
break;
|
|
235
|
+
case 'responsibilities':
|
|
236
|
+
if (this.searchText.responsibility != event) {
|
|
237
|
+
this.searchText.responsibility = event;
|
|
238
|
+
this.getResponsibilities({ search: true });
|
|
239
|
+
}
|
|
240
|
+
break;
|
|
241
|
+
}
|
|
242
|
+
}
|
|
243
|
+
selectProgram(event, data) {
|
|
244
|
+
if (event) {
|
|
245
|
+
this.selectedValues.program = data;
|
|
246
|
+
this.selectedIds.categories = [];
|
|
247
|
+
this.selectedValues.categories = [];
|
|
248
|
+
this.selectedIds.responsibilities = [];
|
|
249
|
+
this.selectedValues.responsibilities = [];
|
|
250
|
+
}
|
|
251
|
+
console.log("=============>", data);
|
|
252
|
+
}
|
|
253
|
+
selectCategory(event, category) {
|
|
254
|
+
if (event) {
|
|
255
|
+
this.selectedIds.categories.push(category.category_id);
|
|
256
|
+
this.selectedValues.categories.push(category);
|
|
257
|
+
}
|
|
258
|
+
else {
|
|
259
|
+
const index = this.selectedIds.categories.findIndex((element) => element == category.category_id);
|
|
260
|
+
this.selectedIds.categories.splice(index, 1);
|
|
261
|
+
const categoryIndex = this.selectedValues.categories.findIndex((ele) => ele.category_id == category.category_id);
|
|
262
|
+
this.selectedValues.categories.splice(categoryIndex, 1);
|
|
263
|
+
}
|
|
264
|
+
}
|
|
265
|
+
selectResponsibility(event, data) {
|
|
266
|
+
if (event) {
|
|
267
|
+
this.selectedIds.responsibilities.push(data.ReportId);
|
|
268
|
+
this.selectedValues.responsibilities.push(data);
|
|
269
|
+
}
|
|
270
|
+
else {
|
|
271
|
+
const index = this.selectedIds.responsibilities.findIndex((element) => element == data.ReportId);
|
|
272
|
+
this.selectedIds.responsibilities.splice(index, 1);
|
|
273
|
+
const reportIndex = this.selectedValues.responsibilities.findIndex((ele) => ele.ReportId == data.ReportId);
|
|
274
|
+
this.selectedValues.responsibilities.splice(reportIndex, 1);
|
|
275
|
+
}
|
|
276
|
+
}
|
|
277
|
+
goBack(from) {
|
|
278
|
+
if (from) {
|
|
279
|
+
switch (from) {
|
|
280
|
+
case 'categories':
|
|
281
|
+
this.currentList = 'programs';
|
|
282
|
+
this.selectedIds.categories = [];
|
|
283
|
+
break;
|
|
284
|
+
case 'responsibilities':
|
|
285
|
+
this.currentList = 'categories';
|
|
286
|
+
this.selectedIds.responsibilities = [];
|
|
287
|
+
break;
|
|
288
|
+
}
|
|
289
|
+
}
|
|
290
|
+
else {
|
|
291
|
+
this.close.emit();
|
|
292
|
+
}
|
|
293
|
+
}
|
|
294
|
+
remove(type, item) {
|
|
295
|
+
switch (type) {
|
|
296
|
+
case 'programs':
|
|
297
|
+
this.selectedValues.program = {};
|
|
298
|
+
this.selectedValues.categories = [];
|
|
299
|
+
this.selectedValues.responsibilities = [];
|
|
300
|
+
break;
|
|
301
|
+
case 'categories':
|
|
302
|
+
const categoryIndex = this.selectedValues.categories.findIndex((ele) => ele.category_id == item.category_id);
|
|
303
|
+
if (categoryIndex != -1) {
|
|
304
|
+
this.selectedValues.categories.splice(categoryIndex, 1);
|
|
305
|
+
this.selectedValues.responsibilities = [];
|
|
306
|
+
}
|
|
307
|
+
const categoryIdIndex = this.selectedIds.categories.findIndex((element) => element == item.category_id);
|
|
308
|
+
if (categoryIdIndex != -1) {
|
|
309
|
+
this.selectedIds.categories.splice(categoryIdIndex, 1);
|
|
310
|
+
}
|
|
311
|
+
break;
|
|
312
|
+
case 'responsibilities':
|
|
313
|
+
const respIndex = this.selectedValues.responsibilities.findIndex((ele) => ele.ReportId == item.ReportId);
|
|
314
|
+
if (respIndex != -1) {
|
|
315
|
+
this.selectedValues.responsibilities.splice(respIndex, 1);
|
|
316
|
+
}
|
|
317
|
+
const index = this.selectedIds.responsibilities.findIndex((element) => element == item.ReportId);
|
|
318
|
+
if (index != -1) {
|
|
319
|
+
this.selectedIds.responsibilities.splice(index, 1);
|
|
320
|
+
}
|
|
321
|
+
break;
|
|
322
|
+
}
|
|
323
|
+
}
|
|
324
|
+
saveChanges(type) {
|
|
325
|
+
switch (type) {
|
|
326
|
+
case 'programs':
|
|
327
|
+
this.currentList = 'categories';
|
|
328
|
+
this.selectedValues.categories = [];
|
|
329
|
+
this.selectedValues.responsibilities = [];
|
|
330
|
+
this.getCategories();
|
|
331
|
+
break;
|
|
332
|
+
case 'categories':
|
|
333
|
+
this.currentList = 'responsibilities';
|
|
334
|
+
this.selectedValues.responsibilities = [];
|
|
335
|
+
this.getResponsibilities();
|
|
336
|
+
break;
|
|
337
|
+
case 'responsibilities':
|
|
338
|
+
this.submitprogramIntegration();
|
|
339
|
+
break;
|
|
340
|
+
case 'programsOnly':
|
|
341
|
+
this.displayConfirmationMessage = true;
|
|
342
|
+
break;
|
|
343
|
+
}
|
|
344
|
+
}
|
|
345
|
+
saveChangesFromProgram(event) {
|
|
346
|
+
if (event) {
|
|
347
|
+
this.displayConfirmationMessage = false;
|
|
348
|
+
this.submitprogramIntegration();
|
|
349
|
+
}
|
|
350
|
+
else {
|
|
351
|
+
this.displayConfirmationMessage = false;
|
|
352
|
+
}
|
|
353
|
+
}
|
|
354
|
+
submitprogramIntegration() {
|
|
355
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l;
|
|
356
|
+
// this.submissionLoader = true;
|
|
357
|
+
let params = new HttpParams();
|
|
358
|
+
params = params.append('mode', 'programPolicyUpdate/update');
|
|
359
|
+
const categoryArray = (_a = this.selectedIds) === null || _a === void 0 ? void 0 : _a.categories;
|
|
360
|
+
const payload = {
|
|
361
|
+
policyId: (_c = (_b = this.policy) === null || _b === void 0 ? void 0 : _b.contract_id) !== null && _c !== void 0 ? _c : 0,
|
|
362
|
+
report_ids: (_e = (_d = this.selectedIds) === null || _d === void 0 ? void 0 : _d.responsibilities) !== null && _e !== void 0 ? _e : 0,
|
|
363
|
+
category_id: [...new Set(categoryArray)],
|
|
364
|
+
parentId: (_g = (_f = this.selectedValues) === null || _f === void 0 ? void 0 : _f.program) === null || _g === void 0 ? void 0 : _g.category_id
|
|
365
|
+
};
|
|
366
|
+
const currentBusinessCycle = {
|
|
367
|
+
"start_date": (_h = this.currentBusinessCycle) === null || _h === void 0 ? void 0 : _h.start_date,
|
|
368
|
+
"end_date": (_j = this.currentBusinessCycle) === null || _j === void 0 ? void 0 : _j.end_date,
|
|
369
|
+
"selected_cycle_arr": (_k = this.currentBusinessCycle) === null || _k === void 0 ? void 0 : _k.selected_cycle_arr,
|
|
370
|
+
"selected_cycle": (_l = this.currentBusinessCycle) === null || _l === void 0 ? void 0 : _l.selected_cycle,
|
|
371
|
+
};
|
|
372
|
+
let linkProgram = {
|
|
373
|
+
added: [payload],
|
|
374
|
+
removed: []
|
|
375
|
+
};
|
|
376
|
+
let selectedProgram = {
|
|
377
|
+
selectedValues: this.selectedValues,
|
|
378
|
+
linkProgram: linkProgram,
|
|
379
|
+
};
|
|
380
|
+
console.log("link Program Payload =>", payload);
|
|
381
|
+
this.updatedProgramDetails.emit(selectedProgram);
|
|
382
|
+
this.submissionLoader = false;
|
|
383
|
+
const request = {
|
|
384
|
+
method: 'post',
|
|
385
|
+
action: '/compliance_post',
|
|
386
|
+
params,
|
|
387
|
+
data: payload,
|
|
388
|
+
businessCycle: currentBusinessCycle
|
|
389
|
+
};
|
|
390
|
+
// this.restApiService.apiDelegate(request).pipe(takeUntil(this.unsubscribe)).subscribe({
|
|
391
|
+
// next: (res: any) => {
|
|
392
|
+
// this.submissionLoader = false;
|
|
393
|
+
// this.snackbar.show('The program has been linked with this Policy.', 'success');
|
|
394
|
+
// setTimeout(() => {
|
|
395
|
+
// if(this.currentTab != 'linked_programs'){
|
|
396
|
+
// this.refreshLinkedPolicies.emit();
|
|
397
|
+
// // this.changeTab.emit();
|
|
398
|
+
// }
|
|
399
|
+
// this.close.emit();
|
|
400
|
+
// }, 1000);
|
|
401
|
+
// },
|
|
402
|
+
// error: (err: any) => {
|
|
403
|
+
// this.submissionLoader = false;
|
|
404
|
+
// this.snackbar.show("Oops Something went wrong and we were unable to complete this action. Let's give it another try shall we ?");
|
|
405
|
+
// },
|
|
406
|
+
// });
|
|
407
|
+
}
|
|
408
|
+
}
|
|
409
|
+
LinkProgramComponent.decorators = [
|
|
410
|
+
{ type: Component, args: [{
|
|
411
|
+
selector: 'vc-link-program',
|
|
412
|
+
template: "<div class=\"link-policy\" [class.animate]=\"animation\">\r\n <ng-container *ngIf=\"currentList =='programs'\">\r\n <div class=\"program-listing-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\">\r\n <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Select a Program</div>\r\n <!-- <button (click)=\"goBack()\" class=\"back-btn vx-fs-12 vx-fw-500 vx-lable-txt vx-tt-uppercase vx-p-0 vx-m-0 vx-d-flex vx-align-center\"><i class=\"icons vx-mr-1\"></i> Back</button> -->\r\n </div>\r\n <div class=\"program-listing-body\">\r\n <div class=\"filter-card-row vx-d-flex vx-mb-2\">\r\n <div class=\"filter-card vx-bg-white vx-d-flex vx-justify-between vx-align-center vx-pt-2 vx-pb-2 vx-pl-3 vx-pr-3 vx-w-100\" [class.active]=\"activeTab == 'regulations'\" (click)=\"changeTabProgram('regulations')\">\r\n <div class=\"left vx-d-block vx-w-100\">\r\n <div class=\"label vx-d-flex vx-align-center\">\r\n <div class=\"vx-d-block vx-lh-3\">\r\n <label class=\"vx-paragraph-txt vx-fw-500 vx-tt-uppercase vx-d-flex vx-justify-between vx-align-center\">REGULATIONS</label>\r\n <span class=\"vx-fs-10 vx-fw-600 vx-label-txt vx-lh-4\" *ngIf=\"programData?.SelectedRegulationProgramsCount> 0\">{{programData?.SelectedRegulationProgramsCount}}\r\n {{(programData?.SelectedRegulationProgramsCount==1)?'Program':'Programs'}} selected</span>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"right vx-d-flex vx-justify-end vx-w-100\">\r\n <span class=\"counter vx-txt-white vx-fw-500 vx-d-inline-block vx-text-center\">{{programData?.AllRegulationProgramsCount}}</span>\r\n </div>\r\n </div>\r\n <div class=\"filter-card vx-bg-white vx-d-flex vx-justify-between vx-align-center vx-pt-2 vx-pb-2 vx-pl-3 vx-pr-3 vx-w-100\" [class.active]=\"activeTab == 'standards'\" (click)=\"changeTabProgram('standards')\">\r\n <div class=\"left vx-d-block vx-w-100\">\r\n <div class=\"label vx-d-flex vx-align-center\">\r\n <div class=\"vx-d-block vx-lh-3\">\r\n <label class=\"vx-paragraph-txt vx-fw-500 vx-tt-uppercase vx-d-flex vx-justify-between vx-align-center\">STANDARDS</label>\r\n <span class=\"vx-fs-10 vx-fw-600 vx-label-txt vx-lh-4\" *ngIf=\"programData?.SelectedStandardProgramsCount> 0\">{{programData?.SelectedStandardProgramsCount}}\r\n {{(programData?.SelectedStandardProgramsCount==1)?'Program':'Programs'}} selected</span>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"right vx-d-flex vx-justify-end vx-w-100\">\r\n <span class=\"counter vx-txt-white vx-fw-500 vx-d-inline-block vx-text-center\">{{programData?.AllStandardProgramsCount}}</span>\r\n </div>\r\n </div>\r\n <div class=\"filter-card vx-bg-white vx-d-flex vx-justify-between vx-align-center vx-pt-2 vx-pb-2 vx-pl-3 vx-pr-3 vx-w-100\" [class.active]=\"activeTab == 'internal_controls'\" (click)=\"changeTabProgram('internal_controls')\">\r\n <div class=\"left vx-d-block vx-w-100\">\r\n <div class=\"label vx-d-flex vx-align-center\">\r\n <div class=\"vx-d-block vx-lh-3\">\r\n <label class=\"vx-paragraph-txt vx-fw-500 vx-tt-uppercase vx-d-flex vx-justify-between vx-align-center\">INTERNAL CONTROLS</label>\r\n <span class=\"vx-fs-10 vx-fw-600 vx-label-txt vx-lh-4\" *ngIf=\"programData?.SelectedInternalControlsProgramsCount> 0\">{{programData?.SelectedInternalControlsProgramsCount}}\r\n {{(programData?.SelectedInternalControlsProgramsCount==1)?'Program':'Programs'}} selected</span>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"right vx-d-flex vx-justify-end vx-w-100\">\r\n <span class=\"counter vx-txt-white vx-fw-500 vx-d-inline-block vx-text-center\">{{programData?.AllInternalControlsProgramsCount}}</span>\r\n </div>\r\n </div>\r\n <div class=\"filter-card vx-bg-white vx-d-flex vx-justify-between vx-align-center vx-pt-2 vx-pb-2 vx-pl-3 vx-pr-3 vx-w-100\" [class.active]=\"activeTab == 'others'\" (click)=\"changeTabProgram('others')\">\r\n <div class=\"left vx-d-block vx-w-100\">\r\n <div class=\"label vx-d-flex vx-align-center\">\r\n <div class=\"vx-d-block vx-lh-3\">\r\n <label class=\"vx-paragraph-txt vx-fw-500 vx-tt-uppercase vx-d-flex vx-justify-between vx-align-center\">OTHERS</label>\r\n <span class=\"vx-fs-10 vx-fw-600 vx-label-txt vx-lh-4\" *ngIf=\"programData?.SelectedOthersProgramsCount> 0\">{{programData?.SelectedOthersProgramsCount}}\r\n {{(programData?.SelectedOthersProgramsCount==1)?'Program':'Programs'}} selected</span>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"right vx-d-flex vx-justify-end vx-w-100\">\r\n <span class=\"counter vx-txt-white vx-fw-500 vx-d-inline-block vx-text-center\">{{programData?.AllOthersProgramsCount}}</span>\r\n </div>\r\n </div>\r\n\r\n\r\n <!-- <div class=\"filter-card\" [class.active]=\"activeTab == 'regulations'\" (click)=\"changeTabProgram('regulations')\">\r\n <div class=\"left\">\r\n <label>REGULATIONS</label>\r\n <p *ngIf=\"programData?.SelectedRegulationProgramsCount> 0\">\r\n {{programData?.SelectedRegulationProgramsCount}}\r\n {{(programData?.SelectedRegulationProgramsCount==1)?'Program':'Programs'}} selected\r\n </p>\r\n </div>\r\n <span class=\"counter\">{{programData?.AllRegulationProgramsCount}}</span>\r\n </div> -->\r\n <!-- <div class=\"filter-card\" [class.active]=\"activeTab == 'standards'\" (click)=\"changeTabProgram('standards')\">\r\n <div class=\"left\">\r\n <label>STANDARDS</label>\r\n <p *ngIf=\"programData?.SelectedStandardProgramsCount> 0\">\r\n {{programData?.SelectedStandardProgramsCount}}\r\n {{(programData?.SelectedStandardProgramsCount==1)?'Program':'Programs'}} selected\r\n </p>\r\n </div>\r\n <span class=\"counter\">{{programData?.AllStandardProgramsCount}}</span>\r\n </div> -->\r\n <!-- <div class=\"filter-card\" [class.active]=\"activeTab == 'internal_controls'\" (click)=\"changeTabProgram('internal_controls')\">\r\n <div class=\"left\">\r\n <label>INTERNAL CONTROLS</label>\r\n <p *ngIf=\"programData?.SelectedInternalControlsProgramsCount> 0\">\r\n {{programData?.SelectedInternalControlsProgramsCount}}\r\n {{(programData?.SelectedInternalControlsProgramsCount==1)?'Program':'Programs'}} selected\r\n </p>\r\n </div>\r\n <span class=\"counter\">{{programData?.AllInternalControlsProgramsCount}}</span>\r\n </div> -->\r\n <!-- <div class=\"filter-card\" [class.active]=\"activeTab == 'others'\" (click)=\"changeTabProgram('others')\">\r\n <div class=\"left\">\r\n <label>OTHERS</label>\r\n <p *ngIf=\"programData?.SelectedOthersProgramsCount> 0\">\r\n {{programData?.SelectedOthersProgramsCount}}\r\n {{(programData?.SelectedOthersProgramsCount==1)?'Program':'Programs'}} selected\r\n </p>\r\n </div>\r\n <span class=\"counter\">{{programData?.AllOthersProgramsCount}}</span>\r\n </div> -->\r\n </div>\r\n <div class=\"link-policy-search vx-mb-2\">\r\n <i class=\"icons vx-fs-12\"></i>\r\n <input type=\"text\" placeholder=\"Search Programs\" #searchProgram\r\n (keyup.enter)=\"searchBy($event.target.value,'programs')\" />\r\n </div>\r\n <vui-pagination *ngIf=\"(!loader) && programData.totalPages>1\" [from]=\"programData.from\"\r\n [to]=\"programData.to\" [total]=\"programData.totalRecords\" [showPageDetail]=\"true\"\r\n [totalPage]=\"programData.totalPages\" [currentPage]=\"programData.currentPage\" [pageInSingleView]=\"5\"\r\n (pageChanged)=\"changePage($event,'programs')\">\r\n </vui-pagination>\r\n <div class=\"program-listing-part vx-mb-4\" [class.with-pagination]=\"(!loader) && programData.totalPages>1\">\r\n <app-no-data *ngIf=\"programData?.data?.length==0 && !loader\"\r\n [noDataImage]=\"'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/search-data.svg'\" [noDataText]=\"'No data to display'\"></app-no-data>\r\n\r\n <div class=\"program-listing-item\" [class.active]=\"selectedValues?.program?.category_id == program?.category_id\"\r\n *ngFor=\"let program of programData.data;let i = index\">\r\n <div class=\"table-row main-list\" [class.active]=\"selectedValues?.program?.category_id == program?.category_id\"\r\n [class.disabled]=\"program?.programReportExists==0\" (click)=\"selectProgram(true,program)\">\r\n <div class=\"table-column serial\">\r\n <div class=\"sr-no\" [appTooltip]=\"i+programData.from\" placement=\"bottom\" delay=\"0\" type=\"black\"\r\n [tooltipMandatory]=\"true\">{{i+programData.from}}</div>\r\n\r\n <app-cs-radio [name]=\"'policyName'\"\r\n [checked]=\"selectedValues?.program?.category_id == program?.category_id\"\r\n (checkedEvent)=\"selectProgram($event.target.checked,program)\"></app-cs-radio>\r\n </div>\r\n <div class=\"table-column name\">\r\n <div class=\"name-inner\">\r\n <div class=\"name-with-count\">\r\n <div class=\"value\" appTooltip=\"{{program?.name | tooltipValidation}}\" placement=\"bottom-left\" delay=\"0\"\r\n type=\"black\" [tooltipMandatory]=\"false\">{{program?.name}}</div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n\r\n </div>\r\n </div>\r\n\r\n <div class=\"link-policy-floating-bar vx-d-flex vx-align-center vx-justify-between vx-p-3\">\r\n <div class=\"link-policy-floating-bar-left vx-d-flex vx-align-center\">\r\n <div class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\" *ngIf=\"selectedValues?.program?.name\">\r\n <i class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\" (click)=\"remove('programs','')\"></i>\r\n <span class=\"chipName vx-fs-11 vx-label-txt\" [appTooltip]=\"selectedValues?.program?.name\" placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"false\">{{selectedValues?.program?.name}}</span>\r\n </div>\r\n\r\n <!-- <div class=\"chip vx-pl-2 vx-pr-2 vx-txt-blue vx-fs-12 vx-lh-6 vx-mr-1\" *ngIf=\"selectedValues?.program?.name\"><i class=\"icons vx-mr-1\" (click)=\"remove('programs','')\"></i>{{selectedValues?.program?.name}}</div> -->\r\n <!-- <div class=\"vx-fs-12 vx-fw-500 vx-paragraph-txt vx-ml-2\">Policy selected</div> -->\r\n\r\n </div>\r\n <div class=\"link-policy-floating-bar-right vx-d-flex vx-align-center\">\r\n <button (click)=\"goBack()\" class=\"cancel-btn vx-fs-11 vx-fw-500 vx-tt-uppercase vx-m-0 vx-mr-2 vx-d-flex vx-align-center vx-justify-center vx-txt-red\">CANCEL</button>\r\n <button (click)=\"saveChanges('programs')\" [class.disabled]=\"!selectedValues?.program?.name\" class=\"white-btn vx-fs-11 vx-fw-500 vx-tt-uppercase vx-m-0 vx-mr-1 vx-d-flex vx-align-center vx-justify-center vx-txt-blue\">\r\n LINK CATEGORIES AND RESPONSIBILITIES</button>\r\n <button (click)=\"saveChanges('programsOnly')\" [class.disabled]=\"!selectedValues?.program?.name\" class=\"next-btn vx-fs-11 vx-fw-500 vx-tt-uppercase vx-m-0 vx-d-flex vx-align-center vx-justify-center vx-txt-white\">Link\r\n <i class=\"icons vx-ml-2\"></i></button>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"program-listing-confirmation\" *ngIf=\"displayConfirmationMessage\">\r\n <div class=\"confirmation-top\">\r\n <div class=\"icon-block\"><i class=\"icons\"></i></div>\r\n <div class=\"text\">You have opted to link all the responsibilities under the selected program \"{{selectedValues?.program?.name }}\" and it's sub-categories.</div>\r\n </div>\r\n <div class=\"confirmation-bottom\">\r\n <div class=\"message\">Are you sure you would like to proceed?</div>\r\n <div class=\"button-group\">\r\n <button class=\"no-btn\" (click)=\"saveChangesFromProgram(false)\">NO</button>\r\n <button class=\"yes-btn\" (click)=\"saveChangesFromProgram(true)\">YES</button>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"currentList=='categories'\">\r\n <div class=\"link-policy-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\">\r\n <div class=\"vx-fs-14 vx-fw-500 vx-label-txt vx-d-flex vx-align-center\"><button (click)=\"goBack('categories')\" class=\"back-btn vx-fs-14 vx-fw-500 vx-lable-txt vx-p-0 vx-mr-2 vx-d-flex vx-align-center\"><i class=\"icons\"></i></button> Select Categories to link with this policy</div>\r\n </div>\r\n <div class=\"link-policy-body\">\r\n <div class=\"link-policy-search vx-mb-2\">\r\n <i class=\"icons vx-fs-12\"></i>\r\n <input type=\"text\" placeholder=\"Search categories\" #searchCategory\r\n (keyup.enter)=\"searchBy($event.target.value,'categories')\" />\r\n </div>\r\n <vui-pagination *ngIf=\"(!loader) && subCategoriesList.totalPage>1\" [from]=\"subCategoriesList.from\"\r\n [to]=\"subCategoriesList.to\" [total]=\"subCategoriesList.totalRecords\" [showPageDetail]=\"true\"\r\n [totalPage]=\"subCategoriesList.totalPage\" [currentPage]=\"subCategoriesList.currentPage\" [pageInSingleView]=\"5\"\r\n (pageChanged)=\"changePage($event,'programs')\">\r\n </vui-pagination>\r\n\r\n <div class=\"link-policy-table vx-mb-4\" [class.with-pagination]=\"(!loader) && subCategoriesList.totalPage>1\">\r\n <ng-container *ngIf=\"!loader && subCategoriesList.data?.length>0\">\r\n <div class=\"table-header\">\r\n <div class=\"table-row\">\r\n <div\r\n class=\"table-column vx-fs-10 vx-fw-500 vx-label-txt vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\">\r\n #</div>\r\n <div\r\n class=\"table-column vx-fs-10 vx-fw-500 vx-label-txt vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center category-name\">\r\n CATEGORIES</div>\r\n </div>\r\n </div>\r\n <div class=\"table-body\">\r\n <!-- when checkbox was checked then active class was true -->\r\n <div class=\"table-row\" [class.active]=\"selectedIds.categories.includes(category.category_id)\"\r\n *ngFor=\"let category of subCategoriesList.data; let i = index;\">\r\n <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\">\r\n <div class=\"sr-no\" [appTooltip]=\"i+subCategoriesList.from\" placement=\"bottom\" delay=\"0\"\r\n type=\"black\" [tooltipMandatory]=\"true\">{{i+subCategoriesList.from}}</div>\r\n <vui-checkbox [checked]=\"selectedIds.categories.includes(category.category_id)\"\r\n (change)=\"selectCategory($event.target.checked,category)\"></vui-checkbox>\r\n </div>\r\n <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center category-name\">\r\n <div class=\"vx-d-block vx-w-100\">\r\n\r\n <div class=\"value vx-fs-12 vx-label-txt\" [appTooltip]=\"category?.item_name | tooltipValidation\"\r\n placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"false\">\r\n {{category?.item_name}}</div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n\r\n\r\n <app-no-data *ngIf=\"!loader && subCategoriesList.data?.length==0\"\r\n [noDataImage]=\"'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/search-data.svg'\" [noDataText]=\"'No data to display'\"></app-no-data>\r\n </div>\r\n\r\n <div class=\"link-policy-floating-bar vx-d-flex vx-align-center vx-justify-between vx-p-3\">\r\n <div class=\"link-policy-floating-bar-left vx-d-flex vx-align-center\">\r\n <div class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\" *ngIf=\"selectedValues?.categories?.length>0\">\r\n <i class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\" (click)=\"remove('categories',selectedValues?.categories[0])\"></i>\r\n <span class=\"chipName vx-fs-11 vx-label-txt\" [appTooltip]=\"selectedValues?.categories[0]?.item_name\" placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"false\">{{selectedValues?.categories[0]?.item_name}}</span>\r\n <button class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\" appPopover (click)=\"programCount.popover()\" placement=\"left\" *ngIf=\"selectedValues?.categories?.length>1\">+{{selectedValues?.categories?.slice(1).length}}</button>\r\n </div>\r\n <app-popover #programCount>\r\n <div class=\"wf-action-list\">\r\n <ul class=\"action-item\">\r\n <li *ngFor=\"let selectedCategory of selectedValues?.categories?.slice(1)\">\r\n <div class=\"avatar-card\">\r\n <i class=\"icons cross-btn vx-fs-12 vx-paragaph-txt vx-mr-2\" (click)=\"remove('categories',selectedCategory)\"></i>\r\n <span class=\"value\">{{selectedCategory?.item_name}}</span>\r\n </div>\r\n </li>\r\n </ul>\r\n </div>\r\n </app-popover>\r\n\r\n\r\n <!-- <div class=\"chip vx-pl-2 vx-pr-2 vx-txt-blue vx-fs-12 vx-lh-6 vx-mr-1\" *ngIf=\"selectedValues.categories.length>0\"><i (click)=\"remove('categories',selectedValues?.categories[0])\" class=\"icons vx-mr-1\"></i> {{selectedValues?.categories[0]?.item_name}}</div>\r\n <ng-container *ngIf=\"selectedValues.categories.length>1\">\r\n <button class=\"count vx-fs-12 vx-fw-500 vx-txt-white vx-p-0 vx-pl-1 vx-pr-1 vx-m-0 vx-ml-1 vx-d-flex vx-align-center vx-justify-center\" vcPopover (click)=\"programCount.popover()\" position=\"left\">+{{selectedValues?.categories?.slice(1).length}}</button>\r\n <div class=\"vx-fs-12 vx-fw-500 vx-paragraph-txt vx-ml-2\">{{(selectedValues?.categories?.slice(1)?.length==1)?'Category selected':'Categories selected'}}</div>\r\n <app-popover #programCount>\r\n <div class=\"wf-action-list\">\r\n <ul class=\"action-item\">\r\n <li *ngFor=\"let selectedCategory of selectedValues?.categories?.slice(1)\">\r\n <div class=\"avatar-card\">\r\n <i class=\"icons cross-btn vx-fs-12 vx-txt-blue vx-mr-2\" (click)=\"remove('categories',selectedCategory)\"></i>\r\n <span class=\"value\">{{selectedCategory?.item_name}}</span>\r\n </div>\r\n </li>\r\n </ul>\r\n </div>\r\n </app-popover>\r\n </ng-container> -->\r\n </div>\r\n <div class=\"link-policy-floating-bar-right vx-d-flex vx-align-center\">\r\n <button (click)=\"goBack('categories')\" class=\"cancel-btn vx-fs-11 vx-fw-500 vx-tt-uppercase vx-d-flex vx-align-center vx-justify-center vx-txt-red\">CANCEL</button>\r\n <button (click)=\"saveChanges('categories')\" [class.disabled]=\"!selectedValues?.categories?.length\" class=\"next-btn vx-fs-11 vx-fw-500 vx-tt-uppercase vx-d-flex vx-align-center vx-justify-center vx-txt-white\">Add <i class=\"icons vx-ml-2\"></i></button>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"currentList=='responsibilities'\">\r\n <div class=\"link-policy-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\">\r\n <div class=\"page-title vx-fs-14 vx-fw-500 vx-label-txt\">Select Responsibilities to link with this policy </div>\r\n <!-- <button (click)=\"goBack('responsibilities')\"\r\n class=\"back-btn vx-fs-14 vx-fw-500 vx-label-txt vx-tt-uppercase vx-p-0 vx-m-0 vx-d-flex vx-align-center\"><i\r\n class=\"icons vx-mr-1\"></i> BACK</button> -->\r\n </div>\r\n <div class=\"link-policy-body vx-p-4 vx-pb-3\">\r\n <div class=\"link-policy-search vx-mb-2\">\r\n <i class=\"icons vx-fs-12\"></i>\r\n <input type=\"text\" placeholder=\"Search Responsibilities\" (keyup.enter)=\"searchBy($event.target.value,'responsibilities')\" />\r\n </div>\r\n <vui-pagination *ngIf=\"(!loader) && responsibilitiesList.totalPage>1\" [from]=\"responsibilitiesList.from\"\r\n [to]=\"responsibilitiesList.to\" [total]=\"responsibilitiesList.totalRecords\" [showPageDetail]=\"true\"\r\n [totalPage]=\"responsibilitiesList.totalPage\" [currentPage]=\"responsibilitiesList.currentPage\" [pageInSingleView]=\"5\"\r\n (pageChanged)=\"changePage($event,'responsibilities')\">\r\n </vui-pagination>\r\n\r\n <div class=\"link-policy-table\" [class.with-pagination]=\"(!loader) && subCategoriesList.totalPage>1\">\r\n <ng-container *ngIf=\"!loader && responsibilitiesList.data?.length>0\">\r\n <div class=\"table-header\">\r\n <div class=\"table-row\">\r\n <div\r\n class=\"table-column vx-fs-10 vx-fw-500 vx-label-txt vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\">\r\n #</div>\r\n <div\r\n class=\"table-column vx-fs-10 vx-fw-500 vx-label-txt vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center category-name\">\r\n RESPONSIBLITIES</div>\r\n </div>\r\n </div>\r\n <div class=\"table-body\">\r\n <!-- when checkbox was checked then active class was true -->\r\n\r\n <div class=\"table-row\"\r\n [class.active]=\"selectedIds.responsibilities.includes(responsibility.ReportId)\"\r\n *ngFor=\"let responsibility of responsibilitiesList.data; let i = index;\">\r\n <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\">\r\n <div class=\"sr-no\" [appTooltip]=\"i+responsibilitiesList.from\" placement=\"bottom\" delay=\"0\"\r\n type=\"black\" [tooltipMandatory]=\"true\">{{i+responsibilitiesList.from}}</div>\r\n <vui-checkbox\r\n [checked]=\"selectedIds.responsibilities.includes(responsibility.ReportId)\"\r\n (change)=\"selectResponsibility($event.target.checked,responsibility)\">\r\n </vui-checkbox>\r\n </div>\r\n <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center category-name\">\r\n\r\n <div class=\"value vx-fs-12 vx-label-txt\" [appTooltip]=\"responsibility?.control_id + responsibility?.ReportName | tooltipValidation\"\r\n placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"false\">\r\n <span class=\"vx-fs-10 vx-fw-500 vx-tt-uppercase vx-mr-1\">{{responsibility?.control_id}}</span> {{responsibility?.ReportName}}</div>\r\n </div>\r\n <!-- <div class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center category-name\">\r\n <div class=\"value vx-fs-12 vx-label-txt\"\r\n [appTooltip]=\"'[CID-20210005] A.8.1.3 Acceptable Use of Assets'\" placement=\"bottom-left\"\r\n delay=\"0\" type=\"black\" [tooltipMandatory]=\"false\"><span\r\n class=\"vx-fs-10 vx-fw-500 vx-tt-uppercase vx-mr-1\">[CID-20210005]</span> A.8.1.3\r\n Acceptable Use of Assets</div>\r\n </div> -->\r\n </div>\r\n </div>\r\n </ng-container>\r\n\r\n <app-no-data *ngIf=\"!loader && responsibilitiesList.data?.length==0\"\r\n [noDataImage]=\"'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/search-data.svg'\" [noDataText]=\"'No data to display'\"></app-no-data>\r\n </div>\r\n <div class=\"link-policy-floating-bar vx-d-flex vx-align-center vx-justify-between vx-p-3 vx-mt-1\">\r\n <div class=\"link-policy-floating-bar-left vx-d-flex vx-align-center\">\r\n <div class=\"chip vx-pl-2 vx-pr-2 vx-txt-blue vx-fs-12 vx-lh-6 vx-mr-1\"\r\n *ngIf=\"selectedValues.responsibilities.length>0\"><i\r\n (click)=\"remove('responsibilities',selectedValues?.responsibilities[0])\"\r\n class=\"icons vx-mr-1\"></i> {{selectedValues?.responsibilities[0]?.ReportName}}</div>\r\n <ng-container *ngIf=\"selectedValues.responsibilities.length>1\">\r\n <button\r\n class=\"count vx-fs-12 vx-fw-500 vx-txt-white vx-p-0 vx-pl-1 vx-pr-1 vx-m-0 vx-ml-1 vx-d-flex vx-align-center vx-justify-center\"\r\n vcPopover (click)=\"responsibilitiesPopover.popover()\"\r\n position=\"left\">+{{selectedValues?.responsibilities?.slice(1).length}}</button>\r\n <div class=\"vx-fs-12 vx-fw-500 vx-paragraph-txt vx-ml-2\">\r\n {{(selectedValues?.responsibilities?.slice(1)?.length==1)?'Responsibility\r\n selected':'Responsibilities selected'}}</div>\r\n <app-popover #responsibilitiesPopover>\r\n <div class=\"wf-action-list\">\r\n <ul class=\"action-item\">\r\n <li *ngFor=\"let selectedres of selectedValues?.responsibilities?.slice(1)\">\r\n <div class=\"avatar-card\">\r\n <i class=\"icons cross-btn vx-fs-12 vx-txt-blue vx-mr-2\" (click)=\"remove('responsibilities',selectedres)\"></i>\r\n <span class=\"value\">{{selectedres?.ReportName}}</span>\r\n </div>\r\n </li>\r\n </ul>\r\n </div>\r\n </app-popover>\r\n </ng-container>\r\n\r\n </div>\r\n <div class=\"link-policy-floating-bar-right vx-d-flex vx-align-center\">\r\n <button (click)=\"goBack('responsibilities')\"\r\n class=\"cancel-btn vx-fs-11 vx-fw-500 vx-tt-uppercase vx-d-flex vx-align-center vx-justify-center vx-txt-red\">CANCEL</button>\r\n <button (click)=\"saveChanges('responsibilities')\" [class.disabled]=\"!selectedValues?.responsibilities?.length\"\r\n class=\"next-btn vx-fs-11 vx-fw-500 vx-tt-uppercase vx-d-flex vx-align-center vx-justify-center vx-txt-white\">ADD\r\n <i class=\"icons vx-ml-2\"></i></button>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <app-loader *ngIf=\"loader || submissionLoader\"></app-loader>\r\n\r\n\r\n</div>\r\n",
|
|
413
|
+
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\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";::ng-deep .link-policy{position:fixed;top:0;right:500px;bottom:0;left:0}::ng-deep .link-policy:before{background:#1E5DD3;content:\"\";position:absolute;top:0;left:0;right:0;width:100%;height:3px}::ng-deep .link-policy.animate{animation:.5s cubic-bezier(.25,.46,.45,.94) both animate-right}::ng-deep .link-policy-head{background:#fbfbfb;height:2.75rem;border-bottom:1px solid #f1f1f1}::ng-deep .link-policy-head button.back-btn{background:transparent;border-radius:0;border:none}::ng-deep .link-policy-body{background:#fff;height:calc(100vh - 2.75rem);padding:2rem}::ng-deep .link-policy-search{position:relative}::ng-deep .link-policy-search 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 .link-policy-search input::placeholder{color:#747576;opacity:1}::ng-deep .link-policy-search i{position:absolute;left:1rem;top:1rem;pointer-events:none;color:#f1f1f1;font-size:12px}::ng-deep .link-policy-table{overflow:hidden;overflow-y:auto;height:calc(100vh - 14rem)}::ng-deep .link-policy-table::-webkit-scrollbar-track{background-color:transparent}::ng-deep .link-policy-table .table-header{background:#fff;position:sticky;top:0;z-index:1}::ng-deep .link-policy-table .table-header .table-row{border:none!important;border-radius:0!important}::ng-deep .link-policy-table .table-header .table-row .table-column{line-height:1rem!important;min-height:1.5rem!important}::ng-deep .link-policy-table .table-row{border:1px solid #f1f1f1;border-radius:.25rem;display:flex;justify-content:space-between;position:relative;margin-bottom:.25rem}::ng-deep .link-policy-table .table-row:hover .table-column.serial .sr-no,::ng-deep .link-policy-table .table-row.active .table-column.serial .sr-no{opacity:0}::ng-deep .link-policy-table .table-row:hover .table-column.serial vui-cs-radio,::ng-deep .link-policy-table .table-row.active .table-column.serial vui-cs-radio,::ng-deep .link-policy-table .table-row:hover .table-column.serial vui-checkbox,::ng-deep .link-policy-table .table-row.active .table-column.serial vui-checkbox{opacity:1}::ng-deep .link-policy-table .table-row .table-column{min-height:2.5rem;position:relative;width:100%}::ng-deep .link-policy-table .table-row .table-column.serial{width:2rem;max-width:2rem;justify-content:center}::ng-deep .link-policy-table .table-row .table-column.serial .sr-no{width:1.25rem;background:#f8f8f8;writing-mode:vertical-lr;color:#747576;font-size:.625rem;font-weight:500;display:flex;height:2.5rem;align-items:center;justify-content:center;position:relative;transition:all .2s ease-in-out}::ng-deep .link-policy-table .table-row .table-column.serial vui-cs-radio{background:#fff;border-radius:50%;position:absolute;top:.75rem;left:.5rem;width:1rem;height:1rem;opacity:0;transition:all .2s ease-in-out}::ng-deep .link-policy-table .table-row .table-column.serial vui-cs-radio .radio-item .radio,::ng-deep .link-policy-table .table-row .table-column.serial vui-cs-radio .radio-item .radiomark{position:absolute;top:0}::ng-deep .link-policy-table .table-row .table-column.serial vui-checkbox{background:#fff;border-radius:.125rem;position:absolute;top:.75rem;left:.5rem;width:1rem;height:1rem;opacity:0;transition:all .2s ease-in-out}::ng-deep .link-policy-table .table-row .table-column.serial vui-checkbox .checkbox-item{position:absolute!important}::ng-deep .link-policy-table .table-row .table-column.serial vui-checkbox .checkbox-item .checkbox,::ng-deep .link-policy-table .table-row .table-column.serial vui-checkbox .checkbox-item .checkmark{position:absolute;top:0}::ng-deep .link-policy-table .table-row .table-column.policies{width:calc(100% - 28rem);min-width:calc(100% - 28rem)}::ng-deep .link-policy-table .table-row .table-column.policies .value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;width:calc(100% - 5rem)}::ng-deep .link-policy-table .table-row .table-column.categories{width:26rem;min-width:26rem}::ng-deep .link-policy-table .table-row .table-column.categories .value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;max-width:calc(100% - 1rem)}::ng-deep .link-policy-table .table-row .table-column.categories button.count{background:#1e5dd3;border:none;border-radius:.125rem;height:1.5rem}::ng-deep .link-policy-table .table-row .table-column.category-name{width:calc(100% - 2rem);min-width:calc(100% - 2rem)}::ng-deep .link-policy-table .table-row .table-column.category-name .value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;width:calc(100% - 5rem)}::ng-deep .link-policy .with-pagination{height:calc(100vh - 16rem)}::ng-deep .link-policy-floating-bar{background:#fff;border-radius:.25rem;box-shadow:0 2px 12px #4681ef40}::ng-deep .link-policy-floating-bar-left .counter{background:#34aa44;border-radius:.125rem;min-width:1.75rem}::ng-deep .link-policy-floating-bar-left .chip{background:#fff;border-radius:.125rem;box-shadow:0 2px 4px #1e5dd31a;height:1.5rem;display:block;max-width:13rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}::ng-deep .link-policy-floating-bar-left .chip i{position:relative;top:.0625rem;cursor:pointer}::ng-deep .link-policy-floating-bar-left button.count{background:#34aa44;border:none;border-radius:.125rem;height:1.5rem}::ng-deep .link-policy-floating-bar-right button{background:transparent;border:none;border-radius:.125rem;padding:0 .5rem;height:1.5rem}::ng-deep .link-policy-floating-bar-right button.white-btn{background:#fff;border:1px solid #f1f1f1}::ng-deep .link-policy-floating-bar-right button.white-btn.disabled{background:#f1f1f1!important;color:#747576!important;pointer-events:none!important}::ng-deep .link-policy-floating-bar-right button.next-btn{background:#1e5dd3}::ng-deep .link-policy-floating-bar-right button.next-btn.disabled{background:#f1f1f1!important;color:#747576!important;pointer-events:none!important}::ng-deep app-popover .wf-action-list ul.action-item li .avatar-card .cross-btn{cursor:pointer}::ng-deep .program-listing{position:fixed;top:0;right:500px;bottom:0;left:0}::ng-deep .program-listing:before{background:#1E5DD3;content:\"\";position:absolute;top:0;left:0;right:0;width:100%;height:3px}::ng-deep .program-listing-head{background:#fbfbfb;height:2.75rem;border-bottom:1px solid #f1f1f1}::ng-deep .program-listing-head button.back-btn{background:transparent;border:none;border-radius:0}::ng-deep .program-listing-body{background:#fff;height:calc(100vh - 2.75rem);padding:2rem}::ng-deep .program-listing-body .filter-card{box-shadow:0 0 2px #00000029;border-radius:.125rem;height:55px;cursor:pointer}::ng-deep .program-listing-body .filter-card.active{box-shadow:0 3px 12px #1e5dd340;border:none;pointer-events:none}::ng-deep .program-listing-body .filter-card.active span.counter{background:#F1F1F1;color:#042e7d}::ng-deep .program-listing-body .filter-card label{font-weight:500;text-transform:uppercase;color:#747576;line-height:16px;margin-left:0;font-size:11px;width:100%;pointer-events:none}::ng-deep .program-listing-body .filter-card p{line-height:16px;font-size:11px;color:#161b2f;font-weight:600;margin:0}::ng-deep .program-listing-body .filter-card span.counter{display:flex;height:28px;min-width:28px;border-radius:2px;background:#042E7D;color:#fff;font-size:11px;font-weight:600;justify-content:center;align-items:center;padding:0 4px;line-height:28px}::ng-deep .program-listing-body .filter-card .left{display:flex;flex-wrap:wrap}::ng-deep .program-listing-body .filter-card+.filter-card{margin-left:10px}::ng-deep .program-listing-body .filter-card-row .vx-table-card.active{box-shadow:0 3px 12px #1e5dd340!important}::ng-deep .program-listing-body .search-block{position:relative}::ng-deep .program-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-listing-body .search-block input::placeholder{font-weight:400}::ng-deep .program-listing-body .search-block input:focus{border-color:#1e5dd3}::ng-deep .program-listing-body .search-block i{position:absolute;left:1rem;top:1rem;pointer-events:none;color:#f1f1f1;font-size:12px}::ng-deep .program-listing-body .program-listing-part{height:calc(100vh - 288px);overflow:auto;padding:0 12px 0 0;width:calc(100% + 12px)}::ng-deep .program-listing-body .program-listing-part::-webkit-scrollbar-track{background-color:#fff;position:absolute}::ng-deep .program-listing-body .program-listing-part::-webkit-scrollbar{width:3px;height:3px;background-color:transparent;position:absolute}::ng-deep .program-listing-body .program-listing-part::-webkit-scrollbar-thumb{border-radius:3px;background-color:#dbdbdb;position:absolute}::ng-deep .program-listing-body .program-listing-part.with-pagination{height:calc(100vh - 320px)}::ng-deep .program-listing-body .program-listing-part .selected-area{background:#fff;height:32px;position:sticky;top:0;z-index:1}::ng-deep .program-listing-body .program-listing-part .selected-area app-cs-checkbox,::ng-deep .program-listing-body .program-listing-part .selected-area app-cs-checkbox-indeterminate{background:#fff;border-radius:2px;width:100%;height:16px}::ng-deep .program-listing-body .program-listing-part .selected-area app-cs-checkbox .checkbox-item,::ng-deep .program-listing-body .program-listing-part .selected-area app-cs-checkbox-indeterminate .checkbox-item{width:100%;position:relative}::ng-deep .program-listing-body .program-listing-part .selected-area app-cs-checkbox .checkbox-item .checkbox,::ng-deep .program-listing-body .program-listing-part .selected-area app-cs-checkbox-indeterminate .checkbox-item .checkbox,::ng-deep .program-listing-body .program-listing-part .selected-area app-cs-checkbox .checkbox-item .checkmark,::ng-deep .program-listing-body .program-listing-part .selected-area app-cs-checkbox-indeterminate .checkbox-item .checkmark{position:absolute;top:0;left:0}::ng-deep .program-listing-body .program-listing-part .selected-area app-cs-checkbox .checkbox-item .value,::ng-deep .program-listing-body .program-listing-part .selected-area app-cs-checkbox-indeterminate .checkbox-item .value{color:#161b2f;font-size:12px;font-weight:500;margin-left:24px}::ng-deep .program-listing-body .program-listing-part .table-head .table-row{display:flex;align-items:center;justify-content:space-between}::ng-deep .program-listing-body .program-listing-part .table-head .table-row .table-column{color:#747576;font-size:11px;font-weight:500;height:28px;position:relative;width:100%;display:flex;align-items:center;padding:0 4px;text-transform:uppercase}::ng-deep .program-listing-body .program-listing-part .table-head .table-row .table-column.serial{width:32px;max-width:32px;justify-content:center}::ng-deep .program-listing-body .program-listing-part .table-head .table-row .table-column.name{width:calc(100% - 64px);min-width:calc(100% - 64px)}::ng-deep .program-listing-body .program-listing-part .table-head .table-row .table-column.action{width:32px;max-width:32px;justify-content:center}::ng-deep .program-listing-body .program-listing-part .program-listing-item{border:1px solid #f1f1f1;border-radius:2px;margin-bottom:4px}::ng-deep .program-listing-body .program-listing-part .program-listing-item .main-list{cursor:pointer}::ng-deep .program-listing-body .program-listing-part .program-listing-item:hover .table-row .serial .sr-no{opacity:0}::ng-deep .program-listing-body .program-listing-part .program-listing-item.active{border-color:#1e5dd3;box-shadow:0 3px 6px #4681ef26}::ng-deep .program-listing-body .program-listing-part .program-listing-item.active .table-row .serial .sr-no{opacity:0}::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row{display:flex;align-items:center;justify-content:space-between}::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row.disabled{pointer-events:none}::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row .table-column{color:#747576;height:48px;position:relative;width:100%;display:flex;align-items:center;padding:0 4px}::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row .table-column.serial{width:32px;max-width:32px;justify-content:center}::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row .table-column.serial .sr-no{width:16px;background:#f8f8f8;writing-mode:vertical-lr;color:#747576;font-size:10px;font-weight:500;display:flex;height:100%;align-items:center;justify-content:center;position:relative;transition:all .2s ease-in-out}::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row .table-column.serial app-cs-radio,::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row .table-column.serial app-cs-checkbox,::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row .table-column.serial app-cs-checkbox-indeterminate{position:absolute;top:14px;left:8px;opacity:0;transition:all .2s ease-in-out}::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row .table-column.serial app-cs-checkbox,::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row .table-column.serial app-cs-checkbox-indeterminate{background:#fff;border-radius:2px;width:16px;height:16px;top:16px}::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row .table-column.serial app-cs-checkbox .checkbox-item .checkbox,::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row .table-column.serial app-cs-checkbox-indeterminate .checkbox-item .checkbox,::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row .table-column.serial app-cs-checkbox .checkbox-item .checkmark,::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row .table-column.serial app-cs-checkbox-indeterminate .checkbox-item .checkmark{position:absolute;top:0;left:0}::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row .table-column.name{width:calc(100% - 32px);min-width:calc(100% - 32px)}::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row .table-column.name .name-inner{width:100%}::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row .table-column.name .name-inner .value{color:#161b2f;font-size:12px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;padding-right:8px}::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row .table-column.name .name-inner .count{background:#1E5DD3;border-radius:20px;color:#fff;font-size:9px;font-weight:500;line-height:16px;min-width:24px;display:inline-block;text-align:center;padding:0 4px}::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row .table-column.name .name-inner .name-with-count{display:flex;align-items:center;width:100%}::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row .table-column.action{width:32px;max-width:32px;justify-content:center}::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row .table-column.action button.arrow{background:transparent;border:none;border-radius:0;color:#747576;font-size:12px;padding:0;margin:0;display:flex;align-items:center;justify-content:center;height:100%;width:100%}::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row .table-column.action button.disabled{opacity:.5!important;pointer-events:none}::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row:hover .table-column.serial app-cs-radio,::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row.active .table-column.serial app-cs-radio,::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row:hover .table-column.serial app-cs-checkbox,::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row.active .table-column.serial app-cs-checkbox,::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row:hover .table-column.serial app-cs-checkbox-indeterminate,::ng-deep .program-listing-body .program-listing-part .program-listing-item .table-row.active .table-column.serial app-cs-checkbox-indeterminate{opacity:1}::ng-deep .program-listing-body .program-listing-part .program-listing-item .sub-list .table-row{border-top:1px solid #f1f1f1}::ng-deep .program-listing-body .program-listing-part .program-listing-item .sub-list .table-row:hover .table-column.serial .sr-no,::ng-deep .program-listing-body .program-listing-part .program-listing-item .sub-list .table-row.active .table-column.serial .sr-no{color:#f8f8f8}::ng-deep .program-listing-body .program-listing-part .program-listing-item .sub-list .table-row:hover .table-column.serial .sr-no vui-checkbox,::ng-deep .program-listing-body .program-listing-part .program-listing-item .sub-list .table-row.active .table-column.serial .sr-no vui-checkbox{opacity:1}::ng-deep .program-listing-body .program-listing-part .program-listing-item .sub-list .table-row .table-column.name .name-inner .value{color:#747576;font-size:12px}::ng-deep .program-listing-body .program-listing-part .program-listing-item.active .table-row .table-column.serial app-cs-radio,::ng-deep .program-listing-body .program-listing-part .program-listing-item.active .table-row .table-column.serial app-cs-checkbox,::ng-deep .program-listing-body .program-listing-part .program-listing-item.active .table-row .table-column.serial app-cs-checkbox-indeterminate{opacity:1}::ng-deep .program-listing-confirmation{background:#161B2F;border-radius:.25rem;position:absolute;left:2rem;right:2rem;bottom:2rem;z-index:1}::ng-deep .program-listing-confirmation .confirmation-top{display:flex;align-items:center;justify-content:flex-start;padding:1.25rem}::ng-deep .program-listing-confirmation .confirmation-top .icon-block{height:2.25rem;width:2.25rem;min-width:2.25rem;border-radius:50%;background:#fff;border:1px solid #dbdbdb;display:flex;justify-content:center;align-items:center;margin-right:1rem}::ng-deep .program-listing-confirmation .confirmation-top .icon-block i{color:#eb2424;font-size:12px}::ng-deep .program-listing-confirmation .confirmation-top .text{color:#fff;font-size:14px;font-weight:300}::ng-deep .program-listing-confirmation .confirmation-bottom{background:#282E48;border-radius:0 0 .25rem .25rem;padding:.75rem .75rem .75rem 1.25rem;display:flex;align-items:center;justify-content:space-between}::ng-deep .program-listing-confirmation .confirmation-bottom .message{font-size:14px;font-weight:500;line-height:20px;color:#fff}::ng-deep .program-listing-confirmation .confirmation-bottom .button-group{display:flex}::ng-deep .program-listing-confirmation .confirmation-bottom .button-group button{height:1.5rem;width:4rem;border:1px solid #fff;border-radius:.125rem;display:flex;align-items:center;justify-content:center;line-height:22px;cursor:pointer;font-size:11px;text-transform:uppercase;font-weight:500;padding:0}::ng-deep .program-listing-confirmation .confirmation-bottom .button-group button.no-btn{background:transparent;color:#fff}::ng-deep .program-listing-confirmation .confirmation-bottom .button-group button.yes-btn{background:#fff;color:#1e5dd3;margin-left:.25rem}@keyframes animate-right{0%{transform:translate(100%)}to{transform:translate(0)}}\n"]
|
|
414
|
+
},] }
|
|
415
|
+
];
|
|
416
|
+
LinkProgramComponent.ctorParameters = () => [
|
|
417
|
+
{ type: RestApiService },
|
|
418
|
+
{ type: SnackBarService }
|
|
419
|
+
];
|
|
420
|
+
LinkProgramComponent.propDecorators = {
|
|
421
|
+
policy: [{ type: Input }],
|
|
422
|
+
currentTab: [{ type: Input }],
|
|
423
|
+
mode: [{ type: Input }],
|
|
424
|
+
changeTab: [{ type: Output }],
|
|
425
|
+
updatedProgramDetails: [{ type: Output }],
|
|
426
|
+
save: [{ type: Output }],
|
|
427
|
+
close: [{ type: Output }],
|
|
428
|
+
refreshLinkedPolicies: [{ type: Output }],
|
|
429
|
+
programsList: [{ type: Input }],
|
|
430
|
+
getSelectedProgram: [{ type: Input, args: ['selectedProgram',] }],
|
|
431
|
+
selectedCategories: [{ type: Input }],
|
|
432
|
+
hideProgramsList: [{ type: Input }],
|
|
433
|
+
searchProgram: [{ type: ViewChild, args: ['searchProgram',] }]
|
|
434
|
+
};
|
|
435
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"link-program.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/link-program/link-program/link-program.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpParams } from '@angular/common/http';\r\nimport { Component, EventEmitter, Input, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\n\r\nimport { RestApiService } from '../restapi.service';\r\nimport { SnackBarService } from '../../../ui-kit/snack-bar/snack-bar.service';\r\nimport { SelectedIds, SelectedValues } from '../program-integration-interfaces';\r\nimport { programList } from './program-list-model';\r\n\r\n@Component({\r\n  selector: 'vc-link-program',\r\n  templateUrl: './link-program.component.html',\r\n  styleUrls: ['./link-program.component.less']\r\n})\r\nexport class LinkProgramComponent implements OnInit {\r\n  animation = false;\r\n\r\n  subCategoriesList = {\r\n    from: 1,\r\n    to: 0,\r\n    currentPage: 1,\r\n    totalPage: 0,\r\n    totalRecords: 0,\r\n    data: [],\r\n  };\r\n  responsibilitiesList = {\r\n    from: 1,\r\n    to: 0,\r\n    currentPage: 1,\r\n    totalPage: 0,\r\n    totalRecords: 0,\r\n    data: [],\r\n  };\r\n\r\n  searchText = {\r\n    program: '',\r\n    category: '',\r\n    responsibility: '',\r\n  }\r\n\r\n  selectedValues: SelectedValues = {\r\n    program: {},\r\n    categories: [],\r\n    responsibilities: []\r\n  }\r\n  selectedIds: SelectedIds = {\r\n    categories: [],\r\n    responsibilities: []\r\n  }\r\n\r\n  submissionLoader=false;\r\n  currentCategory:any={};\r\n\r\n  @Input() policy: any = {}\r\n  @Input() currentTab!:any;\r\n  @Input() mode: string = '';\r\n  @Output() changeTab = new EventEmitter();\r\n  @Output() updatedProgramDetails = new EventEmitter();\r\n\r\n  currentBusinessCycle!: any;\r\n  loader = false;\r\n  programSortBy: 'desc' | 'asc' = 'desc';\r\n  currentList: 'programs' | 'categories' | 'responsibilities' = 'programs';\r\n  unsubscribe = new Subject();\r\n  @Output() save = new EventEmitter();\r\n  @Output() close = new EventEmitter();\r\n\r\n  @Output() refreshLinkedPolicies = new EventEmitter();\r\n  //program\r\n  subList = false;\r\n  @Input() programsList: any;\r\n  // @Input() allPrograms: any[] = [];\r\n  @Input('selectedProgram') set getSelectedProgram( program: any) {\r\n    this.selectedValues = program ?? {\r\n      program: {},\r\n      categories: [],\r\n      responsibilities: []\r\n    } ;\r\n  }\r\n  @Input() selectedCategories: any[] = [];\r\n  @Input() hideProgramsList!: any;\r\n  @ViewChild('searchProgram') searchProgram!: any;\r\n  \r\n\r\n  previousSelectedValues:any={\r\n    program:{},\r\n    categories:[]\r\n  }\r\n  programData: programList = {\r\n    data: [],\r\n    from: 0,\r\n    to: 0,\r\n    totalPages: 0,\r\n    totalRecords: 0,\r\n    currentPage: 1,\r\n    AllInternalControlsProgramsCount: 0,\r\n    AllOthersProgramsCount: 0,\r\n    AllRegulationProgramsCount: 0,\r\n    AllStandardProgramsCount: 0,\r\n    SelectedInternalControlsProgramsCount: 0,\r\n    SelectedOthersProgramsCount: 0,\r\n    SelectedRegulationProgramsCount: 0,\r\n    SelectedStandardProgramsCount: 0\r\n  }\r\n  programTypeObject = {\r\n    regulations: 1,\r\n    standards: 2,\r\n    internal_controls: 3,\r\n    others: 0,\r\n  }\r\n\r\n\r\n  displayConfirmationMessage = false;\r\n\r\n  activeTab: 'regulations' | 'standards' | 'internal_controls' | 'others' = 'regulations'\r\n\r\n  //program\r\n\r\n  constructor(private restApiService: RestApiService,\r\n     private snackbar: SnackBarService,\r\n    ) {\r\n    this.getPrograms();\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    this.currentBusinessCycle = this.restApiService.getBusinessCycle();\r\n  }\r\n\r\n  getPrograms(data?: any) {\r\n    this.loader = true;\r\n    let params = new HttpParams();\r\n    params = params.append('mode', 'complianceCategory/programList');\r\n    params = params.append('programType', this.programTypeObject[this.activeTab]);\r\n      params = params.append('pageName', \"policyWorkroom\");\r\n    if (data?.search || this.searchText.program\r\n      ) {\r\n      params = params.append('searchText', this.searchText.program);\r\n    } else {\r\n      params = params.append('pageNo', this.programData.currentPage);\r\n    }\r\n    const request = {\r\n      method: 'get',\r\n      action: '/compliance/',\r\n      params\r\n    }\r\n    this.restApiService.apiDelegate(request).pipe(takeUntil(this.unsubscribe)).subscribe({\r\n      next: (res: any) => {\r\n        this.programData.data = res.data;\r\n        this.programData.from = res.from;\r\n        this.programData.to = res.to;\r\n        this.programData.totalPages = res.totalPages;\r\n        this.programData.totalRecords = res.totalRecords;\r\n        this.programData.AllInternalControlsProgramsCount = res.AllInternalControlsProgramsCount;\r\n        this.programData.AllOthersProgramsCount = res.AllOthersProgramsCount;\r\n        this.programData.AllRegulationProgramsCount = res.AllRegulationProgramsCount;\r\n        this.programData.AllStandardProgramsCount = res.AllStandardProgramsCount;\r\n        this.loader = false;\r\n\r\n      },\r\n      error: (err: any) => {\r\n        this.loader = false;\r\n      },\r\n    });\r\n  }\r\n\r\n\r\n\r\n  getCategories(data?: any) {\r\n\r\n    this.loader = true;\r\n    let params = new HttpParams();\r\n    params = params.append('parentId', this.selectedValues.program?._id);\r\n\r\n    if (data?.search) {\r\n      params = params.append('q', this.searchText.category);\r\n    }\r\n\r\n    const request = {\r\n      method: 'get',\r\n      action: '/program/subCategories',\r\n      params\r\n    }\r\n    this.restApiService.apiDelegate(request).pipe(takeUntil(this.unsubscribe)).subscribe({\r\n      next: (res: any) => {\r\n        this.subCategoriesList.from = res.items_from ?? 1;\r\n        this.subCategoriesList.to = res.items_to ?? 0;\r\n        this.subCategoriesList.totalPage = res.total_pages ?? 0;\r\n        this.subCategoriesList.totalRecords = res.total_items ?? 0;\r\n        this.subCategoriesList.data = res.data ?? [];\r\n        this.loader=false;\r\n      },\r\n      error: (err: any) => {\r\n        this.loader = false;\r\n      },\r\n    });\r\n  }\r\n  changeTabProgram(type: 'regulations' | 'standards' | 'internal_controls' | 'others') {\r\n    this.activeTab = type;\r\n    this.programData.currentPage = 1;\r\n    this.searchText.program = '';\r\n    this.searchProgram.nativeElement.value = '';\r\n    this.getPrograms();\r\n  }\r\n\r\n  getResponsibilities(data?: any) {\r\n\r\n    this.loader = true;\r\n\r\n    const request = {\r\n      method: 'get',\r\n      action: '/program/categoryResponsibilities',\r\n      payloadObject: {\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        'categoryIds': this.selectedIds.categories,\r\n        'pageNo': this.responsibilitiesList.currentPage,\r\n        'searchText': (data?.search) ? this.searchText.responsibility : ''\r\n      }\r\n    }\r\n    this.restApiService.apiDelegate(request).pipe(takeUntil(this.unsubscribe)).subscribe({\r\n      next: (res: any) => {\r\n        this.loader = false;\r\n        this.responsibilitiesList.from = res.items_from ?? 1;\r\n        this.responsibilitiesList.to = res.items_to ?? 0;\r\n        this.responsibilitiesList.totalPage = res.total_pages ?? 1;\r\n        this.responsibilitiesList.totalRecords = res.total_items ?? 0;\r\n        this.responsibilitiesList.data = res.data ?? [];\r\n\r\n      },\r\n      error: (err: any) => {\r\n        this.loader = false;\r\n      },\r\n    });\r\n  }\r\n\r\n  changePage(event: any, type: 'programs' | 'categories' | 'responsibilities') {\r\n    switch (type) {\r\n      case 'programs':\r\n        this.programData.currentPage = event;\r\n        this.getPrograms();\r\n        break;\r\n      case 'categories':\r\n        this.subCategoriesList.currentPage = event;\r\n        this.getCategories();\r\n        break;\r\n      case 'responsibilities':\r\n        this.responsibilitiesList.currentPage = event;\r\n        this.getResponsibilities();\r\n        break;\r\n    }\r\n\r\n  }\r\n  searchBy(event: any, type: 'programs' | 'categories' | 'responsibilities') {\r\n    switch (type) {\r\n      case 'programs':\r\n        if (this.searchText.program != event) {\r\n          this.searchText.program = event;\r\n          this.getPrograms({ search: true })\r\n        }\r\n        break;\r\n      case 'categories':\r\n        if (this.searchText.category != event) {\r\n          this.searchText.category = event;\r\n          this.getCategories({ search: true })\r\n        }\r\n        break;\r\n      case 'responsibilities':\r\n        if (this.searchText.responsibility != event) {\r\n          this.searchText.responsibility = event;\r\n          this.getResponsibilities({ search: true })\r\n        }\r\n        break;\r\n\r\n    }\r\n  }\r\n\r\n\r\n\r\n  selectProgram(event: any, data: any) {\r\n    if (event) {\r\n      this.selectedValues.program = data;\r\n      this.selectedIds.categories= [];\r\n      this.selectedValues.categories= [];\r\n      this.selectedIds.responsibilities= [];\r\n      this.selectedValues.responsibilities= [];\r\n    }\r\n    console.log(\"=============>\", data)\r\n  }\r\n\r\n  selectCategory(event: any, category: any) {\r\n    if (event) {\r\n      this.selectedIds.categories.push(category.category_id);\r\n      this.selectedValues.categories.push(category);\r\n    } else {\r\n      const index = this.selectedIds.categories.findIndex((element: any) => element == category.category_id);\r\n      this.selectedIds.categories.splice(index, 1);\r\n      const categoryIndex = this.selectedValues.categories.findIndex((ele: any) => ele.category_id == category.category_id)\r\n      this.selectedValues.categories.splice(categoryIndex, 1);\r\n    }\r\n  }\r\n  selectResponsibility(event: any, data: any) {\r\n    if (event) {\r\n      this.selectedIds.responsibilities.push(data.ReportId);\r\n      this.selectedValues.responsibilities.push(data);\r\n    } else {\r\n      const index = this.selectedIds.responsibilities.findIndex((element: any) => element == data.ReportId);\r\n      this.selectedIds.responsibilities.splice(index, 1);\r\n      const reportIndex = this.selectedValues.responsibilities.findIndex((ele: any) => ele.ReportId == data.ReportId)\r\n      this.selectedValues.responsibilities.splice(reportIndex, 1);\r\n    }\r\n  }\r\n  goBack(from?: 'categories' | 'responsibilities') {\r\n    if (from) {\r\n      switch (from) {\r\n        case 'categories':\r\n          this.currentList = 'programs';\r\n          this.selectedIds.categories = [];\r\n          break;\r\n        case 'responsibilities':\r\n          this.currentList = 'categories';\r\n          this.selectedIds.responsibilities = [];\r\n          break;\r\n      }\r\n    } else {\r\n      this.close.emit();\r\n    }\r\n  }\r\n\r\n  remove(type: 'programs' | 'categories' | 'responsibilities', item: any) {\r\n    switch (type) {\r\n      case 'programs':\r\n        this.selectedValues.program = {};\r\n        this.selectedValues.categories = [];\r\n        this.selectedValues.responsibilities = [];\r\n        break;\r\n      case 'categories':\r\n        const categoryIndex = this.selectedValues.categories.findIndex((ele: any) => ele.category_id == item.category_id);\r\n        if (categoryIndex != -1) {\r\n          this.selectedValues.categories.splice(categoryIndex, 1);\r\n          this.selectedValues.responsibilities = [];\r\n        }\r\n        const categoryIdIndex = this.selectedIds.categories.findIndex((element: any) => element == item.category_id);\r\n        if(categoryIdIndex!=-1){\r\n          this.selectedIds.categories.splice(categoryIdIndex, 1);\r\n        }\r\n        break;\r\n      case 'responsibilities':\r\n        const respIndex = this.selectedValues.responsibilities.findIndex((ele: any) => ele.ReportId == item.ReportId);\r\n        if (respIndex != -1) {\r\n          this.selectedValues.responsibilities.splice(respIndex, 1);\r\n        }\r\n        const index = this.selectedIds.responsibilities.findIndex((element: any) => element == item.ReportId);\r\n        if(index!=-1){\r\n          this.selectedIds.responsibilities.splice(index, 1);\r\n        }\r\n\r\n        break;\r\n    }\r\n\r\n  }\r\n\r\n  saveChanges(type: 'programs' | 'categories' | 'responsibilities'|'programsOnly') {\r\n    switch (type) {\r\n      case 'programs':\r\n        this.currentList = 'categories';\r\n        this.selectedValues.categories = [];\r\n        this.selectedValues.responsibilities = [];\r\n        this.getCategories();\r\n        break;\r\n      case 'categories':\r\n        this.currentList = 'responsibilities';\r\n        this.selectedValues.responsibilities = [];\r\n        this.getResponsibilities();\r\n\r\n        break;\r\n      case 'responsibilities':\r\n        this.submitprogramIntegration();\r\n        break;\r\n       case 'programsOnly':\r\n        this.displayConfirmationMessage = true;\r\n        break;\r\n    }\r\n  }\r\n  saveChangesFromProgram(event:boolean){\r\n    if(event){\r\n      this.displayConfirmationMessage = false;\r\n      this.submitprogramIntegration();\r\n    }else{\r\n      this.displayConfirmationMessage = false;\r\n    }\r\n  }\r\n\r\n\r\n  submitprogramIntegration() {\r\n\r\n    // this.submissionLoader = true;\r\n    let params = new HttpParams();\r\n    params = params.append('mode', 'programPolicyUpdate/update');\r\n\r\n    const categoryArray = this.selectedIds?.categories;\r\n\r\n    const payload = {\r\n      policyId: this.policy?.contract_id ?? 0,\r\n      report_ids: this.selectedIds?.responsibilities ?? 0,\r\n      category_id:[... new Set(categoryArray)],\r\n      parentId: this.selectedValues?.program?.category_id\r\n    }\r\n    const currentBusinessCycle = {\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    }\r\n    let linkProgram = {\r\n      added: [payload],\r\n      removed: []\r\n    }\r\n    let selectedProgram = {\r\n      selectedValues : this.selectedValues,\r\n      linkProgram: linkProgram,\r\n    }\r\n    console.log(\"link Program Payload =>\", payload)\r\n    this.updatedProgramDetails.emit(selectedProgram);\r\n    this.submissionLoader = false;\r\n\r\n    \r\n    \r\n\r\n    const request = {\r\n      method: 'post',\r\n      action: '/compliance_post',\r\n      params,\r\n      data: payload,\r\n      businessCycle: currentBusinessCycle\r\n    }\r\n    // this.restApiService.apiDelegate(request).pipe(takeUntil(this.unsubscribe)).subscribe({\r\n    //   next: (res: any) => {\r\n    //     this.submissionLoader = false;\r\n    //     this.snackbar.show('The program has been linked with this Policy.', 'success');\r\n    //     setTimeout(() => {\r\n    //       if(this.currentTab != 'linked_programs'){\r\n    //         this.refreshLinkedPolicies.emit();\r\n    //         // this.changeTab.emit();\r\n    //       }\r\n    //       this.close.emit();\r\n    //     }, 1000);\r\n\r\n    //   },\r\n    //   error: (err: any) => {\r\n    //     this.submissionLoader = false;\r\n    //     this.snackbar.show(\"Oops Something went wrong and we were unable to complete this action. Let's give it another try shall we ?\");\r\n    //   },\r\n    // });\r\n  }\r\n\r\n}\r\n"]}
|