vcomply-workflow-engine 6.0.94 → 6.0.95

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (106) hide show
  1. package/esm2022/lib/add-multiple-responsibility-with-tab/add-multiple-responsibility-with-tab.component.mjs +30 -7
  2. package/esm2022/lib/constants/api.constants.mjs +1 -6
  3. package/esm2022/lib/constants/policy.constant.mjs +6 -0
  4. package/esm2022/lib/constants/regix.constants.mjs +4 -0
  5. package/esm2022/lib/constants/responsibility.mjs +8 -0
  6. package/esm2022/lib/interfaces/policy.interface.mjs +2 -0
  7. package/esm2022/lib/interfaces/responsibilty.interface.mjs +1 -1
  8. package/esm2022/lib/more-option/more-option.component.mjs +193 -13
  9. package/esm2022/lib/report-a-case/services/report-a-case.service.mjs +2 -3
  10. package/esm2022/lib/report-a-case/workflow-case/workflow-case.component.mjs +7 -4
  11. package/esm2022/lib/services/common.service.mjs +1 -40
  12. package/esm2022/lib/services/iframe.service.mjs +1 -14
  13. package/esm2022/lib/sharedComponents/bulk-responsibility-view/bulk-responsibility-view.component.mjs +6 -3
  14. package/esm2022/lib/sharedComponents/format-and-evidence/format-and-evidence.component.mjs +21 -10
  15. package/esm2022/lib/sharedComponents/frequency/frequency-annual/frequency-annual.component.mjs +1 -5
  16. package/esm2022/lib/sharedComponents/frequency/frequency-biannual/frequency-biannual.component.mjs +1 -5
  17. package/esm2022/lib/sharedComponents/frequency/frequency-container/frequency-container.component.mjs +5 -5
  18. package/esm2022/lib/sharedComponents/frequency/frequency-daily/frequency-daily.component.mjs +1 -2
  19. package/esm2022/lib/sharedComponents/frequency/frequency-monthly/frequency-monthly.component.mjs +2 -6
  20. package/esm2022/lib/sharedComponents/frequency/frequency-one-time/frequency-one-time.component.mjs +2 -3
  21. package/esm2022/lib/sharedComponents/frequency/frequency-ongoing/frequency-ongoing.component.mjs +1 -3
  22. package/esm2022/lib/sharedComponents/frequency/frequency-quarterly/frequency-quarterly.component.mjs +1 -5
  23. package/esm2022/lib/sharedComponents/frequency/frequency-random/frequency-random.component.mjs +2 -9
  24. package/esm2022/lib/sharedComponents/frequency/frequency-weekly/frequency-weekly.component.mjs +2 -4
  25. package/esm2022/lib/sharedComponents/frequency/frequency.service.mjs +5 -267
  26. package/esm2022/lib/sharedComponents/link-responsibility/link-responsibility.component.mjs +16 -48
  27. package/esm2022/lib/sharedComponents/link-responsibility/link-responsibility.module.mjs +4 -8
  28. package/esm2022/lib/sharedComponents/pipes/risk-class.pipe.mjs +19 -0
  29. package/esm2022/lib/workflow/grc-object/grc-object-container/grc-object-container.component.mjs +17 -45
  30. package/esm2022/lib/workflow/shared/components/grc-category-listing/grc-category-listing.component.mjs +10 -13
  31. package/esm2022/lib/workflow/shared/components/program-responsibility-listing/program-responsibility-listing.component.mjs +35 -62
  32. package/esm2022/lib/workflow/shared/services/grc.service.mjs +2 -15
  33. package/esm2022/lib/workflow/shared/workflow-pipes/workflow-pipes.module.mjs +3 -8
  34. package/esm2022/lib/workflow-compliance/workflow-compliance.component.mjs +453 -294
  35. package/esm2022/lib/workflow-engine-container/api-constants.mjs +2 -3
  36. package/esm2022/lib/workflow-engine-container/workflow-engine-container.component.mjs +53 -32
  37. package/esm2022/lib/workflow-engine.module.mjs +7 -11
  38. package/esm2022/lib/workflow-policy/workflow-policy.component.mjs +29 -46
  39. package/esm2022/lib/workflow-program/constants.mjs +3 -3
  40. package/esm2022/lib/workflow-program/create-program-ui/user-group-list/user-group-list.component.mjs +9 -13
  41. package/esm2022/lib/workflow-program/workflow-program.component.mjs +365 -327
  42. package/esm2022/lib/workflow-services/policy.service.mjs +9 -8
  43. package/esm2022/lib/workflow-services/programs.service.mjs +114 -26
  44. package/esm2022/lib/workflow-services/responsibility.service.mjs +55 -60
  45. package/fesm2022/vcomply-workflow-engine.mjs +14037 -14469
  46. package/fesm2022/vcomply-workflow-engine.mjs.map +1 -1
  47. package/lib/add-multiple-responsibility-with-tab/add-multiple-responsibility-with-tab.component.d.ts +3 -0
  48. package/lib/constants/api.constants.d.ts +0 -5
  49. package/lib/constants/policy.constant.d.ts +2 -0
  50. package/lib/constants/regix.constants.d.ts +3 -0
  51. package/lib/constants/responsibility.d.ts +7 -0
  52. package/lib/interfaces/policy.interface.d.ts +5 -0
  53. package/lib/interfaces/responsibilty.interface.d.ts +13 -13
  54. package/lib/services/common.service.d.ts +0 -28
  55. package/lib/services/iframe.service.d.ts +0 -6
  56. package/lib/sharedComponents/bulk-responsibility-view/bulk-responsibility-view.component.d.ts +6 -0
  57. package/lib/sharedComponents/format-and-evidence/format-and-evidence.component.d.ts +4 -1
  58. package/lib/sharedComponents/frequency/frequency-random/frequency-random.component.d.ts +0 -1
  59. package/lib/sharedComponents/frequency/frequency.service.d.ts +2 -92
  60. package/lib/sharedComponents/link-responsibility/link-responsibility.component.d.ts +1 -2
  61. package/lib/sharedComponents/link-responsibility/link-responsibility.module.d.ts +1 -2
  62. package/lib/sharedComponents/pipes/risk-class.pipe.d.ts +7 -0
  63. package/lib/workflow/grc-object/grc-object-container/grc-object-container.component.d.ts +1 -5
  64. package/lib/workflow/shared/components/grc-category-listing/grc-category-listing.component.d.ts +1 -3
  65. package/lib/workflow/shared/components/program-responsibility-listing/program-responsibility-listing.component.d.ts +2 -6
  66. package/lib/workflow/shared/services/grc.service.d.ts +0 -1
  67. package/lib/workflow/shared/workflow-pipes/workflow-pipes.module.d.ts +2 -3
  68. package/lib/workflow-compliance/workflow-compliance.component.d.ts +10 -32
  69. package/lib/workflow-engine-container/api-constants.d.ts +0 -1
  70. package/lib/workflow-engine-container/workflow-engine-container.component.d.ts +2 -5
  71. package/lib/workflow-engine.module.d.ts +2 -3
  72. package/lib/workflow-policy/workflow-policy.component.d.ts +0 -9
  73. package/lib/workflow-program/workflow-program.component.d.ts +9 -9
  74. package/lib/workflow-risk/workflow-risk.component.d.ts +1 -1
  75. package/lib/workflow-services/policy.service.d.ts +1 -1
  76. package/lib/workflow-services/programs.service.d.ts +54 -13
  77. package/lib/workflow-services/responsibility.service.d.ts +4 -17
  78. package/package.json +1 -1
  79. package/esm2022/lib/interfaces/frequency.interface.mjs +0 -2
  80. package/esm2022/lib/interfaces/iframe-type.mjs +0 -7
  81. package/esm2022/lib/sharedComponents/list-container/list-container.component.mjs +0 -52
  82. package/esm2022/lib/sharedComponents/program-list/constant.mjs +0 -27
  83. package/esm2022/lib/sharedComponents/program-list/interfaces/data-source.interface.mjs +0 -2
  84. package/esm2022/lib/sharedComponents/program-list/interfaces/list-item.interface.mjs +0 -2
  85. package/esm2022/lib/sharedComponents/program-list/pipes/check-selected-items.pipes.mjs +0 -23
  86. package/esm2022/lib/sharedComponents/program-list/program-list/program-list.component.mjs +0 -273
  87. package/esm2022/lib/sharedComponents/program-list/program-list.module.mjs +0 -51
  88. package/esm2022/lib/sharedComponents/program-list/services/list-utils.service.mjs +0 -27
  89. package/esm2022/lib/sharedComponents/program-list/services/program-list-api.service.mjs +0 -32
  90. package/esm2022/lib/ui-kit/loaders/loaders.module.mjs +0 -24
  91. package/esm2022/lib/ui-kit/loaders/table-loader/table-loader.component.mjs +0 -19
  92. package/esm2022/lib/workflow/shared/workflow-pipes/get-user-details.pipe.mjs +0 -26
  93. package/lib/interfaces/frequency.interface.d.ts +0 -37
  94. package/lib/interfaces/iframe-type.d.ts +0 -5
  95. package/lib/sharedComponents/list-container/list-container.component.d.ts +0 -9
  96. package/lib/sharedComponents/program-list/constant.d.ts +0 -20
  97. package/lib/sharedComponents/program-list/interfaces/data-source.interface.d.ts +0 -4
  98. package/lib/sharedComponents/program-list/interfaces/list-item.interface.d.ts +0 -5
  99. package/lib/sharedComponents/program-list/pipes/check-selected-items.pipes.d.ts +0 -7
  100. package/lib/sharedComponents/program-list/program-list/program-list.component.d.ts +0 -126
  101. package/lib/sharedComponents/program-list/program-list.module.d.ts +0 -15
  102. package/lib/sharedComponents/program-list/services/list-utils.service.d.ts +0 -7
  103. package/lib/sharedComponents/program-list/services/program-list-api.service.d.ts +0 -14
  104. package/lib/ui-kit/loaders/loaders.module.d.ts +0 -8
  105. package/lib/ui-kit/loaders/table-loader/table-loader.component.d.ts +0 -9
  106. package/lib/workflow/shared/workflow-pipes/get-user-details.pipe.d.ts +0 -7
@@ -1,11 +1,9 @@
1
1
  import { Component, ElementRef, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
2
2
  import { Validators, } from '@angular/forms';
3
- import { cloneDeep, isEqual } from 'lodash';
3
+ import { isEqual } from 'lodash';
4
4
  import { distinctUntilChanged, take } from 'rxjs';
5
5
  import { CONSTANTS } from './constants';
6
6
  import { ASSETS } from '../constants/assets.constants';
7
- import { PostMessageEvent } from '../interfaces/iframe-type';
8
- import { PROGRAM_OBJECT } from '../sharedComponents/program-list/constant';
9
7
  import * as i0 from "@angular/core";
10
8
  import * as i1 from "@angular/forms";
11
9
  import * as i2 from "../workflow-services/programs.service";
@@ -24,22 +22,28 @@ import * as i14 from "../ui-kit/popover-hover/popover-hover.component";
24
22
  import * as i15 from "../ui-kit/popover-hover/popover-hover.directive";
25
23
  import * as i16 from "./create-program-ui/tab-selector/tab-selector.component";
26
24
  import * as i17 from "./create-program-ui/form-field/form-field.component";
27
- import * as i18 from "./create-program-ui/input-with-pill/input-with-pill.component";
28
- import * as i19 from "./create-program-ui/directives/input-trim.directive";
29
- import * as i20 from "./create-program-ui/user-group-list/user-group-list.component";
30
- import * as i21 from "./create-program-ui/custom-field/custom-field.component";
31
- import * as i22 from "../sharedComponents/framework-list/framework-list.component";
32
- import * as i23 from "./create-program-ui/pipes/list-to-id.pipe";
33
- import * as i24 from "./create-program-ui/pipes/ref-disconnect.pipe";
34
- import * as i25 from "./create-program-ui/pipes/assessment-resolver.pipe";
25
+ import * as i18 from "./create-program-ui/file-pill/file-pill.component";
26
+ import * as i19 from "./create-program-ui/input-with-pill/input-with-pill.component";
27
+ import * as i20 from "./create-program-ui/cs-switch/cs-switch.component";
28
+ import * as i21 from "./create-program-ui/directives/input-trim.directive";
29
+ import * as i22 from "./create-program-ui/role-list/role-list.component";
30
+ import * as i23 from "./create-program-ui/user-group-list/user-group-list.component";
31
+ import * as i24 from "./create-program-ui/assessment-picker/assessment-picker.component";
32
+ import * as i25 from "./create-program-ui/custom-field/custom-field.component";
33
+ import * as i26 from "../sharedComponents/responsibility-centers-list/responsibility-centers-list.component";
34
+ import * as i27 from "../sharedComponents/framework-list/framework-list.component";
35
+ import * as i28 from "./create-program-ui/pipes/list-to-id.pipe";
36
+ import * as i29 from "./create-program-ui/pipes/ref-disconnect.pipe";
37
+ import * as i30 from "./create-program-ui/pipes/assessment-resolver.pipe";
38
+ import * as i31 from "./create-program-ui/pipes/array-concat.pipe";
35
39
  export class WorkflowProgramComponent {
36
- constructor(fb, programService, authService, uiKitService, changeRef, iframeService) {
40
+ constructor(fb, programService, authService, uiKitService, iframeService, changeRef) {
37
41
  this.fb = fb;
38
42
  this.programService = programService;
39
43
  this.authService = authService;
40
44
  this.uiKitService = uiKitService;
41
- this.changeRef = changeRef;
42
45
  this.iframeService = iframeService;
46
+ this.changeRef = changeRef;
43
47
  this.ASSETS = ASSETS;
44
48
  this.constants = CONSTANTS;
45
49
  this.isAscentAllowed = false;
@@ -63,7 +67,8 @@ export class WorkflowProgramComponent {
63
67
  this.panelTitleDefaultReviewer = 'Select Default Reviewer(s)';
64
68
  this.panelTitleOwner = 'Select Owner(s)';
65
69
  this.panelTitleReviewer = 'Select Reviewer(s)';
66
- this.panelTitleAssignee = 'Select Collaborator(s)';
70
+ this.panelTitleAssignee = 'Select Assignee(s)';
71
+ this.panelTitleCollaborator = 'Select Collaborator(s)';
67
72
  this.panelTitleApprover = 'Select Approver';
68
73
  this.isApproverDisabled = false;
69
74
  this.isProgramScope = false;
@@ -74,11 +79,10 @@ export class WorkflowProgramComponent {
74
79
  <li>To pre-select certain options that are available when creating a responsibility, thereby decreasing the time required to create a responsibility.</li>
75
80
  <li>To limit the options available for selection when creating a responsibility, thereby making it easier to create a responsibility and reducing the likelihood of an incorrect option being selected.</li>
76
81
  `,
77
- collaborators: `Collaborators are required to complete the responsibilities that have been assigned to them. Where Collaborators are selected when creating a Program, only those Collaborators will be available for selection when creating a responsibility linked with the Program.`,
78
82
  };
79
83
  this.featureflagrole = false;
80
84
  this.featureflagGroups = false;
81
- this.disabledAssigneeIds = [];
85
+ this.disableCollaboratorIds = [];
82
86
  this.selectedReviewerIds = [];
83
87
  this.selectedAssigneeIds = [];
84
88
  this.selectedOverseerIds = [];
@@ -98,7 +102,7 @@ export class WorkflowProgramComponent {
98
102
  //form body for program meta data
99
103
  this.programForm = this.fb.group({
100
104
  program_type: [
101
- this.programType ?? 1,
105
+ this.programType,
102
106
  [Validators.required, Validators.min(0), Validators.max(3)],
103
107
  ],
104
108
  program_name: ['', [Validators.required, this.noWhitespaceValidator]],
@@ -107,10 +111,14 @@ export class WorkflowProgramComponent {
107
111
  program_objective: [''],
108
112
  // program_objective: ['', [Validators.required, this.noWhitespaceValidator]],
109
113
  program_objective_attachments: [[]],
114
+ program_roles: [[], [Validators.required, this.blankArrayValidator]],
110
115
  all_user_in_role: [false],
111
- program_owners: [[]],
116
+ program_owners: [[], [Validators.required, this.blankArrayValidator]],
112
117
  program_owners_group: [[]],
113
118
  program_approver: [[]],
119
+ performance_calculation: ['PAST_EVENT', [Validators.required]],
120
+ recurring_frequency: [true, [Validators.required]],
121
+ lock_scope_change: [false, [Validators.required]],
114
122
  framework: [],
115
123
  rc: [[]],
116
124
  program_assignee: [[]],
@@ -134,8 +142,7 @@ export class WorkflowProgramComponent {
134
142
  allow_any_file_key_evidence: [false],
135
143
  custom_fields: [[]],
136
144
  program_state: 0,
137
- collaborators: [[]],
138
- collaborators_group: [[]],
145
+ program_collaborator: [[]],
139
146
  });
140
147
  //exceptional handling of custom fields
141
148
  this.showAddCustomField = true;
@@ -144,6 +151,7 @@ export class WorkflowProgramComponent {
144
151
  programObjective: '',
145
152
  programDescription: '',
146
153
  };
154
+ this.manageProgramsRoleId = [];
147
155
  this.controls = {
148
156
  program_name: this.programForm.get('program_name'),
149
157
  program_type: this.programForm.get('program_type'),
@@ -181,14 +189,13 @@ export class WorkflowProgramComponent {
181
189
  program_assessments: this.programForm.get('program_assessments'),
182
190
  custom_fields: this.programForm.get('custom_fields'),
183
191
  isApproverDisabled: this.programForm.get('isApproverDisabled'),
184
- collaborators: this.programForm.get('collaborators'),
185
- collaborators_group: this.programForm.get('collaborators_group'),
192
+ program_collaborator: this.programForm.get('program_collaborator'),
186
193
  };
187
194
  this.lists = {
188
195
  ROLES: [],
189
196
  OWNERS: [],
190
197
  OWNERS_GROUPS: [],
191
- APPROVERS: [],
198
+ COLLABORATORS: [],
192
199
  REVIEWERS: [],
193
200
  REVIEWERS_GROUP: [],
194
201
  ASSIGNEES: [],
@@ -281,17 +288,20 @@ export class WorkflowProgramComponent {
281
288
  }
282
289
  }
283
290
  ngOnInit() {
284
- this.setFormField('program_type', this.programType ?? 1);
285
- this.fetchOrganizationUsers();
286
- this.fetchOrganizationGroup();
291
+ this.setFormField('program_type', this.programType);
292
+ if (this.mode === 'EDIT') {
293
+ this.getProgramDetails();
294
+ }
295
+ else {
296
+ this.fetchOrganizationUsers();
297
+ this.fetchOrganizationGroup();
298
+ }
287
299
  this.fetchRoles();
288
300
  this.fetchRC();
289
- this.handleDataPopulation();
290
301
  if (this.addToProgramDetails?._id) {
291
302
  this.listAction(this.addToProgramDetails, 'FRAMEWORK');
292
303
  }
293
304
  this.enablefeature();
294
- this.handleDataPopulation();
295
305
  this.changeRef.detectChanges();
296
306
  }
297
307
  get valid() {
@@ -354,77 +364,16 @@ export class WorkflowProgramComponent {
354
364
  this.fieldDeselector(type);
355
365
  break;
356
366
  }
357
- case 'RC': {
358
- const rc = this.setList(this.lists.RC, evt, 'item_id');
359
- this.setFormField('rc', this.uniqueByProp(rc, 'item_id'));
360
- this.fieldDeselector(type);
361
- break;
362
- }
363
367
  case 'OWNER': {
364
- this.setFormField('program_owners', this.uniqueByProp(evt?.users, 'uid'));
365
- this.setFormField('program_owners_group', this.uniqueByProp(evt?.groups, 'ugid'));
366
- this.fieldDeselector(type);
367
- break;
368
- }
369
- case 'APPROVER': {
370
- this.setFormField('program_approver', this.uniqueByProp(evt?.users, 'member_id'));
371
- this.fieldDeselector(type);
372
- break;
373
- }
374
- case 'COLLABORATORS': {
375
- this.setFormField('collaborators', this.uniqueByProp(evt?.users, 'uid'));
376
- this.setFormField('collaborators_group', this.uniqueByProp(evt?.groups, 'ugid'));
377
- this.fieldDeselector(type);
378
- break;
379
- }
380
- case 'DEFAULT_ASSIGNEE': {
381
- this.setFormField('program_default_assignee', this.uniqueByProp(evt?.users, 'member_id'));
382
- this.setFormField('program_default_assignee_group', this.uniqueByProp(evt?.groups, 'group_id'));
368
+ this.setFormField('program_owners', this.uniqueByProp(evt?.users, 'member_id'));
369
+ this.setFormField('program_owners_group', this.uniqueByProp(evt?.groups, 'group_id'));
383
370
  this.fieldDeselector(type);
384
371
  this.refreshList();
385
372
  break;
386
373
  }
387
- case 'REVIEWER': {
388
- this.setFormField('program_reviewer', this.uniqueByProp(evt?.users, 'member_id'));
389
- this.setFormField('program_reviewer_group', this.uniqueByProp(evt?.groups, 'group_id'));
390
- this.fieldDeselector(type);
391
- this.setDefaultReviewer(evt);
392
- break;
393
- }
394
- case 'DEFAULT_REVIEWER': {
395
- this.setFormField('program_default_reviewer', this.uniqueByProp(evt?.users, 'member_id'));
396
- this.setFormField('program_default_reviewer_group', this.uniqueByProp(evt?.groups, 'group_id'));
397
- this.fieldDeselector(type);
398
- this.controls.reviewer_completion_criteria.value =
399
- this.controls?.program_default_reviewer_group?.value?.length > 0
400
- ? 'ANYONE'
401
- : this.controls?.reviewer_completion_criteria?.value;
402
- this.refreshList();
403
- break;
404
- }
405
- case 'OVERSEER': {
406
- this.setFormField('program_overseer', this.uniqueByProp(evt?.users, 'member_id'));
407
- this.setFormField('program_overseer_group', this.uniqueByProp(evt?.groups, 'group_id'));
408
- this.fieldDeselector(type);
409
- this.setDefaultOverseer(evt);
410
- break;
411
- }
412
- case 'DEFAULT_OVERSEER': {
413
- this.setFormField('program_default_overseer', this.uniqueByProp(evt?.users, 'member_id'));
414
- this.setFormField('program_default_overseer_group', this.uniqueByProp(evt?.groups, 'group_id'));
415
- this.fieldDeselector(type);
416
- this.refreshList();
417
- break;
418
- }
419
- case 'DEFAULT_FAILED_OVERSEER': {
420
- this.setFormField('program_default_failed_overseer', this.uniqueByProp(evt?.users, 'member_id'));
421
- this.setFormField('program_default_failed_overseer_group', this.uniqueByProp(evt?.groups, 'group_id'));
422
- this.fieldDeselector(type);
423
- this.refreshList();
424
- break;
425
- }
426
- case 'ASSESSMENT': {
427
- this.setFormField('program_assessments', evt);
374
+ case 'COLLABORATOR': {
375
+ console.log("evt", evt, type);
376
+ this.setFormField('program_collaborator', this.uniqueByProp(evt?.users, 'member_id'));
428
377
  this.fieldDeselector(type);
429
378
  break;
430
379
  }
@@ -448,13 +397,8 @@ export class WorkflowProgramComponent {
448
397
  this.setFormField('program_roles', roles);
449
398
  break;
450
399
  }
451
- case 'RC': {
452
- const rcs = this.controls?.rc?.value?.filter((ele) => ele?.item_id !== evt?.item_id);
453
- this.setFormField('rc', rcs);
454
- break;
455
- }
456
400
  case 'OWNER': {
457
- const owners = this.controls?.program_owners?.value?.filter((ele) => ele?.uid !== evt?.uid);
401
+ const owners = this.controls?.program_owners?.value?.filter((ele) => ele?.member_id !== evt?.member_id);
458
402
  this.setFormField('program_owners', owners);
459
403
  break;
460
404
  }
@@ -463,102 +407,9 @@ export class WorkflowProgramComponent {
463
407
  this.setFormField('program_owners_group', owners_group);
464
408
  break;
465
409
  }
466
- case 'APPROVER': {
467
- const approver = this.controls?.program_approver?.value?.filter((ele) => ele?.member_id !== evt?.member_id);
468
- this.setFormField('program_approver', approver);
469
- break;
470
- }
471
- case 'ASSIGNEE': {
472
- const assignee = this.controls?.program_assignee?.value?.filter((ele) => ele?.member_id !== evt?.member_id);
473
- this.setFormField('program_assignee', assignee);
474
- this.setDefaultAssigneeOnRemove(evt, type);
475
- break;
476
- }
477
- case 'ASSIGNEE_GROUP': {
478
- const assignee_group = this.controls?.program_assignee_group?.value?.filter((ele) => ele?.group_id !== evt?.group_id);
479
- this.setFormField('program_assignee_group', assignee_group);
480
- this.setDefaultAssigneeOnRemove(evt, type);
481
- break;
482
- }
483
- case 'DEFAULT_ASSIGNEE': {
484
- const assignee = this.controls?.program_default_assignee?.value?.filter((ele) => ele?.member_id !== evt?.member_id);
485
- this.setFormField('program_default_assignee', assignee);
486
- this.refreshList();
487
- break;
488
- }
489
- case 'DEFAULT_ASSIGNEE_GROUP': {
490
- const assignee_group = this.controls?.program_default_assignee_group?.value?.filter((ele) => ele?.group_id !== evt?.group_id);
491
- this.setFormField('program_default_assignee_group', assignee_group);
492
- break;
493
- }
494
- case 'REVIEWER': {
495
- const reviewer = this.controls?.program_reviewer?.value?.filter((ele) => ele?.member_id !== evt?.member_id);
496
- this.setFormField('program_reviewer', reviewer);
497
- this.setDefaultReviewerOnRemove(evt, type);
498
- break;
499
- }
500
- case 'REVIEWER_GROUP': {
501
- const reviewer_group = this.controls?.program_reviewer_group?.value?.filter((ele) => ele?.group_id !== evt?.group_id);
502
- this.setFormField('program_reviewer_group', reviewer_group);
503
- this.setDefaultReviewerOnRemove(evt, type);
504
- break;
505
- }
506
- case 'DEFAULT_REVIEWER': {
507
- const reviewer = this.controls?.program_default_reviewer?.value?.filter((ele) => ele?.member_id !== evt?.member_id);
508
- this.setFormField('program_default_reviewer', reviewer);
509
- this.refreshList();
510
- break;
511
- }
512
- case 'DEFAULT_REVIEWER_GROUP': {
513
- const reviewer_group = this.controls?.program_default_reviewer_group?.value?.filter((ele) => ele?.group_id !== evt?.group_id);
514
- this.setFormField('program_default_reviewer_group', reviewer_group);
515
- this.controls.reviewer_completion_criteria.value =
516
- this.controls?.program_default_reviewer_group?.value?.length > 0
517
- ? 'ANYONE'
518
- : this.controls?.reviewer_completion_criteria?.value;
519
- break;
520
- }
521
- case 'OVERSEER': {
522
- const overseer = this.controls?.program_overseer?.value?.filter((ele) => ele?.member_id !== evt?.member_id);
523
- this.setFormField('program_overseer', overseer);
524
- this.setDefaultOverseerOnRemove(evt, type);
525
- break;
526
- }
527
- case 'OVERSEER_GROUP': {
528
- const overseer_group = this.controls?.program_overseer_group?.value?.filter((ele) => ele?.group_id !== evt?.group_id);
529
- this.setFormField('program_overseer_group', overseer_group);
530
- this.setDefaultOverseerOnRemove(evt, type);
531
- break;
532
- }
533
- case 'DEFAULT_OVERSEER': {
534
- const overseer = this.controls?.program_default_overseer?.value?.filter((ele) => ele?.member_id !== evt?.member_id);
535
- this.setFormField('program_default_overseer', overseer);
536
- this.refreshList();
537
- break;
538
- }
539
- case 'DEFAULT_OVERSEER_GROUP': {
540
- const overseer_group = this.controls?.program_default_overseer_group?.value?.filter((ele) => ele?.group_id !== evt?.group_id);
541
- this.setFormField('program_default_overseer_group', overseer_group);
542
- break;
543
- }
544
- case 'DEFAULT_FAILED_OVERSEER': {
545
- const overseer = this.controls?.program_default_failed_overseer?.value?.filter((ele) => ele?.member_id !== evt?.member_id);
546
- this.setFormField('program_default_failed_overseer', overseer);
547
- this.refreshList();
548
- break;
549
- }
550
- case 'DEFAULT_FAILED_OVERSEER_GROUP': {
551
- const overseer_group = this.controls?.program_default_failed_overseer_group?.value?.filter((ele) => ele?.group_id !== evt?.group_id);
552
- this.setFormField('program_default_failed_overseer_group', overseer_group);
553
- break;
554
- }
555
- case 'ASSESSMENT': {
556
- let current = cloneDeep(this.controls.program_assessments?.value);
557
- const index = current.findIndex((ele) => ele.category_id == evt.category_id);
558
- current[index].assessmentIds = current[index].assessmentIds.filter((assessment) => assessment.id !== evt.id);
559
- if (current[index].assessmentIds.length === 0)
560
- current.splice(index, 1);
561
- this.listAction(current, 'ASSESSMENT');
410
+ case 'COLLABORATOR': {
411
+ const approver = this.controls?.program_collaborator?.value?.filter((ele) => ele?.member_id !== evt?.member_id);
412
+ this.setFormField('program_collaborator', approver);
562
413
  break;
563
414
  }
564
415
  case 'FRAMEWORK': {
@@ -577,47 +428,30 @@ export class WorkflowProgramComponent {
577
428
  .filter((ele) => ele);
578
429
  }
579
430
  refreshList() {
580
- this.selectedAssigneeIds = [];
581
- this.selectedReviewerIds = [];
582
- this.selectedOverseerIds = [];
583
- let assignorAndAssigneesIds = [];
584
- this.assignorId = [];
585
- let selectedAssignee = this.controls?.program_default_assignee?.value;
586
- let selectedReviewer = this.controls?.program_default_reviewer?.value;
587
- let selectedOverseerList = this.controls?.program_default_overseer?.value;
588
- let selectedOverseerFailureList = this.controls?.program_default_failed_overseer?.value;
589
- let assignor = this.currentUser();
590
- this.assignorId.push(assignor?.member_id);
591
- assignorAndAssigneesIds.push(assignor?.member_id);
592
- selectedAssignee?.forEach((user) => {
593
- this.selectedAssigneeIds.push(user?.member_id);
594
- assignorAndAssigneesIds.push(user?.member_id);
595
- });
596
- selectedReviewer?.forEach((user) => {
597
- this.selectedReviewerIds.push(user?.member_id);
598
- });
599
- selectedOverseerList?.forEach((user) => {
600
- this.selectedOverseerIds.push(user?.member_id);
601
- });
602
- selectedOverseerFailureList?.forEach((user) => {
603
- this.selectedOverseerIds.push(user?.member_id);
604
- });
605
- this.selectedReviewerIds = [...new Set(this.selectedReviewerIds)];
606
- this.selectedAssigneeIds = [...new Set(this.selectedAssigneeIds)];
607
- this.selectedOverseerIds = [...new Set(this.selectedOverseerIds)];
608
- let disableAssigneeList = this.lists?.ALL_USER?.filter((user) => this.selectedReviewerIds?.includes(user?.member_id) ||
609
- this.selectedOverseerIds?.includes(user?.member_id));
610
- this.disabledAssigneeIds = this.returnIds(disableAssigneeList, 'member_id');
611
- let disableReviewerList = this.lists?.ALL_USER?.filter((user) => this.selectedOverseerIds?.includes(user?.member_id) ||
612
- this.selectedAssigneeIds?.includes(user?.member_id));
613
- this.disableReviewerIds = this.returnIds(disableReviewerList, 'member_id');
614
- let disableOverseerList = this.lists?.ALL_USER?.filter((user) => assignorAndAssigneesIds?.includes(user?.member_id) ||
615
- this.selectedReviewerIds?.includes(user?.member_id));
616
- this.disableOverseerIds = this.returnIds(disableOverseerList, 'member_id');
431
+ let selectedOwner = this.controls?.program_owners?.value?.map((ele) => ele.member_id);
432
+ console.log("collaborators", selectedOwner, this.controls);
433
+ let disableCollaborator = this.lists?.COLLABORATORS?.data?.filter((user) => selectedOwner?.includes(user?.member_id));
434
+ console.log("disableCollaborator ==>", disableCollaborator);
435
+ this.disableCollaboratorIds = this.returnIds(disableCollaborator, 'member_id');
617
436
  }
618
437
  removeRole(evt) {
619
438
  this.onRemovingRole.emit(evt);
620
439
  }
440
+ //below 4 functions can be easilty combined into one as they follow same kind of pattern or can be offloaded to a external service
441
+ setDefaultAssignee(evt) {
442
+ if (evt?.users?.length || evt?.groups?.length) {
443
+ this.lists.DEFAULT_ASSIGNEES = this.uniqueByProp(evt?.users, 'member_id');
444
+ this.lists.DEFAULT_ASSIGNEES_GROUP = this.uniqueByProp(evt?.groups, 'group_id');
445
+ }
446
+ else {
447
+ this.lists.DEFAULT_ASSIGNEES = this.lists.ALL_USER;
448
+ this.lists.DEFAULT_ASSIGNEES_GROUP = this.lists.ALL_GROUP;
449
+ }
450
+ const assigneeMap = evt?.users?.map((ele) => ele?.member_id);
451
+ let currentDefaultAssignee = this.controls.program_default_assignee?.value;
452
+ currentDefaultAssignee = currentDefaultAssignee.filter((ele) => assigneeMap.includes(ele?.member_id));
453
+ this.setFormField('program_default_assignee', currentDefaultAssignee);
454
+ }
621
455
  setDefaultAssigneeOnRemove(evt, type) {
622
456
  switch (type) {
623
457
  case 'ASSIGNEE': {
@@ -739,16 +573,22 @@ export class WorkflowProgramComponent {
739
573
  ?.map((ele) => ele?._id);
740
574
  const defaultVal = this.lists?.ROLES?.data?.filter((ele) => ele?.roleName?.toLowerCase() === 'key admin' ||
741
575
  ele?.roleName?.toLowerCase() === 'admin');
576
+ this.manageProgramsRoleId = this.getManageProgramsRoleId();
742
577
  this.lists.SYSTEM_ROLE_IDS = defaultSystemVal;
743
578
  if (this.mode !== 'EDIT') {
744
579
  this.setFormField('program_roles', defaultVal);
580
+ this.fetchUsersAssociatedWithRoles();
581
+ this.fetchGroupsAssociatedWithRoles();
582
+ this.fetchUserWithManageProgramsRole();
745
583
  }
746
- this.fetchUsersAssociatedWithRoles();
747
- this.fetchGroupsAssociatedWithRoles();
748
584
  },
749
585
  error: (err) => { },
750
586
  });
751
587
  }
588
+ // Get Manage Programs roles Id:
589
+ getManageProgramsRoleId() {
590
+ return this.lists?.ROLES?.data?.filter((ele) => !['key admin', 'admin'].includes(ele?.roleName?.toLowerCase())).map((ele) => ele?._id) ?? [];
591
+ }
752
592
  //fetch the list of responsibilities center
753
593
  fetchRC() {
754
594
  this.programService.getResponsibilityCenterList().subscribe({
@@ -760,7 +600,8 @@ export class WorkflowProgramComponent {
760
600
  }
761
601
  fetchUsersAssociatedWithRoles(calledFrom) {
762
602
  const loggedInUser = this.currentUser();
763
- const roleIds = this.lists.ROLES?.data?.map((ele) => ele?._id);
603
+ const roleIds = this.controls.program_roles?.value?.map((ele) => ele?._id);
604
+ console.log("roleIds", roleIds, this.controls.program_roles);
764
605
  // if (fetchAll) {
765
606
  this.programService.fetchAllRoleUsers(roleIds).subscribe({
766
607
  next: (res) => {
@@ -770,13 +611,28 @@ export class WorkflowProgramComponent {
770
611
  res.total_items = res?.total_items + 1;
771
612
  }
772
613
  this.lists.OWNERS = res;
614
+ if (!res?.data
615
+ ?.map((ele) => ele?.member_id)
616
+ ?.includes(this.controls.program_approver?.value[0]?.member_id)) {
617
+ this.setFormField('program_approver', []);
618
+ }
773
619
  if (this.controls?.all_user_in_role?.value) {
774
620
  this.setFormField('program_owners', res?.data);
775
621
  }
622
+ else {
623
+ this.setDefaultOwners(res?.data, calledFrom);
624
+ }
776
625
  },
777
626
  error: (err) => { },
778
627
  });
779
628
  }
629
+ fetchUserWithManageProgramsRole() {
630
+ this.programService.fetchAllRoleUsers(this.manageProgramsRoleId).subscribe({
631
+ next: (res) => {
632
+ this.lists.COLLABORATORS = res;
633
+ },
634
+ });
635
+ }
780
636
  fetchGroupsAssociatedWithRoles() {
781
637
  const roleIds = this.controls.program_roles?.value?.map((ele) => ele?._id);
782
638
  this.programService.fetchAllRoleGroups(roleIds).subscribe({
@@ -824,6 +680,24 @@ export class WorkflowProgramComponent {
824
680
  next: (res) => {
825
681
  this.lists.ALL_USER = res;
826
682
  this.lists.ASSIGNEES = res;
683
+ this.lists.REVIEWERS = res;
684
+ this.lists.OVERSEERS = res;
685
+ if (this.mode !== 'EDIT') {
686
+ this.lists.DEFAULT_ASSIGNEES = res;
687
+ this.lists.DEFAULT_REVIEWERS = res;
688
+ this.lists.DEFAULT_OVERSEERS = res;
689
+ }
690
+ else if (this.mode === 'EDIT') {
691
+ if (!this.controls.program_assignee?.value?.length) {
692
+ this.lists.DEFAULT_ASSIGNEES = res;
693
+ }
694
+ if (!this.controls.program_reviewer?.value?.length) {
695
+ this.lists.DEFAULT_REVIEWERS = res;
696
+ }
697
+ if (!this.controls.program_overseer?.value?.length) {
698
+ this.lists.DEFAULT_OVERSEERS = res;
699
+ }
700
+ }
827
701
  this.listLoadingState.USERS = false;
828
702
  this.refreshList();
829
703
  },
@@ -837,9 +711,12 @@ export class WorkflowProgramComponent {
837
711
  next: (res) => {
838
712
  this.lists.ALL_GROUP = res;
839
713
  this.lists.ASSIGNEES_GROUP = res;
840
- if (data) {
841
- this.populateGroupsByGID(data, 'owners');
842
- this.populateGroupsByGID(data, 'collaborators');
714
+ this.lists.REVIEWERS_GROUP = res;
715
+ this.lists.OVERSEERS_GROUP = res;
716
+ if (this.mode !== 'EDIT') {
717
+ this.lists.DEFAULT_ASSIGNEES_GROUP = res;
718
+ this.lists.DEFAULT_REVIEWERS_GROUP = res;
719
+ this.lists.DEFAULT_OVERSEERS_GROUP = res;
843
720
  }
844
721
  },
845
722
  error: (err) => { },
@@ -983,8 +860,7 @@ export class WorkflowProgramComponent {
983
860
  this.loader = false;
984
861
  this.showSmiley = true;
985
862
  this.uiKitService.isSmileyOn = true;
986
- this.createdProgramId = res?.data?.program?.id;
987
- this.postIframeMessage(PostMessageEvent.PROGRAM_CREATED, res);
863
+ this.createdProgramId = res._id;
988
864
  },
989
865
  error: (err) => {
990
866
  this.loader = false;
@@ -992,7 +868,6 @@ export class WorkflowProgramComponent {
992
868
  if (err?.error?.message?.includes('Category already exist')) {
993
869
  this.isNameExists = true;
994
870
  }
995
- this.postIframeMessage(PostMessageEvent.PROGRAM_CREATED, err);
996
871
  },
997
872
  });
998
873
  }
@@ -1002,8 +877,7 @@ export class WorkflowProgramComponent {
1002
877
  this.loader = false;
1003
878
  this.showSmiley = true;
1004
879
  this.uiKitService.isSmileyOn = true;
1005
- this.postIframeMessage(PostMessageEvent.PROGRAM_UPDATED, res);
1006
- this.createdProgramId = res?.data?.program?.id;
880
+ this.createdProgramId = res._id;
1007
881
  },
1008
882
  error: (err) => {
1009
883
  this.loader = false;
@@ -1011,15 +885,10 @@ export class WorkflowProgramComponent {
1011
885
  if (err?.error?.message?.includes('Category already exist')) {
1012
886
  this.isNameExists = true;
1013
887
  }
1014
- this.postIframeMessage(PostMessageEvent.PROGRAM_UPDATED, err);
1015
888
  },
1016
889
  });
1017
890
  }
1018
891
  }
1019
- postIframeMessage(event, data) {
1020
- const message = this.iframeService.getCloseWebviewMessage(event, data);
1021
- this.iframeService.postMessage(message);
1022
- }
1023
892
  action(event) {
1024
893
  switch (event) {
1025
894
  case 'addMore':
@@ -1041,10 +910,10 @@ export class WorkflowProgramComponent {
1041
910
  url = 'https://' + window.location.host;
1042
911
  }
1043
912
  if (window.location.host.startsWith('localhost')) {
1044
- url += '/programs/' + this.createdProgramId;
913
+ url += '/program-workroom?id=' + this.createdProgramId;
1045
914
  }
1046
915
  else {
1047
- url += '/compliance/programs/' + this.createdProgramId;
916
+ url += '/program/program-workroom?id=' + this.createdProgramId;
1048
917
  }
1049
918
  this.iframeService.redirectIfInIframe(url, true);
1050
919
  }
@@ -1121,56 +990,148 @@ export class WorkflowProgramComponent {
1121
990
  .getProgram(this.programId)
1122
991
  .pipe(take(1))
1123
992
  .subscribe((res) => {
993
+ this.setFormField('program_name', res?.name);
994
+ this.setFormField('program_type', res?.programType);
995
+ this.setFormField('program_objective', res?.program_objective?.text);
996
+ this.setFormField('all_user_in_role', res?.all_user_in_role);
997
+ this.setFormField('program_description_attachments', res?.description?.attachments);
998
+ this.setFormField('program_objective_attachments', res?.program_objective?.attachments);
999
+ this.setFormField('performance_calculation', res?.calculate_past_upcoming_event);
1000
+ this.setFormField('recurring_frequency', res?.program_frequency);
1001
+ if (res?.program_frequency &&
1002
+ this.mode === 'EDIT' &&
1003
+ (this.orgDetails?.hasProgramFullPermission ||
1004
+ !this.programSimplifyFlag)) {
1005
+ this.additionalOption.PROGRAM_FREQUENCY = true;
1006
+ this.populateOptionalFields();
1007
+ }
1008
+ this.setFormField('lock_scope_change', res?.lock_scope);
1009
+ if (res?.lock_scope &&
1010
+ (this.orgDetails?.hasProgramFullPermission ||
1011
+ !this.programSimplifyFlag)) {
1012
+ this.additionalOption.SCOPE_CHANGES = true;
1013
+ this.populateOptionalFields();
1014
+ }
1015
+ this.setFormField('program_state', res?.state);
1016
+ const rc = res.rc_details.map((ele) => {
1017
+ return { ...ele, item_name: ele?.rc_name, item_id: ele?.rc_id };
1018
+ });
1019
+ this.setFormField('rc', rc);
1020
+ if (res?.rc_details &&
1021
+ res?.rc_details?.length &&
1022
+ (this.orgDetails?.hasProgramFullPermission ||
1023
+ !this.programSimplifyFlag)) {
1024
+ this.additionalOption.RC = true;
1025
+ this.populateOptionalFields();
1026
+ }
1027
+ this.setFormField('evidence_required', res?.evidence_upload_flag);
1028
+ this.setFormField('allow_any_file_key_evidence', res?.is_key_evidence);
1029
+ if ((res?.evidence_upload_flag || res?.is_key_evidence) &&
1030
+ (this.orgDetails?.hasProgramFullPermission ||
1031
+ !this.programSimplifyFlag)) {
1032
+ this.additionalOption.FORMATE_EVIDENCE = true;
1033
+ this.populateOptionalFields();
1034
+ }
1035
+ this.setFormField('assignee_completion_criteria', res.default_assignee_type);
1036
+ this.setFormField('reviewer_completion_criteria', res.default_reviewers_type);
1037
+ this.editorData.programDescription = res.description?.text;
1038
+ this.editorData.programObjective = res.program_objective?.text;
1039
+ this.setFormField('framework', {
1040
+ ...res.framework_details,
1041
+ ...{ _id: res?.framework_details?.framework_id },
1042
+ });
1043
+ const role = res?.roles?.map((ele) => {
1044
+ return {
1045
+ _id: ele?.roleId,
1046
+ roleName: ele?.roleName,
1047
+ licenseType: ele?.licenseType,
1048
+ permissionGroupName: ele?.permissionGroupName,
1049
+ };
1050
+ });
1051
+ this.setFormField('program_roles', role);
1052
+ if (res?.roles && res?.roles?.length && this.mode === 'EDIT') {
1053
+ this.additionalOption.ROLES = true;
1054
+ }
1055
+ if (res.assessmentData.length) {
1056
+ res.assessmentData = res.assessmentData.map((ele) => {
1057
+ return {
1058
+ ...ele,
1059
+ assessmentIds: ele?.assessments.map((assess) => {
1060
+ return { ...assess, id: assess?._id };
1061
+ }),
1062
+ };
1063
+ });
1064
+ this.setFormField('program_assessments', res.assessmentData);
1065
+ if (this.orgDetails?.hasProgramFullPermission ||
1066
+ !this.programSimplifyFlag) {
1067
+ this.additionalOption.ASSESSMENT = true;
1068
+ this.populateOptionalFields();
1069
+ }
1070
+ }
1071
+ if (res.custom_fields.length) {
1072
+ this.setFormField('custom_fields', res.custom_fields);
1073
+ this.additionalOption.CUSTOM_FIELDS = true;
1074
+ this.populateOptionalFields();
1075
+ }
1076
+ this.isApproverDisabled = res?.isApproverDisabled ?? false;
1077
+ if (this.isApproverDisabled) {
1078
+ setTimeout(() => {
1079
+ this.disableElementsFromMoreOptions.emit(['APPROVER']);
1080
+ }, 500);
1081
+ }
1082
+ this.populateMembers(res);
1083
+ this.populateGroups(res);
1084
+ this.fetchUsersAssociatedWithRoles('getProgramDetails');
1085
+ this.fetchGroupsAssociatedWithRoles();
1086
+ this.fetchOrganizationGroup();
1087
+ this.fetchOrganizationUsers();
1124
1088
  });
1125
1089
  }
1126
- populateProgramDetails(res) {
1127
- this.programId = res?.id;
1128
- const programType = PROGRAM_OBJECT[res?.type] ?? PROGRAM_OBJECT.others;
1129
- this.setFormField('program_name', res?.name);
1130
- this.setFormField('program_type', programType);
1131
- this.setFormField('program_objective', res?.description);
1132
- this.editorData.programObjective = res?.description;
1133
- if (res?.roles && res?.roles?.length && this.mode === 'EDIT') {
1134
- this.additionalOption.ROLES = true;
1135
- }
1136
- if (res.customFields.length) {
1137
- this.setFormField('custom_fields', res.customFields);
1138
- this.additionalOption.CUSTOM_FIELDS = true;
1139
- this.populateOptionalFields();
1140
- }
1141
- this.populateMembers(res);
1142
- this.populateGroups(res);
1143
- this.fetchUsersAssociatedWithRoles('getProgramDetails');
1144
- this.fetchGroupsAssociatedWithRoles();
1145
- this.fetchOrganizationGroup(res);
1146
- this.fetchOrganizationUsers();
1147
- }
1148
1090
  populateMembers(res) {
1091
+ this.loader = true;
1149
1092
  const ids = [
1150
1093
  ...new Set([
1151
- ...(res?.owners?.admins?.users ?? []),
1152
- ...(res?.owners?.managers?.users ?? []),
1094
+ ...(res?.owners ?? []),
1095
+ ...(res?.approvers ?? []),
1096
+ ...(res?.assignee_ids ?? []),
1097
+ ...(res?.default_assignee_ids ?? []),
1098
+ ...(res?.reviewers ?? []),
1099
+ ...(res?.default_reviewers ?? []),
1100
+ ...(res?.overseers?.cc_email ?? []),
1101
+ ...(res?.overseers?.failure_cc_email ?? []).filter((ele) => ele),
1102
+ ...(res?.default_overseers?.cc_email ?? []),
1103
+ ...(res?.default_overseers?.failure_cc_email ?? []).filter((ele) => ele),
1153
1104
  ]),
1154
1105
  ];
1155
- this.programService.getMemeberByUIds(ids).subscribe({
1106
+ this.programService.getMemeberByIds(ids).subscribe({
1156
1107
  next: (response) => {
1157
1108
  this.loader = false;
1158
- const selectedOwners = res.owners?.admins;
1159
- const selectedCollaborators = res.owners?.managers;
1160
- if (selectedOwners?.users?.length) {
1161
- const owners = response.filter((ele) => selectedOwners?.users.includes(ele?.uid));
1109
+ if (res.owners && res?.owners?.length) {
1110
+ const owners = response.filter((ele) => res?.owners.includes(ele?.member_id));
1162
1111
  this.setFormField('program_owners', owners);
1163
1112
  if (this.mode === 'EDIT') {
1164
1113
  this.additionalOption.OWNERS = true;
1165
1114
  this.populateOptionalFields();
1166
1115
  }
1167
1116
  }
1168
- if (selectedCollaborators?.users?.length) {
1169
- const collaborators = response.filter((ele) => selectedCollaborators?.users?.includes(ele?.uid));
1170
- this.setFormField('collaborators', collaborators);
1171
- this.additionalOption.COLLABORATORS = true;
1117
+ if (res.approvers &&
1118
+ res?.approvers?.length &&
1119
+ !this.programSimplifyFlag) {
1120
+ const approvers = response.filter((ele) => res?.approvers.includes(ele?.member_id));
1121
+ this.setFormField('program_approver', approvers);
1122
+ this.additionalOption.APPROVER = true;
1172
1123
  this.populateOptionalFields();
1173
1124
  }
1125
+ if (res?.assignee_ids && res?.assignee_ids?.length) {
1126
+ const assignee = response.filter((ele) => res?.assignee_ids.includes(ele?.member_id));
1127
+ this.setFormField('program_assignee', assignee);
1128
+ this.lists.DEFAULT_ASSIGNEES = assignee;
1129
+ if (this.orgDetails?.hasProgramFullPermission ||
1130
+ !this.programSimplifyFlag) {
1131
+ this.additionalOption.ASSIGNEES = true;
1132
+ this.populateOptionalFields();
1133
+ }
1134
+ }
1174
1135
  if (res?.default_assignee_ids && res?.default_assignee_ids?.length) {
1175
1136
  const assignee = response.filter((ele) => res?.default_assignee_ids.includes(ele?.member_id));
1176
1137
  this.setFormField('program_default_assignee', assignee);
@@ -1180,6 +1141,52 @@ export class WorkflowProgramComponent {
1180
1141
  this.populateOptionalFields();
1181
1142
  }
1182
1143
  }
1144
+ if (res?.reviewers && res?.reviewers?.length) {
1145
+ const reviewers = response.filter((ele) => res?.reviewers.includes(ele?.member_id));
1146
+ this.setFormField('program_reviewer', reviewers);
1147
+ this.lists.DEFAULT_REVIEWERS = reviewers;
1148
+ if (this.orgDetails?.hasProgramFullPermission ||
1149
+ !this.programSimplifyFlag) {
1150
+ this.additionalOption.REVIEWER = true;
1151
+ this.populateOptionalFields();
1152
+ }
1153
+ }
1154
+ if (res?.default_reviewers && res?.default_reviewers?.length) {
1155
+ const reviewers = response.filter((ele) => res?.default_reviewers.includes(ele?.member_id));
1156
+ this.setFormField('program_default_reviewer', reviewers);
1157
+ if (this.orgDetails?.hasProgramFullPermission ||
1158
+ !this.programSimplifyFlag) {
1159
+ this.additionalOption.REVIEWER = true;
1160
+ this.populateOptionalFields();
1161
+ }
1162
+ }
1163
+ if (res?.overseers && res?.overseers?.cc_email?.length) {
1164
+ const cc = response.filter((ele) => res?.overseers?.cc_email.includes(ele?.member_id));
1165
+ this.setFormField('program_overseer', cc);
1166
+ this.lists.DEFAULT_OVERSEERS = cc;
1167
+ if (this.orgDetails?.hasProgramFullPermission ||
1168
+ !this.programSimplifyFlag) {
1169
+ this.additionalOption.OVERSEER = true;
1170
+ this.populateOptionalFields();
1171
+ }
1172
+ }
1173
+ if (res?.default_overseers &&
1174
+ (res?.default_overseers?.cc_email?.length ||
1175
+ res?.default_overseers?.failure_cc_email?.length)) {
1176
+ if (res?.default_overseers?.cc_email?.length) {
1177
+ const defaultCC = response.filter((ele) => res?.default_overseers?.cc_email.includes(ele?.member_id));
1178
+ this.setFormField('program_default_overseer', defaultCC);
1179
+ }
1180
+ if (res?.default_overseers?.failure_cc_email?.length) {
1181
+ const failCC = response.filter((ele) => res?.default_overseers?.failure_cc_email.includes(ele?.member_id));
1182
+ this.setFormField('program_default_failed_overseer', failCC);
1183
+ }
1184
+ if (this.orgDetails?.hasProgramFullPermission ||
1185
+ !this.programSimplifyFlag) {
1186
+ this.additionalOption.OVERSEER = true;
1187
+ this.populateOptionalFields();
1188
+ }
1189
+ }
1183
1190
  },
1184
1191
  });
1185
1192
  this.checkProgramOptionField();
@@ -1200,18 +1207,77 @@ export class WorkflowProgramComponent {
1200
1207
  this.programService.getMemberByGroups(ids).subscribe({
1201
1208
  next: (resp) => {
1202
1209
  const response = resp?.data;
1203
- if (res?.owners?.userGroups?.length) {
1204
- const owners = response.filter((ele) => res?.owners?.userGroups?.includes(ele?.ugid));
1205
- this.additionalOption.OWNERS = true;
1206
- this.populateOptionalFields();
1210
+ if (res.owners_group && res?.owners_group?.length) {
1211
+ const owners = response.filter((ele) => res?.owners_group?.includes(ele?.group_id));
1207
1212
  this.setFormField('program_owners_group', owners);
1208
1213
  }
1209
- if (res?.managers?.userGroups?.length) {
1210
- const collaborators = response.filter((ele) => res?.managers?.userGroups?.includes(ele?.ugid));
1211
- this.setFormField('collaborators_group', collaborators);
1212
- this.additionalOption.COLLABORATORS = true;
1213
- this.populateOptionalFields();
1214
- this.lists.ASSIGNEES_GROUP = collaborators;
1214
+ if (res.assignee_group_ids && res?.assignee_group_ids?.length) {
1215
+ const assignee = response.filter((ele) => res?.assignee_group_ids?.includes(ele?.group_id));
1216
+ this.setFormField('program_assignee_group', assignee);
1217
+ this.lists.DEFAULT_ASSIGNEES_GROUP = assignee;
1218
+ if (this.orgDetails?.hasProgramFullPermission ||
1219
+ !this.programSimplifyFlag) {
1220
+ this.additionalOption.ASSIGNEES = true;
1221
+ }
1222
+ }
1223
+ if (res?.default_assignee_group_ids &&
1224
+ res?.default_assignee_group_ids?.length) {
1225
+ const assignee = response.filter((ele) => res?.default_assignee_group_ids?.includes(ele?.group_id));
1226
+ this.setFormField('program_default_assignee_group', assignee);
1227
+ if (this.orgDetails?.hasProgramFullPermission ||
1228
+ !this.programSimplifyFlag) {
1229
+ this.additionalOption.ASSIGNEES = true;
1230
+ }
1231
+ }
1232
+ if (res?.reviewer_group_ids && res?.reviewer_group_ids?.length) {
1233
+ const reviewer = response.filter((ele) => res?.reviewer_group_ids?.includes(ele?.group_id));
1234
+ this.setFormField('program_reviewer_group', reviewer);
1235
+ this.lists.DEFAULT_REVIEWERS_GROUP = reviewer;
1236
+ if (this.orgDetails?.hasProgramFullPermission ||
1237
+ !this.programSimplifyFlag) {
1238
+ this.additionalOption.REVIEWER = true;
1239
+ }
1240
+ }
1241
+ if (res?.default_reviewer_group_ids &&
1242
+ res?.default_reviewer_group_ids?.length) {
1243
+ const reviewer = response?.filter((ele) => res?.default_reviewer_group_ids?.includes(ele?.group_id));
1244
+ this.setFormField('program_default_reviewer_group', reviewer);
1245
+ this.controls.reviewer_completion_criteria.value =
1246
+ this.controls?.program_default_reviewer_group?.value?.length > 0
1247
+ ? 'ANYONE'
1248
+ : this.controls?.reviewer_completion_criteria?.value;
1249
+ if (this.orgDetails?.hasProgramFullPermission ||
1250
+ !this.programSimplifyFlag) {
1251
+ this.additionalOption.REVIEWER = true;
1252
+ }
1253
+ }
1254
+ if (res?.overseers?.cc_email_groups &&
1255
+ res?.overseers?.cc_email_groups?.length) {
1256
+ const overseerGroup = response.filter((ele) => res?.overseers?.cc_email_groups?.includes(ele?.group_id));
1257
+ this.setFormField('program_overseer_group', overseerGroup);
1258
+ this.lists.DEFAULT_OVERSEERS_GROUP = overseerGroup;
1259
+ if (this.orgDetails?.hasProgramFullPermission ||
1260
+ !this.programSimplifyFlag) {
1261
+ this.additionalOption.OVERSEER = true;
1262
+ }
1263
+ }
1264
+ if (res?.default_overseers?.cc_email_groups &&
1265
+ res?.default_overseers?.cc_email_groups?.length) {
1266
+ const defaultOverseerGroup = response.filter((ele) => res?.default_overseers?.cc_email_groups?.includes(ele?.group_id));
1267
+ this.setFormField('program_default_overseer_group', defaultOverseerGroup);
1268
+ if (this.orgDetails?.hasProgramFullPermission ||
1269
+ !this.programSimplifyFlag) {
1270
+ this.additionalOption.OVERSEER = true;
1271
+ }
1272
+ }
1273
+ if (res?.default_overseers?.failure_cc_email_groups &&
1274
+ res?.default_overseers?.failure_cc_email_groups?.length) {
1275
+ const defaultOverseerFailureGroup = response.filter((ele) => res?.default_overseers?.failure_cc_email_groups?.includes(ele?.group_id));
1276
+ this.setFormField('program_default_failed_overseer_group', defaultOverseerFailureGroup);
1277
+ if (this.orgDetails?.hasProgramFullPermission ||
1278
+ !this.programSimplifyFlag) {
1279
+ this.additionalOption.OVERSEER = true;
1280
+ }
1215
1281
  }
1216
1282
  },
1217
1283
  // As of now groups has been removed from reviewer and overseeer if this group feature gets incoperated in
@@ -1219,27 +1285,6 @@ export class WorkflowProgramComponent {
1219
1285
  });
1220
1286
  this.checkProgramOptionField();
1221
1287
  }
1222
- populateGroupsByGID(programDetails, type) {
1223
- switch (type) {
1224
- case 'owners':
1225
- const owner_ugid = programDetails?.owners?.admins?.userGroups;
1226
- const ownersGroup = this.lists.ASSIGNEES_GROUP.filter((ele) => owner_ugid.includes(ele?.ugid));
1227
- const ownersGroupIds = ownersGroup.map((ele) => ele?.group_id);
1228
- this.setFormField('program_owners_group', ownersGroup);
1229
- this.additionalOption.OWNERS = true;
1230
- this.populateOptionalFields();
1231
- break;
1232
- case 'collaborators':
1233
- const collaborator_ugid = programDetails?.owners?.managers?.userGroups;
1234
- const groupList = this.lists.ASSIGNEES_GROUP.filter((ele) => collaborator_ugid.includes(ele?.ugid));
1235
- this.setFormField('collaborators_group', groupList);
1236
- this.additionalOption.COLLABORATORS = true;
1237
- this.populateOptionalFields();
1238
- break;
1239
- default:
1240
- break;
1241
- }
1242
- }
1243
1288
  resetAdditionalOption() {
1244
1289
  this.additionalOption.ROLES = false;
1245
1290
  this.additionalOption.OWNERS = false;
@@ -1285,18 +1330,13 @@ export class WorkflowProgramComponent {
1285
1330
  : 'Owners are responsible for managing a Program. Only Owners can make changes to a Program and the responsibilities that are linked with the Program.<br>The <strong>Key Admin</strong> and all <b>Admin</b> users will be selected as the Owners of a Program by default.';
1286
1331
  this.ff_rc_listing = this.allowedFeature.isFeatureEnabled('ff_rc_listing');
1287
1332
  }
1288
- handleDataPopulation() {
1289
- if (this.mode === 'EDIT') {
1290
- this.populateProgramDetails(this.programDetails);
1291
- }
1292
- }
1293
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: WorkflowProgramComponent, deps: [{ token: i1.UntypedFormBuilder }, { token: i2.ProgramsService }, { token: i3.AuthService }, { token: i4.UiKitService }, { token: i0.ChangeDetectorRef }, { token: i5.IframeService }], target: i0.ɵɵFactoryTarget.Component }); }
1294
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: WorkflowProgramComponent, selector: "app-workflow-program", inputs: { canFrameworkChange: "canFrameworkChange", mode: "mode", programId: "programId", programType: "programType", allowedFeature: "allowedFeature", addToProgramDetails: "addToProgramDetails", orgDetails: "orgDetails", programDetails: "programDetails" }, outputs: { pickerChanged: "pickerChanged", populateOption: "populateOption", closeWorkflow: "closeWorkflow", showConfirmationAlert: "showConfirmationAlert", disconnectRefresh: "disconnectRefresh", refreshForm: "refreshForm", hideElementsFromMoreOptions: "hideElementsFromMoreOptions", onRemovingRole: "onRemovingRole", disableElementsFromMoreOptions: "disableElementsFromMoreOptions" }, viewQueries: [{ propertyName: "form", first: true, predicate: ["form"], descendants: true, read: ElementRef }, { propertyName: "datePicker", first: true, predicate: ["datePicker"], descendants: true }], ngImport: i0, template: "<div class=\"workflow-program\" #form>\n <form novalidate [formGroup]=\"programForm\">\n <!-- Program Category Type -->\n <form-field\n [checked]=\"controls?.program_type?.value > -1\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.issue_type\"\n >\n <label class=\"vx-control-panel\"\n >PROGRAM TYPE <span class=\"required\">*</span></label\n >\n <tab-selector\n formControlName=\"program_type\"\n [displayArray]=\"constants?.categoryType\"\n ></tab-selector>\n <!-- <p *ngIf=\"program_name?.invalid\" class=\"error-message\">Add a program type</p> -->\n </form-field>\n\n <!-- Framework -->\n <form-field\n *ngIf=\"isAscentAllowed\"\n [checked]=\"false\"\n [active]=\"false\"\n [disabled]=\"false\"\n [img]=\"ASSETS.case_category\"\n >\n <label class=\"vx-control-panel\">FRAMEWORK</label>\n <!-- [selectDiv]=\"true\" -->\n <input-with-pill\n [placeholder]=\"'Select a framework that this Program relates to'\"\n (select)=\"activateList('FRAMEWORK')\"\n >\n <div class=\"selected\" *ngIf=\"controls?.framework.value?.name\">\n <div class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\">\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n *ngIf=\"canFrameworkChange\"\n (click)=\"remove('', 'FRAMEWORK')\"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.framework.value?.name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.framework.value?.name }}</span\n >\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i (click)=\"remove('', 'FRAMEWORK')\" *ngIf=\"canFrameworkChange\" class=\"icons\" >&#xe90d;</i> {{controls?.framework.value?.name}}</span>\n </div>\n </div> -->\n <button\n *ngIf=\"canFrameworkChange\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('FRAMEWORK')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n </form-field>\n\n <!-- Program Category Name -->\n <form-field\n [checked]=\"controls?.program_name?.value?.trim()?.length\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.what\"\n >\n <label class=\"vx-control-panel\"\n >PROGRAM NAME <span class=\"required\">*</span></label\n >\n <input\n InputTrim\n formControlName=\"program_name\"\n type=\"text\"\n placeholder=\"What is the Program name?\"\n />\n\n <p\n *ngIf=\"\n controls?.program_name?.errors && controls?.program_name?.touched\n \"\n class=\"error-message\"\n >\n Enter a name for this Program.\n </p>\n <p *ngIf=\"isNameExists\" class=\"error-message\">\n Program name already exists.\n </p>\n <vcomply-editor\n [(ngModel)]=\"editorData.programObjective\"\n [ngModelOptions]=\"{ standalone: true }\"\n (sendSavedFiles)=\"selectFile('OBJECTIVE', $event)\"\n (ngModelChange)=\"setFormField('program_objective', $event, true)\"\n [editorConfig]=\"constants?.description\"\n >\n </vcomply-editor>\n </form-field>\n\n\n\n <!-- Owners -->\n <form-field\n *ngIf=\"additionalOption?.OWNERS\"\n [checked]=\"\n controls?.program_owners?.value?.length > 0 ||\n controls?.program_owners_group?.value?.length > 0\n \"\n [active]=\"activeList === 'OWNER'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'OWNER'\"\n [img]=\"ASSETS.case_owners\"\n >\n <label class=\"vx-control-panel\"\n >OWNER(S) \n <span\n class=\"icon\"\n *ngIf=\"toolTipData.owner !== ''\"\n libPopoverHover\n (mouseover)=\"dataTooltip.popover()\"\n (mouseleave)=\"dataTooltip.closePopover()\"\n placement=\"right\"\n ><i class=\"icons\">&#xe91f;</i></span\n >\n <popover-hover #dataTooltip>\n <div class=\"vx-info-card\">\n <div\n class=\"vx-info-card-body\"\n [innerHTML]=\"toolTipData.owner\"\n id=\"OwnerHelpText\"\n ></div>\n </div>\n </popover-hover>\n </label>\n <input-with-pill\n [placeholder]=\"'Who is responsible for managing this program?'\"\n (select)=\"activateList('OWNER')\"\n >\n <div class=\"selected\" *ngIf=\"controls?.program_owners?.value[0]\">\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_owners?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_owners?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4 greenBg\"\n appPopover\n (click)=\"owner.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_owners?.value?.length > 1\"\n >\n +{{ controls?.program_owners?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_owners_group?.value?.length &&\n controls?.program_owners?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_owners_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n (click)=\"\n remove(\n controls?.program_owners_group?.value[0],\n 'OWNER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_owners_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_owners_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"group.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_owners_group?.value?.length > 1\"\n >\n +{{ controls?.program_owners_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n <button\n *ngIf=\"activeList !== 'OWNER'\"\n [class.disabled]=\"controls?.all_user_in_role?.value\"\n (click)=\"activateList('OWNER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i>Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #owner [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"let owner of controls?.program_owners?.value | slice : 1\"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"\n !(\n lists.NON_REMOVABLE_OWNERS | listToId : 'member_id'\n ).includes(owner?.member_id)\n \"\n class=\"icons\"\n (click)=\"remove(owner, 'OWNER')\"\n >&#xe90d;</i\n >\n {{ owner?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #group [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let owner of controls?.program_owners_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n class=\"icons\"\n (click)=\"remove(owner, 'OWNER_GROUP')\"\n >&#xe90d;</i\n >\n {{ owner?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field>\n\n <!-- Collaborators -->\n <form-field\n *ngIf=\"additionalOption?.COLLABORATORS\"\n [checked]=\"\n controls?.collaborators?.value?.length > 0 ||\n controls?.collaborators_group?.value?.length > 0\n \"\n [active]=\"activeList === 'COLLABORATORS'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'COLLABORATORS'\"\n [img]=\"\n 'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/owner.svg'\n \"\n >\n <label class=\"vx-control-panel\"\n >COLLABORATORS \n <span\n class=\"icon\"\n *ngIf=\"toolTipData.collaborators !== ''\"\n libPopoverHover\n (mouseover)=\"dataTooltip.popover()\"\n (mouseleave)=\"dataTooltip.closePopover()\"\n placement=\"right\"\n ><i class=\"icons\">&#xe91f;</i></span\n >\n <popover-hover #dataTooltip>\n <div class=\"vx-info-card\">\n <div\n class=\"vx-info-card-body\"\n [innerHTML]=\"toolTipData.collaborators\"\n id=\"CollaboratorsHelpText\"\n ></div>\n </div>\n </popover-hover>\n </label>\n <input-with-pill\n [placeholder]=\"'Who is responsible for managing this program?'\"\n (select)=\"activateList('COLLABORATORS')\"\n >\n <div class=\"selected\" *ngIf=\"controls?.collaborators?.value[0] || controls?.collaborators_group?.value[0]\">\n <div class=\"vx-d-flex vx-align-center\">\n <!-- Users -->\n <div \n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.collaborators?.value[0]\"\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.collaborators?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.collaborators?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4 greenBg\"\n appPopover\n (click)=\"owner.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.collaborators?.value?.length > 1\"\n >\n +{{ controls?.collaborators?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\" \n controls?.collaborators_group?.value?.length &&\n controls?.collaborators?.value?.length\n \"\n >&</span\n >\n <!-- Groups -->\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.collaborators_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n (click)=\"\n remove(\n controls?.collaborators_group?.value[0],\n 'COLLABORATORS_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.collaborators_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.collaborators_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"group.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_owners_group?.value?.length > 1\"\n >\n +{{ controls?.collaborators_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\" [appTooltip]=\"controls?.program_owners?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\" >{{controls?.program_owners?.value[0]?.member_name}}</span></span>\n <button *ngIf=\"controls?.program_owners?.value?.length > 1\" class=\"count user\" appPopover (click)=\"owner.popover()\" placement=\"right\">+{{controls?.program_owners?.value?.length -1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_owners_group?.value?.length && controls?.program_owners?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_owners_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" *ngIf=\"!['ADMIN','KEY_ADMIN','LOGGED_IN'].includes(owner?.user_role)\" (click)=\"remove(owner,'OWNER_GROUP')\">&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_owners_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_owners_group?.value[0]?.group_name}}</span></span>\n <button *ngIf=\"controls?.program_owners_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"group.popover()\" placement=\"right\">+{{controls?.program_owners_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'COLLABORATORS'\"\n [class.disabled]=\"controls?.all_user_in_role?.value\"\n (click)=\"activateList('COLLABORATORS')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i>Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #owner [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"let owner of controls?.collaborators?.value | slice : 1\"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n\n class=\"icons\"\n (click)=\"remove(owner, 'COLLABORATORS')\"\n >&#xe90d;</i\n >\n {{ owner?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #group [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let owner of controls?.collaborators_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n class=\"icons\"\n (click)=\"remove(owner, 'COLLABORATORS_GROUP')\"\n >&#xe90d;</i\n >\n {{ owner?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field>\n\n <!-- Performance Calculated -->\n <!-- <form-field [checked]=\"controls?.performance_calculation?.value\" [active]=\"activeList === 'PERFORMANCE'\" [disabled]=\"sideElements.includes(activeList) && activeList !== 'PERFORMANCE'\"\n [img]=\"'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/performance-calc.svg'\">\n <label class=\"vx-control-panel\">HOW SHOULD THE PERFORMANCE OF THIS PROGRAM BE CALCULATED?</label>\n <tab-selector formControlName=\"performance_calculation\" [displayArray]=\"constants?.performanceCalculation\">\n </tab-selector>\n </form-field> -->\n <ng-container *ngIf=\"isProgramScope && false\">\n <div\n class=\"scope-label vx-fs-10 vx-txt-white vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mb-5 vx-lh-4 vx-d-inline-block\"\n >\n PROGRAM SCOPE\n </div>\n <!-- <i class=\"icons info-icon vx-fs-12 vx-txt-blue vx-ml-1\" [appTooltip]=\"tooltip.programScope\" placement=\"bottom\" delay=\"0\" type=\"white\" [tooltipMandatory]=\"true\">&#xe91f;</i> -->\n <span\n class=\"icon info-icon vx-fs-12 vx-txt-blue vx-ml-1\"\n *ngIf=\"toolTipData.programScop !== ''\"\n libPopoverHover\n (mouseover)=\"dataTooltip.popover()\"\n (mouseleave)=\"dataTooltip.closePopover()\"\n placement=\"right\"\n ><i class=\"icons\">&#xe91f;</i></span\n >\n <popover-hover #dataTooltip>\n <div class=\"vx-info-card\">\n <div\n class=\"vx-info-card-body\"\n [innerHTML]=\"toolTipData.programScope\"\n id=\"PSHelpText\"\n ></div>\n </div>\n </popover-hover>\n </ng-container>\n\n <!-- Program Frequency -->\n <form-field\n *ngIf=\"additionalOption?.PROGRAM_FREQUENCY\"\n [checked]=\"[true, false].includes(controls?.recurring_frequency?.value)\"\n [active]=\"activeList === 'FREQUENCY'\"\n [disabled]=\"\n sideElements.includes(activeList) && activeList !== 'FREQUENCY'\n \"\n [img]=\"ASSETS.recurring\"\n >\n <label class=\"vx-control-panel\" id=\"PDChange\"\n >PROGRAM DURATION\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Program Duration refers to the duration of the Program. A Program can occur in perpetuity, or it can occur until the end of the current business cycle that has been specified in ' +\n businessCycle.selectedCycle.business_cycle +\n '. All responsibilities linked with that Program will also have the same Program Duration.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"ProgramDurationHelpText\"\n >&#xeb16;</i\n ></label\n >\n <div class=\"upload-format\">\n <div class=\"vx-d-flex vx-align-center vx-justify-between\">\n <span class=\"text vx-mb-0\">Is this program recurring?</span>\n <div class=\"radio-group program\">\n <app-cs-radio\n [name]=\"'recurring_frequency'\"\n [checked]=\"controls?.recurring_frequency?.value\"\n (checkedEvent)=\"setFormField('recurring_frequency', true)\"\n >YES</app-cs-radio\n >\n <app-cs-radio\n [name]=\"'recurring_frequency'\"\n [checked]=\"!controls?.recurring_frequency?.value\"\n (checkedEvent)=\"setFormField('recurring_frequency', false)\"\n >NO</app-cs-radio\n >\n </div>\n </div>\n </div>\n </form-field>\n\n <!-- Scope Changes -->\n <form-field\n *ngIf=\"additionalOption?.SCOPE_CHANGES\"\n [checked]=\"[true, false].includes(controls?.lock_scope_change?.value)\"\n [active]=\"activeList === 'SCOPE'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'SCOPE'\"\n [img]=\"ASSETS.lock_scope\"\n >\n <label class=\"vx-control-panel\"\n >Lock the Program Scope\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If the Program Scope is locked, neither the Program nor the responsibilities linked with the Program can be edited once the Program begins. In order to edit the Program or the linked responsibilities, the Program details will need to be edited.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"ScopeChangesHelpText\"\n >&#xeb16;</i\n ></label\n >\n <div class=\"upload-format\">\n <span class=\"text\"\n >Would you like to\n <span class=\"vx-label-txt vx-fw-500\">lock changes</span> to the\n program scope?</span\n >\n <div class=\"radio-group program\">\n <app-cs-radio\n [name]=\"'lock_scope_change'\"\n [checked]=\"controls?.lock_scope_change?.value\"\n (checkedEvent)=\"setFormField('lock_scope_change', true)\"\n >YES</app-cs-radio\n >\n <app-cs-radio\n [name]=\"'lock_scope_change'\"\n [checked]=\"!controls?.lock_scope_change?.value\"\n (checkedEvent)=\"setFormField('lock_scope_change', false)\"\n >NO</app-cs-radio\n >\n </div>\n </div>\n </form-field>\n\n <!-- Framework -->\n <!-- <form-field [checked]=\"false\" [active]=\"activeList === 'FRAMEWORK'\" [disabled]=\"sideElements.includes(activeList) && activeList !== 'FRAMEWORK'\"\n [img]=\"'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/category.svg'\">\n <label class=\"vx-control-panel\">FRAMEWORK</label>\n <input-with-pill [placeholder]=\"'Select a framework that this Program relates to'\" (select)=\"activateList('FRAMEWORK')\">\n <div class=\"selected\" *ngIf=\"controls?.framework?.value?.framework_name\">\n <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i (click)=\"remove(controls?.framework.value,'FRAMEWORK')\" class=\"icons\">&#xe90d;</i>{{controls?.framework?.value?.framework_name}}</span>\n <button class=\"count\" appPopover (click)=\"framework.popover()\" placement=\"right\">+5</button>\n </div>\n </div>\n <button *ngIf=\"activeList!=='FRAMEWORK'\" (click)=\"activateList('FRAMEWORK')\" class=\"edit\" type=\"button\"><i class=\"icons\">&#xe9ba;</i> Edit</button>\n </div>\n </input-with-pill>\n <app-popover #framework [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i class=\"icons\">&#xe90d;</i>\n Manage framework name\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field> -->\n\n <!-- Responsibility Center -->\n <form-field\n *ngIf=\"additionalOption?.RC\"\n [checked]=\"controls?.rc?.value?.length\"\n [active]=\"activeList === 'RC'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'RC'\"\n [img]=\"ASSETS.responsibility_center\"\n >\n <label class=\"vx-control-panel\"\n >RESPONSIBILITY CENTER\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Responsibility Centers represent your organizational and operational infrastructure. Where Responsibility Centers are selected when creating a Program, only those Responsibilities Centers will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"RCHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n (select)=\"activateList('RC')\"\n [placeholder]=\"\n 'Which Responsibility Center(s) can be linked to the responsibilities associated with this Program?'\n \"\n >\n <div\n class=\"selected\"\n *ngIf=\"controls?.rc?.value && controls?.rc?.value?.length\"\n >\n <div class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\">\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"remove(controls?.rc?.value[0], 'RC')\"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.rc?.value[0]?.item_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.rc?.value[0]?.item_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"rc.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.rc?.value?.length > 1\"\n >\n +{{ controls?.rc?.value?.length - 1 }}\n </button>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i class=\"icons\" (click)=\"remove(controls?.rc?.value[0],'RC')\">&#xe90d;</i>{{controls?.rc?.value[0]?.item_name}}</span>\n <button *ngIf=\"controls?.rc?.value?.length > 1\" class=\"count\" appPopover (click)=\"rc.popover()\" placement=\"right\">+{{controls?.rc?.value?.length -1 }}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'RC'\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('RC')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #rc [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"let rc of controls?.rc?.value | slice : 1\">\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i class=\"icons\" (click)=\"remove(rc, 'RC')\">&#xe90d;</i>\n {{ rc?.item_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field>\n\n <!-- Assignee -->\n <form-field\n *ngIf=\"additionalOption?.ASSIGNEES\"\n [checked]=\"\n controls?.program_assignee?.value?.length ||\n controls?.program_default_assignee?.value?.length ||\n controls?.program_default_assignee?.value?.length ||\n controls?.program_default_assignee_group?.value?.length\n \"\n [active]=\"['ASSIGNEE', 'DEFAULT_ASSIGNEE']?.includes(activeList)\"\n [disabled]=\"\n sideElements?.includes(activeList) &&\n !['ASSIGNEE', 'DEFAULT_ASSIGNEE'].includes(activeList)\n \"\n [img]=\"ASSETS.case_assignees\"\n >\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"activeList === 'DEFAULT_ASSIGNEE'\"\n >ASSIGNEES\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Assignees are required to complete the responsibilities that have been assigned to them. Where Assignees are selected when creating a Program, only those Assignees will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"AssigneeHelpText\"\n >&#xeb16;</i\n >\n </label>\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'DEFAULT_ASSIGNEE'\"\n [placeholder]=\"\n 'Who is responsible for completing the responsibilities within this Program?'\n \"\n (select)=\"activateList('ASSIGNEE')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_assignee?.value?.length ||\n controls?.program_assignee_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_assignee?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(controls?.program_assignee?.value[0], 'ASSIGNEE')\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_assignee?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_assignee?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"assignee.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_assignee?.value?.length > 1\"\n >\n +{{ controls?.program_assignee?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_assignee_group?.value?.length &&\n controls?.program_assignee?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_assignee_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_assignee_group?.value[0],\n 'ASSIGNEE_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_assignee_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_assignee_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"assignee_group.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_assignee_group?.value?.length > 1\"\n >\n +{{ controls?.program_assignee_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_assignee?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_assignee?.value[0],'ASSIGNEE')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_assignee?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_assignee?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_assignee?.value?.length > 1\" class=\"count user\" appPopover (click)=\"assignee.popover()\" placement=\"right\">+{{controls?.program_assignee?.value?.length -1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_assignee_group?.value?.length && controls?.program_assignee?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_assignee_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_assignee_group?.value[0],'ASSIGNEE_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_assignee_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_assignee_group?.value[0]?.group_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_assignee_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"assignee_group.popover()\" placement=\"right\">+{{controls?.program_assignee_group?.value?.length -1 }}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'ASSIGNEE'\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('ASSIGNEE')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #assignee [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let assignee of controls?.program_assignee?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(assignee, 'ASSIGNEE')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ assignee?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #assignee_group [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_assignee_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(group, 'ASSIGNEE_GROUP')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"activeList === 'ASSIGNEE'\"\n >DEFAULT ASSIGNEE\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'This option lets you specify the Default Assignees for all new responsibilities linked with a Program. If a Default Assignees is selected, the user will automatically be selected the Assignee when creating a responsibility linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility. '\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"DAHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'ASSIGNEE'\"\n [placeholder]=\"\n 'Which persons will be selected as the default assignees for the responsibilities within this Program?'\n \"\n (select)=\"activateList('DEFAULT_ASSIGNEE')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_assignee?.value?.length ||\n controls?.program_default_assignee_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_assignee?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_assignee?.value[0],\n 'DEFAULT_ASSIGNEE'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_assignee?.value[0]?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_assignee?.value[0]?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultAssignee.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_default_assignee?.value?.length > 1\"\n >\n +{{ controls?.program_default_assignee?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_default_assignee_group?.value?.length &&\n controls?.program_default_assignee?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_assignee_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_assignee_group?.value[0],\n 'DEFAULT_ASSIGNEE_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_assignee_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_assignee_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultAssigneeGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_assignee_group?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_assignee_group?.value?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_assignee?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_assignee?.value[0],'DEFAULT_ASSIGNEE')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_assignee?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{ controls?.program_default_assignee?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_assignee?.value?.length > 1\" class=\"count user\" appPopover (click)=\"defaultAssignee.popover()\" placement=\"right\">+{{controls?.program_default_assignee?.value?.length - 1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_default_assignee_group?.value?.length && controls?.program_default_assignee?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_assignee_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_assignee_group?.value[0],'DEFAULT_ASSIGNEE_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_assignee_group?.value[0]?.group_name }}</span>\n </span>\n <button *ngIf=\"controls?.program_default_assignee_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"defaultAssigneeGroup.popover()\" placement=\"right\">+{{controls?.program_default_assignee_group?.value?.length -1 }}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_ASSIGNEE'\"\n (click)=\"activateList('DEFAULT_ASSIGNEE')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #defaultAssignee [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let assignee of controls?.program_default_assignee?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(assignee, 'DEFAULT_ASSIGNEE')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ assignee?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #defaultAssigneeGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_assignee_group?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(assignee, 'DEFAULT_ASSIGNEE_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <div\n class=\"radio-group-selector\"\n [class.disabled]=\"activeList === 'ASSIGNEE'\"\n >\n <app-cs-radio\n [name]=\"'assignee'\"\n [checked]=\"controls?.assignee_completion_criteria?.value === 'ALL'\"\n (checkedEvent)=\"setFormField('assignee_completion_criteria', 'ALL')\"\n >\n ALL SELECTED PERSONS NEED TO COMPLETE THIS\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If selected, separate responsibilities will be created for each person.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n <app-cs-radio\n [name]=\"'assignee'\"\n [checked]=\"controls?.assignee_completion_criteria?.value === 'ANYONE'\"\n (checkedEvent)=\"\n setFormField('assignee_completion_criteria', 'ANYONE')\n \"\n >\n ANY SELECTED PERSON CAN COMPLETE THIS\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If selected, only one responsibility will be created.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n </div>\n </form-field>\n\n <!-- Reviewer -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.REVIEWER\"\n [checked]=\"\n controls?.program_reviewer?.value?.length ||\n controls?.program_default_reviewer?.value?.length ||\n controls?.program_default_reviewer?.value?.length ||\n controls?.program_default_reviewer_group?.value?.length\n \"\n [active]=\"['REVIEWER', 'DEFAULT_REVIEWER']?.includes(activeList)\"\n [disabled]=\"\n sideElements?.includes(activeList) &&\n !['REVIEWER', 'DEFAULT_REVIEWER'].includes(activeList)\n \"\n [img]=\"ASSETS.reviewer\"\n >\n <label\n [class.disabled]=\"activeList === 'DEFAULT_REVIEWER'\"\n class=\"vx-control-panel\"\n >Reviewers\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Reviewers are required to review responsibilities after they have been completed. Where Reviewers are selected when creating a Program, only those Reviewers will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"ReviewerHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'DEFAULT_REVIEWER'\"\n [placeholder]=\"\n 'Who is responsible for reviewing the responsibilities within this Program?'\n \"\n (select)=\"activateList('REVIEWER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_reviewer?.value?.length ||\n controls?.program_reviewer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_reviewer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(controls?.program_reviewer?.value[0], 'REVIEWER')\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_reviewer?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_reviewer?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"reviewer.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_reviewer?.value?.length > 1\"\n >\n +{{ controls?.program_reviewer?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_reviewer_group?.value?.length &&\n controls?.program_reviewer?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_reviewer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_reviewer_group?.value[0],\n 'REVIEWER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_reviewer_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_reviewer_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"reviewerGroup.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_reviewer_group?.value?.length > 1\"\n >\n +{{ controls?.program_reviewer_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_reviewer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_reviewer?.value[0],'REVIEWER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_reviewer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_reviewer?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_reviewer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"reviewer.popover()\" placement=\"right\">+{{controls?.program_reviewer?.value?.length -1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_reviewer_group?.value?.length && controls?.program_reviewer?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_reviewer_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_reviewer_group?.value[0],'REVIEWER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_reviewer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_reviewer_group?.value[0]?.group_name}}\n </span>\n </span>\n <button *ngIf=\"controls?.program_reviewer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"reviewerGroup.popover()\" placement=\"right\">+{{controls?.program_reviewer_group?.value?.length - 1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'REVIEWER'\"\n (click)=\"activateList('REVIEWER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #reviewer [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let reviewer of controls?.program_reviewer?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(reviewer, 'REVIEWER')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ reviewer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #reviewerGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_reviewer_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(group, 'REVIEWER_GROUP')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <label\n [class.disabled]=\"activeList === 'REVIEWER'\"\n class=\"vx-control-panel\"\n >DEFAULT Reviewer\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'This option lets you specify the Default Reviewers for responsibilities linked with a Program. Where a user has been specified as a Default Reviewer, that user will automatically be selected as the Reviewer when creating a responsibility linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"DRHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'REVIEWER'\"\n [placeholder]=\"\n 'Which persons will be selected as the default reviewers for the responsibilities within this Program?'\n \"\n (select)=\"activateList('DEFAULT_REVIEWER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_reviewer?.value?.length ||\n controls?.program_default_reviewer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_reviewer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_reviewer?.value[0],\n 'DEFAULT_REVIEWER'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_reviewer?.value[0]?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_reviewer?.value[0]?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultReviewer.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_default_reviewer?.value?.length > 1\"\n >\n +{{ controls?.program_default_reviewer?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_default_reviewer_group?.value?.length &&\n controls?.program_default_reviewer?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_reviewer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_reviewer_group?.value[0],\n 'DEFAULT_REVIEWER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_reviewer_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_reviewer_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultReviewerGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_reviewer_group?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_reviewer_group?.value?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_reviewer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_reviewer?.value[0],'DEFAULT_REVIEWER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_reviewer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_reviewer?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_reviewer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"defaultReviewer.popover()\" placement=\"right\">+{{controls?.program_default_reviewer?.value?.length - 1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_default_reviewer_group?.value?.length && controls?.program_default_reviewer?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_reviewer_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_reviewer_group?.value[0],'DEFAULT_REVIEWER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_reviewer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_reviewer_group?.value[0]?.group_name}}\n </span>\n </span>\n <button *ngIf=\"controls?.program_default_reviewer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"defaultReviewerGroup.popover()\" placement=\"right\">+{{controls?.program_default_reviewer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_REVIEWER'\"\n (click)=\"activateList('DEFAULT_REVIEWER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #defaultReviewer [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let reviewer of controls?.program_default_reviewer?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(reviewer, 'DEFAULT_REVIEWER')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ reviewer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #defaultReviewerGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_reviewer_group?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(group, 'DEFAULT_REVIEWER_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <div\n class=\"radio-group-selector\"\n [class.disabled]=\"activeList === 'REVIEWER'\"\n >\n <app-cs-radio\n [name]=\"'reviewer'\"\n [checked]=\"\n controls?.reviewer_completion_criteria?.value === 'SEQUENTIAL'\n \"\n (checkedEvent)=\"\n setFormField('reviewer_completion_criteria', 'SEQUENTIAL')\n \"\n [class.disabled]=\"\n controls?.program_default_reviewer_group?.value?.length > 0\n \"\n >\n SEQUENTIAL\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'The responsibility will be sent for review one at a time in the sequence defined by you.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n <app-cs-radio\n [name]=\"'reviewer'\"\n [checked]=\"\n controls?.reviewer_completion_criteria?.value === 'ANYONE' ||\n controls?.program_default_reviewer_group?.value?.length > 0\n \"\n (checkedEvent)=\"\n setFormField('reviewer_completion_criteria', 'ANYONE')\n \"\n >\n ANY REVIEWER CAN MARK THIS AS REVIEWED\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'The responsibility will be sent for review to all reviewers at the same time. If anyone of the reviewer reviews the responsibility, it will be considered as reviewed.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n </div>\n </form-field>\n\n <!-- Overseer -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.OVERSEER\"\n [checked]=\"\n controls?.program_overseer?.value?.length ||\n controls?.program_default_overseer?.value?.length ||\n controls?.program_default_overseer?.value?.length ||\n controls?.program_default_overseer_group?.value?.length\n \"\n [active]=\"activeList === 'OVERSEER'\"\n [disabled]=\"\n sideElements?.includes(activeList) &&\n !['OVERSEER', 'DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(\n activeList\n )\n \"\n [img]=\"ASSETS.oversight\"\n >\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"\n ['DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n \"\n >Oversights\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Oversights receive updates when a responsibility is completed, completed with delay or not completed. Where Oversights are selected when creating a Program, only those Oversights will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"overseerHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"\n ['DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n \"\n [placeholder]=\"\n 'Who is responsible for overseeing the responsibilities within this Program?'\n \"\n (select)=\"activateList('OVERSEER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_overseer?.value?.length ||\n controls?.program_overseer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_overseer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(controls?.program_overseer?.value[0], 'OVERSEER')\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_overseer?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_overseer?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseers.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_overseer?.value?.length > 1\"\n >\n +{{ controls?.program_overseer?.value?.length - 1 }}\n </button>\n </div>\n <span\n *ngIf=\"\n controls?.program_overseer_group?.value?.length &&\n controls?.program_overseer?.value?.length\n \"\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_overseer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_overseer_group?.value[0],\n 'OVERSEER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_overseer_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_overseer_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseerGroup.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_overseer_group?.value?.length > 1\"\n >\n +{{ controls?.program_overseer_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_overseer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_overseer?.value[0],'OVERSEER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_overseer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">\n {{controls?.program_overseer?.value[0]?.member_name}}\n </span>\n </span>\n <button *ngIf=\"controls?.program_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseers.popover()\" placement=\"right\">+{{controls?.program_overseer?.value?.length -1}}</button>\n </div>\n <span *ngIf=\"controls?.program_overseer_group?.value?.length && controls?.program_overseer?.value?.length \" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_overseer_group?.value?.length \">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_overseer_group?.value[0],'OVERSEER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_overseer_group?.value[0]?.group_name}}</span></span>\n <button *ngIf=\"controls?.program_overseer_group?.value?.length> 1\" class=\"count\" appPopover (click)=\"overseerGroup.popover()\" placement=\"right\">+{{controls?.program_overseer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n\n <button\n *ngIf=\"activeList !== 'OVERSEER'\"\n (click)=\"activateList('OVERSEER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #overseers [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let overseer of controls?.program_overseer?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i class=\"icons\" (click)=\"remove(overseer, 'OVERSEER')\"\n >&#xe90d;</i\n >\n {{ overseer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #overseerGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_overseer_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(group, 'OVERSEER_GROUP')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <ng-container [class.disabled]=\"activeList === 'OVERSEER'\">\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"['OVERSEER'].includes(activeList)\"\n >DEFAULT Oversight\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'This option lets you specify the Default Oversight for responsibilities linked with a Program. Where a user has been specified as a Default Oversight, that user will automatically be selected as the Oversight when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"DOHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [disabled]=\"\n ['OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n \"\n [selectDiv]=\"true\"\n [placeholder]=\"\n 'Which persons will be selected as the default overseers for the responsibilities within this Program?'\n \"\n (select)=\"activateList('DEFAULT_OVERSEER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_overseer?.value?.length ||\n controls?.program_default_overseer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_overseer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_overseer?.value[0],\n 'DEFAULT_OVERSEER'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_overseer?.value[0]?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_overseer?.value[0]?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseersDefault.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_default_overseer?.value?.length > 1\"\n >\n +{{ controls?.program_default_overseer?.value?.length - 1 }}\n </button>\n </div>\n <span\n *ngIf=\"\n controls?.program_default_overseer_group?.value?.length &&\n controls?.program_default_overseer?.value?.length\n \"\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_overseer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_overseer_group?.value[0],\n 'DEFAULT_OVERSEER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_overseer_group?.value[0]\n ?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_overseer_group?.value[0]\n ?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseerDefaultGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_overseer_group?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_overseer_group?.value?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_overseer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_overseer?.value[0],'DEFAULT_OVERSEER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_overseer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_overseer?.value[0]?.member_name}}</span></span>\n <button *ngIf=\"controls?.program_default_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseersDefault.popover()\" placement=\"right\">+{{controls?.program_default_overseer?.value?.length -1}}</button>\n </div>\n <span *ngIf=\"controls?.program_default_overseer_group?.value?.length && controls?.program_default_overseer?.value?.length\" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_overseer_group?.value?.length \">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_overseer_group?.value[0],'DEFAULT_OVERSEER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_overseer_group?.value[0]?.group_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_overseer_group?.value?.length >1\" class=\"count\" appPopover (click)=\"overseerDefaultGroup.popover()\" placement=\"right\">+{{controls?.program_default_overseer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_OVERSEER'\"\n (click)=\"activateList('DEFAULT_OVERSEER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #overseersDefault [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let overseer of controls?.program_default_overseer?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n class=\"icons\"\n (click)=\"remove(overseer, 'DEFAULT_OVERSEER')\"\n >&#xe90d;</i\n >\n {{ overseer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #overseerDefaultGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_overseer_group?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(group, 'DEFAULT_OVERSEER_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <label class=\"vx-control-panel\"> </label>\n <input-with-pill\n class=\"vx-mt-2\"\n [selectDiv]=\"true\"\n [line]=\"3\"\n [disabled]=\"['OVERSEER', 'DEFAULT_OVERSEER'].includes(activeList)\"\n [placeholder]=\"\n 'Which persons will be selected as the default overseers for responsibilities that are not completed within this Program?'\n \"\n (select)=\"activateList('DEFAULT_FAILED_OVERSEER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_failed_overseer?.value?.length ||\n controls?.program_default_failed_overseer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_failed_overseer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_failed_overseer?.value[0],\n 'DEFAULT_FAILED_OVERSEER'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_failed_overseer?.value[0]\n ?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_failed_overseer?.value[0]\n ?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseersDefaultFail.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_failed_overseer?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_failed_overseer?.value?.length - 1\n }}\n </button>\n </div>\n <span\n *ngIf=\"\n controls?.program_default_failed_overseer_group?.value\n ?.length &&\n controls?.program_default_failed_overseer?.value?.length\n \"\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"\n controls?.program_default_failed_overseer_group?.value?.length\n \"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_failed_overseer_group?.value[0],\n 'DEFAULT_FAILED_OVERSEER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_failed_overseer_group?.value[0]\n ?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_failed_overseer_group?.value[0]\n ?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseerDefaultFailGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_failed_overseer_group?.value\n ?.length > 1\n \"\n >\n +{{\n controls?.program_default_failed_overseer_group?.value\n ?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_failed_overseer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_failed_overseer?.value[0],'DEFAULT_FAILED_OVERSEER')\" >&#xe90d;</i>\n <span class=\"chip\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_failed_overseer?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_failed_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseersDefaultFail.popover()\" placement=\"right\">+{{controls?.program_default_failed_overseer?.value?.length -1}}</button>\n </div>\n <span *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length && controls?.program_default_failed_overseer?.value?.length\" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length \">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_failed_overseer_group?.value[0],'DEFAULT_FAILED_OVERSEER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_failed_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_failed_overseer_group?.value[0]?.group_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"overseerDefaultFailGroup.popover()\" placement=\"right\">+{{controls?.program_default_failed_overseer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_FAILED_OVERSEER'\"\n (click)=\"activateList('DEFAULT_FAILED_OVERSEER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #overseersDefaultFail [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let overseer of controls?.program_default_failed_overseer\n ?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n class=\"icons\"\n (click)=\"remove(overseer, 'DEFAULT_FAILED_OVERSEER')\"\n >&#xe90d;</i\n >\n {{ overseer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #overseerDefaultFailGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_failed_overseer_group\n ?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(group, 'DEFAULT_FAILED_OVERSEER_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </ng-container>\n </form-field>\n\n <!-- Assessment -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.ASSESSMENT\"\n [checked]=\"controls?.program_assessments?.value?.length\"\n [active]=\"activeList === 'ASSESSMENT'\"\n [disabled]=\"\n sideElements.includes(activeList) && activeList !== 'ASSESSMENT'\n \"\n [img]=\"ASSETS.assessments\"\n >\n <label class=\"vx-control-panel\"\n >ASSESSMENTS\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Assessments are a digital form that are created in \u201CAssessment\u201D within the Compliance Module. Where Assessments are selected when creating a Program, only those Assessments will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"AssessmentHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [placeholder]=\"\n 'Which assessments can be linked to the responsibilities within this Program?'\n \"\n (select)=\"activateList('ASSESSMENT')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"controls?.program_assessments?.value?.length\"\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"\n controls?.program_assessments?.value\n | assessmentResolver as assessments\n \"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"remove(assessments[0], 'ASSESSMENT')\"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"assessments[0]?.assessment_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ assessments[0]?.assessment_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"program_assessments.popover()\"\n placement=\"right\"\n *ngIf=\"assessments?.length > 1\"\n >\n +{{ assessments?.length - 1 }}\n </button>\n </div>\n\n <!-- <div class=\"chip-container\">\n <ng-container *ngIf=\"(controls?.program_assessments?.value | assessmentResolver) as assessments\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i class=\"icons\" (click)=\"remove(assessments[0],'ASSESSMENT')\">&#xe90d;</i>{{assessments[0]?.assessment_name}} </span>\n <button *ngIf=\"assessments?.length > 1\" class=\"count\" appPopover (click)=\"program_assessments.popover()\" placement=\"right\">+{{assessments?.length -1 }}</button>\n </div>\n </ng-container>\n </div> -->\n <button\n *ngIf=\"activeList !== 'ASSESSMENT'\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('ASSESSMENT')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #program_assessments [dontCloseonClick]=\"true\">\n <ng-container>\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let assessment of controls?.program_assessments?.value\n | assessmentResolver\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(assessment, 'ASSESSMENT')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ assessment?.assessment_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </ng-container>\n </app-popover>\n </form-field>\n\n <!-- Format & Evidence -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.FORMATE_EVIDENCE\"\n [checked]=\"[true, false].includes(controls?.evidence_required?.value)\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.format_evidence\"\n >\n <label class=\"vx-control-panel\"\n >Evidence\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If selected, evidence of completion of a responsibility will be required for all responsibilities that are linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"EvidenceHelpText\"\n >&#xeb16;</i\n ></label\n >\n <div class=\"upload-format\">\n <span class=\"text\"\n >Do all responsibilities within this program require evidence?</span\n >\n <div class=\"radio-group program\">\n <app-cs-radio\n [name]=\"'evidence_required'\"\n [checked]=\"controls?.evidence_required?.value\"\n (checkedEvent)=\"setFormField('evidence_required', true)\"\n >YES</app-cs-radio\n >\n <app-cs-radio\n [name]=\"'evidence_required'\"\n [checked]=\"!controls?.evidence_required?.value\"\n (checkedEvent)=\"setFormField('evidence_required', false)\"\n >NO</app-cs-radio\n >\n </div>\n </div>\n <!-- <div class=\"vx-d-flex vx-align-center vx-justify-end vx-mt-2\">\n <div class=\"vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase vx-mr-2\">Allow any file to be marked as\n key\n evidence</div>\n <switch formControlName=\"allow_any_file_key_evidence\"\n (change)=\"setFormField('allow_any_file_key_evidence',$event?.target?.checked)\"></switch>\n </div> -->\n </form-field>\n\n <!-- Custom Field -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.CUSTOM_FIELDS\"\n [checked]=\"controls?.custom_fields?.value?.length\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.custom_fields\"\n >\n <label class=\"vx-control-panel\"\n >CUSTOM FIELD\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Where a custom field is specified, all responsibilities linked with a Program will contain that custom field. Custom fields enable the collection of additional meta data.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"CFHelpText\"\n >&#xeb16;</i\n ></label\n >\n <custom-field formControlName=\"custom_fields\"></custom-field>\n </form-field>\n </form>\n</div>\n\n\n<!-- render userlist with group -->\n<user-group-list\n *ngIf=\"activeList === 'OWNER'\"\n [groupEnabled]=\"true\"\n [singleSelect]=\"false\"\n [loading]=\"listLoadingState.USERS\"\n [userlist]=\"lists?.OWNERS?.data ?? []\"\n [selectedUsers]=\"controls?.program_owners?.value | refDisconnect\"\n (fetchUserData)=\"fetchUsersAssociatedWithRoles(false, $event)\"\n [userListInfo]=\"lists?.OWNERS\"\n [groupListInfo]=\"lists?.OWNERS_GROUPS\"\n [groupList]=\"lists?.OWNERS_GROUPS?.data ?? []\"\n [selectedGroups]=\"controls?.program_owners_group?.value | refDisconnect\"\n (save)=\"listAction($event, 'OWNER')\"\n (cancel)=\"fieldDeselector('OWNER')\"\n [panelTitle]=\"panelTitleOwner\"\n [featureflag]=\"featureflagGroups\"\n></user-group-list>\n<user-group-list\n *ngIf=\"activeList === 'COLLABORATORS'\"\n [groupEnabled]=\"true\"\n [singleSelect]=\"false\"\n [loading]=\"listLoadingState.USERS\"\n [userlist]=\"lists?.OWNERS?.data ?? []\"\n [selectedUsers]=\"controls?.collaborators?.value | refDisconnect\"\n [groupList]=\"lists?.OWNERS_GROUPS ?? []\"\n [FromProgram]=\"true\"\n [selectedGroups]=\"controls?.collaborators_group?.value | refDisconnect\"\n [assignorId]=\"assignorId\"\n [userListInfo]=\"lists?.ASSIGNEES\"\n (save)=\"listAction($event, 'COLLABORATORS')\"\n (cancel)=\"fieldDeselector('COLLABORATORS')\"\n [panelTitle]=\"panelTitleAssignee\"\n [defaultSelectedUsers]=\"\n controls?.collaborators?.value | refDisconnect\n \"\n [userType]=\"'assignees'\"\n [featureflag]=\"featureflagGroups\"\n>\n</user-group-list>\n<app-loader-inline *ngIf=\"loader\"></app-loader-inline>\n<app-smiley-dialog-inline\n *ngIf=\"showSmiley\"\n [message]=\"smileyMessage\"\n [actionButtons]=\"actionButtons\"\n (action)=\"action($event)\"\n (closeSmiley)=\"closeSmiley($event)\"\n>\n</app-smiley-dialog-inline>\n\n<!-- Framework selector -->\n<app-framework-list\n *ngIf=\"activeList === 'FRAMEWORK'\"\n [workflowPage]=\"['FRAMEWORK']\"\n (assignControl)=\"listAction($event, 'FRAMEWORK')\"\n (closeFramework)=\"fieldDeselector('FRAMEWORK')\"\n [previousSelectedValues]=\"{ framework: controls?.framework.value }\"\n (entrustFramework)=\"entrustFramework($event)\"\n [headerText]=\"'Select a framework'\"\n></app-framework-list>", 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/padding/padding.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\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.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-top.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\";::ng-deep .workflow-program{display:block;position:relative}::ng-deep .workflow-program .scope-label{background:#747576;border-radius:.125rem;position:relative;z-index:1}::ng-deep .workflow-program .scope-label:before{background:#f1f1f1;content:\"\";position:absolute;top:.5rem;left:7rem;width:20rem;height:1px;z-index:-1}::ng-deep .workflow-program .scope-label:after{background:#f1f1f1;content:\"\";position:absolute;top:.5rem;left:-2.5rem;width:2.5rem;height:1px;z-index:-1}::ng-deep .workflow-program .scope-label .required{position:absolute;top:0;right:-.625rem}::ng-deep .workflow-program .info-icon{position:relative;top:.125rem;cursor:pointer}::ng-deep .workflow-program .date-picker .picker-group{width:calc(50% - .125rem);position:relative}::ng-deep .workflow-program .date-picker .picker-group:focus-within{border-color:#1e5dd3;box-shadow:0 0 5px #1e5dd345}::ng-deep .workflow-program .date-picker .picker-group input{height:2.5rem;border-radius:.25rem;border:1px solid #DBDBDB;background:#fff;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%;padding:0 2rem 0 .75rem;outline:none}::ng-deep .workflow-program .date-picker .picker-group input:focus,::ng-deep .workflow-program .date-picker .picker-group input:hover{border-color:#1e5dd3;box-shadow:0 0 5px #1e5dd345}::ng-deep .workflow-program .date-picker .picker-group input::placeholder{color:#747576;font-size:13px}::ng-deep .workflow-program .date-picker .picker-group input:-ms-input-placeholder{color:#747576;font-size:13px}::ng-deep .workflow-program .date-picker .picker-group input::-ms-input-placeholder{color:#747576;font-size:13px}::ng-deep .workflow-program .date-picker .picker-group i{height:1rem;width:1rem;position:absolute;right:.75rem;top:.625rem;pointer-events:none}::ng-deep .workflow-program .program-type-field{background:#f8f8f8;border:1px solid #dbdbdb;border-radius:4px;height:40px;display:flex;align-items:center;justify-content:space-between;padding:4px;position:relative;z-index:1}::ng-deep .workflow-program .program-type-field .type-item{position:relative}::ng-deep .workflow-program .program-type-field .type-item:first-of-type{width:6.25rem}::ng-deep .workflow-program .program-type-field .type-item:nth-child(2){width:5.75rem}::ng-deep .workflow-program .program-type-field .type-item:nth-child(2).active~.background-glider{transform:translate(6.4375rem);width:5.75rem}::ng-deep .workflow-program .program-type-field .type-item:nth-child(3){width:8.625rem}::ng-deep .workflow-program .program-type-field .type-item:nth-child(3).active~.background-glider{transform:translate(12.375rem);width:8.625rem}::ng-deep .workflow-program .program-type-field .type-item:last-of-type{width:5.25rem}::ng-deep .workflow-program .program-type-field .type-item:last-of-type.active~.background-glider{transform:translate(21.1875rem);width:5.25rem}::ng-deep .workflow-program .program-type-field .type-item button{background:transparent;border:none;border-radius:0;color:#747576;font-size:11px;font-weight:600;text-transform:uppercase;width:100%;height:32px;padding:0 12px;text-align:center}::ng-deep .workflow-program .program-type-field .type-item button.disabled{background:transparent!important;color:#dbdbdb!important;filter:unset!important;opacity:unset!important;pointer-events:none}::ng-deep .workflow-program .program-type-field .type-item .info{color:#1e5dd3;font-size:12px;position:absolute;top:10px;right:12px;cursor:pointer}::ng-deep .workflow-program .program-type-field .type-item.active button{color:#1e5dd3!important}::ng-deep .workflow-program .program-type-field .background-glider{background:#fff;border-radius:4px;box-shadow:0 1px 3px #161b2f26;position:absolute;display:flex;width:6.25rem;height:32px;z-index:-1;transition:.25s ease-out}::ng-deep .workflow-program .vx-form-group .upload-files .file-item{background:#f1f1f1;border:1px solid #dbdbdb;border-radius:.25rem;padding-left:.125rem}::ng-deep .workflow-program .vx-form-group .upload-files .file-item .file-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;max-width:8.5rem}::ng-deep .workflow-program .vx-form-group .upload-files .file-item button.delete-btn{background:transparent;border-radius:0;border:none;border-left:1px solid #dbdbdb;height:1.625rem}::ng-deep .workflow-program .vx-form-group .upload-files button.file-count{background:#1e5dd3;border-radius:.125rem;border:none;color:#fff;font-size:11px;display:flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0;margin:4px 0 0 4px}::ng-deep .workflow-program .vx-form-group .upload-format .radio-group app-cs-radio{height:1.375rem}::ng-deep .workflow-program .vx-form-group .default-selected{background:#fbfbfb;border:1px solid #F1F1F1;border-radius:.25rem;margin-top:.5rem}::ng-deep .workflow-program .vx-form-group .default-selected .selected{border-radius:0;border:none;background:none}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio{border-top:1px solid #F1F1F1}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio{margin-top:0!important}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item span.radio{position:absolute;top:.5rem;left:.75rem}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item span.value{font-size:11px;text-transform:uppercase;padding:.5rem .5rem .5rem 2.25rem;width:100%;display:flex;justify-content:space-between;margin:0;max-width:100%;font-weight:500;color:#707070}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item span.value i{font-size:12px;color:#1e5dd3}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item svg{position:absolute;top:.5rem;left:.75rem}::ng-deep .workflow-program .vx-form-group .selected .custom-text{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;max-height:2.4rem}::ng-deep .workflow-program .vx-form-group .selected button.cross-btn{background:transparent;border-radius:0;border:0;padding:0}::ng-deep .workflow-program .vx-form-group .custom-input{position:relative}::ng-deep .workflow-program .vx-form-group .custom-input input{padding-right:2rem}::ng-deep .workflow-program .vx-form-group .custom-input button.cross-btn{background:transparent;border-radius:0;border:0;position:absolute;top:.875rem;right:.625rem}::ng-deep .workflow-program .vx-form-group button.add-more-btn{background:transparent;border-radius:0;border:none;padding:0}::ng-deep app-popover .wf-action-list ul.action-item .avatar-card .value{text-transform:none!important}::ng-deep app-popover .wf-action-list ul.action-item li file-pill .file-item{background:transparent!important;border:none!important;border-radius:0!important;padding:0!important;margin:0!important}::ng-deep app-popover .wf-action-list ul.action-item li file-pill .file-name{width:100%!important;max-width:100%!important}::ng-deep app-popover .wf-action-list ul.action-item li file-pill button.delete-btn{border:none!important;padding-right:0!important}.disabled{opacity:.4;pointer-events:none;filter:grayscale(1)}.vx-info-card{width:280px;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both;background:#fff;box-shadow:0 3px 6px #1c5bd140;border-radius:4px;position:static;display:block;left:780}.vx-info-card-body{font-size:12px;padding:8px 12px;margin:0;font-weight:400;text-transform:none;color:#747576}\n", "@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\";::-webkit-scrollbar-track{background-color:#f1f1f1;position:absolute}::-webkit-scrollbar{width:3px;height:3px;background-color:transparent;position:absolute}::-webkit-scrollbar-thumb{border-radius:3px;background-color:#dbdbdb;position:absolute}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}button{font-family:Poppins,sans-serif}::ng-deep input.textField{background:#fff;border-radius:.25rem;border:1px solid #dbdbdb;font-size:13px;color:#747576;padding:8px 12px;position:relative;height:2.5rem;width:100%;transition:all .2s ease-in-out}::ng-deep input.textField::placeholder{font-size:13px;color:#747576}::ng-deep input.textField:hover,::ng-deep input.textField:focus{outline:none;border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .selectBoxEnable{background:#fff;border-radius:.25rem;border:1px solid #dbdbdb;cursor:pointer;height:2.5rem;position:relative;transition:all .2s ease-in-out}::ng-deep .selectBoxEnable:after{border-bottom-style:solid;border-bottom-width:1px;border-right-style:solid;border-right-width:1px;border-color:#747576;content:\"\";display:inline-block;right:12px;position:absolute;top:calc(50% - 4px);width:5px;height:5px;transform:rotate(45deg)}::ng-deep .selectBoxEnable:hover,::ng-deep .selectBoxEnable:focus{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .selectBoxEnable.disabled{background:#f1f1f1;pointer-events:none;opacity:1}::ng-deep .selectBoxEnable.withBtn:after{display:none}::ng-deep .selectBoxEnable.withBtn button.setBtn{background:transparent;border-radius:0;border:none;min-width:98px}::ng-deep .selectBoxSuccess{background:#f8f8f8;border-radius:.25rem;border:1px solid #f1f1f1;min-height:2.5rem;position:relative}::ng-deep .selectBoxSuccess .selectBoxText{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;width:22rem}::ng-deep .selectBoxSuccess button{background:transparent;border-radius:0;border:none}::ng-deep .selectBoxSuccess button.deleteBtn{color:#d93b41}::ng-deep .selectBoxSuccess .level-left{border-right:1px solid #f1f1f1;height:2.375rem;width:5rem}::ng-deep .selectBoxSuccess .level-left .level-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;width:4.5rem}::ng-deep .chipContainer{background:#fff;border-radius:.125rem;box-shadow:0 0 2px #1e5dd340;height:1.5rem}::ng-deep .chipContainer .cross{cursor:pointer;min-width:16px;width:16px;height:16px;display:flex;align-items:center;justify-content:center;background:transparent;border-radius:2px;margin-left:-4px}::ng-deep .chipContainer .cross:hover{background:#f1f1f1}::ng-deep .chipContainer .chipName{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;max-width:6rem}::ng-deep .chipContainer .chipName.no-width{max-width:unset}::ng-deep .chipContainer .chipName.full-width{max-width:25rem}::ng-deep .chipContainer button.countBtn{background:#1e5dd3;border-radius:1.25rem;border:none;min-width:1.5rem;height:1rem;margin:0 0 0 .5rem;padding:0 .25rem}::ng-deep .chipContainer button.countBtn.greenBg{background:#34aa44}::ng-deep .workflowLavel{background:#f1f1f1;border-radius:.125rem;color:#042e7d;min-width:1rem;height:1rem}::ng-deep .reviewSelection{border-radius:.25rem;border:1px solid #dbdbdb;transition:all .2s ease-in-out}::ng-deep .reviewSelection:hover{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .selectButton{background:#fff;border-radius:.25rem;border:1px solid #dbdbdb;cursor:pointer;height:2.5rem;position:relative;transition:all .2s ease-in-out}::ng-deep .selectButton:hover,::ng-deep .selectButton:focus{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep button.createNewBtn{background:transparent;border-radius:0;border:none}::ng-deep .vx-form-group{display:block;position:relative;margin-bottom:20px}::ng-deep .vx-form-group:after{content:\"\";display:block;clear:both}::ng-deep .vx-form-group .select{position:relative}::ng-deep .vx-form-group .select:after{border-bottom-style:solid;border-bottom-width:1px;border-right-style:solid;border-right-width:1px;border-color:#707070;content:\"\";display:inline-block;right:12px;position:absolute;top:calc(50% - 4px);width:5px;height:5px;transform:rotate(45deg)}::ng-deep .vx-form-group .select input{cursor:pointer;padding-right:30px!important}::ng-deep .vx-form-group .select .custom-input{height:40px;border-radius:4px;border:1px solid #dbdbdb;background:#fff;outline:none;padding:3px 12px;line-height:16px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%;cursor:pointer}::ng-deep .vx-form-group .select .custom-input:empty:not(:focus):before{content:attr(aria-placeholder);line-height:16px;font-size:13px;width:94%;display:block;pointer-events:none;opacity:.8}::ng-deep .vx-form-group .select .custom-input:hover{border-color:#1e5dd3;box-shadow:0 0 5px #1e5dd345}::ng-deep .vx-form-group .select .custom-input.frequency-custom-input{padding-right:108px;display:flex;align-items:center}::ng-deep .vx-form-group .select+app-cs-switch{display:block;margin-top:8px}::ng-deep .vx-form-group .select+app-cs-switch label.cs-switch span.value{white-space:nowrap;margin-right:5px;text-transform:uppercase}::ng-deep .vx-form-group .select+app-cs-radio{margin-top:8px!important}::ng-deep .vx-form-group .select~app-cs-radio{margin-top:4px;display:block;width:100%}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item span.radio{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item span.value{font-size:11px;text-transform:uppercase;border:1px solid #dbdbdb;border-radius:4px;padding:8px 8px 8px 36px;width:100%;display:flex;justify-content:space-between;margin:0;max-width:100%;font-weight:500;color:#707070}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item span.value i{font-size:12px;color:#1e5dd3}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item svg{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item input:checked~span.value{background:#eefcf0;border-color:#34aa44}::ng-deep .vx-form-group .select.button-sec:after{display:none}::ng-deep .vx-form-group .select.button-sec button{background:transparent;border:none;display:inline-flex;float:right;color:#1e5dd3;text-transform:uppercase;font-weight:600;cursor:pointer;font-size:11px;position:absolute;top:12px;right:8px;padding:0;margin:0}::ng-deep .vx-form-group .select+.vx-control-panel{margin-top:8px}::ng-deep .vx-form-group .select+.selected{margin-top:8px}::ng-deep .vx-form-group .select.select{margin-top:8px}::ng-deep .vx-form-group .upload-format{border:1px solid #dbdbdb;border-radius:4px;padding:8px 12px;display:block}::ng-deep .vx-form-group .upload-format span.text{line-height:20px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%;display:block;margin-bottom:6px}::ng-deep .vx-form-group .upload-format .radio-group{display:flex}::ng-deep .vx-form-group .upload-format .radio-group app-cs-radio{display:inline-block}::ng-deep .vx-form-group .upload-format .radio-group app-cs-radio label.radio-item span.value{font-size:11px;text-transform:uppercase;margin-left:8px}::ng-deep .vx-form-group .upload-format .radio-group app-cs-radio+app-cs-radio{margin-left:12px}::ng-deep .vx-form-group .upload-format~.upload-format{margin-top:4px}::ng-deep .vx-form-group .form-tab{display:flex;justify-content:flex-start}::ng-deep .vx-form-group .form-tab button{background:transparent;color:#161b2f;font-size:11px;line-height:16px;text-transform:uppercase;cursor:pointer;padding:8px 8px 8px 0;border:none;outline:none;font-weight:500}::ng-deep .vx-form-group .form-tab button:disabled{opacity:.5;pointer-events:none;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group .form-tab button+button{padding:8px}::ng-deep .vx-form-group .form-tab button.active{color:#1e5dd3}::ng-deep .vx-form-group .tab-group{border:1px solid #dbdbdb;border-radius:4px;padding:0;display:block;position:relative;transition:all .2s ease-in-out}::ng-deep .vx-form-group .tab-group:hover{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .vx-form-group .tab-group .upload-file{padding:16px 62px 16px 24px;display:flex;align-items:center;justify-content:space-between}::ng-deep .vx-form-group .tab-group .upload-file .image{width:80px}::ng-deep .vx-form-group .tab-group .upload-file .browse span{display:inline-block;font-size:12px;color:#747576;line-height:16px;padding:0 4px}::ng-deep .vx-form-group .tab-group .upload-file .browse .label{font-size:11px;color:#1e5dd3;line-height:16px;font-weight:600;text-transform:uppercase;margin:0;padding:0}::ng-deep .vx-form-group .tab-group .upload-file .browse .label input{opacity:0;position:absolute;margin:0;padding:0;inset:0;cursor:pointer;width:100%}::ng-deep .vx-form-group .tab-group.active{border-color:#1e5dd3}::ng-deep .vx-form-group .tab-group.uploaded{margin-top:4px}::ng-deep .vx-form-group .tab-group.uploaded .upload-file{padding:8px 0!important;text-align:center}::ng-deep .vx-form-group .tab-group.uploaded .upload-file .image{display:none}::ng-deep .vx-form-group .tab-group.uploaded .upload-file .browse{width:100%;text-align:center}::ng-deep .vx-form-group .tab-group+label.vx-form-group{margin-top:8px;margin-bottom:4px}::ng-deep .vx-form-group .file-list{background:#fbfbfb;border:1px solid #f1f1f1;border-radius:4px;padding:12px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;position:relative}::ng-deep .vx-form-group .file-list span.file-name{color:#747576;line-height:16px;font-size:11px;font-weight:400;cursor:pointer;max-width:calc(100% - 20px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}::ng-deep .vx-form-group .file-list .button-group{display:flex}::ng-deep .vx-form-group .file-list button{font-size:12px;color:#eb2424;cursor:pointer;display:flex;padding:0;border:none;outline:none;background:transparent}::ng-deep .vx-form-group .file-list button.edit{color:#1e5dd3}::ng-deep .vx-form-group .file-list button+button{margin-left:16px}::ng-deep .vx-form-group .file-list+.file-list{margin-top:4px}::ng-deep .vx-form-group .file-list .file-container{display:flex;justify-content:space-between;width:100%}::ng-deep .vx-form-group .file-list.policy{background:#fff}::ng-deep .vx-form-group .file-list cs-select{position:relative;margin-top:8px;width:100%}::ng-deep .vx-form-group .file-list cs-select .selection-wrap .input-group input.value{height:32px!important;font-size:13px!important}::ng-deep .vx-form-group .file-list cs-select .selection-wrap .input-group i{right:12px!important;top:12px!important}::ng-deep .vx-form-group .file-list app-line-loader{display:block;position:absolute;left:10px;right:10px;bottom:0}::ng-deep .vx-form-group label.vx-control-panel{color:#161b2f;font-size:11px;font-weight:500;line-height:16px;margin-bottom:8px;display:block;text-transform:uppercase;text-align:left}::ng-deep .vx-form-group label.vx-control-panel.custom-tag{font-size:10px}::ng-deep .vx-form-group label.vx-control-panel.vx-mt-8{margin-top:8px}::ng-deep .vx-form-group label.vx-control-panel span.required{color:#eb2424;font-size:14px;font-weight:500;position:relative;top:-2px}::ng-deep .vx-form-group label.vx-control-panel .button{background:transparent;border:none;display:inline-flex;float:right;color:#1e5dd3;text-transform:uppercase;font-weight:600;cursor:pointer;font-size:11px;padding:0;margin:0}::ng-deep .vx-form-group label.vx-control-panel app-cs-switch{float:right;display:block}::ng-deep .vx-form-group label.vx-control-panel i{margin-left:8px;font-size:12px;color:#1e5dd3;cursor:pointer;position:relative;top:1px}::ng-deep .vx-form-group label.vx-control-panel i.depreciation-icon{color:#e4b700;font-size:16px;position:relative;top:3px}::ng-deep .vx-form-group label.vx-control-panel .checkpoint-version{background:#f1f1f1;border-radius:2px;color:#042e7d;font-size:10px;font-weight:600;line-height:14px;margin-left:4px;padding:0 2px}::ng-deep .vx-form-group input[type=text],::ng-deep .vx-form-group .input{height:40px;border-radius:4px;border:1px solid #dbdbdb;background:#fff;outline:none;padding:8px 12px;line-height:20px;font-size:13px;color:#747576;transition:all .2s ease-in-out;width:100%;font-weight:400}::ng-deep .vx-form-group input[type=text]::placeholder,::ng-deep .vx-form-group .input::placeholder{color:#747576;font-weight:400}::ng-deep .vx-form-group input[type=text]:focus,::ng-deep .vx-form-group .input:focus,::ng-deep .vx-form-group input[type=text]:hover,::ng-deep .vx-form-group .input:hover{border-color:#1e5dd3!important;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .vx-form-group input[type=text].error,::ng-deep .vx-form-group .input.error{border-color:#eb2424;color:#eb2424;margin-bottom:4px}::ng-deep .vx-form-group input[type=text].error:focus,::ng-deep .vx-form-group .input.error:focus{box-shadow:0 0 5px #d31e1e45}::ng-deep .vx-form-group input[type=text]:disabled,::ng-deep .vx-form-group .input:disabled{background:#f1f1f1;cursor:not-allowed;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group input[type=text]:disabled:hover,::ng-deep .vx-form-group .input:disabled:hover{border-color:#dbdbdb;box-shadow:none}::ng-deep .vx-form-group input[type=text] span.text,::ng-deep .vx-form-group .input span.text{font-size:13px;color:#747576;font-weight:400;display:block;width:100%}::ng-deep .vx-form-group input[type=text] .input-group,::ng-deep .vx-form-group .input .input-group{display:flex;align-items:center}::ng-deep .vx-form-group input[type=text] .input-group.counter,::ng-deep .vx-form-group .input .input-group.counter{min-width:96px;width:96px}::ng-deep .vx-form-group input[type=text] .input-group.counter button,::ng-deep .vx-form-group .input .input-group.counter button{height:24px;width:24px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#747576;font-size:8px;cursor:pointer;outline:none}::ng-deep .vx-form-group input[type=text] .input-group.counter input,::ng-deep .vx-form-group .input .input-group.counter input{-webkit-appearance:textfield;-moz-appearance:textfield;height:24px;width:calc(100% - 48px);border:1px solid #f1f1f1;outline:none;padding:0 6px;text-align:center}::ng-deep .vx-form-group input[type=text] .input-group.counter input::-webkit-inner-spin-button,::ng-deep .vx-form-group .input .input-group.counter input::-webkit-inner-spin-button,::ng-deep .vx-form-group input[type=text] .input-group.counter input::-webkit-outer-spin-button,::ng-deep .vx-form-group .input .input-group.counter input::-webkit-outer-spin-button{appearance:none;margin:0}::ng-deep .vx-form-group input[type=text]+.file-list,::ng-deep .vx-form-group .input+.file-list{margin-top:8px}::ng-deep .vx-form-group input[type=text]::placeholder,::ng-deep .vx-form-group .input::placeholder{font-size:13px}::ng-deep .vx-form-group input[type=text]:-ms-input-placeholder,::ng-deep .vx-form-group .input:-ms-input-placeholder{font-size:13px}::ng-deep .vx-form-group input[type=text]::-ms-input-placeholder,::ng-deep .vx-form-group .input::-ms-input-placeholder{font-size:13px}::ng-deep .vx-form-group .classification{height:40px;border-radius:4px;border:1px solid #dbdbdb;background:#fff;padding:8px 12px;display:flex;justify-content:space-between}::ng-deep .vx-form-group .classification label{margin:0 4px 0 0;width:100%;position:relative;z-index:1}::ng-deep .vx-form-group .classification label span{display:block;width:100%;height:24px;border:1px solid #f1f1f1;border-radius:2px;line-height:24px;font-size:10px;text-align:center;color:#747576;font-weight:500;position:relative;text-transform:uppercase}::ng-deep .vx-form-group .classification label span:before{height:2px;content:\"\";top:0;right:0;left:0;border-radius:2px;position:absolute;transition:all .2s ease-in-out}::ng-deep .vx-form-group .classification label input{opacity:0;position:absolute;inset:0;margin:0;padding:0;width:100%;height:100%;cursor:pointer;z-index:1}::ng-deep .vx-form-group .classification label input:checked+span{color:#fff}::ng-deep .vx-form-group .classification label input:checked+span:before{bottom:0;height:100%;z-index:-1}::ng-deep .vx-form-group .classification label.low span:before{background:#34aa44}::ng-deep .vx-form-group .classification label.low-med span:before{background:#f2bf19}::ng-deep .vx-form-group .classification label.med-high span:before{background:#f29619}::ng-deep .vx-form-group .classification label.high span:before{background:#eb2424}::ng-deep .vx-form-group .classification label:last-of-type{margin-right:0}::ng-deep .vx-form-group .input{display:flex;align-items:center}::ng-deep .vx-form-group .selected{height:40px;border-radius:4px;border:1px solid #f1f1f1;background:#fbfbfb;outline:none;padding:8px;line-height:20px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%;display:flex;align-items:center;position:relative;justify-content:space-between}::ng-deep .vx-form-group .selected.first-field{z-index:2}::ng-deep .vx-form-group .selected .chip-container{display:flex;width:calc(100% - 60px);align-items:center}::ng-deep .vx-form-group .selected .chip-container.checkpoints{width:calc(100% - 120px)}::ng-deep .vx-form-group .selected .chip-container span.chip{background:#fff;border-radius:2px;box-shadow:0 0 3px #1e5dd31a;height:24px;padding:0 8px;color:#1e5dd3;font-size:12px;display:block;width:auto;max-width:100%;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:24px}::ng-deep .vx-form-group .selected .chip-container span.chip.disabled{background:#f1f1f1;box-shadow:none;color:#747576;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group .selected .chip-container span.chip i{font-weight:400;margin-right:8px;cursor:pointer;font-size:10px;position:relative;top:1px}::ng-deep .vx-form-group .selected .chip-container span.chip span.step{background:#1e5dd3;border-radius:2px;color:#fff;font-size:9px;line-height:14px;padding:0 4px;font-weight:400;text-align:center;min-width:auto;margin-right:4px}::ng-deep .vx-form-group .selected .chip-container span.chip+span.chip{margin-left:4px}::ng-deep .vx-form-group .selected .chip-container span.chip.with-question{display:flex;align-items:center;justify-content:space-between;width:100%}::ng-deep .vx-form-group .selected .chip-container span.chip.with-question span.value{color:#1e5dd3;font-size:12px;font-weight:400;line-height:24px;padding:0;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;max-width:calc(100% - 80px)}::ng-deep .vx-form-group .selected .chip-container span.chip.with-question span.label{background:#f1f1f1;border-radius:2px;color:#042e7d;font-size:9px;font-weight:600;text-transform:uppercase;padding-left:4px;padding-right:4px;line-height:12px;margin-left:8px}::ng-deep .vx-form-group .selected .chip-container span.value{color:#747576;font-size:13px;line-height:20px;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:calc(100% - 52px);padding:0 4px}::ng-deep .vx-form-group .selected .chip-container span.checkpoint-point-text{color:#747576;font-size:10px;font-weight:500;padding:0 8px;width:122px;line-height:14px}::ng-deep .vx-form-group .selected .chip-container span.checkpoint-point-text.first{position:relative;min-width:162px}::ng-deep .vx-form-group .selected .chip-container span.checkpoint-point-text.first:before{background:#f1f1f1;content:\"\";position:absolute;top:0;right:0;height:calc(100% + 12px);width:1px}::ng-deep .vx-form-group .selected .chip-container span.checkpoint-point-text .no{color:#1e5dd3}::ng-deep .vx-form-group .selected .chip-container.plus span.chip{max-width:calc(50% - 35px)}::ng-deep .vx-form-group .selected .chip-container.more-one span.chip{max-width:50%}::ng-deep .vx-form-group .selected .chip-container .chip-inner{background:#fff;border-radius:2px;box-shadow:0 2px 4px #1e5dd31a;line-height:24px;padding:0 4px 0 8px;display:flex;align-items:center}::ng-deep .vx-form-group .selected .chip-container .chip-inner .chip{background:transparent;border-radius:0;box-shadow:none;height:auto;line-height:unset;padding:0;color:#747576;max-width:100px}::ng-deep .vx-form-group .selected .chip-container .chip-inner button.count{border-radius:20px;height:16px;padding:0 6px;border:none;font-size:9px;line-height:16px;margin-left:4px;min-width:20px}::ng-deep .vx-form-group .selected .chip-container .chip-inner button.count.user{background:#34aa44}::ng-deep .vx-form-group .selected .chip-container .chip-inner i.cross{cursor:pointer;position:relative;top:1px;font-size:8px}::ng-deep .vx-form-group .selected button.count{background:#1e5dd3;border-radius:2px;height:24px;padding:0 8px;border:1px solid #1e5dd3;cursor:pointer;outline:none;color:#fff;font:13px;font-weight:500;line-height:20px;white-space:nowrap;margin-left:8px}::ng-deep .vx-form-group .selected button.edit{border:none;border-radius:0;background:transparent;outline:none;cursor:pointer;display:block;font-size:11px;font-weight:600;color:#1e5dd3;text-transform:uppercase;white-space:nowrap;margin-left:8px}::ng-deep .vx-form-group .selected button.edit i{font-weight:400;font-size:8px;margin-right:4px}::ng-deep .vx-form-group .selected button.close-btn{background:transparent;border:none;padding:0;margin-left:8px;font-size:10px;color:#c7381b;display:flex;align-items:center}::ng-deep .vx-form-group .selected .workflow-label{min-width:92px;padding:4px;text-align:center;margin-left:-8px;margin-right:8px;border-right:1px solid #f1f1f1}::ng-deep .vx-form-group .selected .workflow-label p{margin:0;display:block;text-transform:uppercase}::ng-deep .vx-form-group .selected .workflow-label p.title{font-size:9px;line-height:12px;color:#161b2f;font-weight:500}::ng-deep .vx-form-group .selected .workflow-label p.description{font-size:11px;line-height:16px;color:#161b2f;font-weight:600}::ng-deep .vx-form-group .selected .workflow-label+.chip-container{width:calc(100% - 148px)}::ng-deep .vx-form-group .selected+.selected{margin-top:8px}::ng-deep .vx-form-group .selected+app-cs-switch{display:block;margin-top:8px}::ng-deep .vx-form-group .selected+app-cs-switch label.cs-switch span.value{white-space:nowrap;margin-right:5px;text-transform:uppercase}::ng-deep .vx-form-group .selected+app-cs-switch.who-toggle label.cs-switch span.value{color:#747576}::ng-deep .vx-form-group .selected+app-cs-radio{margin-top:8px!important}::ng-deep .vx-form-group .selected~app-cs-radio{margin-top:4px;display:block;width:100%}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item span.radio{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item span.value{font-size:11px;text-transform:uppercase;border:1px solid #dbdbdb;border-radius:4px;padding:8px 8px 8px 36px;width:100%;display:flex;justify-content:space-between;margin:0;max-width:100%;font-weight:500;color:#707070}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item span.value i{font-size:12px;color:#1e5dd3}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item svg{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item input:checked~span.value{background:#eefcf0;border-color:#34aa44}::ng-deep .vx-form-group .selected.readOnly{pointer-events:none}::ng-deep .vx-form-group .selected span.chip{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .vx-form-group .select-list{position:absolute;background:#fff;box-shadow:0 0 5px #1e5dd345;top:100%;right:0;left:0;z-index:2}::ng-deep .vx-form-group .select-list .vx-radio-group label.vx-radio-item{width:100%;padding:12px 16px}::ng-deep .vx-form-group .select-list .vx-radio-group label.vx-radio-item:hover{background:#f8f8f8}::ng-deep .vx-form-group ::ng-deep vcomply-editor{margin-top:8px;display:block;pointer-events:auto!important;z-index:1}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container{border-radius:4px;border:1px solid #dbdbdb}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block{min-height:60px;padding:11px 15px;max-height:100px;line-height:20px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block ul{padding:0 0 0 10px;margin-top:0}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block ul li{list-style:disc}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block ol{padding:0 0 0 10px;margin-top:0}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block ol li{list-style:decimal}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools{z-index:1;border-top:1px solid #dbdbdb;transition:none;border-radius:0 0 3px 3px;position:static}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button{height:22px!important;width:22px!important;padding:0 5px}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button svg{height:22px;width:12px}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button.submit{width:80px!important;line-height:22px;justify-content:center}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col .popover.small ul.option-list li button{width:100%!important;height:auto!important}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container:focus-within{border-color:#1e5dd3!important;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container:focus-within .editor-tools{border-color:#1e5dd3!important}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container:hover{border-color:#1e5dd3!important;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container:hover .editor-tools{border-color:#1e5dd3!important}::ng-deep .vx-form-group ::ng-deep vcomply-editor+app-cs-switch{margin-top:8px}::ng-deep .vx-form-group app-cs-switch label.cs-switch span.value{font-size:11px;color:#747576;text-transform:uppercase}::ng-deep .vx-form-group app-cs-switch+app-cs-switch{margin-top:8px}::ng-deep .vx-form-group .date-time-picker{display:flex;justify-content:space-between;height:40px;border-radius:4px;border:1px solid #dbdbdb;padding:11px 0;background:#fff}::ng-deep .vx-form-group .date-time-picker:focus-within{border-color:#1e5dd3;box-shadow:0 0 5px #1e5dd345}::ng-deep .vx-form-group .date-time-picker .picker-group{width:50%;position:relative;display:flex;align-items:center}::ng-deep .vx-form-group .date-time-picker .picker-group:first-of-type{border-right:1px solid #dbdbdb}::ng-deep .vx-form-group .date-time-picker .picker-group:only-of-type{border:none;width:100%}::ng-deep .vx-form-group .date-time-picker .picker-group input{height:38px;background:transparent;line-height:38px;font-size:13px;color:#747576;transition:all .2s ease-in-out;width:100%;font-weight:400;border:none;padding:0 12px 0 34px;outline:none}::ng-deep .vx-form-group .date-time-picker .picker-group input:focus,::ng-deep .vx-form-group .date-time-picker .picker-group input:hover{box-shadow:none;border:none}::ng-deep .vx-form-group .date-time-picker .picker-group input::placeholder{color:#999;font-size:13px}::ng-deep .vx-form-group .date-time-picker .picker-group input:-ms-input-placeholder{color:#999;font-size:13px}::ng-deep .vx-form-group .date-time-picker .picker-group input::-ms-input-placeholder{color:#999;font-size:13px}::ng-deep .vx-form-group .date-time-picker .picker-group i{display:flex;justify-content:center;align-items:center;height:16px;width:12px;position:absolute;left:12px;top:0;color:#747576;font-size:12px;pointer-events:none}::ng-deep .vx-form-group app-cs-radio.main-filed{margin-top:4px;display:block;width:100%}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item{width:100%;position:relative}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item span.radio{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item span.value{font-size:11px;text-transform:uppercase;border:1px solid #dbdbdb;border-radius:4px;padding:8px 8px 8px 36px;width:100%;display:flex;justify-content:space-between;margin:0;max-width:100%;color:#707070}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item span.value i{font-size:12px;color:#1e5dd3}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item svg{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item input:checked~span.value{background:#eefcf0;border-color:#34aa44}::ng-deep .vx-form-group app-cs-radio.disabled{pointer-events:none;opacity:.5;filter:grayscale(1);background:#f1f1f1}::ng-deep .vx-form-group .switch-row{display:flex}::ng-deep .vx-form-group .switch-row app-cs-switch{display:block;margin-top:8px}::ng-deep .vx-form-group .switch-row app-cs-switch label.cs-switch span.value{white-space:nowrap;margin-right:0;text-transform:uppercase;color:#747576!important}::ng-deep .vx-form-group .switch-row app-cs-switch label.cs-switch span.value i{display:inline-flex;font-size:11px;cursor:pointer;color:#1e5dd3;align-items:center;line-height:16px;margin:0 4px}::ng-deep .vx-form-group .switch-row app-cs-switch+app-cs-switch{margin-left:8px}::ng-deep .vx-form-group .switch-row.align-right{justify-content:flex-end}::ng-deep .vx-form-group .switch-row.align-right label.cs-switch span.value{margin-right:8px}::ng-deep .vx-form-group .risk-type-field{background:#f8f8f8;border:1px solid #dbdbdb;border-radius:4px;height:40px;display:flex;align-items:center;padding:4px;position:relative;z-index:1}::ng-deep .vx-form-group .risk-type-field .type-item{width:50%;position:relative}::ng-deep .vx-form-group .risk-type-field .type-item button{background:transparent;border:none;border-radius:0;color:#747576;font-size:11px;font-weight:600;text-transform:uppercase;width:100%;height:32px;padding:0 12px;text-align:left}::ng-deep .vx-form-group .risk-type-field .type-item button.disabled{background:transparent!important;color:#dbdbdb!important;filter:unset!important;opacity:unset!important;pointer-events:none;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group .risk-type-field .type-item .info{color:#1e5dd3;font-size:12px;position:absolute;top:10px;right:12px;cursor:pointer}::ng-deep .vx-form-group .risk-type-field .type-item .info.disabled{background:transparent!important;color:#dbdbdb!important;filter:unset!important;opacity:unset!important;pointer-events:none;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group .risk-type-field .type-item.active button{color:#1e5dd3!important}::ng-deep .vx-form-group .risk-type-field .type-item:nth-child(2).active~.background-glider{transform:translate(100%)}::ng-deep .vx-form-group .risk-type-field .background-glider{background:#fff;border-radius:4px;box-shadow:0 1px 3px #161b2f26;position:absolute;display:flex;width:212px;height:32px;z-index:-1;transition:.25s ease-out}.left{width:36px;height:36px;margin-top:26px;margin-left:-58px;margin-right:20px;display:flex;justify-content:center;align-items:center;position:relative;z-index:10;border-radius:50%}.left.deadline-completed{margin-top:18px}.left.checked{background:transparent}.left img{width:36px}.left .checkIcon{width:32px;height:32px;background:#fff;border-radius:50%;stroke-width:4;stroke:#34aa44;stroke-miterlimit:10;box-shadow:inset 0 0 #34aa44;animation:fillCheck .4s ease-in-out .4s forwards,scale .3s ease-in-out .9s both;margin-top:0}.left .checkIcon__circle{stroke-dasharray:166;stroke-dashoffset:166;stroke-width:2;stroke-miterlimit:10;stroke:#34aa44;fill:none;animation:strokeCheck .6s cubic-bezier(.65,0,.45,1) forwards}.left .checkIcon__check{transform-origin:50% 50%;stroke-dasharray:48;stroke-dashoffset:48;animation:strokeCheck .3s cubic-bezier(.65,0,.45,1) .8s forwards}.right{width:100%}.right span.indicator{position:absolute;top:36px;left:-16px;font-size:12px;color:#f0b819;cursor:pointer}.form-group-row{display:flex;position:relative;transition:all .2s ease-in-out}.form-group-row.disabled{-webkit-user-select:none;user-select:none;pointer-events:none;filter:grayscale(1);z-index:2}.form-group-row.disabled .left{position:relative}.form-group-row.disabled .left:before{content:\"\";position:absolute;inset:2px 0 0 2px;background:#fff;opacity:.7;border-radius:50%;width:32px;height:32px}.form-group-row.disabled .right{opacity:.3}.form-group-row.active{pointer-events:none;filter:grayscale(0);z-index:2;opacity:1}.form-group-row.active .right .vx-form-group input,.form-group-row.active .right .vx-form-group .custom-input,.form-group-row.active .right .vx-form-group .selectBoxEnable{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}.form-group-row.active .right .vx-form-group .selectBoxEnable.disabled{border-color:#dbdbdb;box-shadow:none}::ng-deep .radio-group-selector app-cs-radio{margin-top:4px;display:block;width:100%}::ng-deep .radio-group-selector app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .radio-group-selector app-cs-radio label.radio-item .radio,::ng-deep .radio-group-selector app-cs-radio label.radio-item .radiomark{position:absolute!important;top:9px;left:12px}::ng-deep .radio-group-selector app-cs-radio label.radio-item .value{font-size:11px!important;text-transform:uppercase;border:1px solid #dbdbdb;border-radius:4px;padding:8px 8px 8px 36px;width:100%;display:flex;justify-content:space-between;margin:0!important;max-width:100%!important;font-weight:500!important;color:#707070!important}::ng-deep .radio-group-selector app-cs-radio label.radio-item .value i{font-size:12px;color:#1e5dd3}::ng-deep .radio-group-selector app-cs-radio label.radio-item input:checked~span.value{background:#eefcf0;border-color:#34aa44}@keyframes strokeCheck{to{stroke-dashoffset:0}}@keyframes fillCheck{to{box-shadow:inset 0 0 0 2px #34aa44}}::ng-deep .wf-action-list{width:220px}::ng-deep .wf-action-list ul{padding:0;margin:0;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both;background:#fff;box-shadow:0 3px 6px #1c5bd140;border-radius:4px;max-height:220px;overflow:auto}::ng-deep .wf-action-list ul.action-item{display:block}::ng-deep .wf-action-list ul.action-item li{list-style:none;border:none;border-bottom:1px solid #f1f1f1;display:block;width:100%;padding:0;background:transparent;border-radius:0;margin:0;height:auto;justify-content:flex-start;box-shadow:none}::ng-deep .wf-action-list ul.action-item li button{color:#6e717e;text-align:left;text-decoration:none;cursor:pointer;background:transparent;font-size:12px;text-transform:capitalize;display:flex;width:100%;padding:7.5px 11px;border:none}::ng-deep .wf-action-list ul.action-item li button i{font-size:16px;margin-right:10px;color:#1e5dd3}::ng-deep .wf-action-list ul.action-item li button:hover{background:#f3f3f3}::ng-deep .wf-action-list ul.action-item li .avatar-card{display:flex;align-items:center;width:100%;padding:7.5px}::ng-deep .wf-action-list ul.action-item li .avatar-card.within-con{display:block}::ng-deep .wf-action-list ul.action-item li .avatar-card .avatar{height:24px;width:24px!important;overflow:hidden;background:#1e5dd3;color:#fff;font-size:10px;display:inline-flex;margin-right:5px;border-radius:50%;align-items:center;justify-content:center;text-transform:uppercase}::ng-deep .wf-action-list ul.action-item li .avatar-card .avatar img{width:100%}::ng-deep .wf-action-list ul.action-item li .avatar-card .avatar+span.value{width:calc(100% - 29px)}::ng-deep .wf-action-list ul.action-item li .avatar-card span.value{width:100%;color:#6e717e;text-decoration:none;background:transparent;font-size:12px;text-transform:capitalize;display:block;font-weight:400;text-align-last:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:20px}::ng-deep .wf-action-list ul.action-item li .avatar-card span.value i{font-size:8px;color:#747576;cursor:pointer;margin-right:5px}::ng-deep .wf-action-list ul.action-item li .avatar-card.no-image{display:block}::ng-deep .wf-action-list ul.action-item li .avatar-card.no-image span.value{width:100%;display:block}::ng-deep .wf-action-list ul.action-item li .chip-item{color:#1e5dd3;padding:10px;display:flex;align-items:center}::ng-deep .wf-action-list ul.action-item li .chip-item i{color:#747576;margin-right:7px;font-size:10px;cursor:pointer;display:inline-flex}::ng-deep .wf-action-list ul.action-item li .chip-item span{display:block;width:auto;max-width:calc(100% - 17px);font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}::ng-deep .wf-action-list ul.action-item li .chip-item span.chip-block{display:block;width:100%}::ng-deep .wf-action-list ul.action-item li .chip-item span.id{font-size:9px}::ng-deep .wf-action-list ul.action-item li .within{display:flex;align-items:center;justify-content:flex-start}::ng-deep .wf-action-list ul.action-item li .within .block{background:#f1f1f1;border-radius:2px;padding:0 2px;line-height:14px;font-size:9px;font-weight:500;color:#042e7d;margin-right:6px;display:block;text-transform:uppercase}::ng-deep .wf-action-list ul.action-item li .within .data{width:100%;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#747576;font-size:11px;font-weight:400;line-height:17px}::ng-deep .wf-action-list ul.action-item li:first-child{animation:action-list-open .25s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(2){animation:action-list-open .35s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(3){animation:action-list-open .45s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(4){animation:action-list-open .55s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(5){animation:action-list-open .65s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(6){animation:action-list-open .75s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(7){animation:action-list-open .85s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(8){animation:action-list-open .95s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(9){animation:action-list-open 1.05s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(10){animation:action-list-open 1.15s cubic-bezier(.25,.46,.45,.94) both}@keyframes action-list-open{0%{transform:translateY(50px)}to{transform:translateY(0)}}@keyframes scale-up-center{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}p.error-message{font-size:11px;font-weight:400;color:#eb2424;line-height:16px;margin-top:8px;margin-bottom:0}.edit-loader{position:absolute;top:-3px;left:-3px;width:46px;height:46px;transform:rotate(180deg)}.circular-loader{animation:rotate 2s linear infinite;height:100%;transform-origin:center center;width:100%;position:absolute;top:0;left:0;margin:auto}.loader-path{stroke-dasharray:150,200;stroke-dashoffset:-10;animation:dash 1.5s ease-in-out infinite;stroke-linecap:round}@keyframes rotate{to{transform:rotate(360deg)}}@keyframes dash{0%{stroke-dasharray:1,200;stroke-dashoffset:0}50%{stroke-dasharray:89,200;stroke-dashoffset:-35}to{stroke-dasharray:89,200;stroke-dashoffset:-124}}::ng-deep .dropdown{position:fixed;background:#fff;box-shadow:0 3px 6px #00000029;padding:24px 0;z-index:9;max-height:calc(100vh - 200px);overflow:auto}::ng-deep .dropdown ul.dropdown-list{padding:0 20px;margin:0;display:block}::ng-deep .dropdown ul.dropdown-list li{list-style:none}::ng-deep .dropdown ul.dropdown-list li app-cs-radio{display:flex}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item span.radio{position:absolute;top:12px;left:12px}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item span.value{padding:11px 12px 11px 32px;width:100%;border:1px solid #bcbcbc;border-radius:4px;margin-left:0;max-width:100%}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item svg{position:absolute;top:12px;left:12px}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item input[type=radio]:checked~span.value{background:#e8feeb;border-color:#34aa44}::ng-deep .dropdown ul.dropdown-list li+li{margin-top:8px}app-smiley-dialog{position:relative;z-index:10}app-smiley-dialog-inline{position:absolute;top:-3px;right:0;bottom:0;z-index:999;width:520px;height:calc(100vh + 3px)}::ng-deep .vx-overlay{position:fixed;z-index:3;inset:0}::ng-deep dp-date-picker{width:100%;position:fixed!important;z-index:14;top:-40px;left:0}::ng-deep dp-date-picker input{width:100%;border:none;opacity:0;pointer-events:none}::ng-deep dp-date-picker input:focus{outline:none}::ng-deep dp-date-picker .dp-popup{width:412px;box-shadow:0 0 20px #161b2f26;background-color:#fff;border-radius:4px;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both}::ng-deep dp-date-picker .dp-popup dp-day-calendar,::ng-deep dp-date-picker .dp-popup dp-month-calendar{width:100%;pointer-events:auto}::ng-deep dp-date-picker .dp-popup dp-day-calendar button,::ng-deep dp-date-picker .dp-popup dp-month-calendar button{background:transparent;border:none;outline:none}::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-current-location-btn,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-current-location-btn,::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-calendar-nav-left,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-calendar-nav-left,::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-calendar-nav-right,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-calendar-nav-right{width:40px;height:40px;display:flex;justify-content:center;align-items:center;border-radius:50%;font-size:14px}::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-current-location-btn:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-current-location-btn:hover,::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-calendar-nav-left:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-calendar-nav-left:hover,::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-calendar-nav-right:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-calendar-nav-right:hover{background-color:#f3f3f3}::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-current-location-btn,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-current-location-btn{display:none}::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-current-location-btn:before,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-current-location-btn:before{content:\"\";height:10px;width:10px;border-radius:50%;background:#000;display:inline-flex}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week{display:flex;justify-content:space-around}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays .dp-calendar-weekday,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays .dp-calendar-weekday,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week .dp-calendar-weekday,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week .dp-calendar-weekday{width:52px;border-left:none;border-bottom-color:#fff;color:#747576;font-size:11px;font-weight:600;text-transform:uppercase}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays button,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week button{width:40px;height:40px;border-radius:50%;display:inline-flex;justify-content:center;align-items:center}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays button:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays button:hover,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week button:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week button:hover{background-color:#f3f3f3}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays button.dp-selected,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays button.dp-selected,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week button.dp-selected,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week button.dp-selected{background:#1e5dd3}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays button.dp-current-day,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays button.dp-current-day,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week button.dp-current-day,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week button.dp-current-day{border:1px solid rgba(0,0,0,.38);color:#1e5dd3;background-color:#fff}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-day-calendar-container,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-day-calendar-container{padding:20px;border-radius:2px}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-nav-container,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-nav-container{display:flex;margin:0 0 20px;border:none}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-nav-container .dp-nav-header button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-nav-container .dp-nav-header button{color:#000;font-size:17px;font-weight:500;margin:0 0 0 12px;padding:0}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-nav-btns-container,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-nav-btns-container{width:80px;display:flex}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-nav-btns-container .dp-calendar-nav-container-left button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-nav-btns-container .dp-calendar-nav-container-left button,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-nav-btns-container .dp-calendar-nav-container-right button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-nav-btns-container .dp-calendar-nav-container-right button{margin:0!important}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-wrapper,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-wrapper{border:none}::ng-deep dp-date-picker .dp-open+div{position:fixed!important;inset:0!important;display:flex;justify-content:center;align-items:center;z-index:99;pointer-events:none;background:#0000004d}::ng-deep .cdk-overlay-container{z-index:2147483002!important}::ng-deep .dp-popup{z-index:999;display:flex!important;align-items:center;justify-content:center;width:100vw;height:100vh;background:#0000004d!important;box-shadow:unset!important}::ng-deep .dp-popup dp-day-calendar{width:412px!important;box-shadow:0 0 20px #161b2f26;background-color:#fff;border-radius:4px;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both}::ng-deep .dp-popup dp-day-calendar,::ng-deep .dp-popup dp-month-calendar{width:100%;pointer-events:auto}::ng-deep .dp-popup dp-day-calendar button,::ng-deep .dp-popup dp-month-calendar button{background:transparent;border:none;outline:none}::ng-deep .dp-popup dp-day-calendar button.dp-current-location-btn,::ng-deep .dp-popup dp-month-calendar button.dp-current-location-btn,::ng-deep .dp-popup dp-day-calendar button.dp-calendar-nav-left,::ng-deep .dp-popup dp-month-calendar button.dp-calendar-nav-left,::ng-deep .dp-popup dp-day-calendar button.dp-calendar-nav-right,::ng-deep .dp-popup dp-month-calendar button.dp-calendar-nav-right{width:40px;height:40px;display:flex;justify-content:center;align-items:center;border-radius:50%;font-size:14px}::ng-deep .dp-popup dp-day-calendar button.dp-current-location-btn:hover,::ng-deep .dp-popup dp-month-calendar button.dp-current-location-btn:hover,::ng-deep .dp-popup dp-day-calendar button.dp-calendar-nav-left:hover,::ng-deep .dp-popup dp-month-calendar button.dp-calendar-nav-left:hover,::ng-deep .dp-popup dp-day-calendar button.dp-calendar-nav-right:hover,::ng-deep .dp-popup dp-month-calendar button.dp-calendar-nav-right:hover{background-color:#f3f3f3}::ng-deep .dp-popup dp-day-calendar button.dp-current-location-btn,::ng-deep .dp-popup dp-month-calendar button.dp-current-location-btn{display:none}::ng-deep .dp-popup dp-day-calendar button.dp-current-location-btn:before,::ng-deep .dp-popup dp-month-calendar button.dp-current-location-btn:before{content:\"\";height:10px;width:10px;border-radius:50%;background:#000;display:inline-flex}::ng-deep .dp-popup dp-day-calendar .dp-weekdays,::ng-deep .dp-popup dp-month-calendar .dp-weekdays,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week{display:flex;justify-content:space-around}::ng-deep .dp-popup dp-day-calendar .dp-weekdays .dp-calendar-weekday,::ng-deep .dp-popup dp-month-calendar .dp-weekdays .dp-calendar-weekday,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week .dp-calendar-weekday,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week .dp-calendar-weekday{width:52px;border-left:none;border-bottom-color:#fff;color:#747576;font-size:11px;font-weight:600;text-transform:uppercase}::ng-deep .dp-popup dp-day-calendar .dp-weekdays button,::ng-deep .dp-popup dp-month-calendar .dp-weekdays button,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week button,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week button{width:40px;height:40px;border-radius:50%;display:inline-flex;justify-content:center;align-items:center}::ng-deep .dp-popup dp-day-calendar .dp-weekdays button:hover,::ng-deep .dp-popup dp-month-calendar .dp-weekdays button:hover,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week button:hover,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week button:hover{background-color:#f3f3f3}::ng-deep .dp-popup dp-day-calendar .dp-weekdays button.dp-selected,::ng-deep .dp-popup dp-month-calendar .dp-weekdays button.dp-selected,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week button.dp-selected,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week button.dp-selected{background:#1e5dd3}::ng-deep .dp-popup dp-day-calendar .dp-weekdays button.dp-current-day,::ng-deep .dp-popup dp-month-calendar .dp-weekdays button.dp-current-day,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week button.dp-current-day,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week button.dp-current-day{border:1px solid rgba(0,0,0,.38);color:#1e5dd3;background-color:#fff}::ng-deep .dp-popup dp-day-calendar .dp-day-calendar-container,::ng-deep .dp-popup dp-month-calendar .dp-day-calendar-container{padding:20px;border-radius:2px}::ng-deep .dp-popup dp-day-calendar .dp-calendar-nav-container,::ng-deep .dp-popup dp-month-calendar .dp-calendar-nav-container{display:flex;margin:0 0 20px;border:none}::ng-deep .dp-popup dp-day-calendar .dp-calendar-nav-container .dp-nav-header button,::ng-deep .dp-popup dp-month-calendar .dp-calendar-nav-container .dp-nav-header button{color:#000;font-size:17px;font-weight:500;margin:0 0 0 12px;padding:0}::ng-deep .dp-popup dp-day-calendar .dp-nav-btns-container,::ng-deep .dp-popup dp-month-calendar .dp-nav-btns-container{width:80px;display:flex}::ng-deep .dp-popup dp-day-calendar .dp-nav-btns-container .dp-calendar-nav-container-left button,::ng-deep .dp-popup dp-month-calendar .dp-nav-btns-container .dp-calendar-nav-container-left button,::ng-deep .dp-popup dp-day-calendar .dp-nav-btns-container .dp-calendar-nav-container-right button,::ng-deep .dp-popup dp-month-calendar .dp-nav-btns-container .dp-calendar-nav-container-right button{margin:0!important}::ng-deep .dp-popup dp-day-calendar .dp-calendar-wrapper,::ng-deep .dp-popup dp-month-calendar .dp-calendar-wrapper{border:none}@keyframes slide-bottom{0%{transform:translateY(-100px)}to{transform:translateY(0)}}::ng-deep span.file{display:block;width:20px;min-width:20px;border-radius:0 0 2px 2px;border:1px solid transparent;border-color:#747576;position:relative;margin-right:5px;border-top:none;margin-top:5px;background:#fff}::ng-deep span.file.table{margin-right:8px;width:18px;min-width:18px}::ng-deep span.file.table i{font-size:8px}::ng-deep span.file.table .format{height:8px;font-size:7px;line-height:8px;font-weight:400}::ng-deep span.file:before{position:absolute;border-radius:0;top:-4px;right:-1px;content:\"\";height:4px;width:4px;display:block;background:linear-gradient(45deg,#747576 0% 1%,#747576 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file:after{height:4px;left:-1px;right:3px;border-top:1px solid;border-right:none;border-left:1px solid;content:\"\";top:-4px;position:absolute;border-radius:2px 0 0;background:#fff}::ng-deep span.file .format{height:10px;font-size:6px;text-transform:uppercase;background:transparent;font-weight:600;text-align:center;display:block;line-height:10px}::ng-deep span.file i{font-size:10px;height:10px;display:flex;align-items:center;justify-content:center;color:#dbdbdb}::ng-deep span.file.docx{width:22px!important}::ng-deep span.file.pdf,::ng-deep span.file.template{border-color:#f31c39}::ng-deep span.file.pdf:before,::ng-deep span.file.template:before{background:linear-gradient(45deg,#f31c39 0% 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#f31c39\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.pdf:after,::ng-deep span.file.template:after{border-color:#f31c39}::ng-deep span.file.pdf .format,::ng-deep span.file.template .format{color:#f31c39}::ng-deep span.file.xlsx,::ng-deep span.file.xls,::ng-deep span.file.css,::ng-deep span.file.scss,::ng-deep span.file.less{border-color:#34aa44}::ng-deep span.file.xlsx:before,::ng-deep span.file.xls:before,::ng-deep span.file.css:before,::ng-deep span.file.scss:before,::ng-deep span.file.less:before{background:linear-gradient(45deg,#34aa44 0% 1%,#34aa44 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.xlsx:after,::ng-deep span.file.xls:after,::ng-deep span.file.css:after,::ng-deep span.file.scss:after,::ng-deep span.file.less:after{border-color:#34aa44;color:#34aa44}::ng-deep span.file.xlsx .format,::ng-deep span.file.xls .format,::ng-deep span.file.css .format,::ng-deep span.file.scss .format,::ng-deep span.file.less .format{color:#34aa44}::ng-deep span.file.doc,::ng-deep span.file.docx,::ng-deep span.file.psd{border-color:#1e5dd3}::ng-deep span.file.doc:before,::ng-deep span.file.docx:before,::ng-deep span.file.psd:before{background:linear-gradient(45deg,#1e5dd3 0% 1%,#1e5dd3 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.doc:after,::ng-deep span.file.docx:after,::ng-deep span.file.psd:after{border-color:#1e5dd3}::ng-deep span.file.doc .format,::ng-deep span.file.docx .format,::ng-deep span.file.psd .format{color:#1e5dd3}::ng-deep span.file.ppt,::ng-deep span.file.ai,::ng-deep span.file.html,::ng-deep span.file.jpg,::ng-deep span.file.jpeg,::ng-deep span.file.png{border-color:#f6882f}::ng-deep span.file.ppt:before,::ng-deep span.file.ai:before,::ng-deep span.file.html:before,::ng-deep span.file.jpg:before,::ng-deep span.file.jpeg:before,::ng-deep span.file.png:before{background:linear-gradient(45deg,#f6882f 0% 1%,#f6882f 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.ppt:after,::ng-deep span.file.ai:after,::ng-deep span.file.html:after,::ng-deep span.file.jpg:after,::ng-deep span.file.jpeg:after,::ng-deep span.file.png:after{border-color:#f6882f}::ng-deep span.file.ppt .format,::ng-deep span.file.ai .format,::ng-deep span.file.html .format,::ng-deep span.file.jpg .format,::ng-deep span.file.jpeg .format,::ng-deep span.file.png .format{color:#f6882f}::ng-deep span.file.php{border-color:#7aa6f7}::ng-deep span.file.php:before{background:linear-gradient(45deg,#7aa6f7 0% 1%,#7aa6f7 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.php:after{border-color:#7aa6f7}::ng-deep span.file.php .format{color:#7aa6f7}::ng-deep ngx-material-timepicker-container .timepicker-backdrop-overlay{background-color:#0000000d!important;z-index:9999999999!important}::ng-deep ngx-material-timepicker-container .timepicker-overlay{z-index:9999999999!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker{width:232px!important;border-radius:2px!important;box-shadow:0 4px 30px #161b2f26!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header{background-color:#fff!important;padding:0!important;border-radius:2px 2px 0 0}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container{display:block!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time{color:#000!important;width:150px!important;margin:0 auto;line-height:60px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time ngx-material-timepicker-dial-control .timepicker-dial__control{font-size:40px;background-color:transparent!important;color:#000!important;font-weight:600;text-align:right;caret-color:transparent;outline:none;font-family:Poppins;line-height:56px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time ngx-material-timepicker-dial-control .timepicker-dial__control:focus,::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time ngx-material-timepicker-dial-control .timepicker-dial__control:hover{background-color:transparent!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time ngx-material-timepicker-dial-control:last-of-type .timepicker-dial__control{text-align:left}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time span{padding:0 8px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period{display:flex!important;width:182px;margin:0 auto!important;background:#f1f1f1;padding:4px 10px;border-radius:20px;position:relative}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period:before{background:#f1f1f1;content:\"\";position:absolute;top:15px;left:-25px;width:calc(100% + 50px);height:2px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period{flex-direction:unset!important;position:relative;z-index:1}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period:after{content:\"\";position:absolute;right:-12px;top:0;border-left:solid 14px #f1f1f1;border-bottom:solid 12px transparent;border-top:solid 12px transparent;z-index:-1}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period:before{content:\"\";position:absolute;left:-18px;top:0;border-right:solid 14px #f1f1f1;border-bottom:solid 12px transparent;border-top:solid 12px transparent;z-index:-1}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period button{font-size:11px;background-color:transparent;padding:0;border-radius:20px;color:#747576;font-weight:600;font-family:Poppins;width:84px;height:24px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period button.timepicker-dial__item_active{background:#fff!important;color:#1e5dd3!important;box-shadow:0 1px 2px #dbdbdb}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period button+button{margin-left:0!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face{width:200px!important;height:200px!important;padding:10px!important;background:transparent!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__number--outer{height:92px!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__number--outer span{color:#000}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__number--outer span.active{color:#fff}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__clock-hand{height:80px!important;top:calc(50% - 80px)!important;background-color:#1e5dd3!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__number>span.active{background-color:#1e5dd3!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__clock-hand_minute:before{border:4px solid #1e5dd3!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .timepicker__actions{display:flex!important;padding:10px 0 0!important;background:#fff!important;justify-content:space-around!important;border-radius:0 0 2px 2px!important;overflow:hidden}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .timepicker__actions div:first-child ngx-material-timepicker-button button.timepicker-button{background:#f8f8f8;color:#1e5dd3}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .timepicker__actions div ngx-material-timepicker-button button.timepicker-button{line-height:28px!important;width:100%;background:#1e5dd3;color:#fff;border-radius:0!important;height:32px!important;width:116px!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .timepicker__actions div ngx-material-timepicker-button button.timepicker-button span{font-weight:500!important;font-size:11px;font-family:Poppins}::ng-deep vcomply-editor{display:block}::ng-deep vcomply-editor .editor-container{border-radius:4px;border:1px solid #dbdbdb;transition:all .2s ease-in-out}::ng-deep vcomply-editor .editor-container:hover,::ng-deep vcomply-editor .editor-container:focus-within{border:1px solid #1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep vcomply-editor .editor-container mention-list ul li a{font-size:16px!important}::ng-deep vcomply-editor .editor-container .editable-block{background:#fff;min-height:60px;padding:8px 12px;line-height:20px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%}::ng-deep vcomply-editor .editor-container .editable-block:before{color:#747576!important}::ng-deep vcomply-editor .editor-container .editor-tools{border-top:1px solid #dbdbdb;border-radius:0 0 3px 3px}::ng-deep vcomply-editor .editor-container .editor-tools:hover{border-color:#1e5dd3}::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button{height:22px!important;width:22px!important;padding:0 5px}::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button svg{height:22px;width:12px}::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button.submit{width:80px!important;line-height:22px;justify-content:center}::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col .popover.small ul.option-list li button{width:100%!important;height:auto!important}::ng-deep marx-modal .popup-modal-background{background-color:#161b2fcc!important}::ng-deep .within-box{background:#f1f1f1;border-radius:.125rem;color:#042e7d}::ng-deep .within-value{overflow:hidden;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;word-break:break-word}.wf-tooltip{pointer-events:none;position:absolute;max-width:300px;font-size:12px;text-align:left;color:#fff;padding:8px 12px;background:#000;border-radius:2px;z-index:-222;top:0;opacity:0;white-space:break-spaces;word-break:break-word}.wf-tooltip *{color:#fff!important}.wf-tooltip:empty{display:none!important}.wf-tooltip.white{box-shadow:0 2px 8px #1c5bd159;color:#747576;background:#fff;text-align:left}.wf-tooltip.white b{color:#747576!important}.wf-tooltip.animate-top{animation:animate-top .5s cubic-bezier(.25,.46,.45,.94) both}.wf-tooltip.animate-right{animation:animate-right .3s cubic-bezier(.25,.46,.45,.94) both}.wf-tooltip.animate-bottom{animation:animate-bottom .5s cubic-bezier(.25,.46,.45,.94) both}.wf-tooltip.animate-left{animation:animate-left .5s cubic-bezier(.25,.46,.45,.94) both}.wf-tooltip-top:after{top:100%;left:50%;margin-left:-5px;border-width:5px;border-color:#000000 transparent transparent transparent}.wf-tooltip-top.white:after{border-color:#f1f1f1 transparent transparent transparent}.wf-tooltip-bottom:after{bottom:100%;left:50%;margin-left:-5px;border-width:5px;border-color:transparent transparent #000000 transparent}.wf-tooltip-bottom.white:after{border-color:transparent transparent #f1f1f1 transparent}.wf-tooltip-left.white:after{border-color:transparent transparent transparent #f1f1f1}.wf-tooltip-left:after{top:50%;left:100%;margin-top:-5px;border-width:5px;border-color:transparent transparent transparent #000000}.wf-tooltip-right.white:after{border-color:transparent #f1f1f1 transparent transparent}.wf-tooltip-right:after{top:50%;right:100%;margin-top:-5px;border-width:5px;border-color:transparent #000000 transparent transparent}.wf-tooltip-bottom-right:after{bottom:100%;left:100%;margin-left:-20px;border-width:5px;border-color:transparent transparent #000000 transparent}.wf-tooltip-bottom-right.white:after{border-color:transparent transparent #f1f1f1 transparent}.wf-tooltip-bottom-left:after{bottom:100%;left:0;margin-left:10px;border-width:5px;border-color:transparent transparent #000000 transparent}.wf-tooltip-bottom-left.white:after{border-color:transparent transparent #f1f1f1 transparent}.wf-tooltip-top-left:after{top:100%;left:0;margin-left:10px;border-width:5px;border-color:#000000 transparent transparent transparent}.wf-tooltip-top-left.white:after{border-color:#f1f1f1 transparent transparent transparent}.wf-tooltip-top-right:after{top:100%;left:100%;margin-left:-5px;border-width:5px;border-color:#000000 transparent transparent transparent}.wf-tooltip-top-right.white:after{border-color:#f1f1f1 transparent transparent transparent}.wf-tooltip:after{content:\"\";position:absolute;border-style:solid}.wf-tooltip span.within{font-size:80%;display:block;width:100%}.wf-tooltip .small{display:block;font-size:10px}.wf-tooltip .within-box{background:#f1f1f1;border-radius:2px;color:#042e7d!important;font-size:9px;font-weight:500;text-transform:uppercase;padding:0 2px;margin-right:2px}.wf-tooltip-show{pointer-events:none;opacity:1;z-index:2147483001}\n"], dependencies: [{ kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i6.MarxEditorComponent, selector: "vcomply-editor", inputs: ["editorConfig"], outputs: ["comment", "sendSavedFiles", "popup"] }, { kind: "directive", type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i8.CsRadioComponent, selector: "app-cs-radio", inputs: ["disabled", "readonly", "name", "checked", "value", "oneLine"], outputs: ["checkedEvent"] }, { kind: "directive", type: i9.ToolTipDirective, selector: "[appTooltip]", inputs: ["appTooltip", "placement", "type", "tooltipMandatory", "showTooltip", "animate"] }, { kind: "component", type: i10.PopoverComponent, selector: "app-popover", inputs: ["dontCloseonClick"] }, { kind: "directive", type: i11.PopoverDirective, selector: "[appPopover]", inputs: ["refrence", "placement"] }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i12.LoaderInlineComponent, selector: "app-loader-inline" }, { kind: "component", type: i13.SmileyDialogInlineComponent, selector: "app-smiley-dialog-inline", inputs: ["message", "actionButtons"], outputs: ["action", "closeSmiley"] }, { kind: "component", type: i14.PopoverHoverComponent, selector: "popover-hover" }, { kind: "directive", type: i15.PopoverHoverDirective, selector: "[libPopoverHover]", inputs: ["placement"] }, { kind: "component", type: i16.TabSelector, selector: "tab-selector", inputs: ["disabled", "selectedItem", "displayArray"], outputs: ["onValueChanged"] }, { kind: "component", type: i17.FormFieldComponent, selector: "form-field", inputs: ["active", "disabled", "checked", "img"] }, { kind: "component", type: i18.InputWithPillComponent, selector: "input-with-pill", inputs: ["placeholder", "disabled", "selectDiv", "line"], outputs: ["select"] }, { kind: "directive", type: i19.InputTrimDirective, selector: "[InputTrim]" }, { kind: "component", type: i20.UserGroupListComponent, selector: "user-group-list", inputs: ["groupEnabled", "panelTitle", "singleSelect", "selectedReviewer", "featureflag", "reviewerWorkflowType", "mode", "fieldType", "fromResponsibility", "assignorId", "assigneeIds", "reviewerIds", "overseerIds", "FromProgram", "userListInfo", "groupListInfo", "fromApprovalWorkflow", "approvalType", "showFutureUsersSwitch", "futureUsersWillSelect", "isAllDisabled", "isGroupTabShow", "disabledIds", "nonRemovableUserIds", "allUserSelectedDisabled", "nonRemovableGroupIds", "loading", "userlist", "selectedUsers", "defaultSelectedUsers", "userType", "groupList", "selectedGroups"], outputs: ["save", "cancel", "reviewerWorkflowTypeChange", "fetchUserData"] }, { kind: "component", type: i21.CustomFieldComponent, selector: "custom-field", inputs: ["disabled"] }, { kind: "component", type: i22.FrameworkListComponent, selector: "app-framework-list", inputs: ["previousSelectedValues", "headerText", "workflowPage", "policy", "frameWorkList", "selectedFrameWork", "selectedCategories"], outputs: ["entrustFramework", "closeFramework", "assignControl"] }, { kind: "pipe", type: i7.SlicePipe, name: "slice" }, { kind: "pipe", type: i23.ListToIdPipe, name: "listToId" }, { kind: "pipe", type: i24.RefDisconnectPipe, name: "refDisconnect" }, { kind: "pipe", type: i25.AssessmentResolverPipe, name: "assessmentResolver" }] }); }
1333
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: WorkflowProgramComponent, deps: [{ token: i1.UntypedFormBuilder }, { token: i2.ProgramsService }, { token: i3.AuthService }, { token: i4.UiKitService }, { token: i5.IframeService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
1334
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: WorkflowProgramComponent, selector: "app-workflow-program", inputs: { canFrameworkChange: "canFrameworkChange", mode: "mode", programId: "programId", programType: "programType", allowedFeature: "allowedFeature", addToProgramDetails: "addToProgramDetails", orgDetails: "orgDetails" }, outputs: { pickerChanged: "pickerChanged", populateOption: "populateOption", closeWorkflow: "closeWorkflow", showConfirmationAlert: "showConfirmationAlert", disconnectRefresh: "disconnectRefresh", refreshForm: "refreshForm", hideElementsFromMoreOptions: "hideElementsFromMoreOptions", onRemovingRole: "onRemovingRole", disableElementsFromMoreOptions: "disableElementsFromMoreOptions" }, viewQueries: [{ propertyName: "form", first: true, predicate: ["form"], descendants: true, read: ElementRef }, { propertyName: "datePicker", first: true, predicate: ["datePicker"], descendants: true }], ngImport: i0, template: "<div class=\"workflow-program\" #form>\n <form novalidate [formGroup]=\"programForm\">\n <!-- Program Category Type -->\n <form-field\n [checked]=\"controls?.program_type?.value > -1\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.issue_type\"\n >\n <label class=\"vx-control-panel\"\n >PROGRAM TYPE <span class=\"required\">*</span></label\n >\n <tab-selector\n formControlName=\"program_type\"\n [displayArray]=\"constants?.categoryType\"\n ></tab-selector>\n <!-- <p *ngIf=\"program_name?.invalid\" class=\"error-message\">Add a program type</p> -->\n </form-field>\n\n <!-- Framework -->\n <form-field\n *ngIf=\"isAscentAllowed\"\n [checked]=\"false\"\n [active]=\"false\"\n [disabled]=\"false\"\n [img]=\"ASSETS.case_category\"\n >\n <label class=\"vx-control-panel\">FRAMEWORK</label>\n <!-- [selectDiv]=\"true\" -->\n <input-with-pill\n [placeholder]=\"'Select a framework that this Program relates to'\"\n (select)=\"activateList('FRAMEWORK')\"\n >\n <div class=\"selected\" *ngIf=\"controls?.framework.value?.name\">\n <div class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\">\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n *ngIf=\"canFrameworkChange\"\n (click)=\"remove('', 'FRAMEWORK')\"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.framework.value?.name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.framework.value?.name }}</span\n >\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i (click)=\"remove('', 'FRAMEWORK')\" *ngIf=\"canFrameworkChange\" class=\"icons\" >&#xe90d;</i> {{controls?.framework.value?.name}}</span>\n </div>\n </div> -->\n <button\n *ngIf=\"canFrameworkChange\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('FRAMEWORK')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n </form-field>\n\n <!-- Program Category Name -->\n <form-field\n [checked]=\"controls?.program_name?.value?.trim()?.length\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.what\"\n >\n <label class=\"vx-control-panel\"\n >PROGRAM NAME <span class=\"required\">*</span></label\n >\n <input\n InputTrim\n formControlName=\"program_name\"\n type=\"text\"\n placeholder=\"What is the Program name?\"\n />\n\n <p\n *ngIf=\"\n controls?.program_name?.errors && controls?.program_name?.touched\n \"\n class=\"error-message\"\n >\n Enter a name for this Program.\n </p>\n <p *ngIf=\"isNameExists\" class=\"error-message\">\n Program name already exists.\n </p>\n <div class=\"upload-files vx-d-flex vx-align-center vx-flex-wrap vx-mt-1\">\n <file-pill\n *ngFor=\"\n let attachment of controls?.description_attachment?.value\n | slice : 0 : 2\n \"\n [extension]=\"attachment?.org_file?.split('.').pop()\"\n [name]=\"attachment?.org_file\"\n [disabled]=\"attachment?.uploading\"\n (delete)=\"deleteAttachment('DESCRIPTION', attachment)\"\n >\n </file-pill>\n <button\n *ngIf=\"controls?.description_attachment?.value?.length > 2\"\n class=\"file-count\"\n appPopover\n (click)=\"uploadFile.popover()\"\n placement=\"right\"\n >\n +{{ controls?.description_attachment?.value?.length - 2 }}\n </button>\n <app-popover #uploadFile [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n class=\"vx-p-2\"\n *ngFor=\"\n let attachment of controls?.description_attachment?.value\n | slice : 2\n \"\n >\n <file-pill\n [extension]=\"attachment?.org_file?.split('.').pop()\"\n [name]=\"attachment?.org_file\"\n [disabled]=\"attachment?.uploading\"\n (delete)=\"deleteAttachment('DESCRIPTION', attachment)\"\n ></file-pill>\n </li>\n </ul>\n </div>\n </app-popover>\n </div>\n <vcomply-editor\n [(ngModel)]=\"editorData.programDescription\"\n [ngModelOptions]=\"{ standalone: true }\"\n (sendSavedFiles)=\"selectFile('DESCRIPTION', $event)\"\n (ngModelChange)=\"setFormField('program_description', $event)\"\n [editorConfig]=\"constants?.description\"\n >\n </vcomply-editor>\n </form-field>\n\n <!-- Objective -->\n <form-field\n [checked]=\"controls?.program_objective?.value?.trim()?.length\"\n [active]=\"activeList === 'OBJECTIVE'\"\n [disabled]=\"\n sideElements.includes(activeList) && activeList !== 'OBJECTIVE'\n \"\n [img]=\"ASSETS.objectives\"\n >\n <label class=\"vx-control-panel\"\n >OBJECTIVE\n <!-- <span class=\"required\">*</span> -->\n </label>\n <vcomply-editor\n [(ngModel)]=\"editorData.programObjective\"\n [ngModelOptions]=\"{ standalone: true }\"\n (sendSavedFiles)=\"selectFile('OBJECTIVE', $event)\"\n (ngModelChange)=\"setFormField('program_objective', $event, true)\"\n [editorConfig]=\"constants?.objective\"\n >\n </vcomply-editor>\n <!-- <p *ngIf=\"!isObjectiveValid\" class=\"error-message\">Specify the objective for this Program.</p> -->\n </form-field>\n\n <!-- Roles -->\n <form-field\n *ngIf=\"additionalOption?.ROLES\"\n [checked]=\"controls?.program_roles?.value?.length\"\n [active]=\"activeList === 'ROLE'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'ROLE'\"\n [img]=\"ASSETS.roles\"\n >\n <label class=\"vx-control-panel\" id=\"permissiongroup\"\n >{{ ff_rc_listing ? \"PERMISSIONS\" : \"PERMISSION GROUP(S)\" }}\n <span class=\"required\">*</span\n ><i\n class=\"icons\"\n [appTooltip]=\"\n ff_rc_listing\n ? 'Permissions let you specify the users that can be \u201COwners\u201D' +\n (allowedFeature.isFeatureEnabled('ff_program_simplify')\n ? ' '\n : ' and \u201CApprovers\u201D') +\n 'of a Program.'\n : 'Permission group(s) let you specify the users that can be \u201COwners\u201D' +\n (allowedFeature.isFeatureEnabled('ff_program_simplify')\n ? ' '\n : ' and \u201CApprovers\u201D') +\n 'of a Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"RoleHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n id=\"placeholdername\"\n [placeholder]=\"\n ff_rc_listing\n ? 'Which user permissions have access to this program?'\n : 'Which user permission groups have access to this program?'\n \"\n (select)=\"activateList('ROLE')\"\n >\n <div class=\"selected\" *ngIf=\"controls?.program_roles?.value?.length\">\n <div class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\">\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n *ngIf=\"\n !lists.SYSTEM_ROLE_IDS.includes(\n controls?.program_roles?.value[0]?._id\n )\n \"\n (click)=\"remove(controls?.program_roles?.value[0], 'ROLE')\"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n featureflagrole &&\n controls?.program_roles?.value[0]?.permissionGroupName\n ? controls?.program_roles?.value[0]?.permissionGroupName\n : controls?.program_roles?.value[0]?.roleName\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n featureflagrole &&\n controls?.program_roles?.value[0]?.permissionGroupName\n ? controls?.program_roles?.value[0]?.permissionGroupName\n : controls?.program_roles?.value[0]?.roleName\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"role.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_roles?.value?.length > 1\"\n >\n +{{ controls?.program_roles?.value?.length - 1 }}\n </button>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i *ngIf=\"!lists.SYSTEM_ROLE_IDS.includes(controls?.program_roles?.value[0]?._id)\" (click)=\"remove(controls?.program_roles?.value[0],'ROLE')\" class=\"icons\">&#xe90d;</i>{{featureflagrole && controls?.program_roles?.value[0]?.permissionGroupName ? controls?.program_roles?.value[0]?.permissionGroupName : controls?.program_roles?.value[0]?.roleName}}</span>\n <button *ngIf=\"controls?.program_roles?.value?.length > 1\" class=\"count\" appPopover (click)=\"role.popover()\" placement=\"right\">+{{controls?.program_roles?.value?.length - 1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'ROLE'\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('ROLE')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <p *ngIf=\"false\" class=\"error-message\">\n {{ featureflagrole ? \"Add a permission group(s)\" : \"Add a role(s)\" }}\n </p>\n <app-popover #role [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"let data of controls?.program_roles?.value | slice : 1\">\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"!lists.SYSTEM_ROLE_IDS.includes(data?._id)\"\n class=\"icons\"\n (click)=\"removeRole(data, 'ROLE')\"\n >&#xe90d;</i\n >\n {{\n featureflagrole && data?.permissionGroupName\n ? data?.permissionGroupName\n : data?.roleName\n }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field>\n\n <!-- Owners -->\n <form-field\n *ngIf=\"additionalOption?.OWNERS\"\n [checked]=\"\n controls?.program_owners.value?.length > 0 ||\n controls?.program_owners_group.value?.length > 0\n \"\n [active]=\"activeList === 'OWNER'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'OWNER'\"\n [img]=\"ASSETS.case_owners\"\n >\n <label class=\"vx-control-panel\"\n >OWNER(S)\n <span\n class=\"icon\"\n *ngIf=\"toolTipData.owner !== ''\"\n libPopoverHover\n (mouseover)=\"dataTooltip.popover()\"\n (mouseleave)=\"dataTooltip.closePopover()\"\n placement=\"right\"\n ><i class=\"icons\">&#xe91f;</i></span\n >\n <popover-hover #dataTooltip>\n <div class=\"vx-info-card\">\n <div\n class=\"vx-info-card-body\"\n [innerHTML]=\"toolTipData.owner\"\n id=\"OwnerHelpText\"\n ></div>\n </div>\n </popover-hover>\n </label>\n <input-with-pill\n [placeholder]=\"'Who is responsible for managing this program?'\"\n (select)=\"activateList('OWNER')\"\n >\n <div class=\"selected\" *ngIf=\"controls?.program_owners.value[0]\">\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_owners?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_owners?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4 greenBg\"\n appPopover\n (click)=\"owner.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_owners?.value?.length > 1\"\n >\n +{{ controls?.program_owners?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_owners_group?.value?.length &&\n controls?.program_owners?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_owners_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n (click)=\"\n remove(\n controls?.program_owners_group?.value[0],\n 'OWNER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_owners_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_owners_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"group.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_owners_group?.value?.length > 1\"\n >\n +{{ controls?.program_owners_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <button\n *ngIf=\"activeList !== 'OWNER'\"\n [class.disabled]=\"controls?.all_user_in_role?.value\"\n (click)=\"activateList('OWNER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i>Edit\n </button>\n </div>\n </input-with-pill>\n <p *ngIf=\"false\" class=\"error-message\">Add a owner(s)</p>\n <div class=\"vx-d-flex vx-align-center vx-justify-end vx-mt-2\">\n <div\n class=\"vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase vx-mr-2\"\n >\n {{\n featureflagrole\n ? \"ALL USERS ASSOCIATED WITH THE SELECTED PERMISSION GROUPS\"\n : \"ALL USERS ASSOCIATED WITH THE SELECTED ROLES\"\n }}\n </div>\n <switch\n formControlName=\"all_user_in_role\"\n (change)=\"selectAllRoleOwner($event)\"\n ></switch>\n </div>\n <app-popover #owner [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"let owner of controls?.program_owners?.value | slice : 1\"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"\n !(\n lists.NON_REMOVABLE_OWNERS | listToId : 'member_id'\n ).includes(owner?.member_id)\n \"\n class=\"icons\"\n (click)=\"remove(owner, 'OWNER')\"\n >&#xe90d;</i\n >\n {{ owner?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #group [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let owner of controls?.program_owners_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n class=\"icons\"\n (click)=\"remove(owner, 'OWNER_GROUP')\"\n >&#xe90d;</i\n >\n {{ owner?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field>\n\n <!-- Collaborator -->\n <form-field\n *ngIf=\"additionalOption?.COLLABORATOR\"\n [checked]=\"\n controls?.program_collaborator?.value?.length > 0\n \"\n [active]=\"activeList === 'COLLABORATOR'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'COLLABORATOR'\"\n [img]=\"ASSETS.case_owners\"\n >\n <label class=\"vx-control-panel\"\n >Collaborator(S) <span class=\"required\">*</span>\n <span\n class=\"icon\"\n libPopoverHover\n (mouseover)=\"dataTooltip.popover()\"\n (mouseleave)=\"dataTooltip.closePopover()\"\n placement=\"right\"\n ><i class=\"icons\">&#xe91f;</i></span\n >\n <popover-hover #dataTooltip>\n <div class=\"vx-info-card\">\n <div\n class=\"vx-info-card-body\"\n [innerHTML]=\"toolTipData.owner\"\n id=\"OwnerHelpText\"\n ></div>\n </div>\n </popover-hover>\n </label>\n <input-with-pill\n [placeholder]=\"'Who is responsible for managing this program?'\"\n (select)=\"activateList('COLLABORATOR')\"\n >\n <div class=\"selected\" *ngIf=\"controls?.program_collaborator?.value[0]\">\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_collaborator?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_collaborator?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4 greenBg\"\n appPopover\n (click)=\"collaborator.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_collaborator?.value?.length > 1\"\n >\n +{{ controls?.program_collaborator?.value?.length - 1 }}\n </button>\n </div>\n \n </div>\n\n <button\n *ngIf=\"activeList !== 'COLLABORATOR'\"\n [class.disabled]=\"controls?.all_user_in_role?.value\"\n (click)=\"activateList('COLLABORATOR')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i>Edit\n </button>\n </div>\n </input-with-pill>\n <div class=\"vx-d-flex vx-align-center vx-justify-end vx-mt-2\">\n <div\n class=\"vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase vx-mr-2\"\n >\n </div>\n </div>\n <app-popover #collaborator [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"let collaborator of controls?.program_collaborator?.value | slice : 1\"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n class=\"icons\"\n (click)=\"remove(collaborator, 'COLLABORATOR')\"\n >&#xe90d;</i\n >\n {{ collaborator?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field>\n\n <!-- Performance Calculated -->\n <!-- <form-field [checked]=\"controls?.performance_calculation?.value\" [active]=\"activeList === 'PERFORMANCE'\" [disabled]=\"sideElements.includes(activeList) && activeList !== 'PERFORMANCE'\"\n [img]=\"'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/performance-calc.svg'\">\n <label class=\"vx-control-panel\">HOW SHOULD THE PERFORMANCE OF THIS PROGRAM BE CALCULATED?</label>\n <tab-selector formControlName=\"performance_calculation\" [displayArray]=\"constants?.performanceCalculation\">\n </tab-selector>\n </form-field> -->\n <ng-container *ngIf=\"isProgramScope\">\n <div\n class=\"scope-label vx-fs-10 vx-txt-white vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mb-5 vx-lh-4 vx-d-inline-block\"\n >\n PROGRAM SCOPE\n </div>\n <!-- <i class=\"icons info-icon vx-fs-12 vx-txt-blue vx-ml-1\" [appTooltip]=\"tooltip.programScope\" placement=\"bottom\" delay=\"0\" type=\"white\" [tooltipMandatory]=\"true\">&#xe91f;</i> -->\n <span\n class=\"icon info-icon vx-fs-12 vx-txt-blue vx-ml-1\"\n *ngIf=\"toolTipData.programScop !== ''\"\n libPopoverHover\n (mouseover)=\"dataTooltip.popover()\"\n (mouseleave)=\"dataTooltip.closePopover()\"\n placement=\"right\"\n ><i class=\"icons\">&#xe91f;</i></span\n >\n <popover-hover #dataTooltip>\n <div class=\"vx-info-card\">\n <div\n class=\"vx-info-card-body\"\n [innerHTML]=\"toolTipData.programScope\"\n id=\"PSHelpText\"\n ></div>\n </div>\n </popover-hover>\n </ng-container>\n\n <!-- Program Frequency -->\n <form-field\n *ngIf=\"additionalOption?.PROGRAM_FREQUENCY\"\n [checked]=\"[true, false].includes(controls?.recurring_frequency?.value)\"\n [active]=\"activeList === 'FREQUENCY'\"\n [disabled]=\"\n sideElements.includes(activeList) && activeList !== 'FREQUENCY'\n \"\n [img]=\"ASSETS.recurring\"\n >\n <label class=\"vx-control-panel\" id=\"PDChange\"\n >PROGRAM DURATION\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Program Duration refers to the duration of the Program. A Program can occur in perpetuity, or it can occur until the end of the current business cycle that has been specified in ' +\n businessCycle.selectedCycle.business_cycle +\n '. All responsibilities linked with that Program will also have the same Program Duration.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"ProgramDurationHelpText\"\n >&#xeb16;</i\n ></label\n >\n <div class=\"upload-format\">\n <div class=\"vx-d-flex vx-align-center vx-justify-between\">\n <span class=\"text vx-mb-0\">Is this program recurring?</span>\n <div class=\"radio-group program\">\n <app-cs-radio\n [name]=\"'recurring_frequency'\"\n [checked]=\"controls?.recurring_frequency?.value\"\n (checkedEvent)=\"setFormField('recurring_frequency', true)\"\n >YES</app-cs-radio\n >\n <app-cs-radio\n [name]=\"'recurring_frequency'\"\n [checked]=\"!controls?.recurring_frequency?.value\"\n (checkedEvent)=\"setFormField('recurring_frequency', false)\"\n >NO</app-cs-radio\n >\n </div>\n </div>\n </div>\n </form-field>\n\n <!-- Scope Changes -->\n <form-field\n *ngIf=\"additionalOption?.SCOPE_CHANGES\"\n [checked]=\"[true, false].includes(controls?.lock_scope_change?.value)\"\n [active]=\"activeList === 'SCOPE'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'SCOPE'\"\n [img]=\"ASSETS.lock_scope\"\n >\n <label class=\"vx-control-panel\"\n >Lock the Program Scope\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If the Program Scope is locked, neither the Program nor the responsibilities linked with the Program can be edited once the Program begins. In order to edit the Program or the linked responsibilities, the Program details will need to be edited.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"ScopeChangesHelpText\"\n >&#xeb16;</i\n ></label\n >\n <div class=\"upload-format\">\n <span class=\"text\"\n >Would you like to\n <span class=\"vx-label-txt vx-fw-500\">lock changes</span> to the\n program scope?</span\n >\n <div class=\"radio-group program\">\n <app-cs-radio\n [name]=\"'lock_scope_change'\"\n [checked]=\"controls?.lock_scope_change?.value\"\n (checkedEvent)=\"setFormField('lock_scope_change', true)\"\n >YES</app-cs-radio\n >\n <app-cs-radio\n [name]=\"'lock_scope_change'\"\n [checked]=\"!controls?.lock_scope_change?.value\"\n (checkedEvent)=\"setFormField('lock_scope_change', false)\"\n >NO</app-cs-radio\n >\n </div>\n </div>\n </form-field>\n\n <!-- Framework -->\n <!-- <form-field [checked]=\"false\" [active]=\"activeList === 'FRAMEWORK'\" [disabled]=\"sideElements.includes(activeList) && activeList !== 'FRAMEWORK'\"\n [img]=\"'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/category.svg'\">\n <label class=\"vx-control-panel\">FRAMEWORK</label>\n <input-with-pill [placeholder]=\"'Select a framework that this Program relates to'\" (select)=\"activateList('FRAMEWORK')\">\n <div class=\"selected\" *ngIf=\"controls?.framework?.value?.framework_name\">\n <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i (click)=\"remove(controls?.framework.value,'FRAMEWORK')\" class=\"icons\">&#xe90d;</i>{{controls?.framework?.value?.framework_name}}</span>\n <button class=\"count\" appPopover (click)=\"framework.popover()\" placement=\"right\">+5</button>\n </div>\n </div>\n <button *ngIf=\"activeList!=='FRAMEWORK'\" (click)=\"activateList('FRAMEWORK')\" class=\"edit\" type=\"button\"><i class=\"icons\">&#xe9ba;</i> Edit</button>\n </div>\n </input-with-pill>\n <app-popover #framework [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i class=\"icons\">&#xe90d;</i>\n Manage framework name\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field> -->\n\n <!-- Responsibility Center -->\n <form-field\n *ngIf=\"additionalOption?.RC\"\n [checked]=\"controls?.rc?.value?.length\"\n [active]=\"activeList === 'RC'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'RC'\"\n [img]=\"ASSETS.responsibility_center\"\n >\n <label class=\"vx-control-panel\"\n >RESPONSIBILITY CENTER\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Responsibility Centers represent your organizational and operational infrastructure. Where Responsibility Centers are selected when creating a Program, only those Responsibilities Centers will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"RCHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n (select)=\"activateList('RC')\"\n [placeholder]=\"\n 'Which Responsibility Center(s) can be linked to the responsibilities associated with this Program?'\n \"\n >\n <div\n class=\"selected\"\n *ngIf=\"controls?.rc?.value && controls?.rc?.value?.length\"\n >\n <div class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\">\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"remove(controls?.rc?.value[0], 'RC')\"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.rc?.value[0]?.item_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.rc?.value[0]?.item_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"rc.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.rc?.value?.length > 1\"\n >\n +{{ controls?.rc?.value?.length - 1 }}\n </button>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i class=\"icons\" (click)=\"remove(controls?.rc?.value[0],'RC')\">&#xe90d;</i>{{controls?.rc?.value[0]?.item_name}}</span>\n <button *ngIf=\"controls?.rc?.value?.length > 1\" class=\"count\" appPopover (click)=\"rc.popover()\" placement=\"right\">+{{controls?.rc?.value?.length -1 }}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'RC'\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('RC')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #rc [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"let rc of controls?.rc?.value | slice : 1\">\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i class=\"icons\" (click)=\"remove(rc, 'RC')\">&#xe90d;</i>\n {{ rc?.item_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field>\n\n <!-- Assignee -->\n <form-field\n *ngIf=\"additionalOption?.ASSIGNEES\"\n [checked]=\"\n controls?.program_assignee?.value?.length ||\n controls?.program_default_assignee?.value?.length ||\n controls?.program_default_assignee?.value?.length ||\n controls?.program_default_assignee_group?.value?.length\n \"\n [active]=\"['ASSIGNEE', 'DEFAULT_ASSIGNEE']?.includes(activeList)\"\n [disabled]=\"\n sideElements?.includes(activeList) &&\n !['ASSIGNEE', 'DEFAULT_ASSIGNEE'].includes(activeList)\n \"\n [img]=\"ASSETS.case_assignees\"\n >\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"activeList === 'DEFAULT_ASSIGNEE'\"\n >ASSIGNEES\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Assignees are required to complete the responsibilities that have been assigned to them. Where Assignees are selected when creating a Program, only those Assignees will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"AssigneeHelpText\"\n >&#xeb16;</i\n >\n </label>\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'DEFAULT_ASSIGNEE'\"\n [placeholder]=\"\n 'Who is responsible for completing the responsibilities within this Program?'\n \"\n (select)=\"activateList('ASSIGNEE')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_assignee?.value?.length ||\n controls?.program_assignee_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_assignee?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(controls?.program_assignee?.value[0], 'ASSIGNEE')\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_assignee?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_assignee?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"assignee.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_assignee?.value?.length > 1\"\n >\n +{{ controls?.program_assignee?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_assignee_group?.value?.length &&\n controls?.program_assignee?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_assignee_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_assignee_group?.value[0],\n 'ASSIGNEE_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_assignee_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_assignee_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"assignee_group.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_assignee_group?.value?.length > 1\"\n >\n +{{ controls?.program_assignee_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_assignee?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_assignee?.value[0],'ASSIGNEE')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_assignee?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_assignee?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_assignee?.value?.length > 1\" class=\"count user\" appPopover (click)=\"assignee.popover()\" placement=\"right\">+{{controls?.program_assignee?.value?.length -1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_assignee_group?.value?.length && controls?.program_assignee?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_assignee_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_assignee_group?.value[0],'ASSIGNEE_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_assignee_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_assignee_group?.value[0]?.group_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_assignee_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"assignee_group.popover()\" placement=\"right\">+{{controls?.program_assignee_group?.value?.length -1 }}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'ASSIGNEE'\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('ASSIGNEE')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #assignee [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let assignee of controls?.program_assignee?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(assignee, 'ASSIGNEE')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ assignee?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #assignee_group [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_assignee_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(group, 'ASSIGNEE_GROUP')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"activeList === 'ASSIGNEE'\"\n >DEFAULT ASSIGNEE\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'This option lets you specify the Default Assignees for all new responsibilities linked with a Program. If a Default Assignees is selected, the user will automatically be selected the Assignee when creating a responsibility linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility. '\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"DAHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'ASSIGNEE'\"\n [placeholder]=\"\n 'Which persons will be selected as the default assignees for the responsibilities within this Program?'\n \"\n (select)=\"activateList('DEFAULT_ASSIGNEE')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_assignee?.value?.length ||\n controls?.program_default_assignee_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_assignee?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_assignee?.value[0],\n 'DEFAULT_ASSIGNEE'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_assignee?.value[0]?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_assignee?.value[0]?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultAssignee.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_default_assignee?.value?.length > 1\"\n >\n +{{ controls?.program_default_assignee?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_default_assignee_group?.value?.length &&\n controls?.program_default_assignee?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_assignee_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_assignee_group?.value[0],\n 'DEFAULT_ASSIGNEE_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_assignee_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_assignee_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultAssigneeGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_assignee_group?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_assignee_group?.value?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_assignee?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_assignee?.value[0],'DEFAULT_ASSIGNEE')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_assignee?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{ controls?.program_default_assignee?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_assignee?.value?.length > 1\" class=\"count user\" appPopover (click)=\"defaultAssignee.popover()\" placement=\"right\">+{{controls?.program_default_assignee?.value?.length - 1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_default_assignee_group?.value?.length && controls?.program_default_assignee?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_assignee_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_assignee_group?.value[0],'DEFAULT_ASSIGNEE_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_assignee_group?.value[0]?.group_name }}</span>\n </span>\n <button *ngIf=\"controls?.program_default_assignee_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"defaultAssigneeGroup.popover()\" placement=\"right\">+{{controls?.program_default_assignee_group?.value?.length -1 }}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_ASSIGNEE'\"\n (click)=\"activateList('DEFAULT_ASSIGNEE')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #defaultAssignee [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let assignee of controls?.program_default_assignee?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(assignee, 'DEFAULT_ASSIGNEE')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ assignee?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #defaultAssigneeGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_assignee_group?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(assignee, 'DEFAULT_ASSIGNEE_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <div\n class=\"radio-group-selector\"\n [class.disabled]=\"activeList === 'ASSIGNEE'\"\n >\n <app-cs-radio\n [name]=\"'assignee'\"\n [checked]=\"controls?.assignee_completion_criteria?.value === 'ALL'\"\n (checkedEvent)=\"setFormField('assignee_completion_criteria', 'ALL')\"\n >\n ALL SELECTED PERSONS NEED TO COMPLETE THIS\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If selected, separate responsibilities will be created for each person.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n <app-cs-radio\n [name]=\"'assignee'\"\n [checked]=\"controls?.assignee_completion_criteria?.value === 'ANYONE'\"\n (checkedEvent)=\"\n setFormField('assignee_completion_criteria', 'ANYONE')\n \"\n >\n ANY SELECTED PERSON CAN COMPLETE THIS\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If selected, only one responsibility will be created.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n </div>\n </form-field>\n\n <!-- Reviewer -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.REVIEWER\"\n [checked]=\"\n controls?.program_reviewer?.value?.length ||\n controls?.program_default_reviewer?.value?.length ||\n controls?.program_default_reviewer?.value?.length ||\n controls?.program_default_reviewer_group?.value?.length\n \"\n [active]=\"['REVIEWER', 'DEFAULT_REVIEWER']?.includes(activeList)\"\n [disabled]=\"\n sideElements?.includes(activeList) &&\n !['REVIEWER', 'DEFAULT_REVIEWER'].includes(activeList)\n \"\n [img]=\"ASSETS.reviewer\"\n >\n <label\n [class.disabled]=\"activeList === 'DEFAULT_REVIEWER'\"\n class=\"vx-control-panel\"\n >Reviewers\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Reviewers are required to review responsibilities after they have been completed. Where Reviewers are selected when creating a Program, only those Reviewers will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"ReviewerHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'DEFAULT_REVIEWER'\"\n [placeholder]=\"\n 'Who is responsible for reviewing the responsibilities within this Program?'\n \"\n (select)=\"activateList('REVIEWER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_reviewer?.value?.length ||\n controls?.program_reviewer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_reviewer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(controls?.program_reviewer?.value[0], 'REVIEWER')\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_reviewer?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_reviewer?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"reviewer.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_reviewer?.value?.length > 1\"\n >\n +{{ controls?.program_reviewer?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_reviewer_group?.value?.length &&\n controls?.program_reviewer?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_reviewer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_reviewer_group?.value[0],\n 'REVIEWER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_reviewer_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_reviewer_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"reviewerGroup.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_reviewer_group?.value?.length > 1\"\n >\n +{{ controls?.program_reviewer_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_reviewer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_reviewer?.value[0],'REVIEWER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_reviewer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_reviewer?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_reviewer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"reviewer.popover()\" placement=\"right\">+{{controls?.program_reviewer?.value?.length -1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_reviewer_group?.value?.length && controls?.program_reviewer?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_reviewer_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_reviewer_group?.value[0],'REVIEWER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_reviewer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_reviewer_group?.value[0]?.group_name}}\n </span>\n </span>\n <button *ngIf=\"controls?.program_reviewer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"reviewerGroup.popover()\" placement=\"right\">+{{controls?.program_reviewer_group?.value?.length - 1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'REVIEWER'\"\n (click)=\"activateList('REVIEWER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #reviewer [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let reviewer of controls?.program_reviewer?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(reviewer, 'REVIEWER')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ reviewer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #reviewerGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_reviewer_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(group, 'REVIEWER_GROUP')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <label\n [class.disabled]=\"activeList === 'REVIEWER'\"\n class=\"vx-control-panel\"\n >DEFAULT Reviewer\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'This option lets you specify the Default Reviewers for responsibilities linked with a Program. Where a user has been specified as a Default Reviewer, that user will automatically be selected as the Reviewer when creating a responsibility linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"DRHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'REVIEWER'\"\n [placeholder]=\"\n 'Which persons will be selected as the default reviewers for the responsibilities within this Program?'\n \"\n (select)=\"activateList('DEFAULT_REVIEWER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_reviewer?.value?.length ||\n controls?.program_default_reviewer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_reviewer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_reviewer?.value[0],\n 'DEFAULT_REVIEWER'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_reviewer?.value[0]?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_reviewer?.value[0]?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultReviewer.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_default_reviewer?.value?.length > 1\"\n >\n +{{ controls?.program_default_reviewer?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_default_reviewer_group?.value?.length &&\n controls?.program_default_reviewer?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_reviewer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_reviewer_group?.value[0],\n 'DEFAULT_REVIEWER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_reviewer_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_reviewer_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultReviewerGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_reviewer_group?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_reviewer_group?.value?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_reviewer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_reviewer?.value[0],'DEFAULT_REVIEWER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_reviewer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_reviewer?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_reviewer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"defaultReviewer.popover()\" placement=\"right\">+{{controls?.program_default_reviewer?.value?.length - 1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_default_reviewer_group?.value?.length && controls?.program_default_reviewer?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_reviewer_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_reviewer_group?.value[0],'DEFAULT_REVIEWER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_reviewer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_reviewer_group?.value[0]?.group_name}}\n </span>\n </span>\n <button *ngIf=\"controls?.program_default_reviewer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"defaultReviewerGroup.popover()\" placement=\"right\">+{{controls?.program_default_reviewer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_REVIEWER'\"\n (click)=\"activateList('DEFAULT_REVIEWER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #defaultReviewer [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let reviewer of controls?.program_default_reviewer?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(reviewer, 'DEFAULT_REVIEWER')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ reviewer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #defaultReviewerGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_reviewer_group?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(group, 'DEFAULT_REVIEWER_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <div\n class=\"radio-group-selector\"\n [class.disabled]=\"activeList === 'REVIEWER'\"\n >\n <app-cs-radio\n [name]=\"'reviewer'\"\n [checked]=\"\n controls?.reviewer_completion_criteria?.value === 'SEQUENTIAL'\n \"\n (checkedEvent)=\"\n setFormField('reviewer_completion_criteria', 'SEQUENTIAL')\n \"\n [class.disabled]=\"\n controls?.program_default_reviewer_group?.value?.length > 0\n \"\n >\n SEQUENTIAL\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'The responsibility will be sent for review one at a time in the sequence defined by you.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n <app-cs-radio\n [name]=\"'reviewer'\"\n [checked]=\"\n controls?.reviewer_completion_criteria?.value === 'ANYONE' ||\n controls?.program_default_reviewer_group?.value?.length > 0\n \"\n (checkedEvent)=\"\n setFormField('reviewer_completion_criteria', 'ANYONE')\n \"\n >\n ANY REVIEWER CAN MARK THIS AS REVIEWED\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'The responsibility will be sent for review to all reviewers at the same time. If anyone of the reviewer reviews the responsibility, it will be considered as reviewed.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n </div>\n </form-field>\n\n <!-- Overseer -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.OVERSEER\"\n [checked]=\"\n controls?.program_overseer?.value?.length ||\n controls?.program_default_overseer?.value?.length ||\n controls?.program_default_overseer?.value?.length ||\n controls?.program_default_overseer_group?.value?.length\n \"\n [active]=\"activeList === 'OVERSEER'\"\n [disabled]=\"\n sideElements?.includes(activeList) &&\n !['OVERSEER', 'DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(\n activeList\n )\n \"\n [img]=\"ASSETS.oversight\"\n >\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"\n ['DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n \"\n >Oversights\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Oversights receive updates when a responsibility is completed, completed with delay or not completed. Where Oversights are selected when creating a Program, only those Oversights will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"overseerHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"\n ['DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n \"\n [placeholder]=\"\n 'Who is responsible for overseeing the responsibilities within this Program?'\n \"\n (select)=\"activateList('OVERSEER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_overseer?.value?.length ||\n controls?.program_overseer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_overseer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(controls?.program_overseer?.value[0], 'OVERSEER')\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_overseer?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_overseer?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseers.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_overseer?.value?.length > 1\"\n >\n +{{ controls?.program_overseer?.value?.length - 1 }}\n </button>\n </div>\n <span\n *ngIf=\"\n controls?.program_overseer_group?.value?.length &&\n controls?.program_overseer?.value?.length\n \"\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_overseer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_overseer_group?.value[0],\n 'OVERSEER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_overseer_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_overseer_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseerGroup.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_overseer_group?.value?.length > 1\"\n >\n +{{ controls?.program_overseer_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_overseer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_overseer?.value[0],'OVERSEER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_overseer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">\n {{controls?.program_overseer?.value[0]?.member_name}}\n </span>\n </span>\n <button *ngIf=\"controls?.program_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseers.popover()\" placement=\"right\">+{{controls?.program_overseer?.value?.length -1}}</button>\n </div>\n <span *ngIf=\"controls?.program_overseer_group?.value?.length && controls?.program_overseer?.value?.length \" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_overseer_group?.value?.length \">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_overseer_group?.value[0],'OVERSEER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_overseer_group?.value[0]?.group_name}}</span></span>\n <button *ngIf=\"controls?.program_overseer_group?.value?.length> 1\" class=\"count\" appPopover (click)=\"overseerGroup.popover()\" placement=\"right\">+{{controls?.program_overseer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n\n <button\n *ngIf=\"activeList !== 'OVERSEER'\"\n (click)=\"activateList('OVERSEER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #overseers [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let overseer of controls?.program_overseer?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i class=\"icons\" (click)=\"remove(overseer, 'OVERSEER')\"\n >&#xe90d;</i\n >\n {{ overseer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #overseerGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_overseer_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(group, 'OVERSEER_GROUP')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <ng-container [class.disabled]=\"activeList === 'OVERSEER'\">\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"['OVERSEER'].includes(activeList)\"\n >DEFAULT Oversight\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'This option lets you specify the Default Oversight for responsibilities linked with a Program. Where a user has been specified as a Default Oversight, that user will automatically be selected as the Oversight when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"DOHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [disabled]=\"\n ['OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n \"\n [selectDiv]=\"true\"\n [placeholder]=\"\n 'Which persons will be selected as the default overseers for the responsibilities within this Program?'\n \"\n (select)=\"activateList('DEFAULT_OVERSEER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_overseer?.value?.length ||\n controls?.program_default_overseer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_overseer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_overseer?.value[0],\n 'DEFAULT_OVERSEER'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_overseer?.value[0]?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_overseer?.value[0]?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseersDefault.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_default_overseer?.value?.length > 1\"\n >\n +{{ controls?.program_default_overseer?.value?.length - 1 }}\n </button>\n </div>\n <span\n *ngIf=\"\n controls?.program_default_overseer_group?.value?.length &&\n controls?.program_default_overseer?.value?.length\n \"\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_overseer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_overseer_group?.value[0],\n 'DEFAULT_OVERSEER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_overseer_group?.value[0]\n ?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_overseer_group?.value[0]\n ?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseerDefaultGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_overseer_group?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_overseer_group?.value?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_overseer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_overseer?.value[0],'DEFAULT_OVERSEER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_overseer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_overseer?.value[0]?.member_name}}</span></span>\n <button *ngIf=\"controls?.program_default_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseersDefault.popover()\" placement=\"right\">+{{controls?.program_default_overseer?.value?.length -1}}</button>\n </div>\n <span *ngIf=\"controls?.program_default_overseer_group?.value?.length && controls?.program_default_overseer?.value?.length\" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_overseer_group?.value?.length \">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_overseer_group?.value[0],'DEFAULT_OVERSEER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_overseer_group?.value[0]?.group_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_overseer_group?.value?.length >1\" class=\"count\" appPopover (click)=\"overseerDefaultGroup.popover()\" placement=\"right\">+{{controls?.program_default_overseer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_OVERSEER'\"\n (click)=\"activateList('DEFAULT_OVERSEER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #overseersDefault [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let overseer of controls?.program_default_overseer?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n class=\"icons\"\n (click)=\"remove(overseer, 'DEFAULT_OVERSEER')\"\n >&#xe90d;</i\n >\n {{ overseer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #overseerDefaultGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_overseer_group?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(group, 'DEFAULT_OVERSEER_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <label class=\"vx-control-panel\"> </label>\n <input-with-pill\n class=\"vx-mt-2\"\n [selectDiv]=\"true\"\n [line]=\"3\"\n [disabled]=\"['OVERSEER', 'DEFAULT_OVERSEER'].includes(activeList)\"\n [placeholder]=\"\n 'Which persons will be selected as the default overseers for responsibilities that are not completed within this Program?'\n \"\n (select)=\"activateList('DEFAULT_FAILED_OVERSEER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_failed_overseer?.value?.length ||\n controls?.program_default_failed_overseer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_failed_overseer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_failed_overseer?.value[0],\n 'DEFAULT_FAILED_OVERSEER'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_failed_overseer?.value[0]\n ?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_failed_overseer?.value[0]\n ?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseersDefaultFail.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_failed_overseer?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_failed_overseer?.value?.length - 1\n }}\n </button>\n </div>\n <span\n *ngIf=\"\n controls?.program_default_failed_overseer_group?.value\n ?.length &&\n controls?.program_default_failed_overseer?.value?.length\n \"\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"\n controls?.program_default_failed_overseer_group?.value?.length\n \"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_failed_overseer_group?.value[0],\n 'DEFAULT_FAILED_OVERSEER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_failed_overseer_group?.value[0]\n ?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_failed_overseer_group?.value[0]\n ?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseerDefaultFailGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_failed_overseer_group?.value\n ?.length > 1\n \"\n >\n +{{\n controls?.program_default_failed_overseer_group?.value\n ?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_failed_overseer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_failed_overseer?.value[0],'DEFAULT_FAILED_OVERSEER')\" >&#xe90d;</i>\n <span class=\"chip\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_failed_overseer?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_failed_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseersDefaultFail.popover()\" placement=\"right\">+{{controls?.program_default_failed_overseer?.value?.length -1}}</button>\n </div>\n <span *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length && controls?.program_default_failed_overseer?.value?.length\" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length \">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_failed_overseer_group?.value[0],'DEFAULT_FAILED_OVERSEER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_failed_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_failed_overseer_group?.value[0]?.group_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"overseerDefaultFailGroup.popover()\" placement=\"right\">+{{controls?.program_default_failed_overseer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_FAILED_OVERSEER'\"\n (click)=\"activateList('DEFAULT_FAILED_OVERSEER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #overseersDefaultFail [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let overseer of controls?.program_default_failed_overseer\n ?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n class=\"icons\"\n (click)=\"remove(overseer, 'DEFAULT_FAILED_OVERSEER')\"\n >&#xe90d;</i\n >\n {{ overseer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #overseerDefaultFailGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_failed_overseer_group\n ?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(group, 'DEFAULT_FAILED_OVERSEER_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </ng-container>\n </form-field>\n\n <!-- Assessment -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.ASSESSMENT\"\n [checked]=\"controls?.program_assessments?.value?.length\"\n [active]=\"activeList === 'ASSESSMENT'\"\n [disabled]=\"\n sideElements.includes(activeList) && activeList !== 'ASSESSMENT'\n \"\n [img]=\"ASSETS.assessments\"\n >\n <label class=\"vx-control-panel\"\n >ASSESSMENTS\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Assessments are a digital form that are created in \u201CAssessment\u201D within the Compliance Module. Where Assessments are selected when creating a Program, only those Assessments will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"AssessmentHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [placeholder]=\"\n 'Which assessments can be linked to the responsibilities within this Program?'\n \"\n (select)=\"activateList('ASSESSMENT')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"controls?.program_assessments?.value?.length\"\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"\n controls?.program_assessments?.value\n | assessmentResolver as assessments\n \"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"remove(assessments[0], 'ASSESSMENT')\"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"assessments[0]?.assessment_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ assessments[0]?.assessment_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"program_assessments.popover()\"\n placement=\"right\"\n *ngIf=\"assessments?.length > 1\"\n >\n +{{ assessments?.length - 1 }}\n </button>\n </div>\n\n <!-- <div class=\"chip-container\">\n <ng-container *ngIf=\"(controls?.program_assessments?.value | assessmentResolver) as assessments\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i class=\"icons\" (click)=\"remove(assessments[0],'ASSESSMENT')\">&#xe90d;</i>{{assessments[0]?.assessment_name}} </span>\n <button *ngIf=\"assessments?.length > 1\" class=\"count\" appPopover (click)=\"program_assessments.popover()\" placement=\"right\">+{{assessments?.length -1 }}</button>\n </div>\n </ng-container>\n </div> -->\n <button\n *ngIf=\"activeList !== 'ASSESSMENT'\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('ASSESSMENT')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #program_assessments [dontCloseonClick]=\"true\">\n <ng-container>\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let assessment of controls?.program_assessments?.value\n | assessmentResolver\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(assessment, 'ASSESSMENT')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ assessment?.assessment_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </ng-container>\n </app-popover>\n </form-field>\n\n <!-- Format & Evidence -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.FORMATE_EVIDENCE\"\n [checked]=\"[true, false].includes(controls?.evidence_required?.value)\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.format_evidence\"\n >\n <label class=\"vx-control-panel\"\n >Evidence\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If selected, evidence of completion of a responsibility will be required for all responsibilities that are linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"EvidenceHelpText\"\n >&#xeb16;</i\n ></label\n >\n <div class=\"upload-format\">\n <span class=\"text\"\n >Do all responsibilities within this program require evidence?</span\n >\n <div class=\"radio-group program\">\n <app-cs-radio\n [name]=\"'evidence_required'\"\n [checked]=\"controls?.evidence_required?.value\"\n (checkedEvent)=\"setFormField('evidence_required', true)\"\n >YES</app-cs-radio\n >\n <app-cs-radio\n [name]=\"'evidence_required'\"\n [checked]=\"!controls?.evidence_required?.value\"\n (checkedEvent)=\"setFormField('evidence_required', false)\"\n >NO</app-cs-radio\n >\n </div>\n </div>\n <!-- <div class=\"vx-d-flex vx-align-center vx-justify-end vx-mt-2\">\n <div class=\"vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase vx-mr-2\">Allow any file to be marked as\n key\n evidence</div>\n <switch formControlName=\"allow_any_file_key_evidence\"\n (change)=\"setFormField('allow_any_file_key_evidence',$event?.target?.checked)\"></switch>\n </div> -->\n </form-field>\n\n <!-- Custom Field -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.CUSTOM_FIELDS\"\n [checked]=\"controls?.custom_fields?.value?.length\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.custom_fields\"\n >\n <label class=\"vx-control-panel\"\n >CUSTOM FIELD\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Where a custom field is specified, all responsibilities linked with a Program will contain that custom field. Custom fields enable the collection of additional meta data.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"CFHelpText\"\n >&#xeb16;</i\n ></label\n >\n <custom-field formControlName=\"custom_fields\"></custom-field>\n </form-field>\n </form>\n</div>\n\n<!-- list of roles -->\n<role-list\n *ngIf=\"activeList === 'ROLE'\"\n [selected]=\"controls?.program_roles?.value | refDisconnect\"\n [loading]=\"listLoadingState.ROLES\"\n [list]=\"lists?.ROLES?.data ?? []\"\n (save)=\"listAction($event, 'ROLE')\"\n (cancel)=\"fieldDeselector('ROLE')\"\n [featureflagrole]=\"featureflagrole\"\n [featureflagGroup]=\"featureflagGroups\"\n [ff_rc_listing]=\"ff_rc_listing\"\n></role-list>\n\n<!-- list of frameworks -->\n<!-- <app-define-framework-listing *ngIf=\"activeList === 'FRAMEWORK'\" (cancel)=\"fieldDeselector('FRAMEWORK')\" (next)=\"listAction($event,'FRAMEWORK')\" [mode]=\"mode\" [selectedFramework]=\"controls?.framework?.value\"></app-define-framework-listing> -->\n<!-- list of responsibility center -->\n<app-responsibility-centers-list\n *ngIf=\"activeList === 'RC'\"\n [responsibilityCentersList]=\"lists?.RC ?? []\"\n [radioSelection]=\"false\"\n [rcIdKey]=\"'rc_id'\"\n (closeRcList)=\"fieldDeselector('RC')\"\n (saveSelectedList)=\"listAction($event, 'RC')\"\n [selectedResponsibilityCenters]=\"controls?.rc?.value | refDisconnect\"\n>\n</app-responsibility-centers-list>\n<!-- render userlist with group -->\n\n<user-group-list\n *ngIf=\"activeList === 'OWNER'\"\n [groupEnabled]=\"true\"\n [singleSelect]=\"false\"\n [loading]=\"listLoadingState.USERS\"\n [nonRemovableUserIds]=\"lists.NON_REMOVABLE_OWNERS | listToId : 'member_id'\"\n [userlist]=\"lists?.OWNERS?.data ?? []\"\n [selectedUsers]=\"controls?.program_owners?.value | refDisconnect\"\n (fetchUserData)=\"fetchUsersAssociatedWithRoles(false, $event)\"\n [userListInfo]=\"lists?.OWNERS\"\n [groupListInfo]=\"lists?.OWNERS_GROUPS\"\n [groupList]=\"lists?.OWNERS_GROUPS?.data ?? []\"\n [selectedGroups]=\"controls?.program_owners_group?.value | refDisconnect\"\n (save)=\"listAction($event, 'OWNER')\"\n (cancel)=\"fieldDeselector('OWNER')\"\n [panelTitle]=\"panelTitleOwner\"\n [featureflag]=\"featureflagGroups\"\n></user-group-list>\n\n<user-group-list\n *ngIf=\"activeList === 'COLLABORATOR'\"\n [groupEnabled]=\"false\"\n [singleSelect]=\"false\"\n [userlist]=\"lists?.COLLABORATORS?.data ?? []\"\n [disabledIds]=\"disableCollaboratorIds\"\n [selectedUsers]=\"controls?.program_collaborator?.value | refDisconnect\"\n [userListInfo]=\"lists?.COLLABORATORS\"\n (save)=\"listAction($event, 'COLLABORATOR')\"\n (cancel)=\"fieldDeselector('COLLABORATOR')\"\n [panelTitle]=\"panelTitleCollaborator\"\n>\n</user-group-list>\n<user-group-list\n *ngIf=\"activeList === 'ASSIGNEE'\"\n [groupEnabled]=\"true\"\n [singleSelect]=\"false\"\n [loading]=\"listLoadingState.USERS\"\n [userlist]=\"lists?.ASSIGNEES ?? []\"\n [selectedUsers]=\"controls?.program_assignee?.value | refDisconnect\"\n [groupList]=\"lists?.ASSIGNEES_GROUP ?? []\"\n [FromProgram]=\"true\"\n [selectedGroups]=\"controls?.program_assignee_group?.value | refDisconnect\"\n [disabledIds]=\"disabledAssigneeIds\"\n [fromResponsibility]=\"'Assignee'\"\n [reviewerIds]=\"selectedReviewerIds\"\n [overseerIds]=\"selectedOverseerIds\"\n [assignorId]=\"assignorId\"\n [userListInfo]=\"lists?.ASSIGNEES\"\n (save)=\"listAction($event, 'ASSIGNEE')\"\n (cancel)=\"fieldDeselector('ASSIGNEE')\"\n [panelTitle]=\"panelTitleAssignee\"\n [defaultSelectedUsers]=\"\n controls?.program_default_assignee?.value | refDisconnect\n \"\n [userType]=\"'assignees'\"\n [featureflag]=\"featureflagGroups\"\n>\n</user-group-list>\n<user-group-list\n *ngIf=\"activeList === 'DEFAULT_ASSIGNEE'\"\n [groupEnabled]=\"true\"\n [singleSelect]=\"false\"\n [loading]=\"listLoadingState.USERS\"\n [userlist]=\"lists?.DEFAULT_ASSIGNEES ?? []\"\n [selectedUsers]=\"controls?.program_default_assignee?.value | refDisconnect\"\n [groupList]=\"lists?.DEFAULT_ASSIGNEES_GROUP ?? []\"\n [FromProgram]=\"true\"\n [selectedGroups]=\"\n controls?.program_default_assignee_group?.value | refDisconnect\n \"\n [disabledIds]=\"disabledAssigneeIds\"\n [fromResponsibility]=\"'Assignee'\"\n [reviewerIds]=\"selectedReviewerIds\"\n [overseerIds]=\"selectedOverseerIds\"\n [assignorId]=\"assignorId\"\n [userListInfo]=\"lists?.DEFAULT_ASSIGNEE\"\n (save)=\"listAction($event, 'DEFAULT_ASSIGNEE')\"\n (cancel)=\"fieldDeselector('DEFAULT_ASSIGNEE')\"\n [featureflag]=\"featureflagGroups\"\n>\n</user-group-list>\n\n<user-group-list\n *ngIf=\"activeList === 'REVIEWER' && (!featureflagGroups || featureflagGroups)\"\n [groupEnabled]=\"featureflagGroups\"\n [singleSelect]=\"false\"\n [loading]=\"listLoadingState.USERS\"\n [FromProgram]=\"true\"\n [userlist]=\"lists?.REVIEWERS ?? []\"\n [selectedUsers]=\"controls?.program_reviewer?.value | refDisconnect\"\n [groupList]=\"lists?.REVIEWERS_GROUP ?? []\"\n [featureflag]=\"featureflagGroups\"\n [selectedGroups]=\"controls?.program_reviewer_group?.value | refDisconnect\"\n [disabledIds]=\"disableReviewerIds\"\n [fromResponsibility]=\"'Reviewer'\"\n [assignorId]=\"assignorId\"\n [assigneeIds]=\"selectedAssigneeIds\"\n [overseerIds]=\"selectedOverseerIds\"\n [userListInfo]=\"lists?.REVIEWERS\"\n (save)=\"listAction($event, 'REVIEWER')\"\n (cancel)=\"fieldDeselector('REVIEWER')\"\n [panelTitle]=\"panelTitleReviewer\"\n [defaultSelectedUsers]=\"\n controls?.program_default_reviewer?.value | refDisconnect\n \"\n [userType]=\"'reviewers'\"\n>\n</user-group-list>\n<user-group-list\n *ngIf=\"\n activeList === 'DEFAULT_REVIEWER' &&\n (!featureflagGroups || featureflagGroups)\n \"\n [groupEnabled]=\"featureflagGroups\"\n [singleSelect]=\"false\"\n [loading]=\"listLoadingState.USERS\"\n [FromProgram]=\"true\"\n [userlist]=\"lists?.DEFAULT_REVIEWERS ?? []\"\n [selectedUsers]=\"controls?.program_default_reviewer?.value | refDisconnect\"\n [groupList]=\"lists?.DEFAULT_REVIEWERS_GROUP ?? []\"\n [featureflag]=\"featureflagGroups\"\n [selectedGroups]=\"\n controls?.program_default_reviewer_group?.value | refDisconnect\n \"\n [disabledIds]=\"disableReviewerIds\"\n [fromResponsibility]=\"'Reviewer'\"\n [assignorId]=\"assignorId\"\n [assigneeIds]=\"selectedAssigneeIds\"\n [overseerIds]=\"selectedOverseerIds\"\n [userListInfo]=\"lists?.DEFAULT_REVIEWERS\"\n (save)=\"listAction($event, 'DEFAULT_REVIEWER')\"\n (cancel)=\"fieldDeselector('DEFAULT_REVIEWER')\"\n [panelTitle]=\"panelTitleDefaultReviewer\"\n>\n</user-group-list>\n<user-group-list\n *ngIf=\"activeList === 'OVERSEER' && (!featureflagGroups || featureflagGroups)\"\n [groupEnabled]=\"featureflagGroups\"\n [singleSelect]=\"false\"\n [loading]=\"listLoadingState.USERS\"\n [FromProgram]=\"true\"\n [userlist]=\"lists?.OVERSEERS ?? []\"\n [selectedUsers]=\"controls?.program_overseer?.value | refDisconnect\"\n [groupList]=\"lists?.OVERSEERS_GROUP ?? []\"\n [selectedGroups]=\"controls?.program_overseer_group?.value | refDisconnect\"\n [featureflag]=\"featureflagGroups\"\n [disabledIds]=\"disableOverseerIds\"\n [fromResponsibility]=\"'Overseer'\"\n [assignorId]=\"assignorId\"\n [assigneeIds]=\"selectedAssigneeIds\"\n [reviewerIds]=\"selectedReviewerIds\"\n [userListInfo]=\"lists?.OVERSEES\"\n (save)=\"listAction($event, 'OVERSEER')\"\n (cancel)=\"fieldDeselector('OVERSEER')\"\n [defaultSelectedUsers]=\"\n controls?.program_default_overseer?.value\n | refDisconnect\n | arrayConcat : controls?.program_default_failed_overseer?.value\n \"\n [userType]=\"'overseers'\"\n>\n</user-group-list>\n<user-group-list\n *ngIf=\"\n activeList === 'DEFAULT_OVERSEER' &&\n (!featureflagGroups || featureflagGroups)\n \"\n [groupEnabled]=\"featureflagGroups\"\n [singleSelect]=\"false\"\n [loading]=\"listLoadingState.USERS\"\n [FromProgram]=\"true\"\n [userlist]=\"lists?.DEFAULT_OVERSEERS ?? []\"\n [selectedUsers]=\"controls?.program_default_overseer?.value | refDisconnect\"\n [groupList]=\"lists?.DEFAULT_OVERSEERS_GROUP ?? []\"\n [selectedGroups]=\"\n controls?.program_default_overseer_group?.value | refDisconnect\n \"\n [featureflag]=\"featureflagGroups\"\n [disabledIds]=\"disableOverseerIds\"\n [fromResponsibility]=\"'Overseer'\"\n [assignorId]=\"assignorId\"\n [assigneeIds]=\"selectedAssigneeIds\"\n [reviewerIds]=\"selectedReviewerIds\"\n [userListInfo]=\"lists?.DEFAULT_OVERSEERS\"\n (save)=\"listAction($event, 'DEFAULT_OVERSEER')\"\n (cancel)=\"fieldDeselector('DEFAULT_OVERSEER')\"\n>\n</user-group-list>\n<user-group-list\n *ngIf=\"\n activeList === 'DEFAULT_FAILED_OVERSEER' &&\n (!featureflagGroups || featureflagGroups)\n \"\n [groupEnabled]=\"featureflagGroups\"\n [singleSelect]=\"false\"\n [loading]=\"listLoadingState.USERS\"\n [FromProgram]=\"true\"\n [userlist]=\"lists?.DEFAULT_OVERSEERS ?? []\"\n [selectedUsers]=\"\n controls?.program_default_failed_overseer?.value | refDisconnect\n \"\n [groupList]=\"lists?.DEFAULT_OVERSEERS_GROUP ?? []\"\n [selectedGroups]=\"\n controls?.program_default_failed_overseer_group?.value | refDisconnect\n \"\n [featureflag]=\"featureflagGroups\"\n [disabledIds]=\"disableOverseerIds\"\n [fromResponsibility]=\"'Overseer'\"\n [assignorId]=\"assignorId\"\n [assigneeIds]=\"selectedAssigneeIds\"\n [reviewerIds]=\"selectedReviewerIds\"\n [userListInfo]=\"lists?.DEFAULT_OVERSEERS\"\n (save)=\"listAction($event, 'DEFAULT_FAILED_OVERSEER')\"\n (cancel)=\"fieldDeselector('DEFAULT_FAILED_OVERSEER')\"\n>\n</user-group-list>\n<assessment-picker\n *ngIf=\"activeList === 'ASSESSMENT'\"\n [selectedAssessment]=\"controls?.program_assessments?.value\"\n (cancelAssessment)=\"fieldDeselector('ASSESSMENT')\"\n (onAssessmentSelect)=\"listAction($event, 'ASSESSMENT')\"\n></assessment-picker>\n<app-loader-inline *ngIf=\"loader\"></app-loader-inline>\n<app-smiley-dialog-inline\n *ngIf=\"showSmiley\"\n [message]=\"smileyMessage\"\n [actionButtons]=\"actionButtons\"\n (action)=\"action($event)\"\n (closeSmiley)=\"closeSmiley($event)\"\n>\n</app-smiley-dialog-inline>\n\n<!-- Framework selector -->\n<app-framework-list\n *ngIf=\"activeList === 'FRAMEWORK'\"\n [workflowPage]=\"['FRAMEWORK']\"\n (assignControl)=\"listAction($event, 'FRAMEWORK')\"\n (closeFramework)=\"fieldDeselector('FRAMEWORK')\"\n [previousSelectedValues]=\"{ framework: controls?.framework.value }\"\n (entrustFramework)=\"entrustFramework($event)\"\n [headerText]=\"'Select a framework'\"\n></app-framework-list>\n", 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/padding/padding.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\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.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-top.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\";::ng-deep .workflow-program{display:block;position:relative}::ng-deep .workflow-program .scope-label{background:#747576;border-radius:.125rem;position:relative;z-index:1}::ng-deep .workflow-program .scope-label:before{background:#f1f1f1;content:\"\";position:absolute;top:.5rem;left:7rem;width:20rem;height:1px;z-index:-1}::ng-deep .workflow-program .scope-label:after{background:#f1f1f1;content:\"\";position:absolute;top:.5rem;left:-2.5rem;width:2.5rem;height:1px;z-index:-1}::ng-deep .workflow-program .scope-label .required{position:absolute;top:0;right:-.625rem}::ng-deep .workflow-program .info-icon{position:relative;top:.125rem;cursor:pointer}::ng-deep .workflow-program .date-picker .picker-group{width:calc(50% - .125rem);position:relative}::ng-deep .workflow-program .date-picker .picker-group:focus-within{border-color:#1e5dd3;box-shadow:0 0 5px #1e5dd345}::ng-deep .workflow-program .date-picker .picker-group input{height:2.5rem;border-radius:.25rem;border:1px solid #DBDBDB;background:#fff;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%;padding:0 2rem 0 .75rem;outline:none}::ng-deep .workflow-program .date-picker .picker-group input:focus,::ng-deep .workflow-program .date-picker .picker-group input:hover{border-color:#1e5dd3;box-shadow:0 0 5px #1e5dd345}::ng-deep .workflow-program .date-picker .picker-group input::placeholder{color:#747576;font-size:13px}::ng-deep .workflow-program .date-picker .picker-group input:-ms-input-placeholder{color:#747576;font-size:13px}::ng-deep .workflow-program .date-picker .picker-group input::-ms-input-placeholder{color:#747576;font-size:13px}::ng-deep .workflow-program .date-picker .picker-group i{height:1rem;width:1rem;position:absolute;right:.75rem;top:.625rem;pointer-events:none}::ng-deep .workflow-program .program-type-field{background:#f8f8f8;border:1px solid #dbdbdb;border-radius:4px;height:40px;display:flex;align-items:center;justify-content:space-between;padding:4px;position:relative;z-index:1}::ng-deep .workflow-program .program-type-field .type-item{position:relative}::ng-deep .workflow-program .program-type-field .type-item:first-of-type{width:6.25rem}::ng-deep .workflow-program .program-type-field .type-item:nth-child(2){width:5.75rem}::ng-deep .workflow-program .program-type-field .type-item:nth-child(2).active~.background-glider{transform:translate(6.4375rem);width:5.75rem}::ng-deep .workflow-program .program-type-field .type-item:nth-child(3){width:8.625rem}::ng-deep .workflow-program .program-type-field .type-item:nth-child(3).active~.background-glider{transform:translate(12.375rem);width:8.625rem}::ng-deep .workflow-program .program-type-field .type-item:last-of-type{width:5.25rem}::ng-deep .workflow-program .program-type-field .type-item:last-of-type.active~.background-glider{transform:translate(21.1875rem);width:5.25rem}::ng-deep .workflow-program .program-type-field .type-item button{background:transparent;border:none;border-radius:0;color:#747576;font-size:11px;font-weight:600;text-transform:uppercase;width:100%;height:32px;padding:0 12px;text-align:center}::ng-deep .workflow-program .program-type-field .type-item button.disabled{background:transparent!important;color:#dbdbdb!important;filter:unset!important;opacity:unset!important;pointer-events:none}::ng-deep .workflow-program .program-type-field .type-item .info{color:#1e5dd3;font-size:12px;position:absolute;top:10px;right:12px;cursor:pointer}::ng-deep .workflow-program .program-type-field .type-item.active button{color:#1e5dd3!important}::ng-deep .workflow-program .program-type-field .background-glider{background:#fff;border-radius:4px;box-shadow:0 1px 3px #161b2f26;position:absolute;display:flex;width:6.25rem;height:32px;z-index:-1;transition:.25s ease-out}::ng-deep .workflow-program .vx-form-group .upload-files .file-item{background:#f1f1f1;border:1px solid #dbdbdb;border-radius:.25rem;padding-left:.125rem}::ng-deep .workflow-program .vx-form-group .upload-files .file-item .file-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;max-width:8.5rem}::ng-deep .workflow-program .vx-form-group .upload-files .file-item button.delete-btn{background:transparent;border-radius:0;border:none;border-left:1px solid #dbdbdb;height:1.625rem}::ng-deep .workflow-program .vx-form-group .upload-files button.file-count{background:#1e5dd3;border-radius:.125rem;border:none;color:#fff;font-size:11px;display:flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0;margin:4px 0 0 4px}::ng-deep .workflow-program .vx-form-group .upload-format .radio-group app-cs-radio{height:1.375rem}::ng-deep .workflow-program .vx-form-group .default-selected{background:#fbfbfb;border:1px solid #F1F1F1;border-radius:.25rem;margin-top:.5rem}::ng-deep .workflow-program .vx-form-group .default-selected .selected{border-radius:0;border:none;background:none}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio{border-top:1px solid #F1F1F1}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio{margin-top:0!important}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item span.radio{position:absolute;top:.5rem;left:.75rem}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item span.value{font-size:11px;text-transform:uppercase;padding:.5rem .5rem .5rem 2.25rem;width:100%;display:flex;justify-content:space-between;margin:0;max-width:100%;font-weight:500;color:#707070}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item span.value i{font-size:12px;color:#1e5dd3}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item svg{position:absolute;top:.5rem;left:.75rem}::ng-deep .workflow-program .vx-form-group .selected .custom-text{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;max-height:2.4rem}::ng-deep .workflow-program .vx-form-group .selected button.cross-btn{background:transparent;border-radius:0;border:0;padding:0}::ng-deep .workflow-program .vx-form-group .custom-input{position:relative}::ng-deep .workflow-program .vx-form-group .custom-input input{padding-right:2rem}::ng-deep .workflow-program .vx-form-group .custom-input button.cross-btn{background:transparent;border-radius:0;border:0;position:absolute;top:.875rem;right:.625rem}::ng-deep .workflow-program .vx-form-group button.add-more-btn{background:transparent;border-radius:0;border:none;padding:0}::ng-deep app-popover .wf-action-list ul.action-item .avatar-card .value{text-transform:none!important}::ng-deep app-popover .wf-action-list ul.action-item li file-pill .file-item{background:transparent!important;border:none!important;border-radius:0!important;padding:0!important;margin:0!important}::ng-deep app-popover .wf-action-list ul.action-item li file-pill .file-name{width:100%!important;max-width:100%!important}::ng-deep app-popover .wf-action-list ul.action-item li file-pill button.delete-btn{border:none!important;padding-right:0!important}.disabled{opacity:.4;pointer-events:none;filter:grayscale(1)}.vx-info-card{width:280px;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both;background:#fff;box-shadow:0 3px 6px #1c5bd140;border-radius:4px;position:static;display:block;left:780}.vx-info-card-body{font-size:12px;padding:8px 12px;margin:0;font-weight:400;text-transform:none;color:#747576}\n", "@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\";::-webkit-scrollbar-track{background-color:#f1f1f1;position:absolute}::-webkit-scrollbar{width:3px;height:3px;background-color:transparent;position:absolute}::-webkit-scrollbar-thumb{border-radius:3px;background-color:#dbdbdb;position:absolute}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}button{font-family:Poppins,sans-serif}::ng-deep input.textField{background:#fff;border-radius:.25rem;border:1px solid #dbdbdb;font-size:13px;color:#747576;padding:8px 12px;position:relative;height:2.5rem;width:100%;transition:all .2s ease-in-out}::ng-deep input.textField::placeholder{font-size:13px;color:#747576}::ng-deep input.textField:hover,::ng-deep input.textField:focus{outline:none;border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .selectBoxEnable{background:#fff;border-radius:.25rem;border:1px solid #dbdbdb;cursor:pointer;height:2.5rem;position:relative;transition:all .2s ease-in-out}::ng-deep .selectBoxEnable:after{border-bottom-style:solid;border-bottom-width:1px;border-right-style:solid;border-right-width:1px;border-color:#747576;content:\"\";display:inline-block;right:12px;position:absolute;top:calc(50% - 4px);width:5px;height:5px;transform:rotate(45deg)}::ng-deep .selectBoxEnable:hover,::ng-deep .selectBoxEnable:focus{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .selectBoxEnable.disabled{background:#f1f1f1;pointer-events:none;opacity:1}::ng-deep .selectBoxEnable.withBtn:after{display:none}::ng-deep .selectBoxEnable.withBtn button.setBtn{background:transparent;border-radius:0;border:none;min-width:98px}::ng-deep .selectBoxSuccess{background:#f8f8f8;border-radius:.25rem;border:1px solid #f1f1f1;min-height:2.5rem;position:relative}::ng-deep .selectBoxSuccess .selectBoxText{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;width:22rem}::ng-deep .selectBoxSuccess button{background:transparent;border-radius:0;border:none}::ng-deep .selectBoxSuccess button.deleteBtn{color:#d93b41}::ng-deep .selectBoxSuccess .level-left{border-right:1px solid #f1f1f1;height:2.375rem;width:5rem}::ng-deep .selectBoxSuccess .level-left .level-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;width:4.5rem}::ng-deep .chipContainer{background:#fff;border-radius:.125rem;box-shadow:0 0 2px #1e5dd340;height:1.5rem}::ng-deep .chipContainer .cross{cursor:pointer;min-width:16px;width:16px;height:16px;display:flex;align-items:center;justify-content:center;background:transparent;border-radius:2px;margin-left:-4px}::ng-deep .chipContainer .cross:hover{background:#f1f1f1}::ng-deep .chipContainer .chipName{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;max-width:6rem}::ng-deep .chipContainer .chipName.no-width{max-width:unset}::ng-deep .chipContainer .chipName.full-width{max-width:25rem}::ng-deep .chipContainer button.countBtn{background:#1e5dd3;border-radius:1.25rem;border:none;min-width:1.5rem;height:1rem;margin:0 0 0 .5rem;padding:0 .25rem}::ng-deep .chipContainer button.countBtn.greenBg{background:#34aa44}::ng-deep .workflowLavel{background:#f1f1f1;border-radius:.125rem;color:#042e7d;min-width:1rem;height:1rem}::ng-deep .reviewSelection{border-radius:.25rem;border:1px solid #dbdbdb;transition:all .2s ease-in-out}::ng-deep .reviewSelection:hover{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .selectButton{background:#fff;border-radius:.25rem;border:1px solid #dbdbdb;cursor:pointer;height:2.5rem;position:relative;transition:all .2s ease-in-out}::ng-deep .selectButton:hover,::ng-deep .selectButton:focus{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep button.createNewBtn{background:transparent;border-radius:0;border:none}::ng-deep .vx-form-group{display:block;position:relative;margin-bottom:20px}::ng-deep .vx-form-group:after{content:\"\";display:block;clear:both}::ng-deep .vx-form-group .select{position:relative}::ng-deep .vx-form-group .select:after{border-bottom-style:solid;border-bottom-width:1px;border-right-style:solid;border-right-width:1px;border-color:#707070;content:\"\";display:inline-block;right:12px;position:absolute;top:calc(50% - 4px);width:5px;height:5px;transform:rotate(45deg)}::ng-deep .vx-form-group .select input{cursor:pointer;padding-right:30px!important}::ng-deep .vx-form-group .select .custom-input{height:40px;border-radius:4px;border:1px solid #dbdbdb;background:#fff;outline:none;padding:3px 12px;line-height:16px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%;cursor:pointer}::ng-deep .vx-form-group .select .custom-input:empty:not(:focus):before{content:attr(aria-placeholder);line-height:16px;font-size:13px;width:94%;display:block;pointer-events:none;opacity:.8}::ng-deep .vx-form-group .select .custom-input:hover{border-color:#1e5dd3;box-shadow:0 0 5px #1e5dd345}::ng-deep .vx-form-group .select .custom-input.frequency-custom-input{padding-right:108px;display:flex;align-items:center}::ng-deep .vx-form-group .select+app-cs-switch{display:block;margin-top:8px}::ng-deep .vx-form-group .select+app-cs-switch label.cs-switch span.value{white-space:nowrap;margin-right:5px;text-transform:uppercase}::ng-deep .vx-form-group .select+app-cs-radio{margin-top:8px!important}::ng-deep .vx-form-group .select~app-cs-radio{margin-top:4px;display:block;width:100%}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item span.radio{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item span.value{font-size:11px;text-transform:uppercase;border:1px solid #dbdbdb;border-radius:4px;padding:8px 8px 8px 36px;width:100%;display:flex;justify-content:space-between;margin:0;max-width:100%;font-weight:500;color:#707070}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item span.value i{font-size:12px;color:#1e5dd3}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item svg{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item input:checked~span.value{background:#eefcf0;border-color:#34aa44}::ng-deep .vx-form-group .select.button-sec:after{display:none}::ng-deep .vx-form-group .select.button-sec button{background:transparent;border:none;display:inline-flex;float:right;color:#1e5dd3;text-transform:uppercase;font-weight:600;cursor:pointer;font-size:11px;position:absolute;top:12px;right:8px;padding:0;margin:0}::ng-deep .vx-form-group .select+.vx-control-panel{margin-top:8px}::ng-deep .vx-form-group .select+.selected{margin-top:8px}::ng-deep .vx-form-group .select.select{margin-top:8px}::ng-deep .vx-form-group .upload-format{border:1px solid #dbdbdb;border-radius:4px;padding:8px 12px;display:block}::ng-deep .vx-form-group .upload-format span.text{line-height:20px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%;display:block;margin-bottom:6px}::ng-deep .vx-form-group .upload-format .radio-group{display:flex}::ng-deep .vx-form-group .upload-format .radio-group app-cs-radio{display:inline-block}::ng-deep .vx-form-group .upload-format .radio-group app-cs-radio label.radio-item span.value{font-size:11px;text-transform:uppercase;margin-left:8px}::ng-deep .vx-form-group .upload-format .radio-group app-cs-radio+app-cs-radio{margin-left:12px}::ng-deep .vx-form-group .upload-format~.upload-format{margin-top:4px}::ng-deep .vx-form-group .form-tab{display:flex;justify-content:flex-start}::ng-deep .vx-form-group .form-tab button{background:transparent;color:#161b2f;font-size:11px;line-height:16px;text-transform:uppercase;cursor:pointer;padding:8px 8px 8px 0;border:none;outline:none;font-weight:500}::ng-deep .vx-form-group .form-tab button:disabled{opacity:.5;pointer-events:none;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group .form-tab button+button{padding:8px}::ng-deep .vx-form-group .form-tab button.active{color:#1e5dd3}::ng-deep .vx-form-group .tab-group{border:1px solid #dbdbdb;border-radius:4px;padding:0;display:block;position:relative;transition:all .2s ease-in-out}::ng-deep .vx-form-group .tab-group:hover{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .vx-form-group .tab-group .upload-file{padding:16px 62px 16px 24px;display:flex;align-items:center;justify-content:space-between}::ng-deep .vx-form-group .tab-group .upload-file .image{width:80px}::ng-deep .vx-form-group .tab-group .upload-file .browse span{display:inline-block;font-size:12px;color:#747576;line-height:16px;padding:0 4px}::ng-deep .vx-form-group .tab-group .upload-file .browse .label{font-size:11px;color:#1e5dd3;line-height:16px;font-weight:600;text-transform:uppercase;margin:0;padding:0}::ng-deep .vx-form-group .tab-group .upload-file .browse .label input{opacity:0;position:absolute;margin:0;padding:0;inset:0;cursor:pointer;width:100%}::ng-deep .vx-form-group .tab-group.active{border-color:#1e5dd3}::ng-deep .vx-form-group .tab-group.uploaded{margin-top:4px}::ng-deep .vx-form-group .tab-group.uploaded .upload-file{padding:8px 0!important;text-align:center}::ng-deep .vx-form-group .tab-group.uploaded .upload-file .image{display:none}::ng-deep .vx-form-group .tab-group.uploaded .upload-file .browse{width:100%;text-align:center}::ng-deep .vx-form-group .tab-group+label.vx-form-group{margin-top:8px;margin-bottom:4px}::ng-deep .vx-form-group .file-list{background:#fbfbfb;border:1px solid #f1f1f1;border-radius:4px;padding:12px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;position:relative}::ng-deep .vx-form-group .file-list span.file-name{color:#747576;line-height:16px;font-size:11px;font-weight:400;cursor:pointer;max-width:calc(100% - 20px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}::ng-deep .vx-form-group .file-list .button-group{display:flex}::ng-deep .vx-form-group .file-list button{font-size:12px;color:#eb2424;cursor:pointer;display:flex;padding:0;border:none;outline:none;background:transparent}::ng-deep .vx-form-group .file-list button.edit{color:#1e5dd3}::ng-deep .vx-form-group .file-list button+button{margin-left:16px}::ng-deep .vx-form-group .file-list+.file-list{margin-top:4px}::ng-deep .vx-form-group .file-list .file-container{display:flex;justify-content:space-between;width:100%}::ng-deep .vx-form-group .file-list.policy{background:#fff}::ng-deep .vx-form-group .file-list cs-select{position:relative;margin-top:8px;width:100%}::ng-deep .vx-form-group .file-list cs-select .selection-wrap .input-group input.value{height:32px!important;font-size:13px!important}::ng-deep .vx-form-group .file-list cs-select .selection-wrap .input-group i{right:12px!important;top:12px!important}::ng-deep .vx-form-group .file-list app-line-loader{display:block;position:absolute;left:10px;right:10px;bottom:0}::ng-deep .vx-form-group label.vx-control-panel{color:#161b2f;font-size:11px;font-weight:500;line-height:16px;margin-bottom:8px;display:block;text-transform:uppercase;text-align:left}::ng-deep .vx-form-group label.vx-control-panel.custom-tag{font-size:10px}::ng-deep .vx-form-group label.vx-control-panel.vx-mt-8{margin-top:8px}::ng-deep .vx-form-group label.vx-control-panel span.required{color:#eb2424;font-size:14px;font-weight:500;position:relative;top:-2px}::ng-deep .vx-form-group label.vx-control-panel .button{background:transparent;border:none;display:inline-flex;float:right;color:#1e5dd3;text-transform:uppercase;font-weight:600;cursor:pointer;font-size:11px;padding:0;margin:0}::ng-deep .vx-form-group label.vx-control-panel app-cs-switch{float:right;display:block}::ng-deep .vx-form-group label.vx-control-panel i{margin-left:8px;font-size:12px;color:#1e5dd3;cursor:pointer;position:relative;top:1px}::ng-deep .vx-form-group label.vx-control-panel i.depreciation-icon{color:#e4b700;font-size:16px;position:relative;top:3px}::ng-deep .vx-form-group label.vx-control-panel .checkpoint-version{background:#f1f1f1;border-radius:2px;color:#042e7d;font-size:10px;font-weight:600;line-height:14px;margin-left:4px;padding:0 2px}::ng-deep .vx-form-group input[type=text],::ng-deep .vx-form-group .input{height:40px;border-radius:4px;border:1px solid #dbdbdb;background:#fff;outline:none;padding:8px 12px;line-height:20px;font-size:13px;color:#747576;transition:all .2s ease-in-out;width:100%;font-weight:400}::ng-deep .vx-form-group input[type=text]::placeholder,::ng-deep .vx-form-group .input::placeholder{color:#747576;font-weight:400}::ng-deep .vx-form-group input[type=text]:focus,::ng-deep .vx-form-group .input:focus,::ng-deep .vx-form-group input[type=text]:hover,::ng-deep .vx-form-group .input:hover{border-color:#1e5dd3!important;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .vx-form-group input[type=text].error,::ng-deep .vx-form-group .input.error{border-color:#eb2424;color:#eb2424;margin-bottom:4px}::ng-deep .vx-form-group input[type=text].error:focus,::ng-deep .vx-form-group .input.error:focus{box-shadow:0 0 5px #d31e1e45}::ng-deep .vx-form-group input[type=text]:disabled,::ng-deep .vx-form-group .input:disabled{background:#f1f1f1;cursor:not-allowed;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group input[type=text]:disabled:hover,::ng-deep .vx-form-group .input:disabled:hover{border-color:#dbdbdb;box-shadow:none}::ng-deep .vx-form-group input[type=text] span.text,::ng-deep .vx-form-group .input span.text{font-size:13px;color:#747576;font-weight:400;display:block;width:100%}::ng-deep .vx-form-group input[type=text] .input-group,::ng-deep .vx-form-group .input .input-group{display:flex;align-items:center}::ng-deep .vx-form-group input[type=text] .input-group.counter,::ng-deep .vx-form-group .input .input-group.counter{min-width:96px;width:96px}::ng-deep .vx-form-group input[type=text] .input-group.counter button,::ng-deep .vx-form-group .input .input-group.counter button{height:24px;width:24px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#747576;font-size:8px;cursor:pointer;outline:none}::ng-deep .vx-form-group input[type=text] .input-group.counter input,::ng-deep .vx-form-group .input .input-group.counter input{-webkit-appearance:textfield;-moz-appearance:textfield;height:24px;width:calc(100% - 48px);border:1px solid #f1f1f1;outline:none;padding:0 6px;text-align:center}::ng-deep .vx-form-group input[type=text] .input-group.counter input::-webkit-inner-spin-button,::ng-deep .vx-form-group .input .input-group.counter input::-webkit-inner-spin-button,::ng-deep .vx-form-group input[type=text] .input-group.counter input::-webkit-outer-spin-button,::ng-deep .vx-form-group .input .input-group.counter input::-webkit-outer-spin-button{appearance:none;margin:0}::ng-deep .vx-form-group input[type=text]+.file-list,::ng-deep .vx-form-group .input+.file-list{margin-top:8px}::ng-deep .vx-form-group input[type=text]::placeholder,::ng-deep .vx-form-group .input::placeholder{font-size:13px}::ng-deep .vx-form-group input[type=text]:-ms-input-placeholder,::ng-deep .vx-form-group .input:-ms-input-placeholder{font-size:13px}::ng-deep .vx-form-group input[type=text]::-ms-input-placeholder,::ng-deep .vx-form-group .input::-ms-input-placeholder{font-size:13px}::ng-deep .vx-form-group .classification{height:40px;border-radius:4px;border:1px solid #dbdbdb;background:#fff;padding:8px 12px;display:flex;justify-content:space-between}::ng-deep .vx-form-group .classification label{margin:0 4px 0 0;width:100%;position:relative;z-index:1}::ng-deep .vx-form-group .classification label span{display:block;width:100%;height:24px;border:1px solid #f1f1f1;border-radius:2px;line-height:24px;font-size:10px;text-align:center;color:#747576;font-weight:500;position:relative;text-transform:uppercase}::ng-deep .vx-form-group .classification label span:before{height:2px;content:\"\";top:0;right:0;left:0;border-radius:2px;position:absolute;transition:all .2s ease-in-out}::ng-deep .vx-form-group .classification label input{opacity:0;position:absolute;inset:0;margin:0;padding:0;width:100%;height:100%;cursor:pointer;z-index:1}::ng-deep .vx-form-group .classification label input:checked+span{color:#fff}::ng-deep .vx-form-group .classification label input:checked+span:before{bottom:0;height:100%;z-index:-1}::ng-deep .vx-form-group .classification label.low span:before{background:#34aa44}::ng-deep .vx-form-group .classification label.low-med span:before{background:#f2bf19}::ng-deep .vx-form-group .classification label.med-high span:before{background:#f29619}::ng-deep .vx-form-group .classification label.high span:before{background:#eb2424}::ng-deep .vx-form-group .classification label:last-of-type{margin-right:0}::ng-deep .vx-form-group .input{display:flex;align-items:center}::ng-deep .vx-form-group .selected{height:40px;border-radius:4px;border:1px solid #f1f1f1;background:#fbfbfb;outline:none;padding:8px;line-height:20px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%;display:flex;align-items:center;position:relative;justify-content:space-between}::ng-deep .vx-form-group .selected.first-field{z-index:2}::ng-deep .vx-form-group .selected .chip-container{display:flex;width:calc(100% - 60px);align-items:center}::ng-deep .vx-form-group .selected .chip-container.checkpoints{width:calc(100% - 120px)}::ng-deep .vx-form-group .selected .chip-container span.chip{background:#fff;border-radius:2px;box-shadow:0 0 3px #1e5dd31a;height:24px;padding:0 8px;color:#1e5dd3;font-size:12px;display:block;width:auto;max-width:100%;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:24px}::ng-deep .vx-form-group .selected .chip-container span.chip.disabled{background:#f1f1f1;box-shadow:none;color:#747576;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group .selected .chip-container span.chip i{font-weight:400;margin-right:8px;cursor:pointer;font-size:10px;position:relative;top:1px}::ng-deep .vx-form-group .selected .chip-container span.chip span.step{background:#1e5dd3;border-radius:2px;color:#fff;font-size:9px;line-height:14px;padding:0 4px;font-weight:400;text-align:center;min-width:auto;margin-right:4px}::ng-deep .vx-form-group .selected .chip-container span.chip+span.chip{margin-left:4px}::ng-deep .vx-form-group .selected .chip-container span.chip.with-question{display:flex;align-items:center;justify-content:space-between;width:100%}::ng-deep .vx-form-group .selected .chip-container span.chip.with-question span.value{color:#1e5dd3;font-size:12px;font-weight:400;line-height:24px;padding:0;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;max-width:calc(100% - 80px)}::ng-deep .vx-form-group .selected .chip-container span.chip.with-question span.label{background:#f1f1f1;border-radius:2px;color:#042e7d;font-size:9px;font-weight:600;text-transform:uppercase;padding-left:4px;padding-right:4px;line-height:12px;margin-left:8px}::ng-deep .vx-form-group .selected .chip-container span.value{color:#747576;font-size:13px;line-height:20px;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:calc(100% - 52px);padding:0 4px}::ng-deep .vx-form-group .selected .chip-container span.checkpoint-point-text{color:#747576;font-size:10px;font-weight:500;padding:0 8px;width:122px;line-height:14px}::ng-deep .vx-form-group .selected .chip-container span.checkpoint-point-text.first{position:relative;min-width:162px}::ng-deep .vx-form-group .selected .chip-container span.checkpoint-point-text.first:before{background:#f1f1f1;content:\"\";position:absolute;top:0;right:0;height:calc(100% + 12px);width:1px}::ng-deep .vx-form-group .selected .chip-container span.checkpoint-point-text .no{color:#1e5dd3}::ng-deep .vx-form-group .selected .chip-container.plus span.chip{max-width:calc(50% - 35px)}::ng-deep .vx-form-group .selected .chip-container.more-one span.chip{max-width:50%}::ng-deep .vx-form-group .selected .chip-container .chip-inner{background:#fff;border-radius:2px;box-shadow:0 2px 4px #1e5dd31a;line-height:24px;padding:0 4px 0 8px;display:flex;align-items:center}::ng-deep .vx-form-group .selected .chip-container .chip-inner .chip{background:transparent;border-radius:0;box-shadow:none;height:auto;line-height:unset;padding:0;color:#747576;max-width:100px}::ng-deep .vx-form-group .selected .chip-container .chip-inner button.count{border-radius:20px;height:16px;padding:0 6px;border:none;font-size:9px;line-height:16px;margin-left:4px;min-width:20px}::ng-deep .vx-form-group .selected .chip-container .chip-inner button.count.user{background:#34aa44}::ng-deep .vx-form-group .selected .chip-container .chip-inner i.cross{cursor:pointer;position:relative;top:1px;font-size:8px}::ng-deep .vx-form-group .selected button.count{background:#1e5dd3;border-radius:2px;height:24px;padding:0 8px;border:1px solid #1e5dd3;cursor:pointer;outline:none;color:#fff;font:13px;font-weight:500;line-height:20px;white-space:nowrap;margin-left:8px}::ng-deep .vx-form-group .selected button.edit{border:none;border-radius:0;background:transparent;outline:none;cursor:pointer;display:block;font-size:11px;font-weight:600;color:#1e5dd3;text-transform:uppercase;white-space:nowrap;margin-left:8px}::ng-deep .vx-form-group .selected button.edit i{font-weight:400;font-size:8px;margin-right:4px}::ng-deep .vx-form-group .selected button.close-btn{background:transparent;border:none;padding:0;margin-left:8px;font-size:10px;color:#c7381b;display:flex;align-items:center}::ng-deep .vx-form-group .selected .workflow-label{min-width:92px;padding:4px;text-align:center;margin-left:-8px;margin-right:8px;border-right:1px solid #f1f1f1}::ng-deep .vx-form-group .selected .workflow-label p{margin:0;display:block;text-transform:uppercase}::ng-deep .vx-form-group .selected .workflow-label p.title{font-size:9px;line-height:12px;color:#161b2f;font-weight:500}::ng-deep .vx-form-group .selected .workflow-label p.description{font-size:11px;line-height:16px;color:#161b2f;font-weight:600}::ng-deep .vx-form-group .selected .workflow-label+.chip-container{width:calc(100% - 148px)}::ng-deep .vx-form-group .selected+.selected{margin-top:8px}::ng-deep .vx-form-group .selected+app-cs-switch{display:block;margin-top:8px}::ng-deep .vx-form-group .selected+app-cs-switch label.cs-switch span.value{white-space:nowrap;margin-right:5px;text-transform:uppercase}::ng-deep .vx-form-group .selected+app-cs-switch.who-toggle label.cs-switch span.value{color:#747576}::ng-deep .vx-form-group .selected+app-cs-radio{margin-top:8px!important}::ng-deep .vx-form-group .selected~app-cs-radio{margin-top:4px;display:block;width:100%}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item span.radio{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item span.value{font-size:11px;text-transform:uppercase;border:1px solid #dbdbdb;border-radius:4px;padding:8px 8px 8px 36px;width:100%;display:flex;justify-content:space-between;margin:0;max-width:100%;font-weight:500;color:#707070}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item span.value i{font-size:12px;color:#1e5dd3}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item svg{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item input:checked~span.value{background:#eefcf0;border-color:#34aa44}::ng-deep .vx-form-group .selected.readOnly{pointer-events:none}::ng-deep .vx-form-group .selected span.chip{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .vx-form-group .select-list{position:absolute;background:#fff;box-shadow:0 0 5px #1e5dd345;top:100%;right:0;left:0;z-index:2}::ng-deep .vx-form-group .select-list .vx-radio-group label.vx-radio-item{width:100%;padding:12px 16px}::ng-deep .vx-form-group .select-list .vx-radio-group label.vx-radio-item:hover{background:#f8f8f8}::ng-deep .vx-form-group ::ng-deep vcomply-editor{margin-top:8px;display:block;pointer-events:auto!important;z-index:1}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container{border-radius:4px;border:1px solid #dbdbdb}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block{min-height:60px;padding:11px 15px;max-height:100px;line-height:20px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block ul{padding:0 0 0 10px;margin-top:0}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block ul li{list-style:disc}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block ol{padding:0 0 0 10px;margin-top:0}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block ol li{list-style:decimal}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools{z-index:1;border-top:1px solid #dbdbdb;transition:none;border-radius:0 0 3px 3px;position:static}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button{height:22px!important;width:22px!important;padding:0 5px}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button svg{height:22px;width:12px}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button.submit{width:80px!important;line-height:22px;justify-content:center}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col .popover.small ul.option-list li button{width:100%!important;height:auto!important}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container:focus-within{border-color:#1e5dd3!important;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container:focus-within .editor-tools{border-color:#1e5dd3!important}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container:hover{border-color:#1e5dd3!important;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container:hover .editor-tools{border-color:#1e5dd3!important}::ng-deep .vx-form-group ::ng-deep vcomply-editor+app-cs-switch{margin-top:8px}::ng-deep .vx-form-group app-cs-switch label.cs-switch span.value{font-size:11px;color:#747576;text-transform:uppercase}::ng-deep .vx-form-group app-cs-switch+app-cs-switch{margin-top:8px}::ng-deep .vx-form-group .date-time-picker{display:flex;justify-content:space-between;height:40px;border-radius:4px;border:1px solid #dbdbdb;padding:11px 0;background:#fff}::ng-deep .vx-form-group .date-time-picker:focus-within{border-color:#1e5dd3;box-shadow:0 0 5px #1e5dd345}::ng-deep .vx-form-group .date-time-picker .picker-group{width:50%;position:relative;display:flex;align-items:center}::ng-deep .vx-form-group .date-time-picker .picker-group:first-of-type{border-right:1px solid #dbdbdb}::ng-deep .vx-form-group .date-time-picker .picker-group:only-of-type{border:none;width:100%}::ng-deep .vx-form-group .date-time-picker .picker-group input{height:38px;background:transparent;line-height:38px;font-size:13px;color:#747576;transition:all .2s ease-in-out;width:100%;font-weight:400;border:none;padding:0 12px 0 34px;outline:none}::ng-deep .vx-form-group .date-time-picker .picker-group input:focus,::ng-deep .vx-form-group .date-time-picker .picker-group input:hover{box-shadow:none;border:none}::ng-deep .vx-form-group .date-time-picker .picker-group input::placeholder{color:#999;font-size:13px}::ng-deep .vx-form-group .date-time-picker .picker-group input:-ms-input-placeholder{color:#999;font-size:13px}::ng-deep .vx-form-group .date-time-picker .picker-group input::-ms-input-placeholder{color:#999;font-size:13px}::ng-deep .vx-form-group .date-time-picker .picker-group i{display:flex;justify-content:center;align-items:center;height:16px;width:12px;position:absolute;left:12px;top:0;color:#747576;font-size:12px;pointer-events:none}::ng-deep .vx-form-group app-cs-radio.main-filed{margin-top:4px;display:block;width:100%}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item{width:100%;position:relative}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item span.radio{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item span.value{font-size:11px;text-transform:uppercase;border:1px solid #dbdbdb;border-radius:4px;padding:8px 8px 8px 36px;width:100%;display:flex;justify-content:space-between;margin:0;max-width:100%;color:#707070}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item span.value i{font-size:12px;color:#1e5dd3}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item svg{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item input:checked~span.value{background:#eefcf0;border-color:#34aa44}::ng-deep .vx-form-group app-cs-radio.disabled{pointer-events:none;opacity:.5;filter:grayscale(1);background:#f1f1f1}::ng-deep .vx-form-group .switch-row{display:flex}::ng-deep .vx-form-group .switch-row app-cs-switch{display:block;margin-top:8px}::ng-deep .vx-form-group .switch-row app-cs-switch label.cs-switch span.value{white-space:nowrap;margin-right:0;text-transform:uppercase;color:#747576!important}::ng-deep .vx-form-group .switch-row app-cs-switch label.cs-switch span.value i{display:inline-flex;font-size:11px;cursor:pointer;color:#1e5dd3;align-items:center;line-height:16px;margin:0 4px}::ng-deep .vx-form-group .switch-row app-cs-switch+app-cs-switch{margin-left:8px}::ng-deep .vx-form-group .switch-row.align-right{justify-content:flex-end}::ng-deep .vx-form-group .switch-row.align-right label.cs-switch span.value{margin-right:8px}::ng-deep .vx-form-group .risk-type-field{background:#f8f8f8;border:1px solid #dbdbdb;border-radius:4px;height:40px;display:flex;align-items:center;padding:4px;position:relative;z-index:1}::ng-deep .vx-form-group .risk-type-field .type-item{width:50%;position:relative}::ng-deep .vx-form-group .risk-type-field .type-item button{background:transparent;border:none;border-radius:0;color:#747576;font-size:11px;font-weight:600;text-transform:uppercase;width:100%;height:32px;padding:0 12px;text-align:left}::ng-deep .vx-form-group .risk-type-field .type-item button.disabled{background:transparent!important;color:#dbdbdb!important;filter:unset!important;opacity:unset!important;pointer-events:none;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group .risk-type-field .type-item .info{color:#1e5dd3;font-size:12px;position:absolute;top:10px;right:12px;cursor:pointer}::ng-deep .vx-form-group .risk-type-field .type-item .info.disabled{background:transparent!important;color:#dbdbdb!important;filter:unset!important;opacity:unset!important;pointer-events:none;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group .risk-type-field .type-item.active button{color:#1e5dd3!important}::ng-deep .vx-form-group .risk-type-field .type-item:nth-child(2).active~.background-glider{transform:translate(100%)}::ng-deep .vx-form-group .risk-type-field .background-glider{background:#fff;border-radius:4px;box-shadow:0 1px 3px #161b2f26;position:absolute;display:flex;width:212px;height:32px;z-index:-1;transition:.25s ease-out}.left{width:36px;height:36px;margin-top:26px;margin-left:-58px;margin-right:20px;display:flex;justify-content:center;align-items:center;position:relative;z-index:10;border-radius:50%}.left.deadline-completed{margin-top:18px}.left.checked{background:transparent}.left img{width:36px}.left .checkIcon{width:32px;height:32px;background:#fff;border-radius:50%;stroke-width:4;stroke:#34aa44;stroke-miterlimit:10;box-shadow:inset 0 0 #34aa44;animation:fillCheck .4s ease-in-out .4s forwards,scale .3s ease-in-out .9s both;margin-top:0}.left .checkIcon__circle{stroke-dasharray:166;stroke-dashoffset:166;stroke-width:2;stroke-miterlimit:10;stroke:#34aa44;fill:none;animation:strokeCheck .6s cubic-bezier(.65,0,.45,1) forwards}.left .checkIcon__check{transform-origin:50% 50%;stroke-dasharray:48;stroke-dashoffset:48;animation:strokeCheck .3s cubic-bezier(.65,0,.45,1) .8s forwards}.right{width:100%}.right span.indicator{position:absolute;top:36px;left:-16px;font-size:12px;color:#f0b819;cursor:pointer}.form-group-row{display:flex;position:relative;transition:all .2s ease-in-out}.form-group-row.disabled{-webkit-user-select:none;user-select:none;pointer-events:none;filter:grayscale(1);z-index:2}.form-group-row.disabled .left{position:relative}.form-group-row.disabled .left:before{content:\"\";position:absolute;inset:2px 0 0 2px;background:#fff;opacity:.7;border-radius:50%;width:32px;height:32px}.form-group-row.disabled .right{opacity:.3}.form-group-row.active{pointer-events:none;filter:grayscale(0);z-index:2;opacity:1}.form-group-row.active .right .vx-form-group input,.form-group-row.active .right .vx-form-group .custom-input,.form-group-row.active .right .vx-form-group .selectBoxEnable{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}.form-group-row.active .right .vx-form-group .selectBoxEnable.disabled{border-color:#dbdbdb;box-shadow:none}::ng-deep .radio-group-selector app-cs-radio{margin-top:4px;display:block;width:100%}::ng-deep .radio-group-selector app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .radio-group-selector app-cs-radio label.radio-item .radio,::ng-deep .radio-group-selector app-cs-radio label.radio-item .radiomark{position:absolute!important;top:9px;left:12px}::ng-deep .radio-group-selector app-cs-radio label.radio-item .value{font-size:11px!important;text-transform:uppercase;border:1px solid #dbdbdb;border-radius:4px;padding:8px 8px 8px 36px;width:100%;display:flex;justify-content:space-between;margin:0!important;max-width:100%!important;font-weight:500!important;color:#707070!important}::ng-deep .radio-group-selector app-cs-radio label.radio-item .value i{font-size:12px;color:#1e5dd3}::ng-deep .radio-group-selector app-cs-radio label.radio-item input:checked~span.value{background:#eefcf0;border-color:#34aa44}@keyframes strokeCheck{to{stroke-dashoffset:0}}@keyframes fillCheck{to{box-shadow:inset 0 0 0 2px #34aa44}}::ng-deep .wf-action-list{width:220px}::ng-deep .wf-action-list ul{padding:0;margin:0;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both;background:#fff;box-shadow:0 3px 6px #1c5bd140;border-radius:4px;max-height:220px;overflow:auto}::ng-deep .wf-action-list ul.action-item{display:block}::ng-deep .wf-action-list ul.action-item li{list-style:none;border:none;border-bottom:1px solid #f1f1f1;display:block;width:100%;padding:0;background:transparent;border-radius:0;margin:0;height:auto;justify-content:flex-start;box-shadow:none}::ng-deep .wf-action-list ul.action-item li button{color:#6e717e;text-align:left;text-decoration:none;cursor:pointer;background:transparent;font-size:12px;text-transform:capitalize;display:flex;width:100%;padding:7.5px 11px;border:none}::ng-deep .wf-action-list ul.action-item li button i{font-size:16px;margin-right:10px;color:#1e5dd3}::ng-deep .wf-action-list ul.action-item li button:hover{background:#f3f3f3}::ng-deep .wf-action-list ul.action-item li .avatar-card{display:flex;align-items:center;width:100%;padding:7.5px}::ng-deep .wf-action-list ul.action-item li .avatar-card.within-con{display:block}::ng-deep .wf-action-list ul.action-item li .avatar-card .avatar{height:24px;width:24px!important;overflow:hidden;background:#1e5dd3;color:#fff;font-size:10px;display:inline-flex;margin-right:5px;border-radius:50%;align-items:center;justify-content:center;text-transform:uppercase}::ng-deep .wf-action-list ul.action-item li .avatar-card .avatar img{width:100%}::ng-deep .wf-action-list ul.action-item li .avatar-card .avatar+span.value{width:calc(100% - 29px)}::ng-deep .wf-action-list ul.action-item li .avatar-card span.value{width:100%;color:#6e717e;text-decoration:none;background:transparent;font-size:12px;text-transform:capitalize;display:block;font-weight:400;text-align-last:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:20px}::ng-deep .wf-action-list ul.action-item li .avatar-card span.value i{font-size:8px;color:#747576;cursor:pointer;margin-right:5px}::ng-deep .wf-action-list ul.action-item li .avatar-card.no-image{display:block}::ng-deep .wf-action-list ul.action-item li .avatar-card.no-image span.value{width:100%;display:block}::ng-deep .wf-action-list ul.action-item li .chip-item{color:#1e5dd3;padding:10px;display:flex;align-items:center}::ng-deep .wf-action-list ul.action-item li .chip-item i{color:#747576;margin-right:7px;font-size:10px;cursor:pointer;display:inline-flex}::ng-deep .wf-action-list ul.action-item li .chip-item span{display:block;width:auto;max-width:calc(100% - 17px);font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}::ng-deep .wf-action-list ul.action-item li .chip-item span.chip-block{display:block;width:100%}::ng-deep .wf-action-list ul.action-item li .chip-item span.id{font-size:9px}::ng-deep .wf-action-list ul.action-item li .within{display:flex;align-items:center;justify-content:flex-start}::ng-deep .wf-action-list ul.action-item li .within .block{background:#f1f1f1;border-radius:2px;padding:0 2px;line-height:14px;font-size:9px;font-weight:500;color:#042e7d;margin-right:6px;display:block;text-transform:uppercase}::ng-deep .wf-action-list ul.action-item li .within .data{width:100%;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#747576;font-size:11px;font-weight:400;line-height:17px}::ng-deep .wf-action-list ul.action-item li:first-child{animation:action-list-open .25s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(2){animation:action-list-open .35s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(3){animation:action-list-open .45s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(4){animation:action-list-open .55s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(5){animation:action-list-open .65s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(6){animation:action-list-open .75s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(7){animation:action-list-open .85s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(8){animation:action-list-open .95s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(9){animation:action-list-open 1.05s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(10){animation:action-list-open 1.15s cubic-bezier(.25,.46,.45,.94) both}@keyframes action-list-open{0%{transform:translateY(50px)}to{transform:translateY(0)}}@keyframes scale-up-center{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}p.error-message{font-size:11px;font-weight:400;color:#eb2424;line-height:16px;margin-top:8px;margin-bottom:0}.edit-loader{position:absolute;top:-3px;left:-3px;width:46px;height:46px;transform:rotate(180deg)}.circular-loader{animation:rotate 2s linear infinite;height:100%;transform-origin:center center;width:100%;position:absolute;top:0;left:0;margin:auto}.loader-path{stroke-dasharray:150,200;stroke-dashoffset:-10;animation:dash 1.5s ease-in-out infinite;stroke-linecap:round}@keyframes rotate{to{transform:rotate(360deg)}}@keyframes dash{0%{stroke-dasharray:1,200;stroke-dashoffset:0}50%{stroke-dasharray:89,200;stroke-dashoffset:-35}to{stroke-dasharray:89,200;stroke-dashoffset:-124}}::ng-deep .dropdown{position:fixed;background:#fff;box-shadow:0 3px 6px #00000029;padding:24px 0;z-index:9;max-height:calc(100vh - 200px);overflow:auto}::ng-deep .dropdown ul.dropdown-list{padding:0 20px;margin:0;display:block}::ng-deep .dropdown ul.dropdown-list li{list-style:none}::ng-deep .dropdown ul.dropdown-list li app-cs-radio{display:flex}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item span.radio{position:absolute;top:12px;left:12px}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item span.value{padding:11px 12px 11px 32px;width:100%;border:1px solid #bcbcbc;border-radius:4px;margin-left:0;max-width:100%}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item svg{position:absolute;top:12px;left:12px}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item input[type=radio]:checked~span.value{background:#e8feeb;border-color:#34aa44}::ng-deep .dropdown ul.dropdown-list li+li{margin-top:8px}app-smiley-dialog{position:relative;z-index:10}app-smiley-dialog-inline{position:absolute;top:-3px;right:0;bottom:0;z-index:999;width:520px;height:calc(100vh + 3px)}::ng-deep .vx-overlay{position:fixed;z-index:3;inset:0}::ng-deep dp-date-picker{width:100%;position:fixed!important;z-index:14;top:-40px;left:0}::ng-deep dp-date-picker input{width:100%;border:none;opacity:0;pointer-events:none}::ng-deep dp-date-picker input:focus{outline:none}::ng-deep dp-date-picker .dp-popup{width:412px;box-shadow:0 0 20px #161b2f26;background-color:#fff;border-radius:4px;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both}::ng-deep dp-date-picker .dp-popup dp-day-calendar,::ng-deep dp-date-picker .dp-popup dp-month-calendar{width:100%;pointer-events:auto}::ng-deep dp-date-picker .dp-popup dp-day-calendar button,::ng-deep dp-date-picker .dp-popup dp-month-calendar button{background:transparent;border:none;outline:none}::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-current-location-btn,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-current-location-btn,::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-calendar-nav-left,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-calendar-nav-left,::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-calendar-nav-right,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-calendar-nav-right{width:40px;height:40px;display:flex;justify-content:center;align-items:center;border-radius:50%;font-size:14px}::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-current-location-btn:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-current-location-btn:hover,::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-calendar-nav-left:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-calendar-nav-left:hover,::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-calendar-nav-right:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-calendar-nav-right:hover{background-color:#f3f3f3}::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-current-location-btn,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-current-location-btn{display:none}::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-current-location-btn:before,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-current-location-btn:before{content:\"\";height:10px;width:10px;border-radius:50%;background:#000;display:inline-flex}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week{display:flex;justify-content:space-around}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays .dp-calendar-weekday,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays .dp-calendar-weekday,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week .dp-calendar-weekday,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week .dp-calendar-weekday{width:52px;border-left:none;border-bottom-color:#fff;color:#747576;font-size:11px;font-weight:600;text-transform:uppercase}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays button,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week button{width:40px;height:40px;border-radius:50%;display:inline-flex;justify-content:center;align-items:center}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays button:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays button:hover,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week button:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week button:hover{background-color:#f3f3f3}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays button.dp-selected,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays button.dp-selected,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week button.dp-selected,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week button.dp-selected{background:#1e5dd3}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays button.dp-current-day,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays button.dp-current-day,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week button.dp-current-day,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week button.dp-current-day{border:1px solid rgba(0,0,0,.38);color:#1e5dd3;background-color:#fff}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-day-calendar-container,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-day-calendar-container{padding:20px;border-radius:2px}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-nav-container,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-nav-container{display:flex;margin:0 0 20px;border:none}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-nav-container .dp-nav-header button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-nav-container .dp-nav-header button{color:#000;font-size:17px;font-weight:500;margin:0 0 0 12px;padding:0}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-nav-btns-container,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-nav-btns-container{width:80px;display:flex}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-nav-btns-container .dp-calendar-nav-container-left button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-nav-btns-container .dp-calendar-nav-container-left button,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-nav-btns-container .dp-calendar-nav-container-right button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-nav-btns-container .dp-calendar-nav-container-right button{margin:0!important}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-wrapper,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-wrapper{border:none}::ng-deep dp-date-picker .dp-open+div{position:fixed!important;inset:0!important;display:flex;justify-content:center;align-items:center;z-index:99;pointer-events:none;background:#0000004d}::ng-deep .cdk-overlay-container{z-index:2147483002!important}::ng-deep .dp-popup{z-index:999;display:flex!important;align-items:center;justify-content:center;width:100vw;height:100vh;background:#0000004d!important;box-shadow:unset!important}::ng-deep .dp-popup dp-day-calendar{width:412px!important;box-shadow:0 0 20px #161b2f26;background-color:#fff;border-radius:4px;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both}::ng-deep .dp-popup dp-day-calendar,::ng-deep .dp-popup dp-month-calendar{width:100%;pointer-events:auto}::ng-deep .dp-popup dp-day-calendar button,::ng-deep .dp-popup dp-month-calendar button{background:transparent;border:none;outline:none}::ng-deep .dp-popup dp-day-calendar button.dp-current-location-btn,::ng-deep .dp-popup dp-month-calendar button.dp-current-location-btn,::ng-deep .dp-popup dp-day-calendar button.dp-calendar-nav-left,::ng-deep .dp-popup dp-month-calendar button.dp-calendar-nav-left,::ng-deep .dp-popup dp-day-calendar button.dp-calendar-nav-right,::ng-deep .dp-popup dp-month-calendar button.dp-calendar-nav-right{width:40px;height:40px;display:flex;justify-content:center;align-items:center;border-radius:50%;font-size:14px}::ng-deep .dp-popup dp-day-calendar button.dp-current-location-btn:hover,::ng-deep .dp-popup dp-month-calendar button.dp-current-location-btn:hover,::ng-deep .dp-popup dp-day-calendar button.dp-calendar-nav-left:hover,::ng-deep .dp-popup dp-month-calendar button.dp-calendar-nav-left:hover,::ng-deep .dp-popup dp-day-calendar button.dp-calendar-nav-right:hover,::ng-deep .dp-popup dp-month-calendar button.dp-calendar-nav-right:hover{background-color:#f3f3f3}::ng-deep .dp-popup dp-day-calendar button.dp-current-location-btn,::ng-deep .dp-popup dp-month-calendar button.dp-current-location-btn{display:none}::ng-deep .dp-popup dp-day-calendar button.dp-current-location-btn:before,::ng-deep .dp-popup dp-month-calendar button.dp-current-location-btn:before{content:\"\";height:10px;width:10px;border-radius:50%;background:#000;display:inline-flex}::ng-deep .dp-popup dp-day-calendar .dp-weekdays,::ng-deep .dp-popup dp-month-calendar .dp-weekdays,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week{display:flex;justify-content:space-around}::ng-deep .dp-popup dp-day-calendar .dp-weekdays .dp-calendar-weekday,::ng-deep .dp-popup dp-month-calendar .dp-weekdays .dp-calendar-weekday,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week .dp-calendar-weekday,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week .dp-calendar-weekday{width:52px;border-left:none;border-bottom-color:#fff;color:#747576;font-size:11px;font-weight:600;text-transform:uppercase}::ng-deep .dp-popup dp-day-calendar .dp-weekdays button,::ng-deep .dp-popup dp-month-calendar .dp-weekdays button,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week button,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week button{width:40px;height:40px;border-radius:50%;display:inline-flex;justify-content:center;align-items:center}::ng-deep .dp-popup dp-day-calendar .dp-weekdays button:hover,::ng-deep .dp-popup dp-month-calendar .dp-weekdays button:hover,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week button:hover,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week button:hover{background-color:#f3f3f3}::ng-deep .dp-popup dp-day-calendar .dp-weekdays button.dp-selected,::ng-deep .dp-popup dp-month-calendar .dp-weekdays button.dp-selected,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week button.dp-selected,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week button.dp-selected{background:#1e5dd3}::ng-deep .dp-popup dp-day-calendar .dp-weekdays button.dp-current-day,::ng-deep .dp-popup dp-month-calendar .dp-weekdays button.dp-current-day,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week button.dp-current-day,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week button.dp-current-day{border:1px solid rgba(0,0,0,.38);color:#1e5dd3;background-color:#fff}::ng-deep .dp-popup dp-day-calendar .dp-day-calendar-container,::ng-deep .dp-popup dp-month-calendar .dp-day-calendar-container{padding:20px;border-radius:2px}::ng-deep .dp-popup dp-day-calendar .dp-calendar-nav-container,::ng-deep .dp-popup dp-month-calendar .dp-calendar-nav-container{display:flex;margin:0 0 20px;border:none}::ng-deep .dp-popup dp-day-calendar .dp-calendar-nav-container .dp-nav-header button,::ng-deep .dp-popup dp-month-calendar .dp-calendar-nav-container .dp-nav-header button{color:#000;font-size:17px;font-weight:500;margin:0 0 0 12px;padding:0}::ng-deep .dp-popup dp-day-calendar .dp-nav-btns-container,::ng-deep .dp-popup dp-month-calendar .dp-nav-btns-container{width:80px;display:flex}::ng-deep .dp-popup dp-day-calendar .dp-nav-btns-container .dp-calendar-nav-container-left button,::ng-deep .dp-popup dp-month-calendar .dp-nav-btns-container .dp-calendar-nav-container-left button,::ng-deep .dp-popup dp-day-calendar .dp-nav-btns-container .dp-calendar-nav-container-right button,::ng-deep .dp-popup dp-month-calendar .dp-nav-btns-container .dp-calendar-nav-container-right button{margin:0!important}::ng-deep .dp-popup dp-day-calendar .dp-calendar-wrapper,::ng-deep .dp-popup dp-month-calendar .dp-calendar-wrapper{border:none}@keyframes slide-bottom{0%{transform:translateY(-100px)}to{transform:translateY(0)}}::ng-deep span.file{display:block;width:20px;min-width:20px;border-radius:0 0 2px 2px;border:1px solid transparent;border-color:#747576;position:relative;margin-right:5px;border-top:none;margin-top:5px;background:#fff}::ng-deep span.file.table{margin-right:8px;width:18px;min-width:18px}::ng-deep span.file.table i{font-size:8px}::ng-deep span.file.table .format{height:8px;font-size:7px;line-height:8px;font-weight:400}::ng-deep span.file:before{position:absolute;border-radius:0;top:-4px;right:-1px;content:\"\";height:4px;width:4px;display:block;background:linear-gradient(45deg,#747576 0% 1%,#747576 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file:after{height:4px;left:-1px;right:3px;border-top:1px solid;border-right:none;border-left:1px solid;content:\"\";top:-4px;position:absolute;border-radius:2px 0 0;background:#fff}::ng-deep span.file .format{height:10px;font-size:6px;text-transform:uppercase;background:transparent;font-weight:600;text-align:center;display:block;line-height:10px}::ng-deep span.file i{font-size:10px;height:10px;display:flex;align-items:center;justify-content:center;color:#dbdbdb}::ng-deep span.file.docx{width:22px!important}::ng-deep span.file.pdf,::ng-deep span.file.template{border-color:#f31c39}::ng-deep span.file.pdf:before,::ng-deep span.file.template:before{background:linear-gradient(45deg,#f31c39 0% 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#f31c39\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.pdf:after,::ng-deep span.file.template:after{border-color:#f31c39}::ng-deep span.file.pdf .format,::ng-deep span.file.template .format{color:#f31c39}::ng-deep span.file.xlsx,::ng-deep span.file.xls,::ng-deep span.file.css,::ng-deep span.file.scss,::ng-deep span.file.less{border-color:#34aa44}::ng-deep span.file.xlsx:before,::ng-deep span.file.xls:before,::ng-deep span.file.css:before,::ng-deep span.file.scss:before,::ng-deep span.file.less:before{background:linear-gradient(45deg,#34aa44 0% 1%,#34aa44 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.xlsx:after,::ng-deep span.file.xls:after,::ng-deep span.file.css:after,::ng-deep span.file.scss:after,::ng-deep span.file.less:after{border-color:#34aa44;color:#34aa44}::ng-deep span.file.xlsx .format,::ng-deep span.file.xls .format,::ng-deep span.file.css .format,::ng-deep span.file.scss .format,::ng-deep span.file.less .format{color:#34aa44}::ng-deep span.file.doc,::ng-deep span.file.docx,::ng-deep span.file.psd{border-color:#1e5dd3}::ng-deep span.file.doc:before,::ng-deep span.file.docx:before,::ng-deep span.file.psd:before{background:linear-gradient(45deg,#1e5dd3 0% 1%,#1e5dd3 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.doc:after,::ng-deep span.file.docx:after,::ng-deep span.file.psd:after{border-color:#1e5dd3}::ng-deep span.file.doc .format,::ng-deep span.file.docx .format,::ng-deep span.file.psd .format{color:#1e5dd3}::ng-deep span.file.ppt,::ng-deep span.file.ai,::ng-deep span.file.html,::ng-deep span.file.jpg,::ng-deep span.file.jpeg,::ng-deep span.file.png{border-color:#f6882f}::ng-deep span.file.ppt:before,::ng-deep span.file.ai:before,::ng-deep span.file.html:before,::ng-deep span.file.jpg:before,::ng-deep span.file.jpeg:before,::ng-deep span.file.png:before{background:linear-gradient(45deg,#f6882f 0% 1%,#f6882f 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.ppt:after,::ng-deep span.file.ai:after,::ng-deep span.file.html:after,::ng-deep span.file.jpg:after,::ng-deep span.file.jpeg:after,::ng-deep span.file.png:after{border-color:#f6882f}::ng-deep span.file.ppt .format,::ng-deep span.file.ai .format,::ng-deep span.file.html .format,::ng-deep span.file.jpg .format,::ng-deep span.file.jpeg .format,::ng-deep span.file.png .format{color:#f6882f}::ng-deep span.file.php{border-color:#7aa6f7}::ng-deep span.file.php:before{background:linear-gradient(45deg,#7aa6f7 0% 1%,#7aa6f7 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.php:after{border-color:#7aa6f7}::ng-deep span.file.php .format{color:#7aa6f7}::ng-deep ngx-material-timepicker-container .timepicker-backdrop-overlay{background-color:#0000000d!important;z-index:9999999999!important}::ng-deep ngx-material-timepicker-container .timepicker-overlay{z-index:9999999999!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker{width:232px!important;border-radius:2px!important;box-shadow:0 4px 30px #161b2f26!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header{background-color:#fff!important;padding:0!important;border-radius:2px 2px 0 0}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container{display:block!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time{color:#000!important;width:150px!important;margin:0 auto;line-height:60px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time ngx-material-timepicker-dial-control .timepicker-dial__control{font-size:40px;background-color:transparent!important;color:#000!important;font-weight:600;text-align:right;caret-color:transparent;outline:none;font-family:Poppins;line-height:56px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time ngx-material-timepicker-dial-control .timepicker-dial__control:focus,::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time ngx-material-timepicker-dial-control .timepicker-dial__control:hover{background-color:transparent!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time ngx-material-timepicker-dial-control:last-of-type .timepicker-dial__control{text-align:left}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time span{padding:0 8px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period{display:flex!important;width:182px;margin:0 auto!important;background:#f1f1f1;padding:4px 10px;border-radius:20px;position:relative}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period:before{background:#f1f1f1;content:\"\";position:absolute;top:15px;left:-25px;width:calc(100% + 50px);height:2px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period{flex-direction:unset!important;position:relative;z-index:1}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period:after{content:\"\";position:absolute;right:-12px;top:0;border-left:solid 14px #f1f1f1;border-bottom:solid 12px transparent;border-top:solid 12px transparent;z-index:-1}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period:before{content:\"\";position:absolute;left:-18px;top:0;border-right:solid 14px #f1f1f1;border-bottom:solid 12px transparent;border-top:solid 12px transparent;z-index:-1}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period button{font-size:11px;background-color:transparent;padding:0;border-radius:20px;color:#747576;font-weight:600;font-family:Poppins;width:84px;height:24px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period button.timepicker-dial__item_active{background:#fff!important;color:#1e5dd3!important;box-shadow:0 1px 2px #dbdbdb}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period button+button{margin-left:0!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face{width:200px!important;height:200px!important;padding:10px!important;background:transparent!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__number--outer{height:92px!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__number--outer span{color:#000}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__number--outer span.active{color:#fff}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__clock-hand{height:80px!important;top:calc(50% - 80px)!important;background-color:#1e5dd3!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__number>span.active{background-color:#1e5dd3!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__clock-hand_minute:before{border:4px solid #1e5dd3!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .timepicker__actions{display:flex!important;padding:10px 0 0!important;background:#fff!important;justify-content:space-around!important;border-radius:0 0 2px 2px!important;overflow:hidden}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .timepicker__actions div:first-child ngx-material-timepicker-button button.timepicker-button{background:#f8f8f8;color:#1e5dd3}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .timepicker__actions div ngx-material-timepicker-button button.timepicker-button{line-height:28px!important;width:100%;background:#1e5dd3;color:#fff;border-radius:0!important;height:32px!important;width:116px!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .timepicker__actions div ngx-material-timepicker-button button.timepicker-button span{font-weight:500!important;font-size:11px;font-family:Poppins}::ng-deep vcomply-editor{display:block}::ng-deep vcomply-editor .editor-container{border-radius:4px;border:1px solid #dbdbdb;transition:all .2s ease-in-out}::ng-deep vcomply-editor .editor-container:hover,::ng-deep vcomply-editor .editor-container:focus-within{border:1px solid #1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep vcomply-editor .editor-container mention-list ul li a{font-size:16px!important}::ng-deep vcomply-editor .editor-container .editable-block{background:#fff;min-height:60px;padding:8px 12px;line-height:20px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%}::ng-deep vcomply-editor .editor-container .editable-block:before{color:#747576!important}::ng-deep vcomply-editor .editor-container .editor-tools{border-top:1px solid #dbdbdb;border-radius:0 0 3px 3px}::ng-deep vcomply-editor .editor-container .editor-tools:hover{border-color:#1e5dd3}::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button{height:22px!important;width:22px!important;padding:0 5px}::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button svg{height:22px;width:12px}::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button.submit{width:80px!important;line-height:22px;justify-content:center}::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col .popover.small ul.option-list li button{width:100%!important;height:auto!important}::ng-deep marx-modal .popup-modal-background{background-color:#161b2fcc!important}::ng-deep .within-box{background:#f1f1f1;border-radius:.125rem;color:#042e7d}::ng-deep .within-value{overflow:hidden;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;word-break:break-word}.wf-tooltip{pointer-events:none;position:absolute;max-width:300px;font-size:12px;text-align:left;color:#fff;padding:8px 12px;background:#000;border-radius:2px;z-index:-222;top:0;opacity:0;white-space:break-spaces;word-break:break-word}.wf-tooltip *{color:#fff!important}.wf-tooltip:empty{display:none!important}.wf-tooltip.white{box-shadow:0 2px 8px #1c5bd159;color:#747576;background:#fff;text-align:left}.wf-tooltip.white b{color:#747576!important}.wf-tooltip.animate-top{animation:animate-top .5s cubic-bezier(.25,.46,.45,.94) both}.wf-tooltip.animate-right{animation:animate-right .3s cubic-bezier(.25,.46,.45,.94) both}.wf-tooltip.animate-bottom{animation:animate-bottom .5s cubic-bezier(.25,.46,.45,.94) both}.wf-tooltip.animate-left{animation:animate-left .5s cubic-bezier(.25,.46,.45,.94) both}.wf-tooltip-top:after{top:100%;left:50%;margin-left:-5px;border-width:5px;border-color:#000000 transparent transparent transparent}.wf-tooltip-top.white:after{border-color:#f1f1f1 transparent transparent transparent}.wf-tooltip-bottom:after{bottom:100%;left:50%;margin-left:-5px;border-width:5px;border-color:transparent transparent #000000 transparent}.wf-tooltip-bottom.white:after{border-color:transparent transparent #f1f1f1 transparent}.wf-tooltip-left.white:after{border-color:transparent transparent transparent #f1f1f1}.wf-tooltip-left:after{top:50%;left:100%;margin-top:-5px;border-width:5px;border-color:transparent transparent transparent #000000}.wf-tooltip-right.white:after{border-color:transparent #f1f1f1 transparent transparent}.wf-tooltip-right:after{top:50%;right:100%;margin-top:-5px;border-width:5px;border-color:transparent #000000 transparent transparent}.wf-tooltip-bottom-right:after{bottom:100%;left:100%;margin-left:-20px;border-width:5px;border-color:transparent transparent #000000 transparent}.wf-tooltip-bottom-right.white:after{border-color:transparent transparent #f1f1f1 transparent}.wf-tooltip-bottom-left:after{bottom:100%;left:0;margin-left:10px;border-width:5px;border-color:transparent transparent #000000 transparent}.wf-tooltip-bottom-left.white:after{border-color:transparent transparent #f1f1f1 transparent}.wf-tooltip-top-left:after{top:100%;left:0;margin-left:10px;border-width:5px;border-color:#000000 transparent transparent transparent}.wf-tooltip-top-left.white:after{border-color:#f1f1f1 transparent transparent transparent}.wf-tooltip-top-right:after{top:100%;left:100%;margin-left:-5px;border-width:5px;border-color:#000000 transparent transparent transparent}.wf-tooltip-top-right.white:after{border-color:#f1f1f1 transparent transparent transparent}.wf-tooltip:after{content:\"\";position:absolute;border-style:solid}.wf-tooltip span.within{font-size:80%;display:block;width:100%}.wf-tooltip .small{display:block;font-size:10px}.wf-tooltip .within-box{background:#f1f1f1;border-radius:2px;color:#042e7d!important;font-size:9px;font-weight:500;text-transform:uppercase;padding:0 2px;margin-right:2px}.wf-tooltip-show{pointer-events:none;opacity:1;z-index:2147483001}\n"], dependencies: [{ kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i6.MarxEditorComponent, selector: "vcomply-editor", inputs: ["editorConfig"], outputs: ["comment", "sendSavedFiles", "popup"] }, { kind: "directive", type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i8.CsRadioComponent, selector: "app-cs-radio", inputs: ["disabled", "readonly", "name", "checked", "value", "oneLine"], outputs: ["checkedEvent"] }, { kind: "directive", type: i9.ToolTipDirective, selector: "[appTooltip]", inputs: ["appTooltip", "placement", "type", "tooltipMandatory", "showTooltip", "animate"] }, { kind: "component", type: i10.PopoverComponent, selector: "app-popover", inputs: ["dontCloseonClick"] }, { kind: "directive", type: i11.PopoverDirective, selector: "[appPopover]", inputs: ["refrence", "placement"] }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i12.LoaderInlineComponent, selector: "app-loader-inline" }, { kind: "component", type: i13.SmileyDialogInlineComponent, selector: "app-smiley-dialog-inline", inputs: ["message", "actionButtons"], outputs: ["action", "closeSmiley"] }, { kind: "component", type: i14.PopoverHoverComponent, selector: "popover-hover" }, { kind: "directive", type: i15.PopoverHoverDirective, selector: "[libPopoverHover]", inputs: ["placement"] }, { kind: "component", type: i16.TabSelector, selector: "tab-selector", inputs: ["disabled", "selectedItem", "displayArray"], outputs: ["onValueChanged"] }, { kind: "component", type: i17.FormFieldComponent, selector: "form-field", inputs: ["active", "disabled", "checked", "img"] }, { kind: "component", type: i18.FilePillComponent, selector: "file-pill", inputs: ["name", "extension", "disabled"], outputs: ["delete"] }, { kind: "component", type: i19.InputWithPillComponent, selector: "input-with-pill", inputs: ["placeholder", "disabled", "selectDiv", "line"], outputs: ["select"] }, { kind: "component", type: i20.SwitchComponent, selector: "switch", inputs: ["disabled", "checked", "tooltipMessage", "value", "position"], outputs: ["change"] }, { kind: "directive", type: i21.InputTrimDirective, selector: "[InputTrim]" }, { kind: "component", type: i22.RoleListComponent, selector: "role-list", inputs: ["featureflagrole", "featureflagGroup", "ff_rc_listing", "list", "loading", "selected"], outputs: ["save", "cancel"] }, { kind: "component", type: i23.UserGroupListComponent, selector: "user-group-list", inputs: ["groupEnabled", "panelTitle", "singleSelect", "selectedReviewer", "featureflag", "reviewerWorkflowType", "mode", "fieldType", "fromResponsibility", "assignorId", "assigneeIds", "reviewerIds", "overseerIds", "FromProgram", "userListInfo", "groupListInfo", "fromApprovalWorkflow", "approvalType", "showFutureUsersSwitch", "futureUsersWillSelect", "isAllDisabled", "isGroupTabShow", "disabledIds", "nonRemovableUserIds", "allUserSelectedDisabled", "nonRemovableGroupIds", "loading", "userlist", "selectedUsers", "defaultSelectedUsers", "userType", "groupList", "selectedGroups"], outputs: ["save", "cancel", "reviewerWorkflowTypeChange", "fetchUserData"] }, { kind: "component", type: i24.AssessmentPickerComponent, selector: "assessment-picker", inputs: ["isEdit", "selectedAssessment", "selectedAssessmentData"], outputs: ["onAssessmentSelect", "cancelAssessment"] }, { kind: "component", type: i25.CustomFieldComponent, selector: "custom-field", inputs: ["disabled"] }, { kind: "component", type: i26.ResponsibilityCentersListComponent, selector: "app-responsibility-centers-list", inputs: ["responsibilityCentersList", "selectedResponsibilityCenters", "rcIdKey", "radioSelection", "pluralText", "singularText", "loaded"], outputs: ["saveSelectedList", "closeRcList"] }, { kind: "component", type: i27.FrameworkListComponent, selector: "app-framework-list", inputs: ["previousSelectedValues", "headerText", "workflowPage", "policy", "frameWorkList", "selectedFrameWork", "selectedCategories"], outputs: ["entrustFramework", "closeFramework", "assignControl"] }, { kind: "pipe", type: i7.SlicePipe, name: "slice" }, { kind: "pipe", type: i28.ListToIdPipe, name: "listToId" }, { kind: "pipe", type: i29.RefDisconnectPipe, name: "refDisconnect" }, { kind: "pipe", type: i30.AssessmentResolverPipe, name: "assessmentResolver" }, { kind: "pipe", type: i31.ArrayConcatPipe, name: "arrayConcat" }] }); }
1295
1335
  }
1296
1336
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: WorkflowProgramComponent, decorators: [{
1297
1337
  type: Component,
1298
- args: [{ selector: 'app-workflow-program', template: "<div class=\"workflow-program\" #form>\n <form novalidate [formGroup]=\"programForm\">\n <!-- Program Category Type -->\n <form-field\n [checked]=\"controls?.program_type?.value > -1\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.issue_type\"\n >\n <label class=\"vx-control-panel\"\n >PROGRAM TYPE <span class=\"required\">*</span></label\n >\n <tab-selector\n formControlName=\"program_type\"\n [displayArray]=\"constants?.categoryType\"\n ></tab-selector>\n <!-- <p *ngIf=\"program_name?.invalid\" class=\"error-message\">Add a program type</p> -->\n </form-field>\n\n <!-- Framework -->\n <form-field\n *ngIf=\"isAscentAllowed\"\n [checked]=\"false\"\n [active]=\"false\"\n [disabled]=\"false\"\n [img]=\"ASSETS.case_category\"\n >\n <label class=\"vx-control-panel\">FRAMEWORK</label>\n <!-- [selectDiv]=\"true\" -->\n <input-with-pill\n [placeholder]=\"'Select a framework that this Program relates to'\"\n (select)=\"activateList('FRAMEWORK')\"\n >\n <div class=\"selected\" *ngIf=\"controls?.framework.value?.name\">\n <div class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\">\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n *ngIf=\"canFrameworkChange\"\n (click)=\"remove('', 'FRAMEWORK')\"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.framework.value?.name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.framework.value?.name }}</span\n >\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i (click)=\"remove('', 'FRAMEWORK')\" *ngIf=\"canFrameworkChange\" class=\"icons\" >&#xe90d;</i> {{controls?.framework.value?.name}}</span>\n </div>\n </div> -->\n <button\n *ngIf=\"canFrameworkChange\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('FRAMEWORK')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n </form-field>\n\n <!-- Program Category Name -->\n <form-field\n [checked]=\"controls?.program_name?.value?.trim()?.length\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.what\"\n >\n <label class=\"vx-control-panel\"\n >PROGRAM NAME <span class=\"required\">*</span></label\n >\n <input\n InputTrim\n formControlName=\"program_name\"\n type=\"text\"\n placeholder=\"What is the Program name?\"\n />\n\n <p\n *ngIf=\"\n controls?.program_name?.errors && controls?.program_name?.touched\n \"\n class=\"error-message\"\n >\n Enter a name for this Program.\n </p>\n <p *ngIf=\"isNameExists\" class=\"error-message\">\n Program name already exists.\n </p>\n <vcomply-editor\n [(ngModel)]=\"editorData.programObjective\"\n [ngModelOptions]=\"{ standalone: true }\"\n (sendSavedFiles)=\"selectFile('OBJECTIVE', $event)\"\n (ngModelChange)=\"setFormField('program_objective', $event, true)\"\n [editorConfig]=\"constants?.description\"\n >\n </vcomply-editor>\n </form-field>\n\n\n\n <!-- Owners -->\n <form-field\n *ngIf=\"additionalOption?.OWNERS\"\n [checked]=\"\n controls?.program_owners?.value?.length > 0 ||\n controls?.program_owners_group?.value?.length > 0\n \"\n [active]=\"activeList === 'OWNER'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'OWNER'\"\n [img]=\"ASSETS.case_owners\"\n >\n <label class=\"vx-control-panel\"\n >OWNER(S) \n <span\n class=\"icon\"\n *ngIf=\"toolTipData.owner !== ''\"\n libPopoverHover\n (mouseover)=\"dataTooltip.popover()\"\n (mouseleave)=\"dataTooltip.closePopover()\"\n placement=\"right\"\n ><i class=\"icons\">&#xe91f;</i></span\n >\n <popover-hover #dataTooltip>\n <div class=\"vx-info-card\">\n <div\n class=\"vx-info-card-body\"\n [innerHTML]=\"toolTipData.owner\"\n id=\"OwnerHelpText\"\n ></div>\n </div>\n </popover-hover>\n </label>\n <input-with-pill\n [placeholder]=\"'Who is responsible for managing this program?'\"\n (select)=\"activateList('OWNER')\"\n >\n <div class=\"selected\" *ngIf=\"controls?.program_owners?.value[0]\">\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_owners?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_owners?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4 greenBg\"\n appPopover\n (click)=\"owner.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_owners?.value?.length > 1\"\n >\n +{{ controls?.program_owners?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_owners_group?.value?.length &&\n controls?.program_owners?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_owners_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n (click)=\"\n remove(\n controls?.program_owners_group?.value[0],\n 'OWNER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_owners_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_owners_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"group.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_owners_group?.value?.length > 1\"\n >\n +{{ controls?.program_owners_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n <button\n *ngIf=\"activeList !== 'OWNER'\"\n [class.disabled]=\"controls?.all_user_in_role?.value\"\n (click)=\"activateList('OWNER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i>Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #owner [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"let owner of controls?.program_owners?.value | slice : 1\"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"\n !(\n lists.NON_REMOVABLE_OWNERS | listToId : 'member_id'\n ).includes(owner?.member_id)\n \"\n class=\"icons\"\n (click)=\"remove(owner, 'OWNER')\"\n >&#xe90d;</i\n >\n {{ owner?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #group [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let owner of controls?.program_owners_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n class=\"icons\"\n (click)=\"remove(owner, 'OWNER_GROUP')\"\n >&#xe90d;</i\n >\n {{ owner?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field>\n\n <!-- Collaborators -->\n <form-field\n *ngIf=\"additionalOption?.COLLABORATORS\"\n [checked]=\"\n controls?.collaborators?.value?.length > 0 ||\n controls?.collaborators_group?.value?.length > 0\n \"\n [active]=\"activeList === 'COLLABORATORS'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'COLLABORATORS'\"\n [img]=\"\n 'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/owner.svg'\n \"\n >\n <label class=\"vx-control-panel\"\n >COLLABORATORS \n <span\n class=\"icon\"\n *ngIf=\"toolTipData.collaborators !== ''\"\n libPopoverHover\n (mouseover)=\"dataTooltip.popover()\"\n (mouseleave)=\"dataTooltip.closePopover()\"\n placement=\"right\"\n ><i class=\"icons\">&#xe91f;</i></span\n >\n <popover-hover #dataTooltip>\n <div class=\"vx-info-card\">\n <div\n class=\"vx-info-card-body\"\n [innerHTML]=\"toolTipData.collaborators\"\n id=\"CollaboratorsHelpText\"\n ></div>\n </div>\n </popover-hover>\n </label>\n <input-with-pill\n [placeholder]=\"'Who is responsible for managing this program?'\"\n (select)=\"activateList('COLLABORATORS')\"\n >\n <div class=\"selected\" *ngIf=\"controls?.collaborators?.value[0] || controls?.collaborators_group?.value[0]\">\n <div class=\"vx-d-flex vx-align-center\">\n <!-- Users -->\n <div \n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.collaborators?.value[0]\"\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.collaborators?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.collaborators?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4 greenBg\"\n appPopover\n (click)=\"owner.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.collaborators?.value?.length > 1\"\n >\n +{{ controls?.collaborators?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\" \n controls?.collaborators_group?.value?.length &&\n controls?.collaborators?.value?.length\n \"\n >&</span\n >\n <!-- Groups -->\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.collaborators_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n (click)=\"\n remove(\n controls?.collaborators_group?.value[0],\n 'COLLABORATORS_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.collaborators_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.collaborators_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"group.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_owners_group?.value?.length > 1\"\n >\n +{{ controls?.collaborators_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\" [appTooltip]=\"controls?.program_owners?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\" >{{controls?.program_owners?.value[0]?.member_name}}</span></span>\n <button *ngIf=\"controls?.program_owners?.value?.length > 1\" class=\"count user\" appPopover (click)=\"owner.popover()\" placement=\"right\">+{{controls?.program_owners?.value?.length -1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_owners_group?.value?.length && controls?.program_owners?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_owners_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" *ngIf=\"!['ADMIN','KEY_ADMIN','LOGGED_IN'].includes(owner?.user_role)\" (click)=\"remove(owner,'OWNER_GROUP')\">&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_owners_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_owners_group?.value[0]?.group_name}}</span></span>\n <button *ngIf=\"controls?.program_owners_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"group.popover()\" placement=\"right\">+{{controls?.program_owners_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'COLLABORATORS'\"\n [class.disabled]=\"controls?.all_user_in_role?.value\"\n (click)=\"activateList('COLLABORATORS')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i>Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #owner [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"let owner of controls?.collaborators?.value | slice : 1\"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n\n class=\"icons\"\n (click)=\"remove(owner, 'COLLABORATORS')\"\n >&#xe90d;</i\n >\n {{ owner?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #group [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let owner of controls?.collaborators_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n class=\"icons\"\n (click)=\"remove(owner, 'COLLABORATORS_GROUP')\"\n >&#xe90d;</i\n >\n {{ owner?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field>\n\n <!-- Performance Calculated -->\n <!-- <form-field [checked]=\"controls?.performance_calculation?.value\" [active]=\"activeList === 'PERFORMANCE'\" [disabled]=\"sideElements.includes(activeList) && activeList !== 'PERFORMANCE'\"\n [img]=\"'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/performance-calc.svg'\">\n <label class=\"vx-control-panel\">HOW SHOULD THE PERFORMANCE OF THIS PROGRAM BE CALCULATED?</label>\n <tab-selector formControlName=\"performance_calculation\" [displayArray]=\"constants?.performanceCalculation\">\n </tab-selector>\n </form-field> -->\n <ng-container *ngIf=\"isProgramScope && false\">\n <div\n class=\"scope-label vx-fs-10 vx-txt-white vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mb-5 vx-lh-4 vx-d-inline-block\"\n >\n PROGRAM SCOPE\n </div>\n <!-- <i class=\"icons info-icon vx-fs-12 vx-txt-blue vx-ml-1\" [appTooltip]=\"tooltip.programScope\" placement=\"bottom\" delay=\"0\" type=\"white\" [tooltipMandatory]=\"true\">&#xe91f;</i> -->\n <span\n class=\"icon info-icon vx-fs-12 vx-txt-blue vx-ml-1\"\n *ngIf=\"toolTipData.programScop !== ''\"\n libPopoverHover\n (mouseover)=\"dataTooltip.popover()\"\n (mouseleave)=\"dataTooltip.closePopover()\"\n placement=\"right\"\n ><i class=\"icons\">&#xe91f;</i></span\n >\n <popover-hover #dataTooltip>\n <div class=\"vx-info-card\">\n <div\n class=\"vx-info-card-body\"\n [innerHTML]=\"toolTipData.programScope\"\n id=\"PSHelpText\"\n ></div>\n </div>\n </popover-hover>\n </ng-container>\n\n <!-- Program Frequency -->\n <form-field\n *ngIf=\"additionalOption?.PROGRAM_FREQUENCY\"\n [checked]=\"[true, false].includes(controls?.recurring_frequency?.value)\"\n [active]=\"activeList === 'FREQUENCY'\"\n [disabled]=\"\n sideElements.includes(activeList) && activeList !== 'FREQUENCY'\n \"\n [img]=\"ASSETS.recurring\"\n >\n <label class=\"vx-control-panel\" id=\"PDChange\"\n >PROGRAM DURATION\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Program Duration refers to the duration of the Program. A Program can occur in perpetuity, or it can occur until the end of the current business cycle that has been specified in ' +\n businessCycle.selectedCycle.business_cycle +\n '. All responsibilities linked with that Program will also have the same Program Duration.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"ProgramDurationHelpText\"\n >&#xeb16;</i\n ></label\n >\n <div class=\"upload-format\">\n <div class=\"vx-d-flex vx-align-center vx-justify-between\">\n <span class=\"text vx-mb-0\">Is this program recurring?</span>\n <div class=\"radio-group program\">\n <app-cs-radio\n [name]=\"'recurring_frequency'\"\n [checked]=\"controls?.recurring_frequency?.value\"\n (checkedEvent)=\"setFormField('recurring_frequency', true)\"\n >YES</app-cs-radio\n >\n <app-cs-radio\n [name]=\"'recurring_frequency'\"\n [checked]=\"!controls?.recurring_frequency?.value\"\n (checkedEvent)=\"setFormField('recurring_frequency', false)\"\n >NO</app-cs-radio\n >\n </div>\n </div>\n </div>\n </form-field>\n\n <!-- Scope Changes -->\n <form-field\n *ngIf=\"additionalOption?.SCOPE_CHANGES\"\n [checked]=\"[true, false].includes(controls?.lock_scope_change?.value)\"\n [active]=\"activeList === 'SCOPE'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'SCOPE'\"\n [img]=\"ASSETS.lock_scope\"\n >\n <label class=\"vx-control-panel\"\n >Lock the Program Scope\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If the Program Scope is locked, neither the Program nor the responsibilities linked with the Program can be edited once the Program begins. In order to edit the Program or the linked responsibilities, the Program details will need to be edited.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"ScopeChangesHelpText\"\n >&#xeb16;</i\n ></label\n >\n <div class=\"upload-format\">\n <span class=\"text\"\n >Would you like to\n <span class=\"vx-label-txt vx-fw-500\">lock changes</span> to the\n program scope?</span\n >\n <div class=\"radio-group program\">\n <app-cs-radio\n [name]=\"'lock_scope_change'\"\n [checked]=\"controls?.lock_scope_change?.value\"\n (checkedEvent)=\"setFormField('lock_scope_change', true)\"\n >YES</app-cs-radio\n >\n <app-cs-radio\n [name]=\"'lock_scope_change'\"\n [checked]=\"!controls?.lock_scope_change?.value\"\n (checkedEvent)=\"setFormField('lock_scope_change', false)\"\n >NO</app-cs-radio\n >\n </div>\n </div>\n </form-field>\n\n <!-- Framework -->\n <!-- <form-field [checked]=\"false\" [active]=\"activeList === 'FRAMEWORK'\" [disabled]=\"sideElements.includes(activeList) && activeList !== 'FRAMEWORK'\"\n [img]=\"'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/category.svg'\">\n <label class=\"vx-control-panel\">FRAMEWORK</label>\n <input-with-pill [placeholder]=\"'Select a framework that this Program relates to'\" (select)=\"activateList('FRAMEWORK')\">\n <div class=\"selected\" *ngIf=\"controls?.framework?.value?.framework_name\">\n <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i (click)=\"remove(controls?.framework.value,'FRAMEWORK')\" class=\"icons\">&#xe90d;</i>{{controls?.framework?.value?.framework_name}}</span>\n <button class=\"count\" appPopover (click)=\"framework.popover()\" placement=\"right\">+5</button>\n </div>\n </div>\n <button *ngIf=\"activeList!=='FRAMEWORK'\" (click)=\"activateList('FRAMEWORK')\" class=\"edit\" type=\"button\"><i class=\"icons\">&#xe9ba;</i> Edit</button>\n </div>\n </input-with-pill>\n <app-popover #framework [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i class=\"icons\">&#xe90d;</i>\n Manage framework name\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field> -->\n\n <!-- Responsibility Center -->\n <form-field\n *ngIf=\"additionalOption?.RC\"\n [checked]=\"controls?.rc?.value?.length\"\n [active]=\"activeList === 'RC'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'RC'\"\n [img]=\"ASSETS.responsibility_center\"\n >\n <label class=\"vx-control-panel\"\n >RESPONSIBILITY CENTER\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Responsibility Centers represent your organizational and operational infrastructure. Where Responsibility Centers are selected when creating a Program, only those Responsibilities Centers will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"RCHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n (select)=\"activateList('RC')\"\n [placeholder]=\"\n 'Which Responsibility Center(s) can be linked to the responsibilities associated with this Program?'\n \"\n >\n <div\n class=\"selected\"\n *ngIf=\"controls?.rc?.value && controls?.rc?.value?.length\"\n >\n <div class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\">\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"remove(controls?.rc?.value[0], 'RC')\"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.rc?.value[0]?.item_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.rc?.value[0]?.item_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"rc.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.rc?.value?.length > 1\"\n >\n +{{ controls?.rc?.value?.length - 1 }}\n </button>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i class=\"icons\" (click)=\"remove(controls?.rc?.value[0],'RC')\">&#xe90d;</i>{{controls?.rc?.value[0]?.item_name}}</span>\n <button *ngIf=\"controls?.rc?.value?.length > 1\" class=\"count\" appPopover (click)=\"rc.popover()\" placement=\"right\">+{{controls?.rc?.value?.length -1 }}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'RC'\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('RC')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #rc [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"let rc of controls?.rc?.value | slice : 1\">\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i class=\"icons\" (click)=\"remove(rc, 'RC')\">&#xe90d;</i>\n {{ rc?.item_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field>\n\n <!-- Assignee -->\n <form-field\n *ngIf=\"additionalOption?.ASSIGNEES\"\n [checked]=\"\n controls?.program_assignee?.value?.length ||\n controls?.program_default_assignee?.value?.length ||\n controls?.program_default_assignee?.value?.length ||\n controls?.program_default_assignee_group?.value?.length\n \"\n [active]=\"['ASSIGNEE', 'DEFAULT_ASSIGNEE']?.includes(activeList)\"\n [disabled]=\"\n sideElements?.includes(activeList) &&\n !['ASSIGNEE', 'DEFAULT_ASSIGNEE'].includes(activeList)\n \"\n [img]=\"ASSETS.case_assignees\"\n >\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"activeList === 'DEFAULT_ASSIGNEE'\"\n >ASSIGNEES\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Assignees are required to complete the responsibilities that have been assigned to them. Where Assignees are selected when creating a Program, only those Assignees will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"AssigneeHelpText\"\n >&#xeb16;</i\n >\n </label>\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'DEFAULT_ASSIGNEE'\"\n [placeholder]=\"\n 'Who is responsible for completing the responsibilities within this Program?'\n \"\n (select)=\"activateList('ASSIGNEE')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_assignee?.value?.length ||\n controls?.program_assignee_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_assignee?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(controls?.program_assignee?.value[0], 'ASSIGNEE')\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_assignee?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_assignee?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"assignee.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_assignee?.value?.length > 1\"\n >\n +{{ controls?.program_assignee?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_assignee_group?.value?.length &&\n controls?.program_assignee?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_assignee_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_assignee_group?.value[0],\n 'ASSIGNEE_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_assignee_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_assignee_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"assignee_group.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_assignee_group?.value?.length > 1\"\n >\n +{{ controls?.program_assignee_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_assignee?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_assignee?.value[0],'ASSIGNEE')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_assignee?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_assignee?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_assignee?.value?.length > 1\" class=\"count user\" appPopover (click)=\"assignee.popover()\" placement=\"right\">+{{controls?.program_assignee?.value?.length -1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_assignee_group?.value?.length && controls?.program_assignee?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_assignee_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_assignee_group?.value[0],'ASSIGNEE_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_assignee_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_assignee_group?.value[0]?.group_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_assignee_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"assignee_group.popover()\" placement=\"right\">+{{controls?.program_assignee_group?.value?.length -1 }}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'ASSIGNEE'\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('ASSIGNEE')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #assignee [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let assignee of controls?.program_assignee?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(assignee, 'ASSIGNEE')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ assignee?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #assignee_group [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_assignee_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(group, 'ASSIGNEE_GROUP')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"activeList === 'ASSIGNEE'\"\n >DEFAULT ASSIGNEE\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'This option lets you specify the Default Assignees for all new responsibilities linked with a Program. If a Default Assignees is selected, the user will automatically be selected the Assignee when creating a responsibility linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility. '\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"DAHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'ASSIGNEE'\"\n [placeholder]=\"\n 'Which persons will be selected as the default assignees for the responsibilities within this Program?'\n \"\n (select)=\"activateList('DEFAULT_ASSIGNEE')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_assignee?.value?.length ||\n controls?.program_default_assignee_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_assignee?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_assignee?.value[0],\n 'DEFAULT_ASSIGNEE'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_assignee?.value[0]?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_assignee?.value[0]?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultAssignee.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_default_assignee?.value?.length > 1\"\n >\n +{{ controls?.program_default_assignee?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_default_assignee_group?.value?.length &&\n controls?.program_default_assignee?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_assignee_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_assignee_group?.value[0],\n 'DEFAULT_ASSIGNEE_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_assignee_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_assignee_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultAssigneeGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_assignee_group?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_assignee_group?.value?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_assignee?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_assignee?.value[0],'DEFAULT_ASSIGNEE')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_assignee?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{ controls?.program_default_assignee?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_assignee?.value?.length > 1\" class=\"count user\" appPopover (click)=\"defaultAssignee.popover()\" placement=\"right\">+{{controls?.program_default_assignee?.value?.length - 1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_default_assignee_group?.value?.length && controls?.program_default_assignee?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_assignee_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_assignee_group?.value[0],'DEFAULT_ASSIGNEE_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_assignee_group?.value[0]?.group_name }}</span>\n </span>\n <button *ngIf=\"controls?.program_default_assignee_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"defaultAssigneeGroup.popover()\" placement=\"right\">+{{controls?.program_default_assignee_group?.value?.length -1 }}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_ASSIGNEE'\"\n (click)=\"activateList('DEFAULT_ASSIGNEE')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #defaultAssignee [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let assignee of controls?.program_default_assignee?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(assignee, 'DEFAULT_ASSIGNEE')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ assignee?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #defaultAssigneeGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_assignee_group?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(assignee, 'DEFAULT_ASSIGNEE_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <div\n class=\"radio-group-selector\"\n [class.disabled]=\"activeList === 'ASSIGNEE'\"\n >\n <app-cs-radio\n [name]=\"'assignee'\"\n [checked]=\"controls?.assignee_completion_criteria?.value === 'ALL'\"\n (checkedEvent)=\"setFormField('assignee_completion_criteria', 'ALL')\"\n >\n ALL SELECTED PERSONS NEED TO COMPLETE THIS\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If selected, separate responsibilities will be created for each person.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n <app-cs-radio\n [name]=\"'assignee'\"\n [checked]=\"controls?.assignee_completion_criteria?.value === 'ANYONE'\"\n (checkedEvent)=\"\n setFormField('assignee_completion_criteria', 'ANYONE')\n \"\n >\n ANY SELECTED PERSON CAN COMPLETE THIS\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If selected, only one responsibility will be created.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n </div>\n </form-field>\n\n <!-- Reviewer -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.REVIEWER\"\n [checked]=\"\n controls?.program_reviewer?.value?.length ||\n controls?.program_default_reviewer?.value?.length ||\n controls?.program_default_reviewer?.value?.length ||\n controls?.program_default_reviewer_group?.value?.length\n \"\n [active]=\"['REVIEWER', 'DEFAULT_REVIEWER']?.includes(activeList)\"\n [disabled]=\"\n sideElements?.includes(activeList) &&\n !['REVIEWER', 'DEFAULT_REVIEWER'].includes(activeList)\n \"\n [img]=\"ASSETS.reviewer\"\n >\n <label\n [class.disabled]=\"activeList === 'DEFAULT_REVIEWER'\"\n class=\"vx-control-panel\"\n >Reviewers\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Reviewers are required to review responsibilities after they have been completed. Where Reviewers are selected when creating a Program, only those Reviewers will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"ReviewerHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'DEFAULT_REVIEWER'\"\n [placeholder]=\"\n 'Who is responsible for reviewing the responsibilities within this Program?'\n \"\n (select)=\"activateList('REVIEWER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_reviewer?.value?.length ||\n controls?.program_reviewer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_reviewer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(controls?.program_reviewer?.value[0], 'REVIEWER')\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_reviewer?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_reviewer?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"reviewer.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_reviewer?.value?.length > 1\"\n >\n +{{ controls?.program_reviewer?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_reviewer_group?.value?.length &&\n controls?.program_reviewer?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_reviewer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_reviewer_group?.value[0],\n 'REVIEWER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_reviewer_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_reviewer_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"reviewerGroup.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_reviewer_group?.value?.length > 1\"\n >\n +{{ controls?.program_reviewer_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_reviewer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_reviewer?.value[0],'REVIEWER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_reviewer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_reviewer?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_reviewer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"reviewer.popover()\" placement=\"right\">+{{controls?.program_reviewer?.value?.length -1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_reviewer_group?.value?.length && controls?.program_reviewer?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_reviewer_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_reviewer_group?.value[0],'REVIEWER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_reviewer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_reviewer_group?.value[0]?.group_name}}\n </span>\n </span>\n <button *ngIf=\"controls?.program_reviewer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"reviewerGroup.popover()\" placement=\"right\">+{{controls?.program_reviewer_group?.value?.length - 1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'REVIEWER'\"\n (click)=\"activateList('REVIEWER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #reviewer [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let reviewer of controls?.program_reviewer?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(reviewer, 'REVIEWER')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ reviewer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #reviewerGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_reviewer_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(group, 'REVIEWER_GROUP')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <label\n [class.disabled]=\"activeList === 'REVIEWER'\"\n class=\"vx-control-panel\"\n >DEFAULT Reviewer\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'This option lets you specify the Default Reviewers for responsibilities linked with a Program. Where a user has been specified as a Default Reviewer, that user will automatically be selected as the Reviewer when creating a responsibility linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"DRHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'REVIEWER'\"\n [placeholder]=\"\n 'Which persons will be selected as the default reviewers for the responsibilities within this Program?'\n \"\n (select)=\"activateList('DEFAULT_REVIEWER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_reviewer?.value?.length ||\n controls?.program_default_reviewer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_reviewer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_reviewer?.value[0],\n 'DEFAULT_REVIEWER'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_reviewer?.value[0]?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_reviewer?.value[0]?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultReviewer.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_default_reviewer?.value?.length > 1\"\n >\n +{{ controls?.program_default_reviewer?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_default_reviewer_group?.value?.length &&\n controls?.program_default_reviewer?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_reviewer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_reviewer_group?.value[0],\n 'DEFAULT_REVIEWER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_reviewer_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_reviewer_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultReviewerGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_reviewer_group?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_reviewer_group?.value?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_reviewer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_reviewer?.value[0],'DEFAULT_REVIEWER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_reviewer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_reviewer?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_reviewer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"defaultReviewer.popover()\" placement=\"right\">+{{controls?.program_default_reviewer?.value?.length - 1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_default_reviewer_group?.value?.length && controls?.program_default_reviewer?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_reviewer_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_reviewer_group?.value[0],'DEFAULT_REVIEWER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_reviewer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_reviewer_group?.value[0]?.group_name}}\n </span>\n </span>\n <button *ngIf=\"controls?.program_default_reviewer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"defaultReviewerGroup.popover()\" placement=\"right\">+{{controls?.program_default_reviewer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_REVIEWER'\"\n (click)=\"activateList('DEFAULT_REVIEWER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #defaultReviewer [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let reviewer of controls?.program_default_reviewer?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(reviewer, 'DEFAULT_REVIEWER')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ reviewer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #defaultReviewerGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_reviewer_group?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(group, 'DEFAULT_REVIEWER_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <div\n class=\"radio-group-selector\"\n [class.disabled]=\"activeList === 'REVIEWER'\"\n >\n <app-cs-radio\n [name]=\"'reviewer'\"\n [checked]=\"\n controls?.reviewer_completion_criteria?.value === 'SEQUENTIAL'\n \"\n (checkedEvent)=\"\n setFormField('reviewer_completion_criteria', 'SEQUENTIAL')\n \"\n [class.disabled]=\"\n controls?.program_default_reviewer_group?.value?.length > 0\n \"\n >\n SEQUENTIAL\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'The responsibility will be sent for review one at a time in the sequence defined by you.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n <app-cs-radio\n [name]=\"'reviewer'\"\n [checked]=\"\n controls?.reviewer_completion_criteria?.value === 'ANYONE' ||\n controls?.program_default_reviewer_group?.value?.length > 0\n \"\n (checkedEvent)=\"\n setFormField('reviewer_completion_criteria', 'ANYONE')\n \"\n >\n ANY REVIEWER CAN MARK THIS AS REVIEWED\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'The responsibility will be sent for review to all reviewers at the same time. If anyone of the reviewer reviews the responsibility, it will be considered as reviewed.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n </div>\n </form-field>\n\n <!-- Overseer -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.OVERSEER\"\n [checked]=\"\n controls?.program_overseer?.value?.length ||\n controls?.program_default_overseer?.value?.length ||\n controls?.program_default_overseer?.value?.length ||\n controls?.program_default_overseer_group?.value?.length\n \"\n [active]=\"activeList === 'OVERSEER'\"\n [disabled]=\"\n sideElements?.includes(activeList) &&\n !['OVERSEER', 'DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(\n activeList\n )\n \"\n [img]=\"ASSETS.oversight\"\n >\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"\n ['DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n \"\n >Oversights\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Oversights receive updates when a responsibility is completed, completed with delay or not completed. Where Oversights are selected when creating a Program, only those Oversights will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"overseerHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"\n ['DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n \"\n [placeholder]=\"\n 'Who is responsible for overseeing the responsibilities within this Program?'\n \"\n (select)=\"activateList('OVERSEER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_overseer?.value?.length ||\n controls?.program_overseer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_overseer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(controls?.program_overseer?.value[0], 'OVERSEER')\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_overseer?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_overseer?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseers.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_overseer?.value?.length > 1\"\n >\n +{{ controls?.program_overseer?.value?.length - 1 }}\n </button>\n </div>\n <span\n *ngIf=\"\n controls?.program_overseer_group?.value?.length &&\n controls?.program_overseer?.value?.length\n \"\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_overseer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_overseer_group?.value[0],\n 'OVERSEER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_overseer_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_overseer_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseerGroup.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_overseer_group?.value?.length > 1\"\n >\n +{{ controls?.program_overseer_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_overseer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_overseer?.value[0],'OVERSEER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_overseer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">\n {{controls?.program_overseer?.value[0]?.member_name}}\n </span>\n </span>\n <button *ngIf=\"controls?.program_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseers.popover()\" placement=\"right\">+{{controls?.program_overseer?.value?.length -1}}</button>\n </div>\n <span *ngIf=\"controls?.program_overseer_group?.value?.length && controls?.program_overseer?.value?.length \" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_overseer_group?.value?.length \">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_overseer_group?.value[0],'OVERSEER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_overseer_group?.value[0]?.group_name}}</span></span>\n <button *ngIf=\"controls?.program_overseer_group?.value?.length> 1\" class=\"count\" appPopover (click)=\"overseerGroup.popover()\" placement=\"right\">+{{controls?.program_overseer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n\n <button\n *ngIf=\"activeList !== 'OVERSEER'\"\n (click)=\"activateList('OVERSEER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #overseers [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let overseer of controls?.program_overseer?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i class=\"icons\" (click)=\"remove(overseer, 'OVERSEER')\"\n >&#xe90d;</i\n >\n {{ overseer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #overseerGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_overseer_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(group, 'OVERSEER_GROUP')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <ng-container [class.disabled]=\"activeList === 'OVERSEER'\">\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"['OVERSEER'].includes(activeList)\"\n >DEFAULT Oversight\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'This option lets you specify the Default Oversight for responsibilities linked with a Program. Where a user has been specified as a Default Oversight, that user will automatically be selected as the Oversight when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"DOHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [disabled]=\"\n ['OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n \"\n [selectDiv]=\"true\"\n [placeholder]=\"\n 'Which persons will be selected as the default overseers for the responsibilities within this Program?'\n \"\n (select)=\"activateList('DEFAULT_OVERSEER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_overseer?.value?.length ||\n controls?.program_default_overseer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_overseer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_overseer?.value[0],\n 'DEFAULT_OVERSEER'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_overseer?.value[0]?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_overseer?.value[0]?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseersDefault.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_default_overseer?.value?.length > 1\"\n >\n +{{ controls?.program_default_overseer?.value?.length - 1 }}\n </button>\n </div>\n <span\n *ngIf=\"\n controls?.program_default_overseer_group?.value?.length &&\n controls?.program_default_overseer?.value?.length\n \"\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_overseer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_overseer_group?.value[0],\n 'DEFAULT_OVERSEER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_overseer_group?.value[0]\n ?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_overseer_group?.value[0]\n ?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseerDefaultGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_overseer_group?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_overseer_group?.value?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_overseer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_overseer?.value[0],'DEFAULT_OVERSEER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_overseer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_overseer?.value[0]?.member_name}}</span></span>\n <button *ngIf=\"controls?.program_default_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseersDefault.popover()\" placement=\"right\">+{{controls?.program_default_overseer?.value?.length -1}}</button>\n </div>\n <span *ngIf=\"controls?.program_default_overseer_group?.value?.length && controls?.program_default_overseer?.value?.length\" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_overseer_group?.value?.length \">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_overseer_group?.value[0],'DEFAULT_OVERSEER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_overseer_group?.value[0]?.group_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_overseer_group?.value?.length >1\" class=\"count\" appPopover (click)=\"overseerDefaultGroup.popover()\" placement=\"right\">+{{controls?.program_default_overseer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_OVERSEER'\"\n (click)=\"activateList('DEFAULT_OVERSEER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #overseersDefault [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let overseer of controls?.program_default_overseer?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n class=\"icons\"\n (click)=\"remove(overseer, 'DEFAULT_OVERSEER')\"\n >&#xe90d;</i\n >\n {{ overseer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #overseerDefaultGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_overseer_group?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(group, 'DEFAULT_OVERSEER_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <label class=\"vx-control-panel\"> </label>\n <input-with-pill\n class=\"vx-mt-2\"\n [selectDiv]=\"true\"\n [line]=\"3\"\n [disabled]=\"['OVERSEER', 'DEFAULT_OVERSEER'].includes(activeList)\"\n [placeholder]=\"\n 'Which persons will be selected as the default overseers for responsibilities that are not completed within this Program?'\n \"\n (select)=\"activateList('DEFAULT_FAILED_OVERSEER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_failed_overseer?.value?.length ||\n controls?.program_default_failed_overseer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_failed_overseer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_failed_overseer?.value[0],\n 'DEFAULT_FAILED_OVERSEER'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_failed_overseer?.value[0]\n ?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_failed_overseer?.value[0]\n ?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseersDefaultFail.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_failed_overseer?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_failed_overseer?.value?.length - 1\n }}\n </button>\n </div>\n <span\n *ngIf=\"\n controls?.program_default_failed_overseer_group?.value\n ?.length &&\n controls?.program_default_failed_overseer?.value?.length\n \"\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"\n controls?.program_default_failed_overseer_group?.value?.length\n \"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_failed_overseer_group?.value[0],\n 'DEFAULT_FAILED_OVERSEER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_failed_overseer_group?.value[0]\n ?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_failed_overseer_group?.value[0]\n ?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseerDefaultFailGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_failed_overseer_group?.value\n ?.length > 1\n \"\n >\n +{{\n controls?.program_default_failed_overseer_group?.value\n ?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_failed_overseer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_failed_overseer?.value[0],'DEFAULT_FAILED_OVERSEER')\" >&#xe90d;</i>\n <span class=\"chip\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_failed_overseer?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_failed_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseersDefaultFail.popover()\" placement=\"right\">+{{controls?.program_default_failed_overseer?.value?.length -1}}</button>\n </div>\n <span *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length && controls?.program_default_failed_overseer?.value?.length\" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length \">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_failed_overseer_group?.value[0],'DEFAULT_FAILED_OVERSEER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_failed_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_failed_overseer_group?.value[0]?.group_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"overseerDefaultFailGroup.popover()\" placement=\"right\">+{{controls?.program_default_failed_overseer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_FAILED_OVERSEER'\"\n (click)=\"activateList('DEFAULT_FAILED_OVERSEER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #overseersDefaultFail [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let overseer of controls?.program_default_failed_overseer\n ?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n class=\"icons\"\n (click)=\"remove(overseer, 'DEFAULT_FAILED_OVERSEER')\"\n >&#xe90d;</i\n >\n {{ overseer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #overseerDefaultFailGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_failed_overseer_group\n ?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(group, 'DEFAULT_FAILED_OVERSEER_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </ng-container>\n </form-field>\n\n <!-- Assessment -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.ASSESSMENT\"\n [checked]=\"controls?.program_assessments?.value?.length\"\n [active]=\"activeList === 'ASSESSMENT'\"\n [disabled]=\"\n sideElements.includes(activeList) && activeList !== 'ASSESSMENT'\n \"\n [img]=\"ASSETS.assessments\"\n >\n <label class=\"vx-control-panel\"\n >ASSESSMENTS\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Assessments are a digital form that are created in \u201CAssessment\u201D within the Compliance Module. Where Assessments are selected when creating a Program, only those Assessments will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"AssessmentHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [placeholder]=\"\n 'Which assessments can be linked to the responsibilities within this Program?'\n \"\n (select)=\"activateList('ASSESSMENT')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"controls?.program_assessments?.value?.length\"\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"\n controls?.program_assessments?.value\n | assessmentResolver as assessments\n \"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"remove(assessments[0], 'ASSESSMENT')\"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"assessments[0]?.assessment_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ assessments[0]?.assessment_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"program_assessments.popover()\"\n placement=\"right\"\n *ngIf=\"assessments?.length > 1\"\n >\n +{{ assessments?.length - 1 }}\n </button>\n </div>\n\n <!-- <div class=\"chip-container\">\n <ng-container *ngIf=\"(controls?.program_assessments?.value | assessmentResolver) as assessments\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i class=\"icons\" (click)=\"remove(assessments[0],'ASSESSMENT')\">&#xe90d;</i>{{assessments[0]?.assessment_name}} </span>\n <button *ngIf=\"assessments?.length > 1\" class=\"count\" appPopover (click)=\"program_assessments.popover()\" placement=\"right\">+{{assessments?.length -1 }}</button>\n </div>\n </ng-container>\n </div> -->\n <button\n *ngIf=\"activeList !== 'ASSESSMENT'\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('ASSESSMENT')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #program_assessments [dontCloseonClick]=\"true\">\n <ng-container>\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let assessment of controls?.program_assessments?.value\n | assessmentResolver\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(assessment, 'ASSESSMENT')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ assessment?.assessment_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </ng-container>\n </app-popover>\n </form-field>\n\n <!-- Format & Evidence -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.FORMATE_EVIDENCE\"\n [checked]=\"[true, false].includes(controls?.evidence_required?.value)\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.format_evidence\"\n >\n <label class=\"vx-control-panel\"\n >Evidence\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If selected, evidence of completion of a responsibility will be required for all responsibilities that are linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"EvidenceHelpText\"\n >&#xeb16;</i\n ></label\n >\n <div class=\"upload-format\">\n <span class=\"text\"\n >Do all responsibilities within this program require evidence?</span\n >\n <div class=\"radio-group program\">\n <app-cs-radio\n [name]=\"'evidence_required'\"\n [checked]=\"controls?.evidence_required?.value\"\n (checkedEvent)=\"setFormField('evidence_required', true)\"\n >YES</app-cs-radio\n >\n <app-cs-radio\n [name]=\"'evidence_required'\"\n [checked]=\"!controls?.evidence_required?.value\"\n (checkedEvent)=\"setFormField('evidence_required', false)\"\n >NO</app-cs-radio\n >\n </div>\n </div>\n <!-- <div class=\"vx-d-flex vx-align-center vx-justify-end vx-mt-2\">\n <div class=\"vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase vx-mr-2\">Allow any file to be marked as\n key\n evidence</div>\n <switch formControlName=\"allow_any_file_key_evidence\"\n (change)=\"setFormField('allow_any_file_key_evidence',$event?.target?.checked)\"></switch>\n </div> -->\n </form-field>\n\n <!-- Custom Field -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.CUSTOM_FIELDS\"\n [checked]=\"controls?.custom_fields?.value?.length\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.custom_fields\"\n >\n <label class=\"vx-control-panel\"\n >CUSTOM FIELD\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Where a custom field is specified, all responsibilities linked with a Program will contain that custom field. Custom fields enable the collection of additional meta data.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"CFHelpText\"\n >&#xeb16;</i\n ></label\n >\n <custom-field formControlName=\"custom_fields\"></custom-field>\n </form-field>\n </form>\n</div>\n\n\n<!-- render userlist with group -->\n<user-group-list\n *ngIf=\"activeList === 'OWNER'\"\n [groupEnabled]=\"true\"\n [singleSelect]=\"false\"\n [loading]=\"listLoadingState.USERS\"\n [userlist]=\"lists?.OWNERS?.data ?? []\"\n [selectedUsers]=\"controls?.program_owners?.value | refDisconnect\"\n (fetchUserData)=\"fetchUsersAssociatedWithRoles(false, $event)\"\n [userListInfo]=\"lists?.OWNERS\"\n [groupListInfo]=\"lists?.OWNERS_GROUPS\"\n [groupList]=\"lists?.OWNERS_GROUPS?.data ?? []\"\n [selectedGroups]=\"controls?.program_owners_group?.value | refDisconnect\"\n (save)=\"listAction($event, 'OWNER')\"\n (cancel)=\"fieldDeselector('OWNER')\"\n [panelTitle]=\"panelTitleOwner\"\n [featureflag]=\"featureflagGroups\"\n></user-group-list>\n<user-group-list\n *ngIf=\"activeList === 'COLLABORATORS'\"\n [groupEnabled]=\"true\"\n [singleSelect]=\"false\"\n [loading]=\"listLoadingState.USERS\"\n [userlist]=\"lists?.OWNERS?.data ?? []\"\n [selectedUsers]=\"controls?.collaborators?.value | refDisconnect\"\n [groupList]=\"lists?.OWNERS_GROUPS ?? []\"\n [FromProgram]=\"true\"\n [selectedGroups]=\"controls?.collaborators_group?.value | refDisconnect\"\n [assignorId]=\"assignorId\"\n [userListInfo]=\"lists?.ASSIGNEES\"\n (save)=\"listAction($event, 'COLLABORATORS')\"\n (cancel)=\"fieldDeselector('COLLABORATORS')\"\n [panelTitle]=\"panelTitleAssignee\"\n [defaultSelectedUsers]=\"\n controls?.collaborators?.value | refDisconnect\n \"\n [userType]=\"'assignees'\"\n [featureflag]=\"featureflagGroups\"\n>\n</user-group-list>\n<app-loader-inline *ngIf=\"loader\"></app-loader-inline>\n<app-smiley-dialog-inline\n *ngIf=\"showSmiley\"\n [message]=\"smileyMessage\"\n [actionButtons]=\"actionButtons\"\n (action)=\"action($event)\"\n (closeSmiley)=\"closeSmiley($event)\"\n>\n</app-smiley-dialog-inline>\n\n<!-- Framework selector -->\n<app-framework-list\n *ngIf=\"activeList === 'FRAMEWORK'\"\n [workflowPage]=\"['FRAMEWORK']\"\n (assignControl)=\"listAction($event, 'FRAMEWORK')\"\n (closeFramework)=\"fieldDeselector('FRAMEWORK')\"\n [previousSelectedValues]=\"{ framework: controls?.framework.value }\"\n (entrustFramework)=\"entrustFramework($event)\"\n [headerText]=\"'Select a framework'\"\n></app-framework-list>", 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/padding/padding.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\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.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-top.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\";::ng-deep .workflow-program{display:block;position:relative}::ng-deep .workflow-program .scope-label{background:#747576;border-radius:.125rem;position:relative;z-index:1}::ng-deep .workflow-program .scope-label:before{background:#f1f1f1;content:\"\";position:absolute;top:.5rem;left:7rem;width:20rem;height:1px;z-index:-1}::ng-deep .workflow-program .scope-label:after{background:#f1f1f1;content:\"\";position:absolute;top:.5rem;left:-2.5rem;width:2.5rem;height:1px;z-index:-1}::ng-deep .workflow-program .scope-label .required{position:absolute;top:0;right:-.625rem}::ng-deep .workflow-program .info-icon{position:relative;top:.125rem;cursor:pointer}::ng-deep .workflow-program .date-picker .picker-group{width:calc(50% - .125rem);position:relative}::ng-deep .workflow-program .date-picker .picker-group:focus-within{border-color:#1e5dd3;box-shadow:0 0 5px #1e5dd345}::ng-deep .workflow-program .date-picker .picker-group input{height:2.5rem;border-radius:.25rem;border:1px solid #DBDBDB;background:#fff;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%;padding:0 2rem 0 .75rem;outline:none}::ng-deep .workflow-program .date-picker .picker-group input:focus,::ng-deep .workflow-program .date-picker .picker-group input:hover{border-color:#1e5dd3;box-shadow:0 0 5px #1e5dd345}::ng-deep .workflow-program .date-picker .picker-group input::placeholder{color:#747576;font-size:13px}::ng-deep .workflow-program .date-picker .picker-group input:-ms-input-placeholder{color:#747576;font-size:13px}::ng-deep .workflow-program .date-picker .picker-group input::-ms-input-placeholder{color:#747576;font-size:13px}::ng-deep .workflow-program .date-picker .picker-group i{height:1rem;width:1rem;position:absolute;right:.75rem;top:.625rem;pointer-events:none}::ng-deep .workflow-program .program-type-field{background:#f8f8f8;border:1px solid #dbdbdb;border-radius:4px;height:40px;display:flex;align-items:center;justify-content:space-between;padding:4px;position:relative;z-index:1}::ng-deep .workflow-program .program-type-field .type-item{position:relative}::ng-deep .workflow-program .program-type-field .type-item:first-of-type{width:6.25rem}::ng-deep .workflow-program .program-type-field .type-item:nth-child(2){width:5.75rem}::ng-deep .workflow-program .program-type-field .type-item:nth-child(2).active~.background-glider{transform:translate(6.4375rem);width:5.75rem}::ng-deep .workflow-program .program-type-field .type-item:nth-child(3){width:8.625rem}::ng-deep .workflow-program .program-type-field .type-item:nth-child(3).active~.background-glider{transform:translate(12.375rem);width:8.625rem}::ng-deep .workflow-program .program-type-field .type-item:last-of-type{width:5.25rem}::ng-deep .workflow-program .program-type-field .type-item:last-of-type.active~.background-glider{transform:translate(21.1875rem);width:5.25rem}::ng-deep .workflow-program .program-type-field .type-item button{background:transparent;border:none;border-radius:0;color:#747576;font-size:11px;font-weight:600;text-transform:uppercase;width:100%;height:32px;padding:0 12px;text-align:center}::ng-deep .workflow-program .program-type-field .type-item button.disabled{background:transparent!important;color:#dbdbdb!important;filter:unset!important;opacity:unset!important;pointer-events:none}::ng-deep .workflow-program .program-type-field .type-item .info{color:#1e5dd3;font-size:12px;position:absolute;top:10px;right:12px;cursor:pointer}::ng-deep .workflow-program .program-type-field .type-item.active button{color:#1e5dd3!important}::ng-deep .workflow-program .program-type-field .background-glider{background:#fff;border-radius:4px;box-shadow:0 1px 3px #161b2f26;position:absolute;display:flex;width:6.25rem;height:32px;z-index:-1;transition:.25s ease-out}::ng-deep .workflow-program .vx-form-group .upload-files .file-item{background:#f1f1f1;border:1px solid #dbdbdb;border-radius:.25rem;padding-left:.125rem}::ng-deep .workflow-program .vx-form-group .upload-files .file-item .file-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;max-width:8.5rem}::ng-deep .workflow-program .vx-form-group .upload-files .file-item button.delete-btn{background:transparent;border-radius:0;border:none;border-left:1px solid #dbdbdb;height:1.625rem}::ng-deep .workflow-program .vx-form-group .upload-files button.file-count{background:#1e5dd3;border-radius:.125rem;border:none;color:#fff;font-size:11px;display:flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0;margin:4px 0 0 4px}::ng-deep .workflow-program .vx-form-group .upload-format .radio-group app-cs-radio{height:1.375rem}::ng-deep .workflow-program .vx-form-group .default-selected{background:#fbfbfb;border:1px solid #F1F1F1;border-radius:.25rem;margin-top:.5rem}::ng-deep .workflow-program .vx-form-group .default-selected .selected{border-radius:0;border:none;background:none}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio{border-top:1px solid #F1F1F1}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio{margin-top:0!important}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item span.radio{position:absolute;top:.5rem;left:.75rem}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item span.value{font-size:11px;text-transform:uppercase;padding:.5rem .5rem .5rem 2.25rem;width:100%;display:flex;justify-content:space-between;margin:0;max-width:100%;font-weight:500;color:#707070}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item span.value i{font-size:12px;color:#1e5dd3}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item svg{position:absolute;top:.5rem;left:.75rem}::ng-deep .workflow-program .vx-form-group .selected .custom-text{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;max-height:2.4rem}::ng-deep .workflow-program .vx-form-group .selected button.cross-btn{background:transparent;border-radius:0;border:0;padding:0}::ng-deep .workflow-program .vx-form-group .custom-input{position:relative}::ng-deep .workflow-program .vx-form-group .custom-input input{padding-right:2rem}::ng-deep .workflow-program .vx-form-group .custom-input button.cross-btn{background:transparent;border-radius:0;border:0;position:absolute;top:.875rem;right:.625rem}::ng-deep .workflow-program .vx-form-group button.add-more-btn{background:transparent;border-radius:0;border:none;padding:0}::ng-deep app-popover .wf-action-list ul.action-item .avatar-card .value{text-transform:none!important}::ng-deep app-popover .wf-action-list ul.action-item li file-pill .file-item{background:transparent!important;border:none!important;border-radius:0!important;padding:0!important;margin:0!important}::ng-deep app-popover .wf-action-list ul.action-item li file-pill .file-name{width:100%!important;max-width:100%!important}::ng-deep app-popover .wf-action-list ul.action-item li file-pill button.delete-btn{border:none!important;padding-right:0!important}.disabled{opacity:.4;pointer-events:none;filter:grayscale(1)}.vx-info-card{width:280px;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both;background:#fff;box-shadow:0 3px 6px #1c5bd140;border-radius:4px;position:static;display:block;left:780}.vx-info-card-body{font-size:12px;padding:8px 12px;margin:0;font-weight:400;text-transform:none;color:#747576}\n", "@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\";::-webkit-scrollbar-track{background-color:#f1f1f1;position:absolute}::-webkit-scrollbar{width:3px;height:3px;background-color:transparent;position:absolute}::-webkit-scrollbar-thumb{border-radius:3px;background-color:#dbdbdb;position:absolute}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}button{font-family:Poppins,sans-serif}::ng-deep input.textField{background:#fff;border-radius:.25rem;border:1px solid #dbdbdb;font-size:13px;color:#747576;padding:8px 12px;position:relative;height:2.5rem;width:100%;transition:all .2s ease-in-out}::ng-deep input.textField::placeholder{font-size:13px;color:#747576}::ng-deep input.textField:hover,::ng-deep input.textField:focus{outline:none;border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .selectBoxEnable{background:#fff;border-radius:.25rem;border:1px solid #dbdbdb;cursor:pointer;height:2.5rem;position:relative;transition:all .2s ease-in-out}::ng-deep .selectBoxEnable:after{border-bottom-style:solid;border-bottom-width:1px;border-right-style:solid;border-right-width:1px;border-color:#747576;content:\"\";display:inline-block;right:12px;position:absolute;top:calc(50% - 4px);width:5px;height:5px;transform:rotate(45deg)}::ng-deep .selectBoxEnable:hover,::ng-deep .selectBoxEnable:focus{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .selectBoxEnable.disabled{background:#f1f1f1;pointer-events:none;opacity:1}::ng-deep .selectBoxEnable.withBtn:after{display:none}::ng-deep .selectBoxEnable.withBtn button.setBtn{background:transparent;border-radius:0;border:none;min-width:98px}::ng-deep .selectBoxSuccess{background:#f8f8f8;border-radius:.25rem;border:1px solid #f1f1f1;min-height:2.5rem;position:relative}::ng-deep .selectBoxSuccess .selectBoxText{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;width:22rem}::ng-deep .selectBoxSuccess button{background:transparent;border-radius:0;border:none}::ng-deep .selectBoxSuccess button.deleteBtn{color:#d93b41}::ng-deep .selectBoxSuccess .level-left{border-right:1px solid #f1f1f1;height:2.375rem;width:5rem}::ng-deep .selectBoxSuccess .level-left .level-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;width:4.5rem}::ng-deep .chipContainer{background:#fff;border-radius:.125rem;box-shadow:0 0 2px #1e5dd340;height:1.5rem}::ng-deep .chipContainer .cross{cursor:pointer;min-width:16px;width:16px;height:16px;display:flex;align-items:center;justify-content:center;background:transparent;border-radius:2px;margin-left:-4px}::ng-deep .chipContainer .cross:hover{background:#f1f1f1}::ng-deep .chipContainer .chipName{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;max-width:6rem}::ng-deep .chipContainer .chipName.no-width{max-width:unset}::ng-deep .chipContainer .chipName.full-width{max-width:25rem}::ng-deep .chipContainer button.countBtn{background:#1e5dd3;border-radius:1.25rem;border:none;min-width:1.5rem;height:1rem;margin:0 0 0 .5rem;padding:0 .25rem}::ng-deep .chipContainer button.countBtn.greenBg{background:#34aa44}::ng-deep .workflowLavel{background:#f1f1f1;border-radius:.125rem;color:#042e7d;min-width:1rem;height:1rem}::ng-deep .reviewSelection{border-radius:.25rem;border:1px solid #dbdbdb;transition:all .2s ease-in-out}::ng-deep .reviewSelection:hover{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .selectButton{background:#fff;border-radius:.25rem;border:1px solid #dbdbdb;cursor:pointer;height:2.5rem;position:relative;transition:all .2s ease-in-out}::ng-deep .selectButton:hover,::ng-deep .selectButton:focus{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep button.createNewBtn{background:transparent;border-radius:0;border:none}::ng-deep .vx-form-group{display:block;position:relative;margin-bottom:20px}::ng-deep .vx-form-group:after{content:\"\";display:block;clear:both}::ng-deep .vx-form-group .select{position:relative}::ng-deep .vx-form-group .select:after{border-bottom-style:solid;border-bottom-width:1px;border-right-style:solid;border-right-width:1px;border-color:#707070;content:\"\";display:inline-block;right:12px;position:absolute;top:calc(50% - 4px);width:5px;height:5px;transform:rotate(45deg)}::ng-deep .vx-form-group .select input{cursor:pointer;padding-right:30px!important}::ng-deep .vx-form-group .select .custom-input{height:40px;border-radius:4px;border:1px solid #dbdbdb;background:#fff;outline:none;padding:3px 12px;line-height:16px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%;cursor:pointer}::ng-deep .vx-form-group .select .custom-input:empty:not(:focus):before{content:attr(aria-placeholder);line-height:16px;font-size:13px;width:94%;display:block;pointer-events:none;opacity:.8}::ng-deep .vx-form-group .select .custom-input:hover{border-color:#1e5dd3;box-shadow:0 0 5px #1e5dd345}::ng-deep .vx-form-group .select .custom-input.frequency-custom-input{padding-right:108px;display:flex;align-items:center}::ng-deep .vx-form-group .select+app-cs-switch{display:block;margin-top:8px}::ng-deep .vx-form-group .select+app-cs-switch label.cs-switch span.value{white-space:nowrap;margin-right:5px;text-transform:uppercase}::ng-deep .vx-form-group .select+app-cs-radio{margin-top:8px!important}::ng-deep .vx-form-group .select~app-cs-radio{margin-top:4px;display:block;width:100%}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item span.radio{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item span.value{font-size:11px;text-transform:uppercase;border:1px solid #dbdbdb;border-radius:4px;padding:8px 8px 8px 36px;width:100%;display:flex;justify-content:space-between;margin:0;max-width:100%;font-weight:500;color:#707070}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item span.value i{font-size:12px;color:#1e5dd3}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item svg{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item input:checked~span.value{background:#eefcf0;border-color:#34aa44}::ng-deep .vx-form-group .select.button-sec:after{display:none}::ng-deep .vx-form-group .select.button-sec button{background:transparent;border:none;display:inline-flex;float:right;color:#1e5dd3;text-transform:uppercase;font-weight:600;cursor:pointer;font-size:11px;position:absolute;top:12px;right:8px;padding:0;margin:0}::ng-deep .vx-form-group .select+.vx-control-panel{margin-top:8px}::ng-deep .vx-form-group .select+.selected{margin-top:8px}::ng-deep .vx-form-group .select.select{margin-top:8px}::ng-deep .vx-form-group .upload-format{border:1px solid #dbdbdb;border-radius:4px;padding:8px 12px;display:block}::ng-deep .vx-form-group .upload-format span.text{line-height:20px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%;display:block;margin-bottom:6px}::ng-deep .vx-form-group .upload-format .radio-group{display:flex}::ng-deep .vx-form-group .upload-format .radio-group app-cs-radio{display:inline-block}::ng-deep .vx-form-group .upload-format .radio-group app-cs-radio label.radio-item span.value{font-size:11px;text-transform:uppercase;margin-left:8px}::ng-deep .vx-form-group .upload-format .radio-group app-cs-radio+app-cs-radio{margin-left:12px}::ng-deep .vx-form-group .upload-format~.upload-format{margin-top:4px}::ng-deep .vx-form-group .form-tab{display:flex;justify-content:flex-start}::ng-deep .vx-form-group .form-tab button{background:transparent;color:#161b2f;font-size:11px;line-height:16px;text-transform:uppercase;cursor:pointer;padding:8px 8px 8px 0;border:none;outline:none;font-weight:500}::ng-deep .vx-form-group .form-tab button:disabled{opacity:.5;pointer-events:none;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group .form-tab button+button{padding:8px}::ng-deep .vx-form-group .form-tab button.active{color:#1e5dd3}::ng-deep .vx-form-group .tab-group{border:1px solid #dbdbdb;border-radius:4px;padding:0;display:block;position:relative;transition:all .2s ease-in-out}::ng-deep .vx-form-group .tab-group:hover{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .vx-form-group .tab-group .upload-file{padding:16px 62px 16px 24px;display:flex;align-items:center;justify-content:space-between}::ng-deep .vx-form-group .tab-group .upload-file .image{width:80px}::ng-deep .vx-form-group .tab-group .upload-file .browse span{display:inline-block;font-size:12px;color:#747576;line-height:16px;padding:0 4px}::ng-deep .vx-form-group .tab-group .upload-file .browse .label{font-size:11px;color:#1e5dd3;line-height:16px;font-weight:600;text-transform:uppercase;margin:0;padding:0}::ng-deep .vx-form-group .tab-group .upload-file .browse .label input{opacity:0;position:absolute;margin:0;padding:0;inset:0;cursor:pointer;width:100%}::ng-deep .vx-form-group .tab-group.active{border-color:#1e5dd3}::ng-deep .vx-form-group .tab-group.uploaded{margin-top:4px}::ng-deep .vx-form-group .tab-group.uploaded .upload-file{padding:8px 0!important;text-align:center}::ng-deep .vx-form-group .tab-group.uploaded .upload-file .image{display:none}::ng-deep .vx-form-group .tab-group.uploaded .upload-file .browse{width:100%;text-align:center}::ng-deep .vx-form-group .tab-group+label.vx-form-group{margin-top:8px;margin-bottom:4px}::ng-deep .vx-form-group .file-list{background:#fbfbfb;border:1px solid #f1f1f1;border-radius:4px;padding:12px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;position:relative}::ng-deep .vx-form-group .file-list span.file-name{color:#747576;line-height:16px;font-size:11px;font-weight:400;cursor:pointer;max-width:calc(100% - 20px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}::ng-deep .vx-form-group .file-list .button-group{display:flex}::ng-deep .vx-form-group .file-list button{font-size:12px;color:#eb2424;cursor:pointer;display:flex;padding:0;border:none;outline:none;background:transparent}::ng-deep .vx-form-group .file-list button.edit{color:#1e5dd3}::ng-deep .vx-form-group .file-list button+button{margin-left:16px}::ng-deep .vx-form-group .file-list+.file-list{margin-top:4px}::ng-deep .vx-form-group .file-list .file-container{display:flex;justify-content:space-between;width:100%}::ng-deep .vx-form-group .file-list.policy{background:#fff}::ng-deep .vx-form-group .file-list cs-select{position:relative;margin-top:8px;width:100%}::ng-deep .vx-form-group .file-list cs-select .selection-wrap .input-group input.value{height:32px!important;font-size:13px!important}::ng-deep .vx-form-group .file-list cs-select .selection-wrap .input-group i{right:12px!important;top:12px!important}::ng-deep .vx-form-group .file-list app-line-loader{display:block;position:absolute;left:10px;right:10px;bottom:0}::ng-deep .vx-form-group label.vx-control-panel{color:#161b2f;font-size:11px;font-weight:500;line-height:16px;margin-bottom:8px;display:block;text-transform:uppercase;text-align:left}::ng-deep .vx-form-group label.vx-control-panel.custom-tag{font-size:10px}::ng-deep .vx-form-group label.vx-control-panel.vx-mt-8{margin-top:8px}::ng-deep .vx-form-group label.vx-control-panel span.required{color:#eb2424;font-size:14px;font-weight:500;position:relative;top:-2px}::ng-deep .vx-form-group label.vx-control-panel .button{background:transparent;border:none;display:inline-flex;float:right;color:#1e5dd3;text-transform:uppercase;font-weight:600;cursor:pointer;font-size:11px;padding:0;margin:0}::ng-deep .vx-form-group label.vx-control-panel app-cs-switch{float:right;display:block}::ng-deep .vx-form-group label.vx-control-panel i{margin-left:8px;font-size:12px;color:#1e5dd3;cursor:pointer;position:relative;top:1px}::ng-deep .vx-form-group label.vx-control-panel i.depreciation-icon{color:#e4b700;font-size:16px;position:relative;top:3px}::ng-deep .vx-form-group label.vx-control-panel .checkpoint-version{background:#f1f1f1;border-radius:2px;color:#042e7d;font-size:10px;font-weight:600;line-height:14px;margin-left:4px;padding:0 2px}::ng-deep .vx-form-group input[type=text],::ng-deep .vx-form-group .input{height:40px;border-radius:4px;border:1px solid #dbdbdb;background:#fff;outline:none;padding:8px 12px;line-height:20px;font-size:13px;color:#747576;transition:all .2s ease-in-out;width:100%;font-weight:400}::ng-deep .vx-form-group input[type=text]::placeholder,::ng-deep .vx-form-group .input::placeholder{color:#747576;font-weight:400}::ng-deep .vx-form-group input[type=text]:focus,::ng-deep .vx-form-group .input:focus,::ng-deep .vx-form-group input[type=text]:hover,::ng-deep .vx-form-group .input:hover{border-color:#1e5dd3!important;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .vx-form-group input[type=text].error,::ng-deep .vx-form-group .input.error{border-color:#eb2424;color:#eb2424;margin-bottom:4px}::ng-deep .vx-form-group input[type=text].error:focus,::ng-deep .vx-form-group .input.error:focus{box-shadow:0 0 5px #d31e1e45}::ng-deep .vx-form-group input[type=text]:disabled,::ng-deep .vx-form-group .input:disabled{background:#f1f1f1;cursor:not-allowed;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group input[type=text]:disabled:hover,::ng-deep .vx-form-group .input:disabled:hover{border-color:#dbdbdb;box-shadow:none}::ng-deep .vx-form-group input[type=text] span.text,::ng-deep .vx-form-group .input span.text{font-size:13px;color:#747576;font-weight:400;display:block;width:100%}::ng-deep .vx-form-group input[type=text] .input-group,::ng-deep .vx-form-group .input .input-group{display:flex;align-items:center}::ng-deep .vx-form-group input[type=text] .input-group.counter,::ng-deep .vx-form-group .input .input-group.counter{min-width:96px;width:96px}::ng-deep .vx-form-group input[type=text] .input-group.counter button,::ng-deep .vx-form-group .input .input-group.counter button{height:24px;width:24px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#747576;font-size:8px;cursor:pointer;outline:none}::ng-deep .vx-form-group input[type=text] .input-group.counter input,::ng-deep .vx-form-group .input .input-group.counter input{-webkit-appearance:textfield;-moz-appearance:textfield;height:24px;width:calc(100% - 48px);border:1px solid #f1f1f1;outline:none;padding:0 6px;text-align:center}::ng-deep .vx-form-group input[type=text] .input-group.counter input::-webkit-inner-spin-button,::ng-deep .vx-form-group .input .input-group.counter input::-webkit-inner-spin-button,::ng-deep .vx-form-group input[type=text] .input-group.counter input::-webkit-outer-spin-button,::ng-deep .vx-form-group .input .input-group.counter input::-webkit-outer-spin-button{appearance:none;margin:0}::ng-deep .vx-form-group input[type=text]+.file-list,::ng-deep .vx-form-group .input+.file-list{margin-top:8px}::ng-deep .vx-form-group input[type=text]::placeholder,::ng-deep .vx-form-group .input::placeholder{font-size:13px}::ng-deep .vx-form-group input[type=text]:-ms-input-placeholder,::ng-deep .vx-form-group .input:-ms-input-placeholder{font-size:13px}::ng-deep .vx-form-group input[type=text]::-ms-input-placeholder,::ng-deep .vx-form-group .input::-ms-input-placeholder{font-size:13px}::ng-deep .vx-form-group .classification{height:40px;border-radius:4px;border:1px solid #dbdbdb;background:#fff;padding:8px 12px;display:flex;justify-content:space-between}::ng-deep .vx-form-group .classification label{margin:0 4px 0 0;width:100%;position:relative;z-index:1}::ng-deep .vx-form-group .classification label span{display:block;width:100%;height:24px;border:1px solid #f1f1f1;border-radius:2px;line-height:24px;font-size:10px;text-align:center;color:#747576;font-weight:500;position:relative;text-transform:uppercase}::ng-deep .vx-form-group .classification label span:before{height:2px;content:\"\";top:0;right:0;left:0;border-radius:2px;position:absolute;transition:all .2s ease-in-out}::ng-deep .vx-form-group .classification label input{opacity:0;position:absolute;inset:0;margin:0;padding:0;width:100%;height:100%;cursor:pointer;z-index:1}::ng-deep .vx-form-group .classification label input:checked+span{color:#fff}::ng-deep .vx-form-group .classification label input:checked+span:before{bottom:0;height:100%;z-index:-1}::ng-deep .vx-form-group .classification label.low span:before{background:#34aa44}::ng-deep .vx-form-group .classification label.low-med span:before{background:#f2bf19}::ng-deep .vx-form-group .classification label.med-high span:before{background:#f29619}::ng-deep .vx-form-group .classification label.high span:before{background:#eb2424}::ng-deep .vx-form-group .classification label:last-of-type{margin-right:0}::ng-deep .vx-form-group .input{display:flex;align-items:center}::ng-deep .vx-form-group .selected{height:40px;border-radius:4px;border:1px solid #f1f1f1;background:#fbfbfb;outline:none;padding:8px;line-height:20px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%;display:flex;align-items:center;position:relative;justify-content:space-between}::ng-deep .vx-form-group .selected.first-field{z-index:2}::ng-deep .vx-form-group .selected .chip-container{display:flex;width:calc(100% - 60px);align-items:center}::ng-deep .vx-form-group .selected .chip-container.checkpoints{width:calc(100% - 120px)}::ng-deep .vx-form-group .selected .chip-container span.chip{background:#fff;border-radius:2px;box-shadow:0 0 3px #1e5dd31a;height:24px;padding:0 8px;color:#1e5dd3;font-size:12px;display:block;width:auto;max-width:100%;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:24px}::ng-deep .vx-form-group .selected .chip-container span.chip.disabled{background:#f1f1f1;box-shadow:none;color:#747576;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group .selected .chip-container span.chip i{font-weight:400;margin-right:8px;cursor:pointer;font-size:10px;position:relative;top:1px}::ng-deep .vx-form-group .selected .chip-container span.chip span.step{background:#1e5dd3;border-radius:2px;color:#fff;font-size:9px;line-height:14px;padding:0 4px;font-weight:400;text-align:center;min-width:auto;margin-right:4px}::ng-deep .vx-form-group .selected .chip-container span.chip+span.chip{margin-left:4px}::ng-deep .vx-form-group .selected .chip-container span.chip.with-question{display:flex;align-items:center;justify-content:space-between;width:100%}::ng-deep .vx-form-group .selected .chip-container span.chip.with-question span.value{color:#1e5dd3;font-size:12px;font-weight:400;line-height:24px;padding:0;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;max-width:calc(100% - 80px)}::ng-deep .vx-form-group .selected .chip-container span.chip.with-question span.label{background:#f1f1f1;border-radius:2px;color:#042e7d;font-size:9px;font-weight:600;text-transform:uppercase;padding-left:4px;padding-right:4px;line-height:12px;margin-left:8px}::ng-deep .vx-form-group .selected .chip-container span.value{color:#747576;font-size:13px;line-height:20px;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:calc(100% - 52px);padding:0 4px}::ng-deep .vx-form-group .selected .chip-container span.checkpoint-point-text{color:#747576;font-size:10px;font-weight:500;padding:0 8px;width:122px;line-height:14px}::ng-deep .vx-form-group .selected .chip-container span.checkpoint-point-text.first{position:relative;min-width:162px}::ng-deep .vx-form-group .selected .chip-container span.checkpoint-point-text.first:before{background:#f1f1f1;content:\"\";position:absolute;top:0;right:0;height:calc(100% + 12px);width:1px}::ng-deep .vx-form-group .selected .chip-container span.checkpoint-point-text .no{color:#1e5dd3}::ng-deep .vx-form-group .selected .chip-container.plus span.chip{max-width:calc(50% - 35px)}::ng-deep .vx-form-group .selected .chip-container.more-one span.chip{max-width:50%}::ng-deep .vx-form-group .selected .chip-container .chip-inner{background:#fff;border-radius:2px;box-shadow:0 2px 4px #1e5dd31a;line-height:24px;padding:0 4px 0 8px;display:flex;align-items:center}::ng-deep .vx-form-group .selected .chip-container .chip-inner .chip{background:transparent;border-radius:0;box-shadow:none;height:auto;line-height:unset;padding:0;color:#747576;max-width:100px}::ng-deep .vx-form-group .selected .chip-container .chip-inner button.count{border-radius:20px;height:16px;padding:0 6px;border:none;font-size:9px;line-height:16px;margin-left:4px;min-width:20px}::ng-deep .vx-form-group .selected .chip-container .chip-inner button.count.user{background:#34aa44}::ng-deep .vx-form-group .selected .chip-container .chip-inner i.cross{cursor:pointer;position:relative;top:1px;font-size:8px}::ng-deep .vx-form-group .selected button.count{background:#1e5dd3;border-radius:2px;height:24px;padding:0 8px;border:1px solid #1e5dd3;cursor:pointer;outline:none;color:#fff;font:13px;font-weight:500;line-height:20px;white-space:nowrap;margin-left:8px}::ng-deep .vx-form-group .selected button.edit{border:none;border-radius:0;background:transparent;outline:none;cursor:pointer;display:block;font-size:11px;font-weight:600;color:#1e5dd3;text-transform:uppercase;white-space:nowrap;margin-left:8px}::ng-deep .vx-form-group .selected button.edit i{font-weight:400;font-size:8px;margin-right:4px}::ng-deep .vx-form-group .selected button.close-btn{background:transparent;border:none;padding:0;margin-left:8px;font-size:10px;color:#c7381b;display:flex;align-items:center}::ng-deep .vx-form-group .selected .workflow-label{min-width:92px;padding:4px;text-align:center;margin-left:-8px;margin-right:8px;border-right:1px solid #f1f1f1}::ng-deep .vx-form-group .selected .workflow-label p{margin:0;display:block;text-transform:uppercase}::ng-deep .vx-form-group .selected .workflow-label p.title{font-size:9px;line-height:12px;color:#161b2f;font-weight:500}::ng-deep .vx-form-group .selected .workflow-label p.description{font-size:11px;line-height:16px;color:#161b2f;font-weight:600}::ng-deep .vx-form-group .selected .workflow-label+.chip-container{width:calc(100% - 148px)}::ng-deep .vx-form-group .selected+.selected{margin-top:8px}::ng-deep .vx-form-group .selected+app-cs-switch{display:block;margin-top:8px}::ng-deep .vx-form-group .selected+app-cs-switch label.cs-switch span.value{white-space:nowrap;margin-right:5px;text-transform:uppercase}::ng-deep .vx-form-group .selected+app-cs-switch.who-toggle label.cs-switch span.value{color:#747576}::ng-deep .vx-form-group .selected+app-cs-radio{margin-top:8px!important}::ng-deep .vx-form-group .selected~app-cs-radio{margin-top:4px;display:block;width:100%}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item span.radio{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item span.value{font-size:11px;text-transform:uppercase;border:1px solid #dbdbdb;border-radius:4px;padding:8px 8px 8px 36px;width:100%;display:flex;justify-content:space-between;margin:0;max-width:100%;font-weight:500;color:#707070}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item span.value i{font-size:12px;color:#1e5dd3}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item svg{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item input:checked~span.value{background:#eefcf0;border-color:#34aa44}::ng-deep .vx-form-group .selected.readOnly{pointer-events:none}::ng-deep .vx-form-group .selected span.chip{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .vx-form-group .select-list{position:absolute;background:#fff;box-shadow:0 0 5px #1e5dd345;top:100%;right:0;left:0;z-index:2}::ng-deep .vx-form-group .select-list .vx-radio-group label.vx-radio-item{width:100%;padding:12px 16px}::ng-deep .vx-form-group .select-list .vx-radio-group label.vx-radio-item:hover{background:#f8f8f8}::ng-deep .vx-form-group ::ng-deep vcomply-editor{margin-top:8px;display:block;pointer-events:auto!important;z-index:1}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container{border-radius:4px;border:1px solid #dbdbdb}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block{min-height:60px;padding:11px 15px;max-height:100px;line-height:20px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block ul{padding:0 0 0 10px;margin-top:0}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block ul li{list-style:disc}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block ol{padding:0 0 0 10px;margin-top:0}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block ol li{list-style:decimal}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools{z-index:1;border-top:1px solid #dbdbdb;transition:none;border-radius:0 0 3px 3px;position:static}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button{height:22px!important;width:22px!important;padding:0 5px}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button svg{height:22px;width:12px}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button.submit{width:80px!important;line-height:22px;justify-content:center}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col .popover.small ul.option-list li button{width:100%!important;height:auto!important}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container:focus-within{border-color:#1e5dd3!important;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container:focus-within .editor-tools{border-color:#1e5dd3!important}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container:hover{border-color:#1e5dd3!important;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container:hover .editor-tools{border-color:#1e5dd3!important}::ng-deep .vx-form-group ::ng-deep vcomply-editor+app-cs-switch{margin-top:8px}::ng-deep .vx-form-group app-cs-switch label.cs-switch span.value{font-size:11px;color:#747576;text-transform:uppercase}::ng-deep .vx-form-group app-cs-switch+app-cs-switch{margin-top:8px}::ng-deep .vx-form-group .date-time-picker{display:flex;justify-content:space-between;height:40px;border-radius:4px;border:1px solid #dbdbdb;padding:11px 0;background:#fff}::ng-deep .vx-form-group .date-time-picker:focus-within{border-color:#1e5dd3;box-shadow:0 0 5px #1e5dd345}::ng-deep .vx-form-group .date-time-picker .picker-group{width:50%;position:relative;display:flex;align-items:center}::ng-deep .vx-form-group .date-time-picker .picker-group:first-of-type{border-right:1px solid #dbdbdb}::ng-deep .vx-form-group .date-time-picker .picker-group:only-of-type{border:none;width:100%}::ng-deep .vx-form-group .date-time-picker .picker-group input{height:38px;background:transparent;line-height:38px;font-size:13px;color:#747576;transition:all .2s ease-in-out;width:100%;font-weight:400;border:none;padding:0 12px 0 34px;outline:none}::ng-deep .vx-form-group .date-time-picker .picker-group input:focus,::ng-deep .vx-form-group .date-time-picker .picker-group input:hover{box-shadow:none;border:none}::ng-deep .vx-form-group .date-time-picker .picker-group input::placeholder{color:#999;font-size:13px}::ng-deep .vx-form-group .date-time-picker .picker-group input:-ms-input-placeholder{color:#999;font-size:13px}::ng-deep .vx-form-group .date-time-picker .picker-group input::-ms-input-placeholder{color:#999;font-size:13px}::ng-deep .vx-form-group .date-time-picker .picker-group i{display:flex;justify-content:center;align-items:center;height:16px;width:12px;position:absolute;left:12px;top:0;color:#747576;font-size:12px;pointer-events:none}::ng-deep .vx-form-group app-cs-radio.main-filed{margin-top:4px;display:block;width:100%}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item{width:100%;position:relative}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item span.radio{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item span.value{font-size:11px;text-transform:uppercase;border:1px solid #dbdbdb;border-radius:4px;padding:8px 8px 8px 36px;width:100%;display:flex;justify-content:space-between;margin:0;max-width:100%;color:#707070}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item span.value i{font-size:12px;color:#1e5dd3}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item svg{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item input:checked~span.value{background:#eefcf0;border-color:#34aa44}::ng-deep .vx-form-group app-cs-radio.disabled{pointer-events:none;opacity:.5;filter:grayscale(1);background:#f1f1f1}::ng-deep .vx-form-group .switch-row{display:flex}::ng-deep .vx-form-group .switch-row app-cs-switch{display:block;margin-top:8px}::ng-deep .vx-form-group .switch-row app-cs-switch label.cs-switch span.value{white-space:nowrap;margin-right:0;text-transform:uppercase;color:#747576!important}::ng-deep .vx-form-group .switch-row app-cs-switch label.cs-switch span.value i{display:inline-flex;font-size:11px;cursor:pointer;color:#1e5dd3;align-items:center;line-height:16px;margin:0 4px}::ng-deep .vx-form-group .switch-row app-cs-switch+app-cs-switch{margin-left:8px}::ng-deep .vx-form-group .switch-row.align-right{justify-content:flex-end}::ng-deep .vx-form-group .switch-row.align-right label.cs-switch span.value{margin-right:8px}::ng-deep .vx-form-group .risk-type-field{background:#f8f8f8;border:1px solid #dbdbdb;border-radius:4px;height:40px;display:flex;align-items:center;padding:4px;position:relative;z-index:1}::ng-deep .vx-form-group .risk-type-field .type-item{width:50%;position:relative}::ng-deep .vx-form-group .risk-type-field .type-item button{background:transparent;border:none;border-radius:0;color:#747576;font-size:11px;font-weight:600;text-transform:uppercase;width:100%;height:32px;padding:0 12px;text-align:left}::ng-deep .vx-form-group .risk-type-field .type-item button.disabled{background:transparent!important;color:#dbdbdb!important;filter:unset!important;opacity:unset!important;pointer-events:none;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group .risk-type-field .type-item .info{color:#1e5dd3;font-size:12px;position:absolute;top:10px;right:12px;cursor:pointer}::ng-deep .vx-form-group .risk-type-field .type-item .info.disabled{background:transparent!important;color:#dbdbdb!important;filter:unset!important;opacity:unset!important;pointer-events:none;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group .risk-type-field .type-item.active button{color:#1e5dd3!important}::ng-deep .vx-form-group .risk-type-field .type-item:nth-child(2).active~.background-glider{transform:translate(100%)}::ng-deep .vx-form-group .risk-type-field .background-glider{background:#fff;border-radius:4px;box-shadow:0 1px 3px #161b2f26;position:absolute;display:flex;width:212px;height:32px;z-index:-1;transition:.25s ease-out}.left{width:36px;height:36px;margin-top:26px;margin-left:-58px;margin-right:20px;display:flex;justify-content:center;align-items:center;position:relative;z-index:10;border-radius:50%}.left.deadline-completed{margin-top:18px}.left.checked{background:transparent}.left img{width:36px}.left .checkIcon{width:32px;height:32px;background:#fff;border-radius:50%;stroke-width:4;stroke:#34aa44;stroke-miterlimit:10;box-shadow:inset 0 0 #34aa44;animation:fillCheck .4s ease-in-out .4s forwards,scale .3s ease-in-out .9s both;margin-top:0}.left .checkIcon__circle{stroke-dasharray:166;stroke-dashoffset:166;stroke-width:2;stroke-miterlimit:10;stroke:#34aa44;fill:none;animation:strokeCheck .6s cubic-bezier(.65,0,.45,1) forwards}.left .checkIcon__check{transform-origin:50% 50%;stroke-dasharray:48;stroke-dashoffset:48;animation:strokeCheck .3s cubic-bezier(.65,0,.45,1) .8s forwards}.right{width:100%}.right span.indicator{position:absolute;top:36px;left:-16px;font-size:12px;color:#f0b819;cursor:pointer}.form-group-row{display:flex;position:relative;transition:all .2s ease-in-out}.form-group-row.disabled{-webkit-user-select:none;user-select:none;pointer-events:none;filter:grayscale(1);z-index:2}.form-group-row.disabled .left{position:relative}.form-group-row.disabled .left:before{content:\"\";position:absolute;inset:2px 0 0 2px;background:#fff;opacity:.7;border-radius:50%;width:32px;height:32px}.form-group-row.disabled .right{opacity:.3}.form-group-row.active{pointer-events:none;filter:grayscale(0);z-index:2;opacity:1}.form-group-row.active .right .vx-form-group input,.form-group-row.active .right .vx-form-group .custom-input,.form-group-row.active .right .vx-form-group .selectBoxEnable{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}.form-group-row.active .right .vx-form-group .selectBoxEnable.disabled{border-color:#dbdbdb;box-shadow:none}::ng-deep .radio-group-selector app-cs-radio{margin-top:4px;display:block;width:100%}::ng-deep .radio-group-selector app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .radio-group-selector app-cs-radio label.radio-item .radio,::ng-deep .radio-group-selector app-cs-radio label.radio-item .radiomark{position:absolute!important;top:9px;left:12px}::ng-deep .radio-group-selector app-cs-radio label.radio-item .value{font-size:11px!important;text-transform:uppercase;border:1px solid #dbdbdb;border-radius:4px;padding:8px 8px 8px 36px;width:100%;display:flex;justify-content:space-between;margin:0!important;max-width:100%!important;font-weight:500!important;color:#707070!important}::ng-deep .radio-group-selector app-cs-radio label.radio-item .value i{font-size:12px;color:#1e5dd3}::ng-deep .radio-group-selector app-cs-radio label.radio-item input:checked~span.value{background:#eefcf0;border-color:#34aa44}@keyframes strokeCheck{to{stroke-dashoffset:0}}@keyframes fillCheck{to{box-shadow:inset 0 0 0 2px #34aa44}}::ng-deep .wf-action-list{width:220px}::ng-deep .wf-action-list ul{padding:0;margin:0;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both;background:#fff;box-shadow:0 3px 6px #1c5bd140;border-radius:4px;max-height:220px;overflow:auto}::ng-deep .wf-action-list ul.action-item{display:block}::ng-deep .wf-action-list ul.action-item li{list-style:none;border:none;border-bottom:1px solid #f1f1f1;display:block;width:100%;padding:0;background:transparent;border-radius:0;margin:0;height:auto;justify-content:flex-start;box-shadow:none}::ng-deep .wf-action-list ul.action-item li button{color:#6e717e;text-align:left;text-decoration:none;cursor:pointer;background:transparent;font-size:12px;text-transform:capitalize;display:flex;width:100%;padding:7.5px 11px;border:none}::ng-deep .wf-action-list ul.action-item li button i{font-size:16px;margin-right:10px;color:#1e5dd3}::ng-deep .wf-action-list ul.action-item li button:hover{background:#f3f3f3}::ng-deep .wf-action-list ul.action-item li .avatar-card{display:flex;align-items:center;width:100%;padding:7.5px}::ng-deep .wf-action-list ul.action-item li .avatar-card.within-con{display:block}::ng-deep .wf-action-list ul.action-item li .avatar-card .avatar{height:24px;width:24px!important;overflow:hidden;background:#1e5dd3;color:#fff;font-size:10px;display:inline-flex;margin-right:5px;border-radius:50%;align-items:center;justify-content:center;text-transform:uppercase}::ng-deep .wf-action-list ul.action-item li .avatar-card .avatar img{width:100%}::ng-deep .wf-action-list ul.action-item li .avatar-card .avatar+span.value{width:calc(100% - 29px)}::ng-deep .wf-action-list ul.action-item li .avatar-card span.value{width:100%;color:#6e717e;text-decoration:none;background:transparent;font-size:12px;text-transform:capitalize;display:block;font-weight:400;text-align-last:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:20px}::ng-deep .wf-action-list ul.action-item li .avatar-card span.value i{font-size:8px;color:#747576;cursor:pointer;margin-right:5px}::ng-deep .wf-action-list ul.action-item li .avatar-card.no-image{display:block}::ng-deep .wf-action-list ul.action-item li .avatar-card.no-image span.value{width:100%;display:block}::ng-deep .wf-action-list ul.action-item li .chip-item{color:#1e5dd3;padding:10px;display:flex;align-items:center}::ng-deep .wf-action-list ul.action-item li .chip-item i{color:#747576;margin-right:7px;font-size:10px;cursor:pointer;display:inline-flex}::ng-deep .wf-action-list ul.action-item li .chip-item span{display:block;width:auto;max-width:calc(100% - 17px);font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}::ng-deep .wf-action-list ul.action-item li .chip-item span.chip-block{display:block;width:100%}::ng-deep .wf-action-list ul.action-item li .chip-item span.id{font-size:9px}::ng-deep .wf-action-list ul.action-item li .within{display:flex;align-items:center;justify-content:flex-start}::ng-deep .wf-action-list ul.action-item li .within .block{background:#f1f1f1;border-radius:2px;padding:0 2px;line-height:14px;font-size:9px;font-weight:500;color:#042e7d;margin-right:6px;display:block;text-transform:uppercase}::ng-deep .wf-action-list ul.action-item li .within .data{width:100%;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#747576;font-size:11px;font-weight:400;line-height:17px}::ng-deep .wf-action-list ul.action-item li:first-child{animation:action-list-open .25s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(2){animation:action-list-open .35s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(3){animation:action-list-open .45s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(4){animation:action-list-open .55s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(5){animation:action-list-open .65s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(6){animation:action-list-open .75s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(7){animation:action-list-open .85s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(8){animation:action-list-open .95s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(9){animation:action-list-open 1.05s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(10){animation:action-list-open 1.15s cubic-bezier(.25,.46,.45,.94) both}@keyframes action-list-open{0%{transform:translateY(50px)}to{transform:translateY(0)}}@keyframes scale-up-center{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}p.error-message{font-size:11px;font-weight:400;color:#eb2424;line-height:16px;margin-top:8px;margin-bottom:0}.edit-loader{position:absolute;top:-3px;left:-3px;width:46px;height:46px;transform:rotate(180deg)}.circular-loader{animation:rotate 2s linear infinite;height:100%;transform-origin:center center;width:100%;position:absolute;top:0;left:0;margin:auto}.loader-path{stroke-dasharray:150,200;stroke-dashoffset:-10;animation:dash 1.5s ease-in-out infinite;stroke-linecap:round}@keyframes rotate{to{transform:rotate(360deg)}}@keyframes dash{0%{stroke-dasharray:1,200;stroke-dashoffset:0}50%{stroke-dasharray:89,200;stroke-dashoffset:-35}to{stroke-dasharray:89,200;stroke-dashoffset:-124}}::ng-deep .dropdown{position:fixed;background:#fff;box-shadow:0 3px 6px #00000029;padding:24px 0;z-index:9;max-height:calc(100vh - 200px);overflow:auto}::ng-deep .dropdown ul.dropdown-list{padding:0 20px;margin:0;display:block}::ng-deep .dropdown ul.dropdown-list li{list-style:none}::ng-deep .dropdown ul.dropdown-list li app-cs-radio{display:flex}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item span.radio{position:absolute;top:12px;left:12px}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item span.value{padding:11px 12px 11px 32px;width:100%;border:1px solid #bcbcbc;border-radius:4px;margin-left:0;max-width:100%}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item svg{position:absolute;top:12px;left:12px}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item input[type=radio]:checked~span.value{background:#e8feeb;border-color:#34aa44}::ng-deep .dropdown ul.dropdown-list li+li{margin-top:8px}app-smiley-dialog{position:relative;z-index:10}app-smiley-dialog-inline{position:absolute;top:-3px;right:0;bottom:0;z-index:999;width:520px;height:calc(100vh + 3px)}::ng-deep .vx-overlay{position:fixed;z-index:3;inset:0}::ng-deep dp-date-picker{width:100%;position:fixed!important;z-index:14;top:-40px;left:0}::ng-deep dp-date-picker input{width:100%;border:none;opacity:0;pointer-events:none}::ng-deep dp-date-picker input:focus{outline:none}::ng-deep dp-date-picker .dp-popup{width:412px;box-shadow:0 0 20px #161b2f26;background-color:#fff;border-radius:4px;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both}::ng-deep dp-date-picker .dp-popup dp-day-calendar,::ng-deep dp-date-picker .dp-popup dp-month-calendar{width:100%;pointer-events:auto}::ng-deep dp-date-picker .dp-popup dp-day-calendar button,::ng-deep dp-date-picker .dp-popup dp-month-calendar button{background:transparent;border:none;outline:none}::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-current-location-btn,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-current-location-btn,::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-calendar-nav-left,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-calendar-nav-left,::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-calendar-nav-right,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-calendar-nav-right{width:40px;height:40px;display:flex;justify-content:center;align-items:center;border-radius:50%;font-size:14px}::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-current-location-btn:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-current-location-btn:hover,::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-calendar-nav-left:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-calendar-nav-left:hover,::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-calendar-nav-right:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-calendar-nav-right:hover{background-color:#f3f3f3}::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-current-location-btn,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-current-location-btn{display:none}::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-current-location-btn:before,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-current-location-btn:before{content:\"\";height:10px;width:10px;border-radius:50%;background:#000;display:inline-flex}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week{display:flex;justify-content:space-around}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays .dp-calendar-weekday,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays .dp-calendar-weekday,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week .dp-calendar-weekday,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week .dp-calendar-weekday{width:52px;border-left:none;border-bottom-color:#fff;color:#747576;font-size:11px;font-weight:600;text-transform:uppercase}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays button,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week button{width:40px;height:40px;border-radius:50%;display:inline-flex;justify-content:center;align-items:center}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays button:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays button:hover,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week button:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week button:hover{background-color:#f3f3f3}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays button.dp-selected,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays button.dp-selected,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week button.dp-selected,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week button.dp-selected{background:#1e5dd3}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays button.dp-current-day,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays button.dp-current-day,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week button.dp-current-day,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week button.dp-current-day{border:1px solid rgba(0,0,0,.38);color:#1e5dd3;background-color:#fff}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-day-calendar-container,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-day-calendar-container{padding:20px;border-radius:2px}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-nav-container,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-nav-container{display:flex;margin:0 0 20px;border:none}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-nav-container .dp-nav-header button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-nav-container .dp-nav-header button{color:#000;font-size:17px;font-weight:500;margin:0 0 0 12px;padding:0}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-nav-btns-container,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-nav-btns-container{width:80px;display:flex}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-nav-btns-container .dp-calendar-nav-container-left button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-nav-btns-container .dp-calendar-nav-container-left button,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-nav-btns-container .dp-calendar-nav-container-right button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-nav-btns-container .dp-calendar-nav-container-right button{margin:0!important}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-wrapper,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-wrapper{border:none}::ng-deep dp-date-picker .dp-open+div{position:fixed!important;inset:0!important;display:flex;justify-content:center;align-items:center;z-index:99;pointer-events:none;background:#0000004d}::ng-deep .cdk-overlay-container{z-index:2147483002!important}::ng-deep .dp-popup{z-index:999;display:flex!important;align-items:center;justify-content:center;width:100vw;height:100vh;background:#0000004d!important;box-shadow:unset!important}::ng-deep .dp-popup dp-day-calendar{width:412px!important;box-shadow:0 0 20px #161b2f26;background-color:#fff;border-radius:4px;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both}::ng-deep .dp-popup dp-day-calendar,::ng-deep .dp-popup dp-month-calendar{width:100%;pointer-events:auto}::ng-deep .dp-popup dp-day-calendar button,::ng-deep .dp-popup dp-month-calendar button{background:transparent;border:none;outline:none}::ng-deep .dp-popup dp-day-calendar button.dp-current-location-btn,::ng-deep .dp-popup dp-month-calendar button.dp-current-location-btn,::ng-deep .dp-popup dp-day-calendar button.dp-calendar-nav-left,::ng-deep .dp-popup dp-month-calendar button.dp-calendar-nav-left,::ng-deep .dp-popup dp-day-calendar button.dp-calendar-nav-right,::ng-deep .dp-popup dp-month-calendar button.dp-calendar-nav-right{width:40px;height:40px;display:flex;justify-content:center;align-items:center;border-radius:50%;font-size:14px}::ng-deep .dp-popup dp-day-calendar button.dp-current-location-btn:hover,::ng-deep .dp-popup dp-month-calendar button.dp-current-location-btn:hover,::ng-deep .dp-popup dp-day-calendar button.dp-calendar-nav-left:hover,::ng-deep .dp-popup dp-month-calendar button.dp-calendar-nav-left:hover,::ng-deep .dp-popup dp-day-calendar button.dp-calendar-nav-right:hover,::ng-deep .dp-popup dp-month-calendar button.dp-calendar-nav-right:hover{background-color:#f3f3f3}::ng-deep .dp-popup dp-day-calendar button.dp-current-location-btn,::ng-deep .dp-popup dp-month-calendar button.dp-current-location-btn{display:none}::ng-deep .dp-popup dp-day-calendar button.dp-current-location-btn:before,::ng-deep .dp-popup dp-month-calendar button.dp-current-location-btn:before{content:\"\";height:10px;width:10px;border-radius:50%;background:#000;display:inline-flex}::ng-deep .dp-popup dp-day-calendar .dp-weekdays,::ng-deep .dp-popup dp-month-calendar .dp-weekdays,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week{display:flex;justify-content:space-around}::ng-deep .dp-popup dp-day-calendar .dp-weekdays .dp-calendar-weekday,::ng-deep .dp-popup dp-month-calendar .dp-weekdays .dp-calendar-weekday,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week .dp-calendar-weekday,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week .dp-calendar-weekday{width:52px;border-left:none;border-bottom-color:#fff;color:#747576;font-size:11px;font-weight:600;text-transform:uppercase}::ng-deep .dp-popup dp-day-calendar .dp-weekdays button,::ng-deep .dp-popup dp-month-calendar .dp-weekdays button,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week button,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week button{width:40px;height:40px;border-radius:50%;display:inline-flex;justify-content:center;align-items:center}::ng-deep .dp-popup dp-day-calendar .dp-weekdays button:hover,::ng-deep .dp-popup dp-month-calendar .dp-weekdays button:hover,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week button:hover,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week button:hover{background-color:#f3f3f3}::ng-deep .dp-popup dp-day-calendar .dp-weekdays button.dp-selected,::ng-deep .dp-popup dp-month-calendar .dp-weekdays button.dp-selected,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week button.dp-selected,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week button.dp-selected{background:#1e5dd3}::ng-deep .dp-popup dp-day-calendar .dp-weekdays button.dp-current-day,::ng-deep .dp-popup dp-month-calendar .dp-weekdays button.dp-current-day,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week button.dp-current-day,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week button.dp-current-day{border:1px solid rgba(0,0,0,.38);color:#1e5dd3;background-color:#fff}::ng-deep .dp-popup dp-day-calendar .dp-day-calendar-container,::ng-deep .dp-popup dp-month-calendar .dp-day-calendar-container{padding:20px;border-radius:2px}::ng-deep .dp-popup dp-day-calendar .dp-calendar-nav-container,::ng-deep .dp-popup dp-month-calendar .dp-calendar-nav-container{display:flex;margin:0 0 20px;border:none}::ng-deep .dp-popup dp-day-calendar .dp-calendar-nav-container .dp-nav-header button,::ng-deep .dp-popup dp-month-calendar .dp-calendar-nav-container .dp-nav-header button{color:#000;font-size:17px;font-weight:500;margin:0 0 0 12px;padding:0}::ng-deep .dp-popup dp-day-calendar .dp-nav-btns-container,::ng-deep .dp-popup dp-month-calendar .dp-nav-btns-container{width:80px;display:flex}::ng-deep .dp-popup dp-day-calendar .dp-nav-btns-container .dp-calendar-nav-container-left button,::ng-deep .dp-popup dp-month-calendar .dp-nav-btns-container .dp-calendar-nav-container-left button,::ng-deep .dp-popup dp-day-calendar .dp-nav-btns-container .dp-calendar-nav-container-right button,::ng-deep .dp-popup dp-month-calendar .dp-nav-btns-container .dp-calendar-nav-container-right button{margin:0!important}::ng-deep .dp-popup dp-day-calendar .dp-calendar-wrapper,::ng-deep .dp-popup dp-month-calendar .dp-calendar-wrapper{border:none}@keyframes slide-bottom{0%{transform:translateY(-100px)}to{transform:translateY(0)}}::ng-deep span.file{display:block;width:20px;min-width:20px;border-radius:0 0 2px 2px;border:1px solid transparent;border-color:#747576;position:relative;margin-right:5px;border-top:none;margin-top:5px;background:#fff}::ng-deep span.file.table{margin-right:8px;width:18px;min-width:18px}::ng-deep span.file.table i{font-size:8px}::ng-deep span.file.table .format{height:8px;font-size:7px;line-height:8px;font-weight:400}::ng-deep span.file:before{position:absolute;border-radius:0;top:-4px;right:-1px;content:\"\";height:4px;width:4px;display:block;background:linear-gradient(45deg,#747576 0% 1%,#747576 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file:after{height:4px;left:-1px;right:3px;border-top:1px solid;border-right:none;border-left:1px solid;content:\"\";top:-4px;position:absolute;border-radius:2px 0 0;background:#fff}::ng-deep span.file .format{height:10px;font-size:6px;text-transform:uppercase;background:transparent;font-weight:600;text-align:center;display:block;line-height:10px}::ng-deep span.file i{font-size:10px;height:10px;display:flex;align-items:center;justify-content:center;color:#dbdbdb}::ng-deep span.file.docx{width:22px!important}::ng-deep span.file.pdf,::ng-deep span.file.template{border-color:#f31c39}::ng-deep span.file.pdf:before,::ng-deep span.file.template:before{background:linear-gradient(45deg,#f31c39 0% 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#f31c39\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.pdf:after,::ng-deep span.file.template:after{border-color:#f31c39}::ng-deep span.file.pdf .format,::ng-deep span.file.template .format{color:#f31c39}::ng-deep span.file.xlsx,::ng-deep span.file.xls,::ng-deep span.file.css,::ng-deep span.file.scss,::ng-deep span.file.less{border-color:#34aa44}::ng-deep span.file.xlsx:before,::ng-deep span.file.xls:before,::ng-deep span.file.css:before,::ng-deep span.file.scss:before,::ng-deep span.file.less:before{background:linear-gradient(45deg,#34aa44 0% 1%,#34aa44 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.xlsx:after,::ng-deep span.file.xls:after,::ng-deep span.file.css:after,::ng-deep span.file.scss:after,::ng-deep span.file.less:after{border-color:#34aa44;color:#34aa44}::ng-deep span.file.xlsx .format,::ng-deep span.file.xls .format,::ng-deep span.file.css .format,::ng-deep span.file.scss .format,::ng-deep span.file.less .format{color:#34aa44}::ng-deep span.file.doc,::ng-deep span.file.docx,::ng-deep span.file.psd{border-color:#1e5dd3}::ng-deep span.file.doc:before,::ng-deep span.file.docx:before,::ng-deep span.file.psd:before{background:linear-gradient(45deg,#1e5dd3 0% 1%,#1e5dd3 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.doc:after,::ng-deep span.file.docx:after,::ng-deep span.file.psd:after{border-color:#1e5dd3}::ng-deep span.file.doc .format,::ng-deep span.file.docx .format,::ng-deep span.file.psd .format{color:#1e5dd3}::ng-deep span.file.ppt,::ng-deep span.file.ai,::ng-deep span.file.html,::ng-deep span.file.jpg,::ng-deep span.file.jpeg,::ng-deep span.file.png{border-color:#f6882f}::ng-deep span.file.ppt:before,::ng-deep span.file.ai:before,::ng-deep span.file.html:before,::ng-deep span.file.jpg:before,::ng-deep span.file.jpeg:before,::ng-deep span.file.png:before{background:linear-gradient(45deg,#f6882f 0% 1%,#f6882f 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.ppt:after,::ng-deep span.file.ai:after,::ng-deep span.file.html:after,::ng-deep span.file.jpg:after,::ng-deep span.file.jpeg:after,::ng-deep span.file.png:after{border-color:#f6882f}::ng-deep span.file.ppt .format,::ng-deep span.file.ai .format,::ng-deep span.file.html .format,::ng-deep span.file.jpg .format,::ng-deep span.file.jpeg .format,::ng-deep span.file.png .format{color:#f6882f}::ng-deep span.file.php{border-color:#7aa6f7}::ng-deep span.file.php:before{background:linear-gradient(45deg,#7aa6f7 0% 1%,#7aa6f7 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.php:after{border-color:#7aa6f7}::ng-deep span.file.php .format{color:#7aa6f7}::ng-deep ngx-material-timepicker-container .timepicker-backdrop-overlay{background-color:#0000000d!important;z-index:9999999999!important}::ng-deep ngx-material-timepicker-container .timepicker-overlay{z-index:9999999999!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker{width:232px!important;border-radius:2px!important;box-shadow:0 4px 30px #161b2f26!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header{background-color:#fff!important;padding:0!important;border-radius:2px 2px 0 0}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container{display:block!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time{color:#000!important;width:150px!important;margin:0 auto;line-height:60px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time ngx-material-timepicker-dial-control .timepicker-dial__control{font-size:40px;background-color:transparent!important;color:#000!important;font-weight:600;text-align:right;caret-color:transparent;outline:none;font-family:Poppins;line-height:56px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time ngx-material-timepicker-dial-control .timepicker-dial__control:focus,::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time ngx-material-timepicker-dial-control .timepicker-dial__control:hover{background-color:transparent!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time ngx-material-timepicker-dial-control:last-of-type .timepicker-dial__control{text-align:left}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time span{padding:0 8px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period{display:flex!important;width:182px;margin:0 auto!important;background:#f1f1f1;padding:4px 10px;border-radius:20px;position:relative}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period:before{background:#f1f1f1;content:\"\";position:absolute;top:15px;left:-25px;width:calc(100% + 50px);height:2px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period{flex-direction:unset!important;position:relative;z-index:1}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period:after{content:\"\";position:absolute;right:-12px;top:0;border-left:solid 14px #f1f1f1;border-bottom:solid 12px transparent;border-top:solid 12px transparent;z-index:-1}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period:before{content:\"\";position:absolute;left:-18px;top:0;border-right:solid 14px #f1f1f1;border-bottom:solid 12px transparent;border-top:solid 12px transparent;z-index:-1}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period button{font-size:11px;background-color:transparent;padding:0;border-radius:20px;color:#747576;font-weight:600;font-family:Poppins;width:84px;height:24px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period button.timepicker-dial__item_active{background:#fff!important;color:#1e5dd3!important;box-shadow:0 1px 2px #dbdbdb}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period button+button{margin-left:0!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face{width:200px!important;height:200px!important;padding:10px!important;background:transparent!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__number--outer{height:92px!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__number--outer span{color:#000}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__number--outer span.active{color:#fff}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__clock-hand{height:80px!important;top:calc(50% - 80px)!important;background-color:#1e5dd3!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__number>span.active{background-color:#1e5dd3!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__clock-hand_minute:before{border:4px solid #1e5dd3!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .timepicker__actions{display:flex!important;padding:10px 0 0!important;background:#fff!important;justify-content:space-around!important;border-radius:0 0 2px 2px!important;overflow:hidden}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .timepicker__actions div:first-child ngx-material-timepicker-button button.timepicker-button{background:#f8f8f8;color:#1e5dd3}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .timepicker__actions div ngx-material-timepicker-button button.timepicker-button{line-height:28px!important;width:100%;background:#1e5dd3;color:#fff;border-radius:0!important;height:32px!important;width:116px!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .timepicker__actions div ngx-material-timepicker-button button.timepicker-button span{font-weight:500!important;font-size:11px;font-family:Poppins}::ng-deep vcomply-editor{display:block}::ng-deep vcomply-editor .editor-container{border-radius:4px;border:1px solid #dbdbdb;transition:all .2s ease-in-out}::ng-deep vcomply-editor .editor-container:hover,::ng-deep vcomply-editor .editor-container:focus-within{border:1px solid #1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep vcomply-editor .editor-container mention-list ul li a{font-size:16px!important}::ng-deep vcomply-editor .editor-container .editable-block{background:#fff;min-height:60px;padding:8px 12px;line-height:20px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%}::ng-deep vcomply-editor .editor-container .editable-block:before{color:#747576!important}::ng-deep vcomply-editor .editor-container .editor-tools{border-top:1px solid #dbdbdb;border-radius:0 0 3px 3px}::ng-deep vcomply-editor .editor-container .editor-tools:hover{border-color:#1e5dd3}::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button{height:22px!important;width:22px!important;padding:0 5px}::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button svg{height:22px;width:12px}::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button.submit{width:80px!important;line-height:22px;justify-content:center}::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col .popover.small ul.option-list li button{width:100%!important;height:auto!important}::ng-deep marx-modal .popup-modal-background{background-color:#161b2fcc!important}::ng-deep .within-box{background:#f1f1f1;border-radius:.125rem;color:#042e7d}::ng-deep .within-value{overflow:hidden;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;word-break:break-word}.wf-tooltip{pointer-events:none;position:absolute;max-width:300px;font-size:12px;text-align:left;color:#fff;padding:8px 12px;background:#000;border-radius:2px;z-index:-222;top:0;opacity:0;white-space:break-spaces;word-break:break-word}.wf-tooltip *{color:#fff!important}.wf-tooltip:empty{display:none!important}.wf-tooltip.white{box-shadow:0 2px 8px #1c5bd159;color:#747576;background:#fff;text-align:left}.wf-tooltip.white b{color:#747576!important}.wf-tooltip.animate-top{animation:animate-top .5s cubic-bezier(.25,.46,.45,.94) both}.wf-tooltip.animate-right{animation:animate-right .3s cubic-bezier(.25,.46,.45,.94) both}.wf-tooltip.animate-bottom{animation:animate-bottom .5s cubic-bezier(.25,.46,.45,.94) both}.wf-tooltip.animate-left{animation:animate-left .5s cubic-bezier(.25,.46,.45,.94) both}.wf-tooltip-top:after{top:100%;left:50%;margin-left:-5px;border-width:5px;border-color:#000000 transparent transparent transparent}.wf-tooltip-top.white:after{border-color:#f1f1f1 transparent transparent transparent}.wf-tooltip-bottom:after{bottom:100%;left:50%;margin-left:-5px;border-width:5px;border-color:transparent transparent #000000 transparent}.wf-tooltip-bottom.white:after{border-color:transparent transparent #f1f1f1 transparent}.wf-tooltip-left.white:after{border-color:transparent transparent transparent #f1f1f1}.wf-tooltip-left:after{top:50%;left:100%;margin-top:-5px;border-width:5px;border-color:transparent transparent transparent #000000}.wf-tooltip-right.white:after{border-color:transparent #f1f1f1 transparent transparent}.wf-tooltip-right:after{top:50%;right:100%;margin-top:-5px;border-width:5px;border-color:transparent #000000 transparent transparent}.wf-tooltip-bottom-right:after{bottom:100%;left:100%;margin-left:-20px;border-width:5px;border-color:transparent transparent #000000 transparent}.wf-tooltip-bottom-right.white:after{border-color:transparent transparent #f1f1f1 transparent}.wf-tooltip-bottom-left:after{bottom:100%;left:0;margin-left:10px;border-width:5px;border-color:transparent transparent #000000 transparent}.wf-tooltip-bottom-left.white:after{border-color:transparent transparent #f1f1f1 transparent}.wf-tooltip-top-left:after{top:100%;left:0;margin-left:10px;border-width:5px;border-color:#000000 transparent transparent transparent}.wf-tooltip-top-left.white:after{border-color:#f1f1f1 transparent transparent transparent}.wf-tooltip-top-right:after{top:100%;left:100%;margin-left:-5px;border-width:5px;border-color:#000000 transparent transparent transparent}.wf-tooltip-top-right.white:after{border-color:#f1f1f1 transparent transparent transparent}.wf-tooltip:after{content:\"\";position:absolute;border-style:solid}.wf-tooltip span.within{font-size:80%;display:block;width:100%}.wf-tooltip .small{display:block;font-size:10px}.wf-tooltip .within-box{background:#f1f1f1;border-radius:2px;color:#042e7d!important;font-size:9px;font-weight:500;text-transform:uppercase;padding:0 2px;margin-right:2px}.wf-tooltip-show{pointer-events:none;opacity:1;z-index:2147483001}\n"] }]
1299
- }], ctorParameters: function () { return [{ type: i1.UntypedFormBuilder }, { type: i2.ProgramsService }, { type: i3.AuthService }, { type: i4.UiKitService }, { type: i0.ChangeDetectorRef }, { type: i5.IframeService }]; }, propDecorators: { form: [{
1338
+ args: [{ selector: 'app-workflow-program', template: "<div class=\"workflow-program\" #form>\n <form novalidate [formGroup]=\"programForm\">\n <!-- Program Category Type -->\n <form-field\n [checked]=\"controls?.program_type?.value > -1\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.issue_type\"\n >\n <label class=\"vx-control-panel\"\n >PROGRAM TYPE <span class=\"required\">*</span></label\n >\n <tab-selector\n formControlName=\"program_type\"\n [displayArray]=\"constants?.categoryType\"\n ></tab-selector>\n <!-- <p *ngIf=\"program_name?.invalid\" class=\"error-message\">Add a program type</p> -->\n </form-field>\n\n <!-- Framework -->\n <form-field\n *ngIf=\"isAscentAllowed\"\n [checked]=\"false\"\n [active]=\"false\"\n [disabled]=\"false\"\n [img]=\"ASSETS.case_category\"\n >\n <label class=\"vx-control-panel\">FRAMEWORK</label>\n <!-- [selectDiv]=\"true\" -->\n <input-with-pill\n [placeholder]=\"'Select a framework that this Program relates to'\"\n (select)=\"activateList('FRAMEWORK')\"\n >\n <div class=\"selected\" *ngIf=\"controls?.framework.value?.name\">\n <div class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\">\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n *ngIf=\"canFrameworkChange\"\n (click)=\"remove('', 'FRAMEWORK')\"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.framework.value?.name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.framework.value?.name }}</span\n >\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i (click)=\"remove('', 'FRAMEWORK')\" *ngIf=\"canFrameworkChange\" class=\"icons\" >&#xe90d;</i> {{controls?.framework.value?.name}}</span>\n </div>\n </div> -->\n <button\n *ngIf=\"canFrameworkChange\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('FRAMEWORK')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n </form-field>\n\n <!-- Program Category Name -->\n <form-field\n [checked]=\"controls?.program_name?.value?.trim()?.length\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.what\"\n >\n <label class=\"vx-control-panel\"\n >PROGRAM NAME <span class=\"required\">*</span></label\n >\n <input\n InputTrim\n formControlName=\"program_name\"\n type=\"text\"\n placeholder=\"What is the Program name?\"\n />\n\n <p\n *ngIf=\"\n controls?.program_name?.errors && controls?.program_name?.touched\n \"\n class=\"error-message\"\n >\n Enter a name for this Program.\n </p>\n <p *ngIf=\"isNameExists\" class=\"error-message\">\n Program name already exists.\n </p>\n <div class=\"upload-files vx-d-flex vx-align-center vx-flex-wrap vx-mt-1\">\n <file-pill\n *ngFor=\"\n let attachment of controls?.description_attachment?.value\n | slice : 0 : 2\n \"\n [extension]=\"attachment?.org_file?.split('.').pop()\"\n [name]=\"attachment?.org_file\"\n [disabled]=\"attachment?.uploading\"\n (delete)=\"deleteAttachment('DESCRIPTION', attachment)\"\n >\n </file-pill>\n <button\n *ngIf=\"controls?.description_attachment?.value?.length > 2\"\n class=\"file-count\"\n appPopover\n (click)=\"uploadFile.popover()\"\n placement=\"right\"\n >\n +{{ controls?.description_attachment?.value?.length - 2 }}\n </button>\n <app-popover #uploadFile [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n class=\"vx-p-2\"\n *ngFor=\"\n let attachment of controls?.description_attachment?.value\n | slice : 2\n \"\n >\n <file-pill\n [extension]=\"attachment?.org_file?.split('.').pop()\"\n [name]=\"attachment?.org_file\"\n [disabled]=\"attachment?.uploading\"\n (delete)=\"deleteAttachment('DESCRIPTION', attachment)\"\n ></file-pill>\n </li>\n </ul>\n </div>\n </app-popover>\n </div>\n <vcomply-editor\n [(ngModel)]=\"editorData.programDescription\"\n [ngModelOptions]=\"{ standalone: true }\"\n (sendSavedFiles)=\"selectFile('DESCRIPTION', $event)\"\n (ngModelChange)=\"setFormField('program_description', $event)\"\n [editorConfig]=\"constants?.description\"\n >\n </vcomply-editor>\n </form-field>\n\n <!-- Objective -->\n <form-field\n [checked]=\"controls?.program_objective?.value?.trim()?.length\"\n [active]=\"activeList === 'OBJECTIVE'\"\n [disabled]=\"\n sideElements.includes(activeList) && activeList !== 'OBJECTIVE'\n \"\n [img]=\"ASSETS.objectives\"\n >\n <label class=\"vx-control-panel\"\n >OBJECTIVE\n <!-- <span class=\"required\">*</span> -->\n </label>\n <vcomply-editor\n [(ngModel)]=\"editorData.programObjective\"\n [ngModelOptions]=\"{ standalone: true }\"\n (sendSavedFiles)=\"selectFile('OBJECTIVE', $event)\"\n (ngModelChange)=\"setFormField('program_objective', $event, true)\"\n [editorConfig]=\"constants?.objective\"\n >\n </vcomply-editor>\n <!-- <p *ngIf=\"!isObjectiveValid\" class=\"error-message\">Specify the objective for this Program.</p> -->\n </form-field>\n\n <!-- Roles -->\n <form-field\n *ngIf=\"additionalOption?.ROLES\"\n [checked]=\"controls?.program_roles?.value?.length\"\n [active]=\"activeList === 'ROLE'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'ROLE'\"\n [img]=\"ASSETS.roles\"\n >\n <label class=\"vx-control-panel\" id=\"permissiongroup\"\n >{{ ff_rc_listing ? \"PERMISSIONS\" : \"PERMISSION GROUP(S)\" }}\n <span class=\"required\">*</span\n ><i\n class=\"icons\"\n [appTooltip]=\"\n ff_rc_listing\n ? 'Permissions let you specify the users that can be \u201COwners\u201D' +\n (allowedFeature.isFeatureEnabled('ff_program_simplify')\n ? ' '\n : ' and \u201CApprovers\u201D') +\n 'of a Program.'\n : 'Permission group(s) let you specify the users that can be \u201COwners\u201D' +\n (allowedFeature.isFeatureEnabled('ff_program_simplify')\n ? ' '\n : ' and \u201CApprovers\u201D') +\n 'of a Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"RoleHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n id=\"placeholdername\"\n [placeholder]=\"\n ff_rc_listing\n ? 'Which user permissions have access to this program?'\n : 'Which user permission groups have access to this program?'\n \"\n (select)=\"activateList('ROLE')\"\n >\n <div class=\"selected\" *ngIf=\"controls?.program_roles?.value?.length\">\n <div class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\">\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n *ngIf=\"\n !lists.SYSTEM_ROLE_IDS.includes(\n controls?.program_roles?.value[0]?._id\n )\n \"\n (click)=\"remove(controls?.program_roles?.value[0], 'ROLE')\"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n featureflagrole &&\n controls?.program_roles?.value[0]?.permissionGroupName\n ? controls?.program_roles?.value[0]?.permissionGroupName\n : controls?.program_roles?.value[0]?.roleName\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n featureflagrole &&\n controls?.program_roles?.value[0]?.permissionGroupName\n ? controls?.program_roles?.value[0]?.permissionGroupName\n : controls?.program_roles?.value[0]?.roleName\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"role.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_roles?.value?.length > 1\"\n >\n +{{ controls?.program_roles?.value?.length - 1 }}\n </button>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i *ngIf=\"!lists.SYSTEM_ROLE_IDS.includes(controls?.program_roles?.value[0]?._id)\" (click)=\"remove(controls?.program_roles?.value[0],'ROLE')\" class=\"icons\">&#xe90d;</i>{{featureflagrole && controls?.program_roles?.value[0]?.permissionGroupName ? controls?.program_roles?.value[0]?.permissionGroupName : controls?.program_roles?.value[0]?.roleName}}</span>\n <button *ngIf=\"controls?.program_roles?.value?.length > 1\" class=\"count\" appPopover (click)=\"role.popover()\" placement=\"right\">+{{controls?.program_roles?.value?.length - 1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'ROLE'\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('ROLE')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <p *ngIf=\"false\" class=\"error-message\">\n {{ featureflagrole ? \"Add a permission group(s)\" : \"Add a role(s)\" }}\n </p>\n <app-popover #role [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"let data of controls?.program_roles?.value | slice : 1\">\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"!lists.SYSTEM_ROLE_IDS.includes(data?._id)\"\n class=\"icons\"\n (click)=\"removeRole(data, 'ROLE')\"\n >&#xe90d;</i\n >\n {{\n featureflagrole && data?.permissionGroupName\n ? data?.permissionGroupName\n : data?.roleName\n }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field>\n\n <!-- Owners -->\n <form-field\n *ngIf=\"additionalOption?.OWNERS\"\n [checked]=\"\n controls?.program_owners.value?.length > 0 ||\n controls?.program_owners_group.value?.length > 0\n \"\n [active]=\"activeList === 'OWNER'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'OWNER'\"\n [img]=\"ASSETS.case_owners\"\n >\n <label class=\"vx-control-panel\"\n >OWNER(S)\n <span\n class=\"icon\"\n *ngIf=\"toolTipData.owner !== ''\"\n libPopoverHover\n (mouseover)=\"dataTooltip.popover()\"\n (mouseleave)=\"dataTooltip.closePopover()\"\n placement=\"right\"\n ><i class=\"icons\">&#xe91f;</i></span\n >\n <popover-hover #dataTooltip>\n <div class=\"vx-info-card\">\n <div\n class=\"vx-info-card-body\"\n [innerHTML]=\"toolTipData.owner\"\n id=\"OwnerHelpText\"\n ></div>\n </div>\n </popover-hover>\n </label>\n <input-with-pill\n [placeholder]=\"'Who is responsible for managing this program?'\"\n (select)=\"activateList('OWNER')\"\n >\n <div class=\"selected\" *ngIf=\"controls?.program_owners.value[0]\">\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_owners?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_owners?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4 greenBg\"\n appPopover\n (click)=\"owner.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_owners?.value?.length > 1\"\n >\n +{{ controls?.program_owners?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_owners_group?.value?.length &&\n controls?.program_owners?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_owners_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n (click)=\"\n remove(\n controls?.program_owners_group?.value[0],\n 'OWNER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_owners_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_owners_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"group.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_owners_group?.value?.length > 1\"\n >\n +{{ controls?.program_owners_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <button\n *ngIf=\"activeList !== 'OWNER'\"\n [class.disabled]=\"controls?.all_user_in_role?.value\"\n (click)=\"activateList('OWNER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i>Edit\n </button>\n </div>\n </input-with-pill>\n <p *ngIf=\"false\" class=\"error-message\">Add a owner(s)</p>\n <div class=\"vx-d-flex vx-align-center vx-justify-end vx-mt-2\">\n <div\n class=\"vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase vx-mr-2\"\n >\n {{\n featureflagrole\n ? \"ALL USERS ASSOCIATED WITH THE SELECTED PERMISSION GROUPS\"\n : \"ALL USERS ASSOCIATED WITH THE SELECTED ROLES\"\n }}\n </div>\n <switch\n formControlName=\"all_user_in_role\"\n (change)=\"selectAllRoleOwner($event)\"\n ></switch>\n </div>\n <app-popover #owner [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"let owner of controls?.program_owners?.value | slice : 1\"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"\n !(\n lists.NON_REMOVABLE_OWNERS | listToId : 'member_id'\n ).includes(owner?.member_id)\n \"\n class=\"icons\"\n (click)=\"remove(owner, 'OWNER')\"\n >&#xe90d;</i\n >\n {{ owner?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #group [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let owner of controls?.program_owners_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n class=\"icons\"\n (click)=\"remove(owner, 'OWNER_GROUP')\"\n >&#xe90d;</i\n >\n {{ owner?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field>\n\n <!-- Collaborator -->\n <form-field\n *ngIf=\"additionalOption?.COLLABORATOR\"\n [checked]=\"\n controls?.program_collaborator?.value?.length > 0\n \"\n [active]=\"activeList === 'COLLABORATOR'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'COLLABORATOR'\"\n [img]=\"ASSETS.case_owners\"\n >\n <label class=\"vx-control-panel\"\n >Collaborator(S) <span class=\"required\">*</span>\n <span\n class=\"icon\"\n libPopoverHover\n (mouseover)=\"dataTooltip.popover()\"\n (mouseleave)=\"dataTooltip.closePopover()\"\n placement=\"right\"\n ><i class=\"icons\">&#xe91f;</i></span\n >\n <popover-hover #dataTooltip>\n <div class=\"vx-info-card\">\n <div\n class=\"vx-info-card-body\"\n [innerHTML]=\"toolTipData.owner\"\n id=\"OwnerHelpText\"\n ></div>\n </div>\n </popover-hover>\n </label>\n <input-with-pill\n [placeholder]=\"'Who is responsible for managing this program?'\"\n (select)=\"activateList('COLLABORATOR')\"\n >\n <div class=\"selected\" *ngIf=\"controls?.program_collaborator?.value[0]\">\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_collaborator?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_collaborator?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4 greenBg\"\n appPopover\n (click)=\"collaborator.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_collaborator?.value?.length > 1\"\n >\n +{{ controls?.program_collaborator?.value?.length - 1 }}\n </button>\n </div>\n \n </div>\n\n <button\n *ngIf=\"activeList !== 'COLLABORATOR'\"\n [class.disabled]=\"controls?.all_user_in_role?.value\"\n (click)=\"activateList('COLLABORATOR')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i>Edit\n </button>\n </div>\n </input-with-pill>\n <div class=\"vx-d-flex vx-align-center vx-justify-end vx-mt-2\">\n <div\n class=\"vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase vx-mr-2\"\n >\n </div>\n </div>\n <app-popover #collaborator [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"let collaborator of controls?.program_collaborator?.value | slice : 1\"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n class=\"icons\"\n (click)=\"remove(collaborator, 'COLLABORATOR')\"\n >&#xe90d;</i\n >\n {{ collaborator?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field>\n\n <!-- Performance Calculated -->\n <!-- <form-field [checked]=\"controls?.performance_calculation?.value\" [active]=\"activeList === 'PERFORMANCE'\" [disabled]=\"sideElements.includes(activeList) && activeList !== 'PERFORMANCE'\"\n [img]=\"'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/performance-calc.svg'\">\n <label class=\"vx-control-panel\">HOW SHOULD THE PERFORMANCE OF THIS PROGRAM BE CALCULATED?</label>\n <tab-selector formControlName=\"performance_calculation\" [displayArray]=\"constants?.performanceCalculation\">\n </tab-selector>\n </form-field> -->\n <ng-container *ngIf=\"isProgramScope\">\n <div\n class=\"scope-label vx-fs-10 vx-txt-white vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mb-5 vx-lh-4 vx-d-inline-block\"\n >\n PROGRAM SCOPE\n </div>\n <!-- <i class=\"icons info-icon vx-fs-12 vx-txt-blue vx-ml-1\" [appTooltip]=\"tooltip.programScope\" placement=\"bottom\" delay=\"0\" type=\"white\" [tooltipMandatory]=\"true\">&#xe91f;</i> -->\n <span\n class=\"icon info-icon vx-fs-12 vx-txt-blue vx-ml-1\"\n *ngIf=\"toolTipData.programScop !== ''\"\n libPopoverHover\n (mouseover)=\"dataTooltip.popover()\"\n (mouseleave)=\"dataTooltip.closePopover()\"\n placement=\"right\"\n ><i class=\"icons\">&#xe91f;</i></span\n >\n <popover-hover #dataTooltip>\n <div class=\"vx-info-card\">\n <div\n class=\"vx-info-card-body\"\n [innerHTML]=\"toolTipData.programScope\"\n id=\"PSHelpText\"\n ></div>\n </div>\n </popover-hover>\n </ng-container>\n\n <!-- Program Frequency -->\n <form-field\n *ngIf=\"additionalOption?.PROGRAM_FREQUENCY\"\n [checked]=\"[true, false].includes(controls?.recurring_frequency?.value)\"\n [active]=\"activeList === 'FREQUENCY'\"\n [disabled]=\"\n sideElements.includes(activeList) && activeList !== 'FREQUENCY'\n \"\n [img]=\"ASSETS.recurring\"\n >\n <label class=\"vx-control-panel\" id=\"PDChange\"\n >PROGRAM DURATION\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Program Duration refers to the duration of the Program. A Program can occur in perpetuity, or it can occur until the end of the current business cycle that has been specified in ' +\n businessCycle.selectedCycle.business_cycle +\n '. All responsibilities linked with that Program will also have the same Program Duration.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"ProgramDurationHelpText\"\n >&#xeb16;</i\n ></label\n >\n <div class=\"upload-format\">\n <div class=\"vx-d-flex vx-align-center vx-justify-between\">\n <span class=\"text vx-mb-0\">Is this program recurring?</span>\n <div class=\"radio-group program\">\n <app-cs-radio\n [name]=\"'recurring_frequency'\"\n [checked]=\"controls?.recurring_frequency?.value\"\n (checkedEvent)=\"setFormField('recurring_frequency', true)\"\n >YES</app-cs-radio\n >\n <app-cs-radio\n [name]=\"'recurring_frequency'\"\n [checked]=\"!controls?.recurring_frequency?.value\"\n (checkedEvent)=\"setFormField('recurring_frequency', false)\"\n >NO</app-cs-radio\n >\n </div>\n </div>\n </div>\n </form-field>\n\n <!-- Scope Changes -->\n <form-field\n *ngIf=\"additionalOption?.SCOPE_CHANGES\"\n [checked]=\"[true, false].includes(controls?.lock_scope_change?.value)\"\n [active]=\"activeList === 'SCOPE'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'SCOPE'\"\n [img]=\"ASSETS.lock_scope\"\n >\n <label class=\"vx-control-panel\"\n >Lock the Program Scope\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If the Program Scope is locked, neither the Program nor the responsibilities linked with the Program can be edited once the Program begins. In order to edit the Program or the linked responsibilities, the Program details will need to be edited.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"ScopeChangesHelpText\"\n >&#xeb16;</i\n ></label\n >\n <div class=\"upload-format\">\n <span class=\"text\"\n >Would you like to\n <span class=\"vx-label-txt vx-fw-500\">lock changes</span> to the\n program scope?</span\n >\n <div class=\"radio-group program\">\n <app-cs-radio\n [name]=\"'lock_scope_change'\"\n [checked]=\"controls?.lock_scope_change?.value\"\n (checkedEvent)=\"setFormField('lock_scope_change', true)\"\n >YES</app-cs-radio\n >\n <app-cs-radio\n [name]=\"'lock_scope_change'\"\n [checked]=\"!controls?.lock_scope_change?.value\"\n (checkedEvent)=\"setFormField('lock_scope_change', false)\"\n >NO</app-cs-radio\n >\n </div>\n </div>\n </form-field>\n\n <!-- Framework -->\n <!-- <form-field [checked]=\"false\" [active]=\"activeList === 'FRAMEWORK'\" [disabled]=\"sideElements.includes(activeList) && activeList !== 'FRAMEWORK'\"\n [img]=\"'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/category.svg'\">\n <label class=\"vx-control-panel\">FRAMEWORK</label>\n <input-with-pill [placeholder]=\"'Select a framework that this Program relates to'\" (select)=\"activateList('FRAMEWORK')\">\n <div class=\"selected\" *ngIf=\"controls?.framework?.value?.framework_name\">\n <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i (click)=\"remove(controls?.framework.value,'FRAMEWORK')\" class=\"icons\">&#xe90d;</i>{{controls?.framework?.value?.framework_name}}</span>\n <button class=\"count\" appPopover (click)=\"framework.popover()\" placement=\"right\">+5</button>\n </div>\n </div>\n <button *ngIf=\"activeList!=='FRAMEWORK'\" (click)=\"activateList('FRAMEWORK')\" class=\"edit\" type=\"button\"><i class=\"icons\">&#xe9ba;</i> Edit</button>\n </div>\n </input-with-pill>\n <app-popover #framework [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i class=\"icons\">&#xe90d;</i>\n Manage framework name\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field> -->\n\n <!-- Responsibility Center -->\n <form-field\n *ngIf=\"additionalOption?.RC\"\n [checked]=\"controls?.rc?.value?.length\"\n [active]=\"activeList === 'RC'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'RC'\"\n [img]=\"ASSETS.responsibility_center\"\n >\n <label class=\"vx-control-panel\"\n >RESPONSIBILITY CENTER\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Responsibility Centers represent your organizational and operational infrastructure. Where Responsibility Centers are selected when creating a Program, only those Responsibilities Centers will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"RCHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n (select)=\"activateList('RC')\"\n [placeholder]=\"\n 'Which Responsibility Center(s) can be linked to the responsibilities associated with this Program?'\n \"\n >\n <div\n class=\"selected\"\n *ngIf=\"controls?.rc?.value && controls?.rc?.value?.length\"\n >\n <div class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\">\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"remove(controls?.rc?.value[0], 'RC')\"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.rc?.value[0]?.item_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.rc?.value[0]?.item_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"rc.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.rc?.value?.length > 1\"\n >\n +{{ controls?.rc?.value?.length - 1 }}\n </button>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i class=\"icons\" (click)=\"remove(controls?.rc?.value[0],'RC')\">&#xe90d;</i>{{controls?.rc?.value[0]?.item_name}}</span>\n <button *ngIf=\"controls?.rc?.value?.length > 1\" class=\"count\" appPopover (click)=\"rc.popover()\" placement=\"right\">+{{controls?.rc?.value?.length -1 }}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'RC'\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('RC')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #rc [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"let rc of controls?.rc?.value | slice : 1\">\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i class=\"icons\" (click)=\"remove(rc, 'RC')\">&#xe90d;</i>\n {{ rc?.item_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field>\n\n <!-- Assignee -->\n <form-field\n *ngIf=\"additionalOption?.ASSIGNEES\"\n [checked]=\"\n controls?.program_assignee?.value?.length ||\n controls?.program_default_assignee?.value?.length ||\n controls?.program_default_assignee?.value?.length ||\n controls?.program_default_assignee_group?.value?.length\n \"\n [active]=\"['ASSIGNEE', 'DEFAULT_ASSIGNEE']?.includes(activeList)\"\n [disabled]=\"\n sideElements?.includes(activeList) &&\n !['ASSIGNEE', 'DEFAULT_ASSIGNEE'].includes(activeList)\n \"\n [img]=\"ASSETS.case_assignees\"\n >\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"activeList === 'DEFAULT_ASSIGNEE'\"\n >ASSIGNEES\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Assignees are required to complete the responsibilities that have been assigned to them. Where Assignees are selected when creating a Program, only those Assignees will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"AssigneeHelpText\"\n >&#xeb16;</i\n >\n </label>\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'DEFAULT_ASSIGNEE'\"\n [placeholder]=\"\n 'Who is responsible for completing the responsibilities within this Program?'\n \"\n (select)=\"activateList('ASSIGNEE')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_assignee?.value?.length ||\n controls?.program_assignee_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_assignee?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(controls?.program_assignee?.value[0], 'ASSIGNEE')\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_assignee?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_assignee?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"assignee.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_assignee?.value?.length > 1\"\n >\n +{{ controls?.program_assignee?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_assignee_group?.value?.length &&\n controls?.program_assignee?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_assignee_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_assignee_group?.value[0],\n 'ASSIGNEE_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_assignee_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_assignee_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"assignee_group.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_assignee_group?.value?.length > 1\"\n >\n +{{ controls?.program_assignee_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_assignee?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_assignee?.value[0],'ASSIGNEE')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_assignee?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_assignee?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_assignee?.value?.length > 1\" class=\"count user\" appPopover (click)=\"assignee.popover()\" placement=\"right\">+{{controls?.program_assignee?.value?.length -1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_assignee_group?.value?.length && controls?.program_assignee?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_assignee_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_assignee_group?.value[0],'ASSIGNEE_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_assignee_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_assignee_group?.value[0]?.group_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_assignee_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"assignee_group.popover()\" placement=\"right\">+{{controls?.program_assignee_group?.value?.length -1 }}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'ASSIGNEE'\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('ASSIGNEE')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #assignee [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let assignee of controls?.program_assignee?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(assignee, 'ASSIGNEE')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ assignee?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #assignee_group [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_assignee_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(group, 'ASSIGNEE_GROUP')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"activeList === 'ASSIGNEE'\"\n >DEFAULT ASSIGNEE\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'This option lets you specify the Default Assignees for all new responsibilities linked with a Program. If a Default Assignees is selected, the user will automatically be selected the Assignee when creating a responsibility linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility. '\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"DAHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'ASSIGNEE'\"\n [placeholder]=\"\n 'Which persons will be selected as the default assignees for the responsibilities within this Program?'\n \"\n (select)=\"activateList('DEFAULT_ASSIGNEE')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_assignee?.value?.length ||\n controls?.program_default_assignee_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_assignee?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_assignee?.value[0],\n 'DEFAULT_ASSIGNEE'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_assignee?.value[0]?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_assignee?.value[0]?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultAssignee.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_default_assignee?.value?.length > 1\"\n >\n +{{ controls?.program_default_assignee?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_default_assignee_group?.value?.length &&\n controls?.program_default_assignee?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_assignee_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_assignee_group?.value[0],\n 'DEFAULT_ASSIGNEE_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_assignee_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_assignee_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultAssigneeGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_assignee_group?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_assignee_group?.value?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_assignee?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_assignee?.value[0],'DEFAULT_ASSIGNEE')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_assignee?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{ controls?.program_default_assignee?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_assignee?.value?.length > 1\" class=\"count user\" appPopover (click)=\"defaultAssignee.popover()\" placement=\"right\">+{{controls?.program_default_assignee?.value?.length - 1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_default_assignee_group?.value?.length && controls?.program_default_assignee?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_assignee_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_assignee_group?.value[0],'DEFAULT_ASSIGNEE_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_assignee_group?.value[0]?.group_name }}</span>\n </span>\n <button *ngIf=\"controls?.program_default_assignee_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"defaultAssigneeGroup.popover()\" placement=\"right\">+{{controls?.program_default_assignee_group?.value?.length -1 }}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_ASSIGNEE'\"\n (click)=\"activateList('DEFAULT_ASSIGNEE')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #defaultAssignee [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let assignee of controls?.program_default_assignee?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(assignee, 'DEFAULT_ASSIGNEE')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ assignee?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #defaultAssigneeGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_assignee_group?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(assignee, 'DEFAULT_ASSIGNEE_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <div\n class=\"radio-group-selector\"\n [class.disabled]=\"activeList === 'ASSIGNEE'\"\n >\n <app-cs-radio\n [name]=\"'assignee'\"\n [checked]=\"controls?.assignee_completion_criteria?.value === 'ALL'\"\n (checkedEvent)=\"setFormField('assignee_completion_criteria', 'ALL')\"\n >\n ALL SELECTED PERSONS NEED TO COMPLETE THIS\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If selected, separate responsibilities will be created for each person.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n <app-cs-radio\n [name]=\"'assignee'\"\n [checked]=\"controls?.assignee_completion_criteria?.value === 'ANYONE'\"\n (checkedEvent)=\"\n setFormField('assignee_completion_criteria', 'ANYONE')\n \"\n >\n ANY SELECTED PERSON CAN COMPLETE THIS\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If selected, only one responsibility will be created.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n </div>\n </form-field>\n\n <!-- Reviewer -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.REVIEWER\"\n [checked]=\"\n controls?.program_reviewer?.value?.length ||\n controls?.program_default_reviewer?.value?.length ||\n controls?.program_default_reviewer?.value?.length ||\n controls?.program_default_reviewer_group?.value?.length\n \"\n [active]=\"['REVIEWER', 'DEFAULT_REVIEWER']?.includes(activeList)\"\n [disabled]=\"\n sideElements?.includes(activeList) &&\n !['REVIEWER', 'DEFAULT_REVIEWER'].includes(activeList)\n \"\n [img]=\"ASSETS.reviewer\"\n >\n <label\n [class.disabled]=\"activeList === 'DEFAULT_REVIEWER'\"\n class=\"vx-control-panel\"\n >Reviewers\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Reviewers are required to review responsibilities after they have been completed. Where Reviewers are selected when creating a Program, only those Reviewers will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"ReviewerHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'DEFAULT_REVIEWER'\"\n [placeholder]=\"\n 'Who is responsible for reviewing the responsibilities within this Program?'\n \"\n (select)=\"activateList('REVIEWER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_reviewer?.value?.length ||\n controls?.program_reviewer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_reviewer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(controls?.program_reviewer?.value[0], 'REVIEWER')\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_reviewer?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_reviewer?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"reviewer.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_reviewer?.value?.length > 1\"\n >\n +{{ controls?.program_reviewer?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_reviewer_group?.value?.length &&\n controls?.program_reviewer?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_reviewer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_reviewer_group?.value[0],\n 'REVIEWER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_reviewer_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_reviewer_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"reviewerGroup.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_reviewer_group?.value?.length > 1\"\n >\n +{{ controls?.program_reviewer_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_reviewer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_reviewer?.value[0],'REVIEWER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_reviewer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_reviewer?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_reviewer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"reviewer.popover()\" placement=\"right\">+{{controls?.program_reviewer?.value?.length -1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_reviewer_group?.value?.length && controls?.program_reviewer?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_reviewer_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_reviewer_group?.value[0],'REVIEWER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_reviewer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_reviewer_group?.value[0]?.group_name}}\n </span>\n </span>\n <button *ngIf=\"controls?.program_reviewer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"reviewerGroup.popover()\" placement=\"right\">+{{controls?.program_reviewer_group?.value?.length - 1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'REVIEWER'\"\n (click)=\"activateList('REVIEWER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #reviewer [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let reviewer of controls?.program_reviewer?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(reviewer, 'REVIEWER')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ reviewer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #reviewerGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_reviewer_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(group, 'REVIEWER_GROUP')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <label\n [class.disabled]=\"activeList === 'REVIEWER'\"\n class=\"vx-control-panel\"\n >DEFAULT Reviewer\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'This option lets you specify the Default Reviewers for responsibilities linked with a Program. Where a user has been specified as a Default Reviewer, that user will automatically be selected as the Reviewer when creating a responsibility linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"DRHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'REVIEWER'\"\n [placeholder]=\"\n 'Which persons will be selected as the default reviewers for the responsibilities within this Program?'\n \"\n (select)=\"activateList('DEFAULT_REVIEWER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_reviewer?.value?.length ||\n controls?.program_default_reviewer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_reviewer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_reviewer?.value[0],\n 'DEFAULT_REVIEWER'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_reviewer?.value[0]?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_reviewer?.value[0]?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultReviewer.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_default_reviewer?.value?.length > 1\"\n >\n +{{ controls?.program_default_reviewer?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_default_reviewer_group?.value?.length &&\n controls?.program_default_reviewer?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_reviewer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_reviewer_group?.value[0],\n 'DEFAULT_REVIEWER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_reviewer_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_reviewer_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultReviewerGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_reviewer_group?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_reviewer_group?.value?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_reviewer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_reviewer?.value[0],'DEFAULT_REVIEWER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_reviewer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_reviewer?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_reviewer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"defaultReviewer.popover()\" placement=\"right\">+{{controls?.program_default_reviewer?.value?.length - 1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_default_reviewer_group?.value?.length && controls?.program_default_reviewer?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_reviewer_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_reviewer_group?.value[0],'DEFAULT_REVIEWER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_reviewer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_reviewer_group?.value[0]?.group_name}}\n </span>\n </span>\n <button *ngIf=\"controls?.program_default_reviewer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"defaultReviewerGroup.popover()\" placement=\"right\">+{{controls?.program_default_reviewer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_REVIEWER'\"\n (click)=\"activateList('DEFAULT_REVIEWER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #defaultReviewer [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let reviewer of controls?.program_default_reviewer?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(reviewer, 'DEFAULT_REVIEWER')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ reviewer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #defaultReviewerGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_reviewer_group?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(group, 'DEFAULT_REVIEWER_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <div\n class=\"radio-group-selector\"\n [class.disabled]=\"activeList === 'REVIEWER'\"\n >\n <app-cs-radio\n [name]=\"'reviewer'\"\n [checked]=\"\n controls?.reviewer_completion_criteria?.value === 'SEQUENTIAL'\n \"\n (checkedEvent)=\"\n setFormField('reviewer_completion_criteria', 'SEQUENTIAL')\n \"\n [class.disabled]=\"\n controls?.program_default_reviewer_group?.value?.length > 0\n \"\n >\n SEQUENTIAL\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'The responsibility will be sent for review one at a time in the sequence defined by you.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n <app-cs-radio\n [name]=\"'reviewer'\"\n [checked]=\"\n controls?.reviewer_completion_criteria?.value === 'ANYONE' ||\n controls?.program_default_reviewer_group?.value?.length > 0\n \"\n (checkedEvent)=\"\n setFormField('reviewer_completion_criteria', 'ANYONE')\n \"\n >\n ANY REVIEWER CAN MARK THIS AS REVIEWED\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'The responsibility will be sent for review to all reviewers at the same time. If anyone of the reviewer reviews the responsibility, it will be considered as reviewed.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n </div>\n </form-field>\n\n <!-- Overseer -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.OVERSEER\"\n [checked]=\"\n controls?.program_overseer?.value?.length ||\n controls?.program_default_overseer?.value?.length ||\n controls?.program_default_overseer?.value?.length ||\n controls?.program_default_overseer_group?.value?.length\n \"\n [active]=\"activeList === 'OVERSEER'\"\n [disabled]=\"\n sideElements?.includes(activeList) &&\n !['OVERSEER', 'DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(\n activeList\n )\n \"\n [img]=\"ASSETS.oversight\"\n >\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"\n ['DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n \"\n >Oversights\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Oversights receive updates when a responsibility is completed, completed with delay or not completed. Where Oversights are selected when creating a Program, only those Oversights will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"overseerHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"\n ['DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n \"\n [placeholder]=\"\n 'Who is responsible for overseeing the responsibilities within this Program?'\n \"\n (select)=\"activateList('OVERSEER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_overseer?.value?.length ||\n controls?.program_overseer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_overseer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(controls?.program_overseer?.value[0], 'OVERSEER')\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_overseer?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_overseer?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseers.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_overseer?.value?.length > 1\"\n >\n +{{ controls?.program_overseer?.value?.length - 1 }}\n </button>\n </div>\n <span\n *ngIf=\"\n controls?.program_overseer_group?.value?.length &&\n controls?.program_overseer?.value?.length\n \"\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_overseer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_overseer_group?.value[0],\n 'OVERSEER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_overseer_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_overseer_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseerGroup.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_overseer_group?.value?.length > 1\"\n >\n +{{ controls?.program_overseer_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_overseer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_overseer?.value[0],'OVERSEER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_overseer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">\n {{controls?.program_overseer?.value[0]?.member_name}}\n </span>\n </span>\n <button *ngIf=\"controls?.program_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseers.popover()\" placement=\"right\">+{{controls?.program_overseer?.value?.length -1}}</button>\n </div>\n <span *ngIf=\"controls?.program_overseer_group?.value?.length && controls?.program_overseer?.value?.length \" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_overseer_group?.value?.length \">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_overseer_group?.value[0],'OVERSEER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_overseer_group?.value[0]?.group_name}}</span></span>\n <button *ngIf=\"controls?.program_overseer_group?.value?.length> 1\" class=\"count\" appPopover (click)=\"overseerGroup.popover()\" placement=\"right\">+{{controls?.program_overseer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n\n <button\n *ngIf=\"activeList !== 'OVERSEER'\"\n (click)=\"activateList('OVERSEER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #overseers [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let overseer of controls?.program_overseer?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i class=\"icons\" (click)=\"remove(overseer, 'OVERSEER')\"\n >&#xe90d;</i\n >\n {{ overseer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #overseerGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_overseer_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(group, 'OVERSEER_GROUP')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <ng-container [class.disabled]=\"activeList === 'OVERSEER'\">\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"['OVERSEER'].includes(activeList)\"\n >DEFAULT Oversight\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'This option lets you specify the Default Oversight for responsibilities linked with a Program. Where a user has been specified as a Default Oversight, that user will automatically be selected as the Oversight when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"DOHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [disabled]=\"\n ['OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n \"\n [selectDiv]=\"true\"\n [placeholder]=\"\n 'Which persons will be selected as the default overseers for the responsibilities within this Program?'\n \"\n (select)=\"activateList('DEFAULT_OVERSEER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_overseer?.value?.length ||\n controls?.program_default_overseer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_overseer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_overseer?.value[0],\n 'DEFAULT_OVERSEER'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_overseer?.value[0]?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_overseer?.value[0]?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseersDefault.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_default_overseer?.value?.length > 1\"\n >\n +{{ controls?.program_default_overseer?.value?.length - 1 }}\n </button>\n </div>\n <span\n *ngIf=\"\n controls?.program_default_overseer_group?.value?.length &&\n controls?.program_default_overseer?.value?.length\n \"\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_overseer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_overseer_group?.value[0],\n 'DEFAULT_OVERSEER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_overseer_group?.value[0]\n ?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_overseer_group?.value[0]\n ?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseerDefaultGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_overseer_group?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_overseer_group?.value?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_overseer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_overseer?.value[0],'DEFAULT_OVERSEER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_overseer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_overseer?.value[0]?.member_name}}</span></span>\n <button *ngIf=\"controls?.program_default_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseersDefault.popover()\" placement=\"right\">+{{controls?.program_default_overseer?.value?.length -1}}</button>\n </div>\n <span *ngIf=\"controls?.program_default_overseer_group?.value?.length && controls?.program_default_overseer?.value?.length\" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_overseer_group?.value?.length \">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_overseer_group?.value[0],'DEFAULT_OVERSEER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_overseer_group?.value[0]?.group_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_overseer_group?.value?.length >1\" class=\"count\" appPopover (click)=\"overseerDefaultGroup.popover()\" placement=\"right\">+{{controls?.program_default_overseer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_OVERSEER'\"\n (click)=\"activateList('DEFAULT_OVERSEER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #overseersDefault [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let overseer of controls?.program_default_overseer?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n class=\"icons\"\n (click)=\"remove(overseer, 'DEFAULT_OVERSEER')\"\n >&#xe90d;</i\n >\n {{ overseer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #overseerDefaultGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_overseer_group?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(group, 'DEFAULT_OVERSEER_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <label class=\"vx-control-panel\"> </label>\n <input-with-pill\n class=\"vx-mt-2\"\n [selectDiv]=\"true\"\n [line]=\"3\"\n [disabled]=\"['OVERSEER', 'DEFAULT_OVERSEER'].includes(activeList)\"\n [placeholder]=\"\n 'Which persons will be selected as the default overseers for responsibilities that are not completed within this Program?'\n \"\n (select)=\"activateList('DEFAULT_FAILED_OVERSEER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_failed_overseer?.value?.length ||\n controls?.program_default_failed_overseer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_failed_overseer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_failed_overseer?.value[0],\n 'DEFAULT_FAILED_OVERSEER'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_failed_overseer?.value[0]\n ?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_failed_overseer?.value[0]\n ?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseersDefaultFail.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_failed_overseer?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_failed_overseer?.value?.length - 1\n }}\n </button>\n </div>\n <span\n *ngIf=\"\n controls?.program_default_failed_overseer_group?.value\n ?.length &&\n controls?.program_default_failed_overseer?.value?.length\n \"\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"\n controls?.program_default_failed_overseer_group?.value?.length\n \"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_failed_overseer_group?.value[0],\n 'DEFAULT_FAILED_OVERSEER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_failed_overseer_group?.value[0]\n ?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_failed_overseer_group?.value[0]\n ?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseerDefaultFailGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_failed_overseer_group?.value\n ?.length > 1\n \"\n >\n +{{\n controls?.program_default_failed_overseer_group?.value\n ?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_failed_overseer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_failed_overseer?.value[0],'DEFAULT_FAILED_OVERSEER')\" >&#xe90d;</i>\n <span class=\"chip\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_failed_overseer?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_failed_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseersDefaultFail.popover()\" placement=\"right\">+{{controls?.program_default_failed_overseer?.value?.length -1}}</button>\n </div>\n <span *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length && controls?.program_default_failed_overseer?.value?.length\" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length \">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_failed_overseer_group?.value[0],'DEFAULT_FAILED_OVERSEER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_failed_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_failed_overseer_group?.value[0]?.group_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"overseerDefaultFailGroup.popover()\" placement=\"right\">+{{controls?.program_default_failed_overseer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_FAILED_OVERSEER'\"\n (click)=\"activateList('DEFAULT_FAILED_OVERSEER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #overseersDefaultFail [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let overseer of controls?.program_default_failed_overseer\n ?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n class=\"icons\"\n (click)=\"remove(overseer, 'DEFAULT_FAILED_OVERSEER')\"\n >&#xe90d;</i\n >\n {{ overseer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #overseerDefaultFailGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_failed_overseer_group\n ?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(group, 'DEFAULT_FAILED_OVERSEER_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </ng-container>\n </form-field>\n\n <!-- Assessment -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.ASSESSMENT\"\n [checked]=\"controls?.program_assessments?.value?.length\"\n [active]=\"activeList === 'ASSESSMENT'\"\n [disabled]=\"\n sideElements.includes(activeList) && activeList !== 'ASSESSMENT'\n \"\n [img]=\"ASSETS.assessments\"\n >\n <label class=\"vx-control-panel\"\n >ASSESSMENTS\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Assessments are a digital form that are created in \u201CAssessment\u201D within the Compliance Module. Where Assessments are selected when creating a Program, only those Assessments will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"AssessmentHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [placeholder]=\"\n 'Which assessments can be linked to the responsibilities within this Program?'\n \"\n (select)=\"activateList('ASSESSMENT')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"controls?.program_assessments?.value?.length\"\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"\n controls?.program_assessments?.value\n | assessmentResolver as assessments\n \"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"remove(assessments[0], 'ASSESSMENT')\"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"assessments[0]?.assessment_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ assessments[0]?.assessment_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"program_assessments.popover()\"\n placement=\"right\"\n *ngIf=\"assessments?.length > 1\"\n >\n +{{ assessments?.length - 1 }}\n </button>\n </div>\n\n <!-- <div class=\"chip-container\">\n <ng-container *ngIf=\"(controls?.program_assessments?.value | assessmentResolver) as assessments\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i class=\"icons\" (click)=\"remove(assessments[0],'ASSESSMENT')\">&#xe90d;</i>{{assessments[0]?.assessment_name}} </span>\n <button *ngIf=\"assessments?.length > 1\" class=\"count\" appPopover (click)=\"program_assessments.popover()\" placement=\"right\">+{{assessments?.length -1 }}</button>\n </div>\n </ng-container>\n </div> -->\n <button\n *ngIf=\"activeList !== 'ASSESSMENT'\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('ASSESSMENT')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #program_assessments [dontCloseonClick]=\"true\">\n <ng-container>\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let assessment of controls?.program_assessments?.value\n | assessmentResolver\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(assessment, 'ASSESSMENT')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ assessment?.assessment_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </ng-container>\n </app-popover>\n </form-field>\n\n <!-- Format & Evidence -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.FORMATE_EVIDENCE\"\n [checked]=\"[true, false].includes(controls?.evidence_required?.value)\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.format_evidence\"\n >\n <label class=\"vx-control-panel\"\n >Evidence\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If selected, evidence of completion of a responsibility will be required for all responsibilities that are linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"EvidenceHelpText\"\n >&#xeb16;</i\n ></label\n >\n <div class=\"upload-format\">\n <span class=\"text\"\n >Do all responsibilities within this program require evidence?</span\n >\n <div class=\"radio-group program\">\n <app-cs-radio\n [name]=\"'evidence_required'\"\n [checked]=\"controls?.evidence_required?.value\"\n (checkedEvent)=\"setFormField('evidence_required', true)\"\n >YES</app-cs-radio\n >\n <app-cs-radio\n [name]=\"'evidence_required'\"\n [checked]=\"!controls?.evidence_required?.value\"\n (checkedEvent)=\"setFormField('evidence_required', false)\"\n >NO</app-cs-radio\n >\n </div>\n </div>\n <!-- <div class=\"vx-d-flex vx-align-center vx-justify-end vx-mt-2\">\n <div class=\"vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase vx-mr-2\">Allow any file to be marked as\n key\n evidence</div>\n <switch formControlName=\"allow_any_file_key_evidence\"\n (change)=\"setFormField('allow_any_file_key_evidence',$event?.target?.checked)\"></switch>\n </div> -->\n </form-field>\n\n <!-- Custom Field -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.CUSTOM_FIELDS\"\n [checked]=\"controls?.custom_fields?.value?.length\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.custom_fields\"\n >\n <label class=\"vx-control-panel\"\n >CUSTOM FIELD\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Where a custom field is specified, all responsibilities linked with a Program will contain that custom field. Custom fields enable the collection of additional meta data.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"CFHelpText\"\n >&#xeb16;</i\n ></label\n >\n <custom-field formControlName=\"custom_fields\"></custom-field>\n </form-field>\n </form>\n</div>\n\n<!-- list of roles -->\n<role-list\n *ngIf=\"activeList === 'ROLE'\"\n [selected]=\"controls?.program_roles?.value | refDisconnect\"\n [loading]=\"listLoadingState.ROLES\"\n [list]=\"lists?.ROLES?.data ?? []\"\n (save)=\"listAction($event, 'ROLE')\"\n (cancel)=\"fieldDeselector('ROLE')\"\n [featureflagrole]=\"featureflagrole\"\n [featureflagGroup]=\"featureflagGroups\"\n [ff_rc_listing]=\"ff_rc_listing\"\n></role-list>\n\n<!-- list of frameworks -->\n<!-- <app-define-framework-listing *ngIf=\"activeList === 'FRAMEWORK'\" (cancel)=\"fieldDeselector('FRAMEWORK')\" (next)=\"listAction($event,'FRAMEWORK')\" [mode]=\"mode\" [selectedFramework]=\"controls?.framework?.value\"></app-define-framework-listing> -->\n<!-- list of responsibility center -->\n<app-responsibility-centers-list\n *ngIf=\"activeList === 'RC'\"\n [responsibilityCentersList]=\"lists?.RC ?? []\"\n [radioSelection]=\"false\"\n [rcIdKey]=\"'rc_id'\"\n (closeRcList)=\"fieldDeselector('RC')\"\n (saveSelectedList)=\"listAction($event, 'RC')\"\n [selectedResponsibilityCenters]=\"controls?.rc?.value | refDisconnect\"\n>\n</app-responsibility-centers-list>\n<!-- render userlist with group -->\n\n<user-group-list\n *ngIf=\"activeList === 'OWNER'\"\n [groupEnabled]=\"true\"\n [singleSelect]=\"false\"\n [loading]=\"listLoadingState.USERS\"\n [nonRemovableUserIds]=\"lists.NON_REMOVABLE_OWNERS | listToId : 'member_id'\"\n [userlist]=\"lists?.OWNERS?.data ?? []\"\n [selectedUsers]=\"controls?.program_owners?.value | refDisconnect\"\n (fetchUserData)=\"fetchUsersAssociatedWithRoles(false, $event)\"\n [userListInfo]=\"lists?.OWNERS\"\n [groupListInfo]=\"lists?.OWNERS_GROUPS\"\n [groupList]=\"lists?.OWNERS_GROUPS?.data ?? []\"\n [selectedGroups]=\"controls?.program_owners_group?.value | refDisconnect\"\n (save)=\"listAction($event, 'OWNER')\"\n (cancel)=\"fieldDeselector('OWNER')\"\n [panelTitle]=\"panelTitleOwner\"\n [featureflag]=\"featureflagGroups\"\n></user-group-list>\n\n<user-group-list\n *ngIf=\"activeList === 'COLLABORATOR'\"\n [groupEnabled]=\"false\"\n [singleSelect]=\"false\"\n [userlist]=\"lists?.COLLABORATORS?.data ?? []\"\n [disabledIds]=\"disableCollaboratorIds\"\n [selectedUsers]=\"controls?.program_collaborator?.value | refDisconnect\"\n [userListInfo]=\"lists?.COLLABORATORS\"\n (save)=\"listAction($event, 'COLLABORATOR')\"\n (cancel)=\"fieldDeselector('COLLABORATOR')\"\n [panelTitle]=\"panelTitleCollaborator\"\n>\n</user-group-list>\n<user-group-list\n *ngIf=\"activeList === 'ASSIGNEE'\"\n [groupEnabled]=\"true\"\n [singleSelect]=\"false\"\n [loading]=\"listLoadingState.USERS\"\n [userlist]=\"lists?.ASSIGNEES ?? []\"\n [selectedUsers]=\"controls?.program_assignee?.value | refDisconnect\"\n [groupList]=\"lists?.ASSIGNEES_GROUP ?? []\"\n [FromProgram]=\"true\"\n [selectedGroups]=\"controls?.program_assignee_group?.value | refDisconnect\"\n [disabledIds]=\"disabledAssigneeIds\"\n [fromResponsibility]=\"'Assignee'\"\n [reviewerIds]=\"selectedReviewerIds\"\n [overseerIds]=\"selectedOverseerIds\"\n [assignorId]=\"assignorId\"\n [userListInfo]=\"lists?.ASSIGNEES\"\n (save)=\"listAction($event, 'ASSIGNEE')\"\n (cancel)=\"fieldDeselector('ASSIGNEE')\"\n [panelTitle]=\"panelTitleAssignee\"\n [defaultSelectedUsers]=\"\n controls?.program_default_assignee?.value | refDisconnect\n \"\n [userType]=\"'assignees'\"\n [featureflag]=\"featureflagGroups\"\n>\n</user-group-list>\n<user-group-list\n *ngIf=\"activeList === 'DEFAULT_ASSIGNEE'\"\n [groupEnabled]=\"true\"\n [singleSelect]=\"false\"\n [loading]=\"listLoadingState.USERS\"\n [userlist]=\"lists?.DEFAULT_ASSIGNEES ?? []\"\n [selectedUsers]=\"controls?.program_default_assignee?.value | refDisconnect\"\n [groupList]=\"lists?.DEFAULT_ASSIGNEES_GROUP ?? []\"\n [FromProgram]=\"true\"\n [selectedGroups]=\"\n controls?.program_default_assignee_group?.value | refDisconnect\n \"\n [disabledIds]=\"disabledAssigneeIds\"\n [fromResponsibility]=\"'Assignee'\"\n [reviewerIds]=\"selectedReviewerIds\"\n [overseerIds]=\"selectedOverseerIds\"\n [assignorId]=\"assignorId\"\n [userListInfo]=\"lists?.DEFAULT_ASSIGNEE\"\n (save)=\"listAction($event, 'DEFAULT_ASSIGNEE')\"\n (cancel)=\"fieldDeselector('DEFAULT_ASSIGNEE')\"\n [featureflag]=\"featureflagGroups\"\n>\n</user-group-list>\n\n<user-group-list\n *ngIf=\"activeList === 'REVIEWER' && (!featureflagGroups || featureflagGroups)\"\n [groupEnabled]=\"featureflagGroups\"\n [singleSelect]=\"false\"\n [loading]=\"listLoadingState.USERS\"\n [FromProgram]=\"true\"\n [userlist]=\"lists?.REVIEWERS ?? []\"\n [selectedUsers]=\"controls?.program_reviewer?.value | refDisconnect\"\n [groupList]=\"lists?.REVIEWERS_GROUP ?? []\"\n [featureflag]=\"featureflagGroups\"\n [selectedGroups]=\"controls?.program_reviewer_group?.value | refDisconnect\"\n [disabledIds]=\"disableReviewerIds\"\n [fromResponsibility]=\"'Reviewer'\"\n [assignorId]=\"assignorId\"\n [assigneeIds]=\"selectedAssigneeIds\"\n [overseerIds]=\"selectedOverseerIds\"\n [userListInfo]=\"lists?.REVIEWERS\"\n (save)=\"listAction($event, 'REVIEWER')\"\n (cancel)=\"fieldDeselector('REVIEWER')\"\n [panelTitle]=\"panelTitleReviewer\"\n [defaultSelectedUsers]=\"\n controls?.program_default_reviewer?.value | refDisconnect\n \"\n [userType]=\"'reviewers'\"\n>\n</user-group-list>\n<user-group-list\n *ngIf=\"\n activeList === 'DEFAULT_REVIEWER' &&\n (!featureflagGroups || featureflagGroups)\n \"\n [groupEnabled]=\"featureflagGroups\"\n [singleSelect]=\"false\"\n [loading]=\"listLoadingState.USERS\"\n [FromProgram]=\"true\"\n [userlist]=\"lists?.DEFAULT_REVIEWERS ?? []\"\n [selectedUsers]=\"controls?.program_default_reviewer?.value | refDisconnect\"\n [groupList]=\"lists?.DEFAULT_REVIEWERS_GROUP ?? []\"\n [featureflag]=\"featureflagGroups\"\n [selectedGroups]=\"\n controls?.program_default_reviewer_group?.value | refDisconnect\n \"\n [disabledIds]=\"disableReviewerIds\"\n [fromResponsibility]=\"'Reviewer'\"\n [assignorId]=\"assignorId\"\n [assigneeIds]=\"selectedAssigneeIds\"\n [overseerIds]=\"selectedOverseerIds\"\n [userListInfo]=\"lists?.DEFAULT_REVIEWERS\"\n (save)=\"listAction($event, 'DEFAULT_REVIEWER')\"\n (cancel)=\"fieldDeselector('DEFAULT_REVIEWER')\"\n [panelTitle]=\"panelTitleDefaultReviewer\"\n>\n</user-group-list>\n<user-group-list\n *ngIf=\"activeList === 'OVERSEER' && (!featureflagGroups || featureflagGroups)\"\n [groupEnabled]=\"featureflagGroups\"\n [singleSelect]=\"false\"\n [loading]=\"listLoadingState.USERS\"\n [FromProgram]=\"true\"\n [userlist]=\"lists?.OVERSEERS ?? []\"\n [selectedUsers]=\"controls?.program_overseer?.value | refDisconnect\"\n [groupList]=\"lists?.OVERSEERS_GROUP ?? []\"\n [selectedGroups]=\"controls?.program_overseer_group?.value | refDisconnect\"\n [featureflag]=\"featureflagGroups\"\n [disabledIds]=\"disableOverseerIds\"\n [fromResponsibility]=\"'Overseer'\"\n [assignorId]=\"assignorId\"\n [assigneeIds]=\"selectedAssigneeIds\"\n [reviewerIds]=\"selectedReviewerIds\"\n [userListInfo]=\"lists?.OVERSEES\"\n (save)=\"listAction($event, 'OVERSEER')\"\n (cancel)=\"fieldDeselector('OVERSEER')\"\n [defaultSelectedUsers]=\"\n controls?.program_default_overseer?.value\n | refDisconnect\n | arrayConcat : controls?.program_default_failed_overseer?.value\n \"\n [userType]=\"'overseers'\"\n>\n</user-group-list>\n<user-group-list\n *ngIf=\"\n activeList === 'DEFAULT_OVERSEER' &&\n (!featureflagGroups || featureflagGroups)\n \"\n [groupEnabled]=\"featureflagGroups\"\n [singleSelect]=\"false\"\n [loading]=\"listLoadingState.USERS\"\n [FromProgram]=\"true\"\n [userlist]=\"lists?.DEFAULT_OVERSEERS ?? []\"\n [selectedUsers]=\"controls?.program_default_overseer?.value | refDisconnect\"\n [groupList]=\"lists?.DEFAULT_OVERSEERS_GROUP ?? []\"\n [selectedGroups]=\"\n controls?.program_default_overseer_group?.value | refDisconnect\n \"\n [featureflag]=\"featureflagGroups\"\n [disabledIds]=\"disableOverseerIds\"\n [fromResponsibility]=\"'Overseer'\"\n [assignorId]=\"assignorId\"\n [assigneeIds]=\"selectedAssigneeIds\"\n [reviewerIds]=\"selectedReviewerIds\"\n [userListInfo]=\"lists?.DEFAULT_OVERSEERS\"\n (save)=\"listAction($event, 'DEFAULT_OVERSEER')\"\n (cancel)=\"fieldDeselector('DEFAULT_OVERSEER')\"\n>\n</user-group-list>\n<user-group-list\n *ngIf=\"\n activeList === 'DEFAULT_FAILED_OVERSEER' &&\n (!featureflagGroups || featureflagGroups)\n \"\n [groupEnabled]=\"featureflagGroups\"\n [singleSelect]=\"false\"\n [loading]=\"listLoadingState.USERS\"\n [FromProgram]=\"true\"\n [userlist]=\"lists?.DEFAULT_OVERSEERS ?? []\"\n [selectedUsers]=\"\n controls?.program_default_failed_overseer?.value | refDisconnect\n \"\n [groupList]=\"lists?.DEFAULT_OVERSEERS_GROUP ?? []\"\n [selectedGroups]=\"\n controls?.program_default_failed_overseer_group?.value | refDisconnect\n \"\n [featureflag]=\"featureflagGroups\"\n [disabledIds]=\"disableOverseerIds\"\n [fromResponsibility]=\"'Overseer'\"\n [assignorId]=\"assignorId\"\n [assigneeIds]=\"selectedAssigneeIds\"\n [reviewerIds]=\"selectedReviewerIds\"\n [userListInfo]=\"lists?.DEFAULT_OVERSEERS\"\n (save)=\"listAction($event, 'DEFAULT_FAILED_OVERSEER')\"\n (cancel)=\"fieldDeselector('DEFAULT_FAILED_OVERSEER')\"\n>\n</user-group-list>\n<assessment-picker\n *ngIf=\"activeList === 'ASSESSMENT'\"\n [selectedAssessment]=\"controls?.program_assessments?.value\"\n (cancelAssessment)=\"fieldDeselector('ASSESSMENT')\"\n (onAssessmentSelect)=\"listAction($event, 'ASSESSMENT')\"\n></assessment-picker>\n<app-loader-inline *ngIf=\"loader\"></app-loader-inline>\n<app-smiley-dialog-inline\n *ngIf=\"showSmiley\"\n [message]=\"smileyMessage\"\n [actionButtons]=\"actionButtons\"\n (action)=\"action($event)\"\n (closeSmiley)=\"closeSmiley($event)\"\n>\n</app-smiley-dialog-inline>\n\n<!-- Framework selector -->\n<app-framework-list\n *ngIf=\"activeList === 'FRAMEWORK'\"\n [workflowPage]=\"['FRAMEWORK']\"\n (assignControl)=\"listAction($event, 'FRAMEWORK')\"\n (closeFramework)=\"fieldDeselector('FRAMEWORK')\"\n [previousSelectedValues]=\"{ framework: controls?.framework.value }\"\n (entrustFramework)=\"entrustFramework($event)\"\n [headerText]=\"'Select a framework'\"\n></app-framework-list>\n", 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/padding/padding.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\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.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-top.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\";::ng-deep .workflow-program{display:block;position:relative}::ng-deep .workflow-program .scope-label{background:#747576;border-radius:.125rem;position:relative;z-index:1}::ng-deep .workflow-program .scope-label:before{background:#f1f1f1;content:\"\";position:absolute;top:.5rem;left:7rem;width:20rem;height:1px;z-index:-1}::ng-deep .workflow-program .scope-label:after{background:#f1f1f1;content:\"\";position:absolute;top:.5rem;left:-2.5rem;width:2.5rem;height:1px;z-index:-1}::ng-deep .workflow-program .scope-label .required{position:absolute;top:0;right:-.625rem}::ng-deep .workflow-program .info-icon{position:relative;top:.125rem;cursor:pointer}::ng-deep .workflow-program .date-picker .picker-group{width:calc(50% - .125rem);position:relative}::ng-deep .workflow-program .date-picker .picker-group:focus-within{border-color:#1e5dd3;box-shadow:0 0 5px #1e5dd345}::ng-deep .workflow-program .date-picker .picker-group input{height:2.5rem;border-radius:.25rem;border:1px solid #DBDBDB;background:#fff;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%;padding:0 2rem 0 .75rem;outline:none}::ng-deep .workflow-program .date-picker .picker-group input:focus,::ng-deep .workflow-program .date-picker .picker-group input:hover{border-color:#1e5dd3;box-shadow:0 0 5px #1e5dd345}::ng-deep .workflow-program .date-picker .picker-group input::placeholder{color:#747576;font-size:13px}::ng-deep .workflow-program .date-picker .picker-group input:-ms-input-placeholder{color:#747576;font-size:13px}::ng-deep .workflow-program .date-picker .picker-group input::-ms-input-placeholder{color:#747576;font-size:13px}::ng-deep .workflow-program .date-picker .picker-group i{height:1rem;width:1rem;position:absolute;right:.75rem;top:.625rem;pointer-events:none}::ng-deep .workflow-program .program-type-field{background:#f8f8f8;border:1px solid #dbdbdb;border-radius:4px;height:40px;display:flex;align-items:center;justify-content:space-between;padding:4px;position:relative;z-index:1}::ng-deep .workflow-program .program-type-field .type-item{position:relative}::ng-deep .workflow-program .program-type-field .type-item:first-of-type{width:6.25rem}::ng-deep .workflow-program .program-type-field .type-item:nth-child(2){width:5.75rem}::ng-deep .workflow-program .program-type-field .type-item:nth-child(2).active~.background-glider{transform:translate(6.4375rem);width:5.75rem}::ng-deep .workflow-program .program-type-field .type-item:nth-child(3){width:8.625rem}::ng-deep .workflow-program .program-type-field .type-item:nth-child(3).active~.background-glider{transform:translate(12.375rem);width:8.625rem}::ng-deep .workflow-program .program-type-field .type-item:last-of-type{width:5.25rem}::ng-deep .workflow-program .program-type-field .type-item:last-of-type.active~.background-glider{transform:translate(21.1875rem);width:5.25rem}::ng-deep .workflow-program .program-type-field .type-item button{background:transparent;border:none;border-radius:0;color:#747576;font-size:11px;font-weight:600;text-transform:uppercase;width:100%;height:32px;padding:0 12px;text-align:center}::ng-deep .workflow-program .program-type-field .type-item button.disabled{background:transparent!important;color:#dbdbdb!important;filter:unset!important;opacity:unset!important;pointer-events:none}::ng-deep .workflow-program .program-type-field .type-item .info{color:#1e5dd3;font-size:12px;position:absolute;top:10px;right:12px;cursor:pointer}::ng-deep .workflow-program .program-type-field .type-item.active button{color:#1e5dd3!important}::ng-deep .workflow-program .program-type-field .background-glider{background:#fff;border-radius:4px;box-shadow:0 1px 3px #161b2f26;position:absolute;display:flex;width:6.25rem;height:32px;z-index:-1;transition:.25s ease-out}::ng-deep .workflow-program .vx-form-group .upload-files .file-item{background:#f1f1f1;border:1px solid #dbdbdb;border-radius:.25rem;padding-left:.125rem}::ng-deep .workflow-program .vx-form-group .upload-files .file-item .file-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;max-width:8.5rem}::ng-deep .workflow-program .vx-form-group .upload-files .file-item button.delete-btn{background:transparent;border-radius:0;border:none;border-left:1px solid #dbdbdb;height:1.625rem}::ng-deep .workflow-program .vx-form-group .upload-files button.file-count{background:#1e5dd3;border-radius:.125rem;border:none;color:#fff;font-size:11px;display:flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0;margin:4px 0 0 4px}::ng-deep .workflow-program .vx-form-group .upload-format .radio-group app-cs-radio{height:1.375rem}::ng-deep .workflow-program .vx-form-group .default-selected{background:#fbfbfb;border:1px solid #F1F1F1;border-radius:.25rem;margin-top:.5rem}::ng-deep .workflow-program .vx-form-group .default-selected .selected{border-radius:0;border:none;background:none}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio{border-top:1px solid #F1F1F1}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio{margin-top:0!important}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item span.radio{position:absolute;top:.5rem;left:.75rem}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item span.value{font-size:11px;text-transform:uppercase;padding:.5rem .5rem .5rem 2.25rem;width:100%;display:flex;justify-content:space-between;margin:0;max-width:100%;font-weight:500;color:#707070}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item span.value i{font-size:12px;color:#1e5dd3}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item svg{position:absolute;top:.5rem;left:.75rem}::ng-deep .workflow-program .vx-form-group .selected .custom-text{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;max-height:2.4rem}::ng-deep .workflow-program .vx-form-group .selected button.cross-btn{background:transparent;border-radius:0;border:0;padding:0}::ng-deep .workflow-program .vx-form-group .custom-input{position:relative}::ng-deep .workflow-program .vx-form-group .custom-input input{padding-right:2rem}::ng-deep .workflow-program .vx-form-group .custom-input button.cross-btn{background:transparent;border-radius:0;border:0;position:absolute;top:.875rem;right:.625rem}::ng-deep .workflow-program .vx-form-group button.add-more-btn{background:transparent;border-radius:0;border:none;padding:0}::ng-deep app-popover .wf-action-list ul.action-item .avatar-card .value{text-transform:none!important}::ng-deep app-popover .wf-action-list ul.action-item li file-pill .file-item{background:transparent!important;border:none!important;border-radius:0!important;padding:0!important;margin:0!important}::ng-deep app-popover .wf-action-list ul.action-item li file-pill .file-name{width:100%!important;max-width:100%!important}::ng-deep app-popover .wf-action-list ul.action-item li file-pill button.delete-btn{border:none!important;padding-right:0!important}.disabled{opacity:.4;pointer-events:none;filter:grayscale(1)}.vx-info-card{width:280px;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both;background:#fff;box-shadow:0 3px 6px #1c5bd140;border-radius:4px;position:static;display:block;left:780}.vx-info-card-body{font-size:12px;padding:8px 12px;margin:0;font-weight:400;text-transform:none;color:#747576}\n", "@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\";::-webkit-scrollbar-track{background-color:#f1f1f1;position:absolute}::-webkit-scrollbar{width:3px;height:3px;background-color:transparent;position:absolute}::-webkit-scrollbar-thumb{border-radius:3px;background-color:#dbdbdb;position:absolute}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}button{font-family:Poppins,sans-serif}::ng-deep input.textField{background:#fff;border-radius:.25rem;border:1px solid #dbdbdb;font-size:13px;color:#747576;padding:8px 12px;position:relative;height:2.5rem;width:100%;transition:all .2s ease-in-out}::ng-deep input.textField::placeholder{font-size:13px;color:#747576}::ng-deep input.textField:hover,::ng-deep input.textField:focus{outline:none;border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .selectBoxEnable{background:#fff;border-radius:.25rem;border:1px solid #dbdbdb;cursor:pointer;height:2.5rem;position:relative;transition:all .2s ease-in-out}::ng-deep .selectBoxEnable:after{border-bottom-style:solid;border-bottom-width:1px;border-right-style:solid;border-right-width:1px;border-color:#747576;content:\"\";display:inline-block;right:12px;position:absolute;top:calc(50% - 4px);width:5px;height:5px;transform:rotate(45deg)}::ng-deep .selectBoxEnable:hover,::ng-deep .selectBoxEnable:focus{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .selectBoxEnable.disabled{background:#f1f1f1;pointer-events:none;opacity:1}::ng-deep .selectBoxEnable.withBtn:after{display:none}::ng-deep .selectBoxEnable.withBtn button.setBtn{background:transparent;border-radius:0;border:none;min-width:98px}::ng-deep .selectBoxSuccess{background:#f8f8f8;border-radius:.25rem;border:1px solid #f1f1f1;min-height:2.5rem;position:relative}::ng-deep .selectBoxSuccess .selectBoxText{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;width:22rem}::ng-deep .selectBoxSuccess button{background:transparent;border-radius:0;border:none}::ng-deep .selectBoxSuccess button.deleteBtn{color:#d93b41}::ng-deep .selectBoxSuccess .level-left{border-right:1px solid #f1f1f1;height:2.375rem;width:5rem}::ng-deep .selectBoxSuccess .level-left .level-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;width:4.5rem}::ng-deep .chipContainer{background:#fff;border-radius:.125rem;box-shadow:0 0 2px #1e5dd340;height:1.5rem}::ng-deep .chipContainer .cross{cursor:pointer;min-width:16px;width:16px;height:16px;display:flex;align-items:center;justify-content:center;background:transparent;border-radius:2px;margin-left:-4px}::ng-deep .chipContainer .cross:hover{background:#f1f1f1}::ng-deep .chipContainer .chipName{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;max-width:6rem}::ng-deep .chipContainer .chipName.no-width{max-width:unset}::ng-deep .chipContainer .chipName.full-width{max-width:25rem}::ng-deep .chipContainer button.countBtn{background:#1e5dd3;border-radius:1.25rem;border:none;min-width:1.5rem;height:1rem;margin:0 0 0 .5rem;padding:0 .25rem}::ng-deep .chipContainer button.countBtn.greenBg{background:#34aa44}::ng-deep .workflowLavel{background:#f1f1f1;border-radius:.125rem;color:#042e7d;min-width:1rem;height:1rem}::ng-deep .reviewSelection{border-radius:.25rem;border:1px solid #dbdbdb;transition:all .2s ease-in-out}::ng-deep .reviewSelection:hover{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .selectButton{background:#fff;border-radius:.25rem;border:1px solid #dbdbdb;cursor:pointer;height:2.5rem;position:relative;transition:all .2s ease-in-out}::ng-deep .selectButton:hover,::ng-deep .selectButton:focus{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep button.createNewBtn{background:transparent;border-radius:0;border:none}::ng-deep .vx-form-group{display:block;position:relative;margin-bottom:20px}::ng-deep .vx-form-group:after{content:\"\";display:block;clear:both}::ng-deep .vx-form-group .select{position:relative}::ng-deep .vx-form-group .select:after{border-bottom-style:solid;border-bottom-width:1px;border-right-style:solid;border-right-width:1px;border-color:#707070;content:\"\";display:inline-block;right:12px;position:absolute;top:calc(50% - 4px);width:5px;height:5px;transform:rotate(45deg)}::ng-deep .vx-form-group .select input{cursor:pointer;padding-right:30px!important}::ng-deep .vx-form-group .select .custom-input{height:40px;border-radius:4px;border:1px solid #dbdbdb;background:#fff;outline:none;padding:3px 12px;line-height:16px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%;cursor:pointer}::ng-deep .vx-form-group .select .custom-input:empty:not(:focus):before{content:attr(aria-placeholder);line-height:16px;font-size:13px;width:94%;display:block;pointer-events:none;opacity:.8}::ng-deep .vx-form-group .select .custom-input:hover{border-color:#1e5dd3;box-shadow:0 0 5px #1e5dd345}::ng-deep .vx-form-group .select .custom-input.frequency-custom-input{padding-right:108px;display:flex;align-items:center}::ng-deep .vx-form-group .select+app-cs-switch{display:block;margin-top:8px}::ng-deep .vx-form-group .select+app-cs-switch label.cs-switch span.value{white-space:nowrap;margin-right:5px;text-transform:uppercase}::ng-deep .vx-form-group .select+app-cs-radio{margin-top:8px!important}::ng-deep .vx-form-group .select~app-cs-radio{margin-top:4px;display:block;width:100%}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item span.radio{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item span.value{font-size:11px;text-transform:uppercase;border:1px solid #dbdbdb;border-radius:4px;padding:8px 8px 8px 36px;width:100%;display:flex;justify-content:space-between;margin:0;max-width:100%;font-weight:500;color:#707070}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item span.value i{font-size:12px;color:#1e5dd3}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item svg{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item input:checked~span.value{background:#eefcf0;border-color:#34aa44}::ng-deep .vx-form-group .select.button-sec:after{display:none}::ng-deep .vx-form-group .select.button-sec button{background:transparent;border:none;display:inline-flex;float:right;color:#1e5dd3;text-transform:uppercase;font-weight:600;cursor:pointer;font-size:11px;position:absolute;top:12px;right:8px;padding:0;margin:0}::ng-deep .vx-form-group .select+.vx-control-panel{margin-top:8px}::ng-deep .vx-form-group .select+.selected{margin-top:8px}::ng-deep .vx-form-group .select.select{margin-top:8px}::ng-deep .vx-form-group .upload-format{border:1px solid #dbdbdb;border-radius:4px;padding:8px 12px;display:block}::ng-deep .vx-form-group .upload-format span.text{line-height:20px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%;display:block;margin-bottom:6px}::ng-deep .vx-form-group .upload-format .radio-group{display:flex}::ng-deep .vx-form-group .upload-format .radio-group app-cs-radio{display:inline-block}::ng-deep .vx-form-group .upload-format .radio-group app-cs-radio label.radio-item span.value{font-size:11px;text-transform:uppercase;margin-left:8px}::ng-deep .vx-form-group .upload-format .radio-group app-cs-radio+app-cs-radio{margin-left:12px}::ng-deep .vx-form-group .upload-format~.upload-format{margin-top:4px}::ng-deep .vx-form-group .form-tab{display:flex;justify-content:flex-start}::ng-deep .vx-form-group .form-tab button{background:transparent;color:#161b2f;font-size:11px;line-height:16px;text-transform:uppercase;cursor:pointer;padding:8px 8px 8px 0;border:none;outline:none;font-weight:500}::ng-deep .vx-form-group .form-tab button:disabled{opacity:.5;pointer-events:none;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group .form-tab button+button{padding:8px}::ng-deep .vx-form-group .form-tab button.active{color:#1e5dd3}::ng-deep .vx-form-group .tab-group{border:1px solid #dbdbdb;border-radius:4px;padding:0;display:block;position:relative;transition:all .2s ease-in-out}::ng-deep .vx-form-group .tab-group:hover{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .vx-form-group .tab-group .upload-file{padding:16px 62px 16px 24px;display:flex;align-items:center;justify-content:space-between}::ng-deep .vx-form-group .tab-group .upload-file .image{width:80px}::ng-deep .vx-form-group .tab-group .upload-file .browse span{display:inline-block;font-size:12px;color:#747576;line-height:16px;padding:0 4px}::ng-deep .vx-form-group .tab-group .upload-file .browse .label{font-size:11px;color:#1e5dd3;line-height:16px;font-weight:600;text-transform:uppercase;margin:0;padding:0}::ng-deep .vx-form-group .tab-group .upload-file .browse .label input{opacity:0;position:absolute;margin:0;padding:0;inset:0;cursor:pointer;width:100%}::ng-deep .vx-form-group .tab-group.active{border-color:#1e5dd3}::ng-deep .vx-form-group .tab-group.uploaded{margin-top:4px}::ng-deep .vx-form-group .tab-group.uploaded .upload-file{padding:8px 0!important;text-align:center}::ng-deep .vx-form-group .tab-group.uploaded .upload-file .image{display:none}::ng-deep .vx-form-group .tab-group.uploaded .upload-file .browse{width:100%;text-align:center}::ng-deep .vx-form-group .tab-group+label.vx-form-group{margin-top:8px;margin-bottom:4px}::ng-deep .vx-form-group .file-list{background:#fbfbfb;border:1px solid #f1f1f1;border-radius:4px;padding:12px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;position:relative}::ng-deep .vx-form-group .file-list span.file-name{color:#747576;line-height:16px;font-size:11px;font-weight:400;cursor:pointer;max-width:calc(100% - 20px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}::ng-deep .vx-form-group .file-list .button-group{display:flex}::ng-deep .vx-form-group .file-list button{font-size:12px;color:#eb2424;cursor:pointer;display:flex;padding:0;border:none;outline:none;background:transparent}::ng-deep .vx-form-group .file-list button.edit{color:#1e5dd3}::ng-deep .vx-form-group .file-list button+button{margin-left:16px}::ng-deep .vx-form-group .file-list+.file-list{margin-top:4px}::ng-deep .vx-form-group .file-list .file-container{display:flex;justify-content:space-between;width:100%}::ng-deep .vx-form-group .file-list.policy{background:#fff}::ng-deep .vx-form-group .file-list cs-select{position:relative;margin-top:8px;width:100%}::ng-deep .vx-form-group .file-list cs-select .selection-wrap .input-group input.value{height:32px!important;font-size:13px!important}::ng-deep .vx-form-group .file-list cs-select .selection-wrap .input-group i{right:12px!important;top:12px!important}::ng-deep .vx-form-group .file-list app-line-loader{display:block;position:absolute;left:10px;right:10px;bottom:0}::ng-deep .vx-form-group label.vx-control-panel{color:#161b2f;font-size:11px;font-weight:500;line-height:16px;margin-bottom:8px;display:block;text-transform:uppercase;text-align:left}::ng-deep .vx-form-group label.vx-control-panel.custom-tag{font-size:10px}::ng-deep .vx-form-group label.vx-control-panel.vx-mt-8{margin-top:8px}::ng-deep .vx-form-group label.vx-control-panel span.required{color:#eb2424;font-size:14px;font-weight:500;position:relative;top:-2px}::ng-deep .vx-form-group label.vx-control-panel .button{background:transparent;border:none;display:inline-flex;float:right;color:#1e5dd3;text-transform:uppercase;font-weight:600;cursor:pointer;font-size:11px;padding:0;margin:0}::ng-deep .vx-form-group label.vx-control-panel app-cs-switch{float:right;display:block}::ng-deep .vx-form-group label.vx-control-panel i{margin-left:8px;font-size:12px;color:#1e5dd3;cursor:pointer;position:relative;top:1px}::ng-deep .vx-form-group label.vx-control-panel i.depreciation-icon{color:#e4b700;font-size:16px;position:relative;top:3px}::ng-deep .vx-form-group label.vx-control-panel .checkpoint-version{background:#f1f1f1;border-radius:2px;color:#042e7d;font-size:10px;font-weight:600;line-height:14px;margin-left:4px;padding:0 2px}::ng-deep .vx-form-group input[type=text],::ng-deep .vx-form-group .input{height:40px;border-radius:4px;border:1px solid #dbdbdb;background:#fff;outline:none;padding:8px 12px;line-height:20px;font-size:13px;color:#747576;transition:all .2s ease-in-out;width:100%;font-weight:400}::ng-deep .vx-form-group input[type=text]::placeholder,::ng-deep .vx-form-group .input::placeholder{color:#747576;font-weight:400}::ng-deep .vx-form-group input[type=text]:focus,::ng-deep .vx-form-group .input:focus,::ng-deep .vx-form-group input[type=text]:hover,::ng-deep .vx-form-group .input:hover{border-color:#1e5dd3!important;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .vx-form-group input[type=text].error,::ng-deep .vx-form-group .input.error{border-color:#eb2424;color:#eb2424;margin-bottom:4px}::ng-deep .vx-form-group input[type=text].error:focus,::ng-deep .vx-form-group .input.error:focus{box-shadow:0 0 5px #d31e1e45}::ng-deep .vx-form-group input[type=text]:disabled,::ng-deep .vx-form-group .input:disabled{background:#f1f1f1;cursor:not-allowed;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group input[type=text]:disabled:hover,::ng-deep .vx-form-group .input:disabled:hover{border-color:#dbdbdb;box-shadow:none}::ng-deep .vx-form-group input[type=text] span.text,::ng-deep .vx-form-group .input span.text{font-size:13px;color:#747576;font-weight:400;display:block;width:100%}::ng-deep .vx-form-group input[type=text] .input-group,::ng-deep .vx-form-group .input .input-group{display:flex;align-items:center}::ng-deep .vx-form-group input[type=text] .input-group.counter,::ng-deep .vx-form-group .input .input-group.counter{min-width:96px;width:96px}::ng-deep .vx-form-group input[type=text] .input-group.counter button,::ng-deep .vx-form-group .input .input-group.counter button{height:24px;width:24px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#747576;font-size:8px;cursor:pointer;outline:none}::ng-deep .vx-form-group input[type=text] .input-group.counter input,::ng-deep .vx-form-group .input .input-group.counter input{-webkit-appearance:textfield;-moz-appearance:textfield;height:24px;width:calc(100% - 48px);border:1px solid #f1f1f1;outline:none;padding:0 6px;text-align:center}::ng-deep .vx-form-group input[type=text] .input-group.counter input::-webkit-inner-spin-button,::ng-deep .vx-form-group .input .input-group.counter input::-webkit-inner-spin-button,::ng-deep .vx-form-group input[type=text] .input-group.counter input::-webkit-outer-spin-button,::ng-deep .vx-form-group .input .input-group.counter input::-webkit-outer-spin-button{appearance:none;margin:0}::ng-deep .vx-form-group input[type=text]+.file-list,::ng-deep .vx-form-group .input+.file-list{margin-top:8px}::ng-deep .vx-form-group input[type=text]::placeholder,::ng-deep .vx-form-group .input::placeholder{font-size:13px}::ng-deep .vx-form-group input[type=text]:-ms-input-placeholder,::ng-deep .vx-form-group .input:-ms-input-placeholder{font-size:13px}::ng-deep .vx-form-group input[type=text]::-ms-input-placeholder,::ng-deep .vx-form-group .input::-ms-input-placeholder{font-size:13px}::ng-deep .vx-form-group .classification{height:40px;border-radius:4px;border:1px solid #dbdbdb;background:#fff;padding:8px 12px;display:flex;justify-content:space-between}::ng-deep .vx-form-group .classification label{margin:0 4px 0 0;width:100%;position:relative;z-index:1}::ng-deep .vx-form-group .classification label span{display:block;width:100%;height:24px;border:1px solid #f1f1f1;border-radius:2px;line-height:24px;font-size:10px;text-align:center;color:#747576;font-weight:500;position:relative;text-transform:uppercase}::ng-deep .vx-form-group .classification label span:before{height:2px;content:\"\";top:0;right:0;left:0;border-radius:2px;position:absolute;transition:all .2s ease-in-out}::ng-deep .vx-form-group .classification label input{opacity:0;position:absolute;inset:0;margin:0;padding:0;width:100%;height:100%;cursor:pointer;z-index:1}::ng-deep .vx-form-group .classification label input:checked+span{color:#fff}::ng-deep .vx-form-group .classification label input:checked+span:before{bottom:0;height:100%;z-index:-1}::ng-deep .vx-form-group .classification label.low span:before{background:#34aa44}::ng-deep .vx-form-group .classification label.low-med span:before{background:#f2bf19}::ng-deep .vx-form-group .classification label.med-high span:before{background:#f29619}::ng-deep .vx-form-group .classification label.high span:before{background:#eb2424}::ng-deep .vx-form-group .classification label:last-of-type{margin-right:0}::ng-deep .vx-form-group .input{display:flex;align-items:center}::ng-deep .vx-form-group .selected{height:40px;border-radius:4px;border:1px solid #f1f1f1;background:#fbfbfb;outline:none;padding:8px;line-height:20px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%;display:flex;align-items:center;position:relative;justify-content:space-between}::ng-deep .vx-form-group .selected.first-field{z-index:2}::ng-deep .vx-form-group .selected .chip-container{display:flex;width:calc(100% - 60px);align-items:center}::ng-deep .vx-form-group .selected .chip-container.checkpoints{width:calc(100% - 120px)}::ng-deep .vx-form-group .selected .chip-container span.chip{background:#fff;border-radius:2px;box-shadow:0 0 3px #1e5dd31a;height:24px;padding:0 8px;color:#1e5dd3;font-size:12px;display:block;width:auto;max-width:100%;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:24px}::ng-deep .vx-form-group .selected .chip-container span.chip.disabled{background:#f1f1f1;box-shadow:none;color:#747576;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group .selected .chip-container span.chip i{font-weight:400;margin-right:8px;cursor:pointer;font-size:10px;position:relative;top:1px}::ng-deep .vx-form-group .selected .chip-container span.chip span.step{background:#1e5dd3;border-radius:2px;color:#fff;font-size:9px;line-height:14px;padding:0 4px;font-weight:400;text-align:center;min-width:auto;margin-right:4px}::ng-deep .vx-form-group .selected .chip-container span.chip+span.chip{margin-left:4px}::ng-deep .vx-form-group .selected .chip-container span.chip.with-question{display:flex;align-items:center;justify-content:space-between;width:100%}::ng-deep .vx-form-group .selected .chip-container span.chip.with-question span.value{color:#1e5dd3;font-size:12px;font-weight:400;line-height:24px;padding:0;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;max-width:calc(100% - 80px)}::ng-deep .vx-form-group .selected .chip-container span.chip.with-question span.label{background:#f1f1f1;border-radius:2px;color:#042e7d;font-size:9px;font-weight:600;text-transform:uppercase;padding-left:4px;padding-right:4px;line-height:12px;margin-left:8px}::ng-deep .vx-form-group .selected .chip-container span.value{color:#747576;font-size:13px;line-height:20px;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:calc(100% - 52px);padding:0 4px}::ng-deep .vx-form-group .selected .chip-container span.checkpoint-point-text{color:#747576;font-size:10px;font-weight:500;padding:0 8px;width:122px;line-height:14px}::ng-deep .vx-form-group .selected .chip-container span.checkpoint-point-text.first{position:relative;min-width:162px}::ng-deep .vx-form-group .selected .chip-container span.checkpoint-point-text.first:before{background:#f1f1f1;content:\"\";position:absolute;top:0;right:0;height:calc(100% + 12px);width:1px}::ng-deep .vx-form-group .selected .chip-container span.checkpoint-point-text .no{color:#1e5dd3}::ng-deep .vx-form-group .selected .chip-container.plus span.chip{max-width:calc(50% - 35px)}::ng-deep .vx-form-group .selected .chip-container.more-one span.chip{max-width:50%}::ng-deep .vx-form-group .selected .chip-container .chip-inner{background:#fff;border-radius:2px;box-shadow:0 2px 4px #1e5dd31a;line-height:24px;padding:0 4px 0 8px;display:flex;align-items:center}::ng-deep .vx-form-group .selected .chip-container .chip-inner .chip{background:transparent;border-radius:0;box-shadow:none;height:auto;line-height:unset;padding:0;color:#747576;max-width:100px}::ng-deep .vx-form-group .selected .chip-container .chip-inner button.count{border-radius:20px;height:16px;padding:0 6px;border:none;font-size:9px;line-height:16px;margin-left:4px;min-width:20px}::ng-deep .vx-form-group .selected .chip-container .chip-inner button.count.user{background:#34aa44}::ng-deep .vx-form-group .selected .chip-container .chip-inner i.cross{cursor:pointer;position:relative;top:1px;font-size:8px}::ng-deep .vx-form-group .selected button.count{background:#1e5dd3;border-radius:2px;height:24px;padding:0 8px;border:1px solid #1e5dd3;cursor:pointer;outline:none;color:#fff;font:13px;font-weight:500;line-height:20px;white-space:nowrap;margin-left:8px}::ng-deep .vx-form-group .selected button.edit{border:none;border-radius:0;background:transparent;outline:none;cursor:pointer;display:block;font-size:11px;font-weight:600;color:#1e5dd3;text-transform:uppercase;white-space:nowrap;margin-left:8px}::ng-deep .vx-form-group .selected button.edit i{font-weight:400;font-size:8px;margin-right:4px}::ng-deep .vx-form-group .selected button.close-btn{background:transparent;border:none;padding:0;margin-left:8px;font-size:10px;color:#c7381b;display:flex;align-items:center}::ng-deep .vx-form-group .selected .workflow-label{min-width:92px;padding:4px;text-align:center;margin-left:-8px;margin-right:8px;border-right:1px solid #f1f1f1}::ng-deep .vx-form-group .selected .workflow-label p{margin:0;display:block;text-transform:uppercase}::ng-deep .vx-form-group .selected .workflow-label p.title{font-size:9px;line-height:12px;color:#161b2f;font-weight:500}::ng-deep .vx-form-group .selected .workflow-label p.description{font-size:11px;line-height:16px;color:#161b2f;font-weight:600}::ng-deep .vx-form-group .selected .workflow-label+.chip-container{width:calc(100% - 148px)}::ng-deep .vx-form-group .selected+.selected{margin-top:8px}::ng-deep .vx-form-group .selected+app-cs-switch{display:block;margin-top:8px}::ng-deep .vx-form-group .selected+app-cs-switch label.cs-switch span.value{white-space:nowrap;margin-right:5px;text-transform:uppercase}::ng-deep .vx-form-group .selected+app-cs-switch.who-toggle label.cs-switch span.value{color:#747576}::ng-deep .vx-form-group .selected+app-cs-radio{margin-top:8px!important}::ng-deep .vx-form-group .selected~app-cs-radio{margin-top:4px;display:block;width:100%}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item span.radio{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item span.value{font-size:11px;text-transform:uppercase;border:1px solid #dbdbdb;border-radius:4px;padding:8px 8px 8px 36px;width:100%;display:flex;justify-content:space-between;margin:0;max-width:100%;font-weight:500;color:#707070}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item span.value i{font-size:12px;color:#1e5dd3}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item svg{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item input:checked~span.value{background:#eefcf0;border-color:#34aa44}::ng-deep .vx-form-group .selected.readOnly{pointer-events:none}::ng-deep .vx-form-group .selected span.chip{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .vx-form-group .select-list{position:absolute;background:#fff;box-shadow:0 0 5px #1e5dd345;top:100%;right:0;left:0;z-index:2}::ng-deep .vx-form-group .select-list .vx-radio-group label.vx-radio-item{width:100%;padding:12px 16px}::ng-deep .vx-form-group .select-list .vx-radio-group label.vx-radio-item:hover{background:#f8f8f8}::ng-deep .vx-form-group ::ng-deep vcomply-editor{margin-top:8px;display:block;pointer-events:auto!important;z-index:1}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container{border-radius:4px;border:1px solid #dbdbdb}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block{min-height:60px;padding:11px 15px;max-height:100px;line-height:20px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block ul{padding:0 0 0 10px;margin-top:0}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block ul li{list-style:disc}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block ol{padding:0 0 0 10px;margin-top:0}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block ol li{list-style:decimal}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools{z-index:1;border-top:1px solid #dbdbdb;transition:none;border-radius:0 0 3px 3px;position:static}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button{height:22px!important;width:22px!important;padding:0 5px}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button svg{height:22px;width:12px}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button.submit{width:80px!important;line-height:22px;justify-content:center}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col .popover.small ul.option-list li button{width:100%!important;height:auto!important}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container:focus-within{border-color:#1e5dd3!important;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container:focus-within .editor-tools{border-color:#1e5dd3!important}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container:hover{border-color:#1e5dd3!important;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container:hover .editor-tools{border-color:#1e5dd3!important}::ng-deep .vx-form-group ::ng-deep vcomply-editor+app-cs-switch{margin-top:8px}::ng-deep .vx-form-group app-cs-switch label.cs-switch span.value{font-size:11px;color:#747576;text-transform:uppercase}::ng-deep .vx-form-group app-cs-switch+app-cs-switch{margin-top:8px}::ng-deep .vx-form-group .date-time-picker{display:flex;justify-content:space-between;height:40px;border-radius:4px;border:1px solid #dbdbdb;padding:11px 0;background:#fff}::ng-deep .vx-form-group .date-time-picker:focus-within{border-color:#1e5dd3;box-shadow:0 0 5px #1e5dd345}::ng-deep .vx-form-group .date-time-picker .picker-group{width:50%;position:relative;display:flex;align-items:center}::ng-deep .vx-form-group .date-time-picker .picker-group:first-of-type{border-right:1px solid #dbdbdb}::ng-deep .vx-form-group .date-time-picker .picker-group:only-of-type{border:none;width:100%}::ng-deep .vx-form-group .date-time-picker .picker-group input{height:38px;background:transparent;line-height:38px;font-size:13px;color:#747576;transition:all .2s ease-in-out;width:100%;font-weight:400;border:none;padding:0 12px 0 34px;outline:none}::ng-deep .vx-form-group .date-time-picker .picker-group input:focus,::ng-deep .vx-form-group .date-time-picker .picker-group input:hover{box-shadow:none;border:none}::ng-deep .vx-form-group .date-time-picker .picker-group input::placeholder{color:#999;font-size:13px}::ng-deep .vx-form-group .date-time-picker .picker-group input:-ms-input-placeholder{color:#999;font-size:13px}::ng-deep .vx-form-group .date-time-picker .picker-group input::-ms-input-placeholder{color:#999;font-size:13px}::ng-deep .vx-form-group .date-time-picker .picker-group i{display:flex;justify-content:center;align-items:center;height:16px;width:12px;position:absolute;left:12px;top:0;color:#747576;font-size:12px;pointer-events:none}::ng-deep .vx-form-group app-cs-radio.main-filed{margin-top:4px;display:block;width:100%}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item{width:100%;position:relative}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item span.radio{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item span.value{font-size:11px;text-transform:uppercase;border:1px solid #dbdbdb;border-radius:4px;padding:8px 8px 8px 36px;width:100%;display:flex;justify-content:space-between;margin:0;max-width:100%;color:#707070}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item span.value i{font-size:12px;color:#1e5dd3}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item svg{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item input:checked~span.value{background:#eefcf0;border-color:#34aa44}::ng-deep .vx-form-group app-cs-radio.disabled{pointer-events:none;opacity:.5;filter:grayscale(1);background:#f1f1f1}::ng-deep .vx-form-group .switch-row{display:flex}::ng-deep .vx-form-group .switch-row app-cs-switch{display:block;margin-top:8px}::ng-deep .vx-form-group .switch-row app-cs-switch label.cs-switch span.value{white-space:nowrap;margin-right:0;text-transform:uppercase;color:#747576!important}::ng-deep .vx-form-group .switch-row app-cs-switch label.cs-switch span.value i{display:inline-flex;font-size:11px;cursor:pointer;color:#1e5dd3;align-items:center;line-height:16px;margin:0 4px}::ng-deep .vx-form-group .switch-row app-cs-switch+app-cs-switch{margin-left:8px}::ng-deep .vx-form-group .switch-row.align-right{justify-content:flex-end}::ng-deep .vx-form-group .switch-row.align-right label.cs-switch span.value{margin-right:8px}::ng-deep .vx-form-group .risk-type-field{background:#f8f8f8;border:1px solid #dbdbdb;border-radius:4px;height:40px;display:flex;align-items:center;padding:4px;position:relative;z-index:1}::ng-deep .vx-form-group .risk-type-field .type-item{width:50%;position:relative}::ng-deep .vx-form-group .risk-type-field .type-item button{background:transparent;border:none;border-radius:0;color:#747576;font-size:11px;font-weight:600;text-transform:uppercase;width:100%;height:32px;padding:0 12px;text-align:left}::ng-deep .vx-form-group .risk-type-field .type-item button.disabled{background:transparent!important;color:#dbdbdb!important;filter:unset!important;opacity:unset!important;pointer-events:none;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group .risk-type-field .type-item .info{color:#1e5dd3;font-size:12px;position:absolute;top:10px;right:12px;cursor:pointer}::ng-deep .vx-form-group .risk-type-field .type-item .info.disabled{background:transparent!important;color:#dbdbdb!important;filter:unset!important;opacity:unset!important;pointer-events:none;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group .risk-type-field .type-item.active button{color:#1e5dd3!important}::ng-deep .vx-form-group .risk-type-field .type-item:nth-child(2).active~.background-glider{transform:translate(100%)}::ng-deep .vx-form-group .risk-type-field .background-glider{background:#fff;border-radius:4px;box-shadow:0 1px 3px #161b2f26;position:absolute;display:flex;width:212px;height:32px;z-index:-1;transition:.25s ease-out}.left{width:36px;height:36px;margin-top:26px;margin-left:-58px;margin-right:20px;display:flex;justify-content:center;align-items:center;position:relative;z-index:10;border-radius:50%}.left.deadline-completed{margin-top:18px}.left.checked{background:transparent}.left img{width:36px}.left .checkIcon{width:32px;height:32px;background:#fff;border-radius:50%;stroke-width:4;stroke:#34aa44;stroke-miterlimit:10;box-shadow:inset 0 0 #34aa44;animation:fillCheck .4s ease-in-out .4s forwards,scale .3s ease-in-out .9s both;margin-top:0}.left .checkIcon__circle{stroke-dasharray:166;stroke-dashoffset:166;stroke-width:2;stroke-miterlimit:10;stroke:#34aa44;fill:none;animation:strokeCheck .6s cubic-bezier(.65,0,.45,1) forwards}.left .checkIcon__check{transform-origin:50% 50%;stroke-dasharray:48;stroke-dashoffset:48;animation:strokeCheck .3s cubic-bezier(.65,0,.45,1) .8s forwards}.right{width:100%}.right span.indicator{position:absolute;top:36px;left:-16px;font-size:12px;color:#f0b819;cursor:pointer}.form-group-row{display:flex;position:relative;transition:all .2s ease-in-out}.form-group-row.disabled{-webkit-user-select:none;user-select:none;pointer-events:none;filter:grayscale(1);z-index:2}.form-group-row.disabled .left{position:relative}.form-group-row.disabled .left:before{content:\"\";position:absolute;inset:2px 0 0 2px;background:#fff;opacity:.7;border-radius:50%;width:32px;height:32px}.form-group-row.disabled .right{opacity:.3}.form-group-row.active{pointer-events:none;filter:grayscale(0);z-index:2;opacity:1}.form-group-row.active .right .vx-form-group input,.form-group-row.active .right .vx-form-group .custom-input,.form-group-row.active .right .vx-form-group .selectBoxEnable{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}.form-group-row.active .right .vx-form-group .selectBoxEnable.disabled{border-color:#dbdbdb;box-shadow:none}::ng-deep .radio-group-selector app-cs-radio{margin-top:4px;display:block;width:100%}::ng-deep .radio-group-selector app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .radio-group-selector app-cs-radio label.radio-item .radio,::ng-deep .radio-group-selector app-cs-radio label.radio-item .radiomark{position:absolute!important;top:9px;left:12px}::ng-deep .radio-group-selector app-cs-radio label.radio-item .value{font-size:11px!important;text-transform:uppercase;border:1px solid #dbdbdb;border-radius:4px;padding:8px 8px 8px 36px;width:100%;display:flex;justify-content:space-between;margin:0!important;max-width:100%!important;font-weight:500!important;color:#707070!important}::ng-deep .radio-group-selector app-cs-radio label.radio-item .value i{font-size:12px;color:#1e5dd3}::ng-deep .radio-group-selector app-cs-radio label.radio-item input:checked~span.value{background:#eefcf0;border-color:#34aa44}@keyframes strokeCheck{to{stroke-dashoffset:0}}@keyframes fillCheck{to{box-shadow:inset 0 0 0 2px #34aa44}}::ng-deep .wf-action-list{width:220px}::ng-deep .wf-action-list ul{padding:0;margin:0;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both;background:#fff;box-shadow:0 3px 6px #1c5bd140;border-radius:4px;max-height:220px;overflow:auto}::ng-deep .wf-action-list ul.action-item{display:block}::ng-deep .wf-action-list ul.action-item li{list-style:none;border:none;border-bottom:1px solid #f1f1f1;display:block;width:100%;padding:0;background:transparent;border-radius:0;margin:0;height:auto;justify-content:flex-start;box-shadow:none}::ng-deep .wf-action-list ul.action-item li button{color:#6e717e;text-align:left;text-decoration:none;cursor:pointer;background:transparent;font-size:12px;text-transform:capitalize;display:flex;width:100%;padding:7.5px 11px;border:none}::ng-deep .wf-action-list ul.action-item li button i{font-size:16px;margin-right:10px;color:#1e5dd3}::ng-deep .wf-action-list ul.action-item li button:hover{background:#f3f3f3}::ng-deep .wf-action-list ul.action-item li .avatar-card{display:flex;align-items:center;width:100%;padding:7.5px}::ng-deep .wf-action-list ul.action-item li .avatar-card.within-con{display:block}::ng-deep .wf-action-list ul.action-item li .avatar-card .avatar{height:24px;width:24px!important;overflow:hidden;background:#1e5dd3;color:#fff;font-size:10px;display:inline-flex;margin-right:5px;border-radius:50%;align-items:center;justify-content:center;text-transform:uppercase}::ng-deep .wf-action-list ul.action-item li .avatar-card .avatar img{width:100%}::ng-deep .wf-action-list ul.action-item li .avatar-card .avatar+span.value{width:calc(100% - 29px)}::ng-deep .wf-action-list ul.action-item li .avatar-card span.value{width:100%;color:#6e717e;text-decoration:none;background:transparent;font-size:12px;text-transform:capitalize;display:block;font-weight:400;text-align-last:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:20px}::ng-deep .wf-action-list ul.action-item li .avatar-card span.value i{font-size:8px;color:#747576;cursor:pointer;margin-right:5px}::ng-deep .wf-action-list ul.action-item li .avatar-card.no-image{display:block}::ng-deep .wf-action-list ul.action-item li .avatar-card.no-image span.value{width:100%;display:block}::ng-deep .wf-action-list ul.action-item li .chip-item{color:#1e5dd3;padding:10px;display:flex;align-items:center}::ng-deep .wf-action-list ul.action-item li .chip-item i{color:#747576;margin-right:7px;font-size:10px;cursor:pointer;display:inline-flex}::ng-deep .wf-action-list ul.action-item li .chip-item span{display:block;width:auto;max-width:calc(100% - 17px);font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}::ng-deep .wf-action-list ul.action-item li .chip-item span.chip-block{display:block;width:100%}::ng-deep .wf-action-list ul.action-item li .chip-item span.id{font-size:9px}::ng-deep .wf-action-list ul.action-item li .within{display:flex;align-items:center;justify-content:flex-start}::ng-deep .wf-action-list ul.action-item li .within .block{background:#f1f1f1;border-radius:2px;padding:0 2px;line-height:14px;font-size:9px;font-weight:500;color:#042e7d;margin-right:6px;display:block;text-transform:uppercase}::ng-deep .wf-action-list ul.action-item li .within .data{width:100%;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#747576;font-size:11px;font-weight:400;line-height:17px}::ng-deep .wf-action-list ul.action-item li:first-child{animation:action-list-open .25s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(2){animation:action-list-open .35s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(3){animation:action-list-open .45s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(4){animation:action-list-open .55s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(5){animation:action-list-open .65s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(6){animation:action-list-open .75s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(7){animation:action-list-open .85s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(8){animation:action-list-open .95s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(9){animation:action-list-open 1.05s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(10){animation:action-list-open 1.15s cubic-bezier(.25,.46,.45,.94) both}@keyframes action-list-open{0%{transform:translateY(50px)}to{transform:translateY(0)}}@keyframes scale-up-center{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}p.error-message{font-size:11px;font-weight:400;color:#eb2424;line-height:16px;margin-top:8px;margin-bottom:0}.edit-loader{position:absolute;top:-3px;left:-3px;width:46px;height:46px;transform:rotate(180deg)}.circular-loader{animation:rotate 2s linear infinite;height:100%;transform-origin:center center;width:100%;position:absolute;top:0;left:0;margin:auto}.loader-path{stroke-dasharray:150,200;stroke-dashoffset:-10;animation:dash 1.5s ease-in-out infinite;stroke-linecap:round}@keyframes rotate{to{transform:rotate(360deg)}}@keyframes dash{0%{stroke-dasharray:1,200;stroke-dashoffset:0}50%{stroke-dasharray:89,200;stroke-dashoffset:-35}to{stroke-dasharray:89,200;stroke-dashoffset:-124}}::ng-deep .dropdown{position:fixed;background:#fff;box-shadow:0 3px 6px #00000029;padding:24px 0;z-index:9;max-height:calc(100vh - 200px);overflow:auto}::ng-deep .dropdown ul.dropdown-list{padding:0 20px;margin:0;display:block}::ng-deep .dropdown ul.dropdown-list li{list-style:none}::ng-deep .dropdown ul.dropdown-list li app-cs-radio{display:flex}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item span.radio{position:absolute;top:12px;left:12px}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item span.value{padding:11px 12px 11px 32px;width:100%;border:1px solid #bcbcbc;border-radius:4px;margin-left:0;max-width:100%}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item svg{position:absolute;top:12px;left:12px}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item input[type=radio]:checked~span.value{background:#e8feeb;border-color:#34aa44}::ng-deep .dropdown ul.dropdown-list li+li{margin-top:8px}app-smiley-dialog{position:relative;z-index:10}app-smiley-dialog-inline{position:absolute;top:-3px;right:0;bottom:0;z-index:999;width:520px;height:calc(100vh + 3px)}::ng-deep .vx-overlay{position:fixed;z-index:3;inset:0}::ng-deep dp-date-picker{width:100%;position:fixed!important;z-index:14;top:-40px;left:0}::ng-deep dp-date-picker input{width:100%;border:none;opacity:0;pointer-events:none}::ng-deep dp-date-picker input:focus{outline:none}::ng-deep dp-date-picker .dp-popup{width:412px;box-shadow:0 0 20px #161b2f26;background-color:#fff;border-radius:4px;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both}::ng-deep dp-date-picker .dp-popup dp-day-calendar,::ng-deep dp-date-picker .dp-popup dp-month-calendar{width:100%;pointer-events:auto}::ng-deep dp-date-picker .dp-popup dp-day-calendar button,::ng-deep dp-date-picker .dp-popup dp-month-calendar button{background:transparent;border:none;outline:none}::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-current-location-btn,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-current-location-btn,::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-calendar-nav-left,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-calendar-nav-left,::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-calendar-nav-right,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-calendar-nav-right{width:40px;height:40px;display:flex;justify-content:center;align-items:center;border-radius:50%;font-size:14px}::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-current-location-btn:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-current-location-btn:hover,::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-calendar-nav-left:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-calendar-nav-left:hover,::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-calendar-nav-right:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-calendar-nav-right:hover{background-color:#f3f3f3}::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-current-location-btn,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-current-location-btn{display:none}::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-current-location-btn:before,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-current-location-btn:before{content:\"\";height:10px;width:10px;border-radius:50%;background:#000;display:inline-flex}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week{display:flex;justify-content:space-around}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays .dp-calendar-weekday,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays .dp-calendar-weekday,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week .dp-calendar-weekday,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week .dp-calendar-weekday{width:52px;border-left:none;border-bottom-color:#fff;color:#747576;font-size:11px;font-weight:600;text-transform:uppercase}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays button,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week button{width:40px;height:40px;border-radius:50%;display:inline-flex;justify-content:center;align-items:center}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays button:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays button:hover,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week button:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week button:hover{background-color:#f3f3f3}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays button.dp-selected,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays button.dp-selected,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week button.dp-selected,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week button.dp-selected{background:#1e5dd3}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays button.dp-current-day,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays button.dp-current-day,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week button.dp-current-day,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week button.dp-current-day{border:1px solid rgba(0,0,0,.38);color:#1e5dd3;background-color:#fff}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-day-calendar-container,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-day-calendar-container{padding:20px;border-radius:2px}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-nav-container,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-nav-container{display:flex;margin:0 0 20px;border:none}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-nav-container .dp-nav-header button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-nav-container .dp-nav-header button{color:#000;font-size:17px;font-weight:500;margin:0 0 0 12px;padding:0}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-nav-btns-container,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-nav-btns-container{width:80px;display:flex}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-nav-btns-container .dp-calendar-nav-container-left button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-nav-btns-container .dp-calendar-nav-container-left button,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-nav-btns-container .dp-calendar-nav-container-right button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-nav-btns-container .dp-calendar-nav-container-right button{margin:0!important}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-wrapper,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-wrapper{border:none}::ng-deep dp-date-picker .dp-open+div{position:fixed!important;inset:0!important;display:flex;justify-content:center;align-items:center;z-index:99;pointer-events:none;background:#0000004d}::ng-deep .cdk-overlay-container{z-index:2147483002!important}::ng-deep .dp-popup{z-index:999;display:flex!important;align-items:center;justify-content:center;width:100vw;height:100vh;background:#0000004d!important;box-shadow:unset!important}::ng-deep .dp-popup dp-day-calendar{width:412px!important;box-shadow:0 0 20px #161b2f26;background-color:#fff;border-radius:4px;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both}::ng-deep .dp-popup dp-day-calendar,::ng-deep .dp-popup dp-month-calendar{width:100%;pointer-events:auto}::ng-deep .dp-popup dp-day-calendar button,::ng-deep .dp-popup dp-month-calendar button{background:transparent;border:none;outline:none}::ng-deep .dp-popup dp-day-calendar button.dp-current-location-btn,::ng-deep .dp-popup dp-month-calendar button.dp-current-location-btn,::ng-deep .dp-popup dp-day-calendar button.dp-calendar-nav-left,::ng-deep .dp-popup dp-month-calendar button.dp-calendar-nav-left,::ng-deep .dp-popup dp-day-calendar button.dp-calendar-nav-right,::ng-deep .dp-popup dp-month-calendar button.dp-calendar-nav-right{width:40px;height:40px;display:flex;justify-content:center;align-items:center;border-radius:50%;font-size:14px}::ng-deep .dp-popup dp-day-calendar button.dp-current-location-btn:hover,::ng-deep .dp-popup dp-month-calendar button.dp-current-location-btn:hover,::ng-deep .dp-popup dp-day-calendar button.dp-calendar-nav-left:hover,::ng-deep .dp-popup dp-month-calendar button.dp-calendar-nav-left:hover,::ng-deep .dp-popup dp-day-calendar button.dp-calendar-nav-right:hover,::ng-deep .dp-popup dp-month-calendar button.dp-calendar-nav-right:hover{background-color:#f3f3f3}::ng-deep .dp-popup dp-day-calendar button.dp-current-location-btn,::ng-deep .dp-popup dp-month-calendar button.dp-current-location-btn{display:none}::ng-deep .dp-popup dp-day-calendar button.dp-current-location-btn:before,::ng-deep .dp-popup dp-month-calendar button.dp-current-location-btn:before{content:\"\";height:10px;width:10px;border-radius:50%;background:#000;display:inline-flex}::ng-deep .dp-popup dp-day-calendar .dp-weekdays,::ng-deep .dp-popup dp-month-calendar .dp-weekdays,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week{display:flex;justify-content:space-around}::ng-deep .dp-popup dp-day-calendar .dp-weekdays .dp-calendar-weekday,::ng-deep .dp-popup dp-month-calendar .dp-weekdays .dp-calendar-weekday,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week .dp-calendar-weekday,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week .dp-calendar-weekday{width:52px;border-left:none;border-bottom-color:#fff;color:#747576;font-size:11px;font-weight:600;text-transform:uppercase}::ng-deep .dp-popup dp-day-calendar .dp-weekdays button,::ng-deep .dp-popup dp-month-calendar .dp-weekdays button,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week button,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week button{width:40px;height:40px;border-radius:50%;display:inline-flex;justify-content:center;align-items:center}::ng-deep .dp-popup dp-day-calendar .dp-weekdays button:hover,::ng-deep .dp-popup dp-month-calendar .dp-weekdays button:hover,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week button:hover,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week button:hover{background-color:#f3f3f3}::ng-deep .dp-popup dp-day-calendar .dp-weekdays button.dp-selected,::ng-deep .dp-popup dp-month-calendar .dp-weekdays button.dp-selected,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week button.dp-selected,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week button.dp-selected{background:#1e5dd3}::ng-deep .dp-popup dp-day-calendar .dp-weekdays button.dp-current-day,::ng-deep .dp-popup dp-month-calendar .dp-weekdays button.dp-current-day,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week button.dp-current-day,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week button.dp-current-day{border:1px solid rgba(0,0,0,.38);color:#1e5dd3;background-color:#fff}::ng-deep .dp-popup dp-day-calendar .dp-day-calendar-container,::ng-deep .dp-popup dp-month-calendar .dp-day-calendar-container{padding:20px;border-radius:2px}::ng-deep .dp-popup dp-day-calendar .dp-calendar-nav-container,::ng-deep .dp-popup dp-month-calendar .dp-calendar-nav-container{display:flex;margin:0 0 20px;border:none}::ng-deep .dp-popup dp-day-calendar .dp-calendar-nav-container .dp-nav-header button,::ng-deep .dp-popup dp-month-calendar .dp-calendar-nav-container .dp-nav-header button{color:#000;font-size:17px;font-weight:500;margin:0 0 0 12px;padding:0}::ng-deep .dp-popup dp-day-calendar .dp-nav-btns-container,::ng-deep .dp-popup dp-month-calendar .dp-nav-btns-container{width:80px;display:flex}::ng-deep .dp-popup dp-day-calendar .dp-nav-btns-container .dp-calendar-nav-container-left button,::ng-deep .dp-popup dp-month-calendar .dp-nav-btns-container .dp-calendar-nav-container-left button,::ng-deep .dp-popup dp-day-calendar .dp-nav-btns-container .dp-calendar-nav-container-right button,::ng-deep .dp-popup dp-month-calendar .dp-nav-btns-container .dp-calendar-nav-container-right button{margin:0!important}::ng-deep .dp-popup dp-day-calendar .dp-calendar-wrapper,::ng-deep .dp-popup dp-month-calendar .dp-calendar-wrapper{border:none}@keyframes slide-bottom{0%{transform:translateY(-100px)}to{transform:translateY(0)}}::ng-deep span.file{display:block;width:20px;min-width:20px;border-radius:0 0 2px 2px;border:1px solid transparent;border-color:#747576;position:relative;margin-right:5px;border-top:none;margin-top:5px;background:#fff}::ng-deep span.file.table{margin-right:8px;width:18px;min-width:18px}::ng-deep span.file.table i{font-size:8px}::ng-deep span.file.table .format{height:8px;font-size:7px;line-height:8px;font-weight:400}::ng-deep span.file:before{position:absolute;border-radius:0;top:-4px;right:-1px;content:\"\";height:4px;width:4px;display:block;background:linear-gradient(45deg,#747576 0% 1%,#747576 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file:after{height:4px;left:-1px;right:3px;border-top:1px solid;border-right:none;border-left:1px solid;content:\"\";top:-4px;position:absolute;border-radius:2px 0 0;background:#fff}::ng-deep span.file .format{height:10px;font-size:6px;text-transform:uppercase;background:transparent;font-weight:600;text-align:center;display:block;line-height:10px}::ng-deep span.file i{font-size:10px;height:10px;display:flex;align-items:center;justify-content:center;color:#dbdbdb}::ng-deep span.file.docx{width:22px!important}::ng-deep span.file.pdf,::ng-deep span.file.template{border-color:#f31c39}::ng-deep span.file.pdf:before,::ng-deep span.file.template:before{background:linear-gradient(45deg,#f31c39 0% 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#f31c39\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.pdf:after,::ng-deep span.file.template:after{border-color:#f31c39}::ng-deep span.file.pdf .format,::ng-deep span.file.template .format{color:#f31c39}::ng-deep span.file.xlsx,::ng-deep span.file.xls,::ng-deep span.file.css,::ng-deep span.file.scss,::ng-deep span.file.less{border-color:#34aa44}::ng-deep span.file.xlsx:before,::ng-deep span.file.xls:before,::ng-deep span.file.css:before,::ng-deep span.file.scss:before,::ng-deep span.file.less:before{background:linear-gradient(45deg,#34aa44 0% 1%,#34aa44 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.xlsx:after,::ng-deep span.file.xls:after,::ng-deep span.file.css:after,::ng-deep span.file.scss:after,::ng-deep span.file.less:after{border-color:#34aa44;color:#34aa44}::ng-deep span.file.xlsx .format,::ng-deep span.file.xls .format,::ng-deep span.file.css .format,::ng-deep span.file.scss .format,::ng-deep span.file.less .format{color:#34aa44}::ng-deep span.file.doc,::ng-deep span.file.docx,::ng-deep span.file.psd{border-color:#1e5dd3}::ng-deep span.file.doc:before,::ng-deep span.file.docx:before,::ng-deep span.file.psd:before{background:linear-gradient(45deg,#1e5dd3 0% 1%,#1e5dd3 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.doc:after,::ng-deep span.file.docx:after,::ng-deep span.file.psd:after{border-color:#1e5dd3}::ng-deep span.file.doc .format,::ng-deep span.file.docx .format,::ng-deep span.file.psd .format{color:#1e5dd3}::ng-deep span.file.ppt,::ng-deep span.file.ai,::ng-deep span.file.html,::ng-deep span.file.jpg,::ng-deep span.file.jpeg,::ng-deep span.file.png{border-color:#f6882f}::ng-deep span.file.ppt:before,::ng-deep span.file.ai:before,::ng-deep span.file.html:before,::ng-deep span.file.jpg:before,::ng-deep span.file.jpeg:before,::ng-deep span.file.png:before{background:linear-gradient(45deg,#f6882f 0% 1%,#f6882f 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.ppt:after,::ng-deep span.file.ai:after,::ng-deep span.file.html:after,::ng-deep span.file.jpg:after,::ng-deep span.file.jpeg:after,::ng-deep span.file.png:after{border-color:#f6882f}::ng-deep span.file.ppt .format,::ng-deep span.file.ai .format,::ng-deep span.file.html .format,::ng-deep span.file.jpg .format,::ng-deep span.file.jpeg .format,::ng-deep span.file.png .format{color:#f6882f}::ng-deep span.file.php{border-color:#7aa6f7}::ng-deep span.file.php:before{background:linear-gradient(45deg,#7aa6f7 0% 1%,#7aa6f7 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.php:after{border-color:#7aa6f7}::ng-deep span.file.php .format{color:#7aa6f7}::ng-deep ngx-material-timepicker-container .timepicker-backdrop-overlay{background-color:#0000000d!important;z-index:9999999999!important}::ng-deep ngx-material-timepicker-container .timepicker-overlay{z-index:9999999999!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker{width:232px!important;border-radius:2px!important;box-shadow:0 4px 30px #161b2f26!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header{background-color:#fff!important;padding:0!important;border-radius:2px 2px 0 0}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container{display:block!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time{color:#000!important;width:150px!important;margin:0 auto;line-height:60px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time ngx-material-timepicker-dial-control .timepicker-dial__control{font-size:40px;background-color:transparent!important;color:#000!important;font-weight:600;text-align:right;caret-color:transparent;outline:none;font-family:Poppins;line-height:56px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time ngx-material-timepicker-dial-control .timepicker-dial__control:focus,::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time ngx-material-timepicker-dial-control .timepicker-dial__control:hover{background-color:transparent!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time ngx-material-timepicker-dial-control:last-of-type .timepicker-dial__control{text-align:left}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time span{padding:0 8px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period{display:flex!important;width:182px;margin:0 auto!important;background:#f1f1f1;padding:4px 10px;border-radius:20px;position:relative}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period:before{background:#f1f1f1;content:\"\";position:absolute;top:15px;left:-25px;width:calc(100% + 50px);height:2px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period{flex-direction:unset!important;position:relative;z-index:1}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period:after{content:\"\";position:absolute;right:-12px;top:0;border-left:solid 14px #f1f1f1;border-bottom:solid 12px transparent;border-top:solid 12px transparent;z-index:-1}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period:before{content:\"\";position:absolute;left:-18px;top:0;border-right:solid 14px #f1f1f1;border-bottom:solid 12px transparent;border-top:solid 12px transparent;z-index:-1}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period button{font-size:11px;background-color:transparent;padding:0;border-radius:20px;color:#747576;font-weight:600;font-family:Poppins;width:84px;height:24px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period button.timepicker-dial__item_active{background:#fff!important;color:#1e5dd3!important;box-shadow:0 1px 2px #dbdbdb}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period button+button{margin-left:0!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face{width:200px!important;height:200px!important;padding:10px!important;background:transparent!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__number--outer{height:92px!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__number--outer span{color:#000}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__number--outer span.active{color:#fff}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__clock-hand{height:80px!important;top:calc(50% - 80px)!important;background-color:#1e5dd3!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__number>span.active{background-color:#1e5dd3!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__clock-hand_minute:before{border:4px solid #1e5dd3!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .timepicker__actions{display:flex!important;padding:10px 0 0!important;background:#fff!important;justify-content:space-around!important;border-radius:0 0 2px 2px!important;overflow:hidden}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .timepicker__actions div:first-child ngx-material-timepicker-button button.timepicker-button{background:#f8f8f8;color:#1e5dd3}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .timepicker__actions div ngx-material-timepicker-button button.timepicker-button{line-height:28px!important;width:100%;background:#1e5dd3;color:#fff;border-radius:0!important;height:32px!important;width:116px!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .timepicker__actions div ngx-material-timepicker-button button.timepicker-button span{font-weight:500!important;font-size:11px;font-family:Poppins}::ng-deep vcomply-editor{display:block}::ng-deep vcomply-editor .editor-container{border-radius:4px;border:1px solid #dbdbdb;transition:all .2s ease-in-out}::ng-deep vcomply-editor .editor-container:hover,::ng-deep vcomply-editor .editor-container:focus-within{border:1px solid #1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep vcomply-editor .editor-container mention-list ul li a{font-size:16px!important}::ng-deep vcomply-editor .editor-container .editable-block{background:#fff;min-height:60px;padding:8px 12px;line-height:20px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%}::ng-deep vcomply-editor .editor-container .editable-block:before{color:#747576!important}::ng-deep vcomply-editor .editor-container .editor-tools{border-top:1px solid #dbdbdb;border-radius:0 0 3px 3px}::ng-deep vcomply-editor .editor-container .editor-tools:hover{border-color:#1e5dd3}::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button{height:22px!important;width:22px!important;padding:0 5px}::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button svg{height:22px;width:12px}::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button.submit{width:80px!important;line-height:22px;justify-content:center}::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col .popover.small ul.option-list li button{width:100%!important;height:auto!important}::ng-deep marx-modal .popup-modal-background{background-color:#161b2fcc!important}::ng-deep .within-box{background:#f1f1f1;border-radius:.125rem;color:#042e7d}::ng-deep .within-value{overflow:hidden;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;word-break:break-word}.wf-tooltip{pointer-events:none;position:absolute;max-width:300px;font-size:12px;text-align:left;color:#fff;padding:8px 12px;background:#000;border-radius:2px;z-index:-222;top:0;opacity:0;white-space:break-spaces;word-break:break-word}.wf-tooltip *{color:#fff!important}.wf-tooltip:empty{display:none!important}.wf-tooltip.white{box-shadow:0 2px 8px #1c5bd159;color:#747576;background:#fff;text-align:left}.wf-tooltip.white b{color:#747576!important}.wf-tooltip.animate-top{animation:animate-top .5s cubic-bezier(.25,.46,.45,.94) both}.wf-tooltip.animate-right{animation:animate-right .3s cubic-bezier(.25,.46,.45,.94) both}.wf-tooltip.animate-bottom{animation:animate-bottom .5s cubic-bezier(.25,.46,.45,.94) both}.wf-tooltip.animate-left{animation:animate-left .5s cubic-bezier(.25,.46,.45,.94) both}.wf-tooltip-top:after{top:100%;left:50%;margin-left:-5px;border-width:5px;border-color:#000000 transparent transparent transparent}.wf-tooltip-top.white:after{border-color:#f1f1f1 transparent transparent transparent}.wf-tooltip-bottom:after{bottom:100%;left:50%;margin-left:-5px;border-width:5px;border-color:transparent transparent #000000 transparent}.wf-tooltip-bottom.white:after{border-color:transparent transparent #f1f1f1 transparent}.wf-tooltip-left.white:after{border-color:transparent transparent transparent #f1f1f1}.wf-tooltip-left:after{top:50%;left:100%;margin-top:-5px;border-width:5px;border-color:transparent transparent transparent #000000}.wf-tooltip-right.white:after{border-color:transparent #f1f1f1 transparent transparent}.wf-tooltip-right:after{top:50%;right:100%;margin-top:-5px;border-width:5px;border-color:transparent #000000 transparent transparent}.wf-tooltip-bottom-right:after{bottom:100%;left:100%;margin-left:-20px;border-width:5px;border-color:transparent transparent #000000 transparent}.wf-tooltip-bottom-right.white:after{border-color:transparent transparent #f1f1f1 transparent}.wf-tooltip-bottom-left:after{bottom:100%;left:0;margin-left:10px;border-width:5px;border-color:transparent transparent #000000 transparent}.wf-tooltip-bottom-left.white:after{border-color:transparent transparent #f1f1f1 transparent}.wf-tooltip-top-left:after{top:100%;left:0;margin-left:10px;border-width:5px;border-color:#000000 transparent transparent transparent}.wf-tooltip-top-left.white:after{border-color:#f1f1f1 transparent transparent transparent}.wf-tooltip-top-right:after{top:100%;left:100%;margin-left:-5px;border-width:5px;border-color:#000000 transparent transparent transparent}.wf-tooltip-top-right.white:after{border-color:#f1f1f1 transparent transparent transparent}.wf-tooltip:after{content:\"\";position:absolute;border-style:solid}.wf-tooltip span.within{font-size:80%;display:block;width:100%}.wf-tooltip .small{display:block;font-size:10px}.wf-tooltip .within-box{background:#f1f1f1;border-radius:2px;color:#042e7d!important;font-size:9px;font-weight:500;text-transform:uppercase;padding:0 2px;margin-right:2px}.wf-tooltip-show{pointer-events:none;opacity:1;z-index:2147483001}\n"] }]
1339
+ }], ctorParameters: function () { return [{ type: i1.UntypedFormBuilder }, { type: i2.ProgramsService }, { type: i3.AuthService }, { type: i4.UiKitService }, { type: i5.IframeService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { form: [{
1300
1340
  type: ViewChild,
1301
1341
  args: ['form', { read: ElementRef }]
1302
1342
  }], datePicker: [{
@@ -1334,7 +1374,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
1334
1374
  type: Input
1335
1375
  }], orgDetails: [{
1336
1376
  type: Input
1337
- }], programDetails: [{
1338
- type: Input
1339
1377
  }] } });
1340
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow-program.component.js","sourceRoot":"","sources":["../../../../../projects/vx-workflow-engine/src/lib/workflow-program/workflow-program.component.ts","../../../../../projects/vx-workflow-engine/src/lib/workflow-program/workflow-program.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EACT,UAAU,EACV,YAAY,EACZ,KAAK,EAEL,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAGL,UAAU,GACX,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,QAAQ,CAAC;AAE5C,OAAO,EAAE,oBAAoB,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAIlD,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAExC,OAAO,EAAE,MAAM,EAAE,MAAM,+BAA+B,CAAC;AACvD,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAAE,cAAc,EAAE,MAAM,2CAA2C,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;AAO3E,MAAM,OAAO,wBAAwB;IA2DnC,YACU,EAAsB,EACtB,cAA+B,EAC/B,WAAwB,EACxB,YAA0B,EAC1B,SAA4B,EAC5B,aAA4B;QAL5B,OAAE,GAAF,EAAE,CAAoB;QACtB,mBAAc,GAAd,cAAc,CAAiB;QAC/B,gBAAW,GAAX,WAAW,CAAa;QACxB,iBAAY,GAAZ,YAAY,CAAc;QAC1B,cAAS,GAAT,SAAS,CAAmB;QAC5B,kBAAa,GAAb,aAAa,CAAe;QAhEtC,WAAM,GAAG,MAAM,CAAC;QAChB,cAAS,GAAG,SAAS,CAAC;QAEtB,oBAAe,GAAY,KAAK,CAAC;QACjC,kBAAa,GAAY,KAAK,CAAC;QAE/B,sBAAiB,GAAG,KAAK,CAAC;QAEhB,kBAAa,GAAG,IAAI,YAAY,EAAE,CAAC;QACnC,mBAAc,GAAG,IAAI,YAAY,EAAE,CAAC;QACpC,kBAAa,GAAG,IAAI,YAAY,EAAE,CAAC;QACnC,0BAAqB,GAAG,IAAI,YAAY,EAAE,CAAC;QAC3C,sBAAiB,GAAG,IAAI,YAAY,EAAE,CAAC;QACvC,gBAAW,GAAG,IAAI,YAAY,EAAE,CAAC;QACjC,gCAA2B,GAAG,IAAI,YAAY,EAAE,CAAC;QACjD,mBAAc,GAAsB,IAAI,YAAY,EAAE,CAAC;QACvD,mCAA8B,GAAG,IAAI,YAAY,EAAE,CAAC;QAErD,uBAAkB,GAAY,IAAI,CAAC;QAC5C,wBAAmB,GAAY,KAAK,CAAC;QAErC,mBAAmB;QACV,SAAI,GAAW,EAAE,CAAC;QAClB,cAAS,GAAW,EAAE,CAAC;QACvB,gBAAW,GAAW,CAAC,CAAC;QAMjC,8BAAyB,GAAG,4BAA4B,CAAC;QACzD,oBAAe,GAAG,iBAAiB,CAAC;QACpC,uBAAkB,GAAG,oBAAoB,CAAC;QAC1C,uBAAkB,GAAG,wBAAwB,CAAC;QAC9C,uBAAkB,GAAG,kBAAkB,CAAC;QACxC,uBAAkB,GAAY,KAAK,CAAC;QACpC,mBAAc,GAAY,KAAK,CAAC;QAChC,gBAAW,GAAQ;YACjB,KAAK,EACH,0QAA0Q;YAC5Q,YAAY,EAAE;;;;KAIb;YACD,aAAa,EAAE,yQAAyQ;SACzR,CAAC;QAEF,oBAAe,GAAY,KAAK,CAAC;QACjC,sBAAiB,GAAY,KAAK,CAAC;QACnC,wBAAmB,GAAU,EAAE,CAAC;QAChC,wBAAmB,GAAU,EAAE,CAAC;QAChC,wBAAmB,GAAU,EAAE,CAAC;QAChC,wBAAmB,GAAU,EAAE,CAAC;QAChC,eAAU,GAAa,EAAE,CAAC;QAC1B,uBAAkB,GAAU,EAAE,CAAC;QAC/B,uBAAkB,GAAU,EAAE,CAAC;QAyB/B,WAAM,GAAG,KAAK,CAAC;QACf,eAAU,GAAG,KAAK,CAAC;QACnB,kBAAa,GAAG;YACd,EAAE,UAAU,EAAE,mBAAmB,EAAE,KAAK,EAAE,WAAW,EAAE,EAAE,EAAE,SAAS,EAAE;YACtE,EAAE,UAAU,EAAE,cAAc,EAAE,KAAK,EAAE,UAAU,EAAE,EAAE,EAAE,aAAa,EAAE;SACrE,CAAC;QACF,kBAAa,GAAG,iBAAiB,CAAC;QAClC,qBAAgB,GAAG,EAAE,CAAC;QACtB,qBAAgB,GAAY,IAAI,CAAC;QACjC,iBAAY,GAAY,KAAK,CAAC;QAC9B,iCAAiC;QACjC,gBAAW,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC;YAC1B,YAAY,EAAE;gBACZ,IAAI,CAAC,WAAW,IAAI,CAAC;gBACrB,CAAC,UAAU,CAAC,QAAQ,EAAE,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;aAC5D;YACD,YAAY,EAAE,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,QAAQ,EAAE,IAAI,CAAC,qBAAqB,CAAC,CAAC;YACrE,mBAAmB,EAAE,CAAC,EAAE,CAAC;YACzB,+BAA+B,EAAE,CAAC,EAAE,CAAC;YACrC,iBAAiB,EAAE,CAAC,EAAE,CAAC;YACvB,8EAA8E;YAC9E,6BAA6B,EAAE,CAAC,EAAE,CAAC;YACnC,gBAAgB,EAAE,CAAC,KAAK,CAAC;YACzB,cAAc,EAAE,CAAC,EAAE,CAAC;YACpB,oBAAoB,EAAE,CAAC,EAAE,CAAC;YAC1B,gBAAgB,EAAE,CAAC,EAAE,CAAC;YACtB,SAAS,EAAE,EAAE;YACb,EAAE,EAAE,CAAC,EAAE,CAAC;YACR,gBAAgB,EAAE,CAAC,EAAE,CAAC;YACtB,sBAAsB,EAAE,CAAC,EAAE,CAAC;YAC5B,wBAAwB,EAAE,CAAC,EAAE,CAAC;YAC9B,8BAA8B,EAAE,CAAC,EAAE,CAAC;YACpC,4BAA4B,EAAE,CAAC,KAAK,CAAC;YACrC,gBAAgB,EAAE,CAAC,EAAE,CAAC;YACtB,sBAAsB,EAAE,CAAC,EAAE,CAAC;YAC5B,wBAAwB,EAAE,CAAC,EAAE,CAAC;YAC9B,8BAA8B,EAAE,CAAC,EAAE,CAAC;YACpC,4BAA4B,EAAE,CAAC,YAAY,CAAC;YAC5C,gBAAgB,EAAE,CAAC,EAAE,CAAC;YACtB,sBAAsB,EAAE,CAAC,EAAE,CAAC;YAC5B,wBAAwB,EAAE,CAAC,EAAE,CAAC;YAC9B,8BAA8B,EAAE,CAAC,EAAE,CAAC;YACpC,+BAA+B,EAAE,CAAC,EAAE,CAAC;YACrC,qCAAqC,EAAE,CAAC,EAAE,CAAC;YAC3C,mBAAmB,EAAE,CAAC,EAAE,CAAC;YACzB,iBAAiB,EAAE,CAAC,KAAK,CAAC;YAC1B,2BAA2B,EAAE,CAAC,KAAK,CAAC;YACpC,aAAa,EAAE,CAAC,EAAE,CAAC;YACnB,aAAa,EAAE,CAAC;YAChB,aAAa,EAAE,CAAC,EAAE,CAAC;YACnB,mBAAmB,EAAE,CAAC,EAAE,CAAC;SAC1B,CAAC,CAAC;QAEH,uCAAuC;QAEvC,uBAAkB,GAAG,IAAI,CAAC;QAC1B,sIAAsI;QACtI,eAAU,GAAG;YACX,gBAAgB,EAAE,EAAE;YACpB,kBAAkB,EAAE,EAAE;SACvB,CAAC;QAyCF,aAAQ,GAAQ;YACd,YAAY,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,cAAc,CAAC;YAClD,YAAY,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,cAAc,CAAC;YAClD,iBAAiB,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,mBAAmB,CAAC;YAC5D,aAAa,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,eAAe,CAAC;YACpD,cAAc,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,gBAAgB,CAAC;YACtD,oBAAoB,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,sBAAsB,CAAC;YAClE,gBAAgB,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,kBAAkB,CAAC;YAC1D,gBAAgB,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,kBAAkB,CAAC;YAC1D,sBAAsB,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAC1C,iCAAiC,CAClC;YACD,qBAAqB,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CACzC,+BAA+B,CAChC;YACD,uBAAuB,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,yBAAyB,CAAC;YACxE,mBAAmB,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,qBAAqB,CAAC;YAChE,iBAAiB,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,mBAAmB,CAAC;YAC5D,EAAE,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC;YAC9B,iBAAiB,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,mBAAmB,CAAC;YAC5D,SAAS,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,WAAW,CAAC;YAC5C,2BAA2B,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAC/C,6BAA6B,CAC9B;YACD,gBAAgB,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,kBAAkB,CAAC;YAC1D,sBAAsB,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,wBAAwB,CAAC;YACtE,wBAAwB,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,0BAA0B,CAAC;YAC1E,8BAA8B,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAClD,gCAAgC,CACjC;YACD,4BAA4B,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAChD,8BAA8B,CAC/B;YACD,wBAAwB,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,0BAA0B,CAAC;YAC1E,8BAA8B,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAClD,gCAAgC,CACjC;YACD,gBAAgB,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,kBAAkB,CAAC;YAC1D,sBAAsB,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,wBAAwB,CAAC;YACtE,gBAAgB,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,kBAAkB,CAAC;YAC1D,sBAAsB,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,wBAAwB,CAAC;YACtE,wBAAwB,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,0BAA0B,CAAC;YAC1E,8BAA8B,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAClD,gCAAgC,CACjC;YACD,+BAA+B,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CACnD,iCAAiC,CAClC;YACD,qCAAqC,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CACzD,uCAAuC,CACxC;YACD,4BAA4B,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAChD,8BAA8B,CAC/B;YACD,mBAAmB,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,qBAAqB,CAAC;YAChE,aAAa,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,eAAe,CAAC;YACpD,kBAAkB,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,oBAAoB,CAAC;YAC9D,aAAa,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,eAAe,CAAC;YACpD,mBAAmB,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,qBAAqB,CAAC;SACjE,CAAC;QAEF,UAAK,GAAQ;YACX,KAAK,EAAE,EAAE;YACT,MAAM,EAAE,EAAE;YACV,aAAa,EAAE,EAAE;YACjB,SAAS,EAAE,EAAE;YACb,SAAS,EAAE,EAAE;YACb,eAAe,EAAE,EAAE;YACnB,SAAS,EAAE,EAAE;YACb,eAAe,EAAE,EAAE;YACnB,iBAAiB,EAAE,EAAE;YACrB,uBAAuB,EAAE,EAAE;YAC3B,iBAAiB,EAAE,EAAE;YACrB,uBAAuB,EAAE,EAAE;YAC3B,SAAS,EAAE,EAAE;YACb,eAAe,EAAE,EAAE;YACnB,iBAAiB,EAAE,EAAE;YACrB,uBAAuB,EAAE,EAAE;YAC3B,EAAE,EAAE,EAAE;YACN,oBAAoB,EAAE,EAAE;YACxB,QAAQ,EAAE,EAAE;YACZ,SAAS,EAAE,EAAE;YACb,eAAe,EAAE,EAAE;SACpB,CAAC;QAEF,qBAAgB,GAAG;YACjB,KAAK,EAAE,KAAK;YACZ,KAAK,EAAE,KAAK;YACZ,KAAK,EAAE,KAAK;YACZ,EAAE,EAAE,KAAK;SACV,CAAC;QACF,iBAAY,GAAG;YACb,MAAM;YACN,IAAI;YACJ,OAAO;YACP,UAAU;YACV,UAAU;YACV,kBAAkB;YAClB,UAAU;YACV,kBAAkB;YAClB,YAAY;YACZ,WAAW;YACX,UAAU;YACV,yBAAyB;YACzB,kBAAkB;YAClB,UAAU;SACX,CAAC;QAoBF,qBAAgB,GAAQ,EAAE,GAAG,SAAS,CAAC,gBAAgB,EAAE,CAAC;QAC1D,eAAU,GAAG,EAAE,CAAC;QA2wBhB,sBAAiB,GAAG;YAClB,WAAW,EAAE,EAAE;YACf,SAAS,EAAE,EAAE;SACd,CAAC;QAhgCA,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,KAAK,CAC7B,YAAY,CAAC,OAAO,CAAC,eAAe,CAAC,IAAI,IAAI,CAC9C,CAAC;IACJ,CAAC;IACM,qBAAqB,CAAC,OAA2B;QACtD,MAAM,YAAY,GAAG,CAAC,OAAO,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,MAAM,KAAK,CAAC,CAAC;QAC/D,MAAM,OAAO,GAAG,CAAC,YAAY,CAAC;QAC9B,OAAO,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC;IAC/C,CAAC;IACM,mBAAmB,CAAC,OAA2B;QACpD,MAAM,OAAO,GAAG,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,MAAM,KAAK,CAAC,CAAC;QACvE,MAAM,OAAO,GAAG,CAAC,OAAO,CAAC;QACzB,OAAO,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;IAC1C,CAAC;IAiED,WAAW;QACT,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,EAAE,CAAC;QAC1C,OAAO;YACL,YAAY,EAAE,IAAI,EAAE,KAAK;YACzB,SAAS,EAAE,IAAI,EAAE,EAAE;YACnB,WAAW,EAAE,IAAI,EAAE,IAAI;YACvB,SAAS,EAAE,WAAW;YACtB,GAAG,EAAE,EAAE;SACR,CAAC;IACJ,CAAC;IACD,kCAAkC;IAClC,YAAY,CAAC,WAAmB,EAAE,KAAU,EAAE,UAAoB;QAChE,IAAI,KAAK,GAAQ,EAAE,CAAC;QACpB,KAAK,CAAC,WAAW,CAAC,GAAG,KAAK,CAAC;QAC3B,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QACnC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE,aAAa,EAAE,CAAC;QAC5C,IACE,UAAU;YACV,WAAW,KAAK,mBAAmB;YACnC,CAAC,KAAK,CAAC,OAAO,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC,IAAI,EAAE;YAErC,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;;YAC3B,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;IACpC,CAAC;IAED,0CAA0C;IAC1C,IAAI,SAAS;QACX,IACE,IAAI,CAAC,WAAW,CAAC,KAAK;YACtB,IAAI,CAAC,UAAU,EAAE,gBAAgB,EAAE,OAAO,CAAC,SAAS,EAAE,GAAG,CAAC,EAAE,IAAI,EAAE,EAAE,MAAM,EAC1E;YACA,OAAO,IAAI,CAAC;SACb;aAAM;YACL,OAAO,KAAK,CAAC;SACd;IACH,CAAC;IA8GD,QAAQ;QACN,IAAI,CAAC,YAAY,CAAC,cAAc,EAAE,IAAI,CAAC,WAAW,IAAI,CAAC,CAAC,CAAC;QACzD,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAC9B,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAC9B,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,CAAC,OAAO,EAAE,CAAC;QACf,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,IAAI,CAAC,mBAAmB,EAAE,GAAG,EAAE;YACjC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,mBAAmB,EAAE,WAAW,CAAC,CAAC;SACxD;QACD,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,CAAC;IACjC,CAAC;IACD,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;IAChC,CAAC;IAID;;;OAGG;IACH,sBAAsB;QACpB,MAAM,gBAAgB,GAAG,EAAE,CAAC;QAC5B,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,EAAE;YACpD,IAAI,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,KAAK,IAAI,EAAE;gBACvC,gBAAgB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;aAC5B;SACF;QACD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;IAC7C,CAAC;IACD,WAAW,CAAC,KAAU;QACpB,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC,OAAO,CAAC;QAClD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,IAAI,CAAC,uBAAuB,EAAE,CAAC;IACjC,CAAC;IAED,gDAAgD;IAChD,iBAAiB;QACf,MAAM,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC1C,MAAM,CAAC,OAAO,CAAC,CAAC,GAAQ,EAAE,EAAE;YAC1B,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,YAAY,CAAC,IAAI,CAAC,oBAAoB,EAAE,CAAC,CAAC,SAAS,CAAC;gBACtE,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;oBACjB,IAAI,CAAC,qBAAqB,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;gBACvC,CAAC;aACF,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,qBAAqB,CAAC,OAAe,EAAE,OAAa;QAClD,QAAQ,OAAO,EAAE;YACf,KAAK,eAAe,CAAC,CAAC;gBACpB,IAAI,CAAC,6BAA6B,EAAE,CAAC;aACtC;SACF;IACH,CAAC;IAED,YAAY,CAAC,GAAW;QACtB,IAAI,GAAG,KAAK,WAAW,IAAI,CAAC,IAAI,CAAC,kBAAkB;YAAE,OAAO;QAC5D,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC;QACtB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC;IAED,UAAU,CAAC,GAAQ,EAAE,IAAS;QAC5B,QAAQ,IAAI,EAAE;YACZ,KAAK,MAAM,CAAC,CAAC;gBACX,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;gBAC7B,MAAM,WAAW,GAAG,GAAG,EAAE,MAAM,CAC7B,CAAC,GAAQ,EAAE,EAAE,CACX,GAAG,EAAE,QAAQ,EAAE,WAAW,EAAE,KAAK,WAAW;oBAC5C,GAAG,EAAE,QAAQ,EAAE,WAAW,EAAE,KAAK,OAAO,CAC3C,CAAC;gBACF,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,GAAG,WAAW,EAAE,GAAG,GAAG,CAAC,EAAE,KAAK,CAAC,CAAC;gBACpE,IACE,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,EAAE,EAAE,QAAQ,CAAC,IAAI,EAAE,CAAC,EACnE;oBACA,IAAI,CAAC,YAAY,CAAC,eAAe,EAAE,QAAQ,CAAC,CAAC;oBAC7C,IAAI,CAAC,6BAA6B,EAAE,CAAC;oBACrC,IAAI,CAAC,8BAA8B,EAAE,CAAC;iBACvC;gBACD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;gBAC3B,MAAM;aACP;YACD,KAAK,IAAI,CAAC,CAAC;gBACT,MAAM,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,EAAE,GAAG,EAAE,SAAS,CAAC,CAAC;gBACvD,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,EAAE,EAAE,SAAS,CAAC,CAAC,CAAC;gBAC1D,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;gBAC3B,MAAM;aACP;YACD,KAAK,OAAO,CAAC,CAAC;gBACZ,IAAI,CAAC,YAAY,CACf,gBAAgB,EAChB,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,KAAK,EAAE,KAAK,CAAC,CACrC,CAAC;gBACF,IAAI,CAAC,YAAY,CACf,sBAAsB,EACtB,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,CAAC,CACvC,CAAC;gBACF,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;gBAC3B,MAAM;aACP;YACD,KAAK,UAAU,CAAC,CAAC;gBACf,IAAI,CAAC,YAAY,CACf,kBAAkB,EAClB,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,KAAK,EAAE,WAAW,CAAC,CAC3C,CAAC;gBACF,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;gBAC3B,MAAM;aACP;YACD,KAAK,eAAe,CAAC,CAAC;gBACpB,IAAI,CAAC,YAAY,CACf,eAAe,EACf,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,KAAK,EAAE,KAAK,CAAC,CACrC,CAAC;gBACF,IAAI,CAAC,YAAY,CACf,qBAAqB,EACrB,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,CAAC,CACvC,CAAC;gBACF,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;gBAC3B,MAAM;aACP;YACD,KAAK,kBAAkB,CAAC,CAAC;gBACvB,IAAI,CAAC,YAAY,CACf,0BAA0B,EAC1B,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,KAAK,EAAE,WAAW,CAAC,CAC3C,CAAC;gBACF,IAAI,CAAC,YAAY,CACf,gCAAgC,EAChC,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,EAAE,UAAU,CAAC,CAC3C,CAAC;gBACF,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;gBAC3B,IAAI,CAAC,WAAW,EAAE,CAAC;gBACnB,MAAM;aACP;YACD,KAAK,UAAU,CAAC,CAAC;gBACf,IAAI,CAAC,YAAY,CACf,kBAAkB,EAClB,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,KAAK,EAAE,WAAW,CAAC,CAC3C,CAAC;gBACF,IAAI,CAAC,YAAY,CACf,wBAAwB,EACxB,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,EAAE,UAAU,CAAC,CAC3C,CAAC;gBACF,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;gBAC3B,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC;gBAC7B,MAAM;aACP;YACD,KAAK,kBAAkB,CAAC,CAAC;gBACvB,IAAI,CAAC,YAAY,CACf,0BAA0B,EAC1B,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,KAAK,EAAE,WAAW,CAAC,CAC3C,CAAC;gBACF,IAAI,CAAC,YAAY,CACf,gCAAgC,EAChC,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,EAAE,UAAU,CAAC,CAC3C,CAAC;gBACF,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;gBAC3B,IAAI,CAAC,QAAQ,CAAC,4BAA4B,CAAC,KAAK;oBAC9C,IAAI,CAAC,QAAQ,EAAE,8BAA8B,EAAE,KAAK,EAAE,MAAM,GAAG,CAAC;wBAC9D,CAAC,CAAC,QAAQ;wBACV,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,4BAA4B,EAAE,KAAK,CAAC;gBACzD,IAAI,CAAC,WAAW,EAAE,CAAC;gBACnB,MAAM;aACP;YACD,KAAK,UAAU,CAAC,CAAC;gBACf,IAAI,CAAC,YAAY,CACf,kBAAkB,EAClB,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,KAAK,EAAE,WAAW,CAAC,CAC3C,CAAC;gBACF,IAAI,CAAC,YAAY,CACf,wBAAwB,EACxB,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,EAAE,UAAU,CAAC,CAC3C,CAAC;gBACF,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;gBAC3B,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC;gBAC7B,MAAM;aACP;YACD,KAAK,kBAAkB,CAAC,CAAC;gBACvB,IAAI,CAAC,YAAY,CACf,0BAA0B,EAC1B,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,KAAK,EAAE,WAAW,CAAC,CAC3C,CAAC;gBACF,IAAI,CAAC,YAAY,CACf,gCAAgC,EAChC,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,EAAE,UAAU,CAAC,CAC3C,CAAC;gBACF,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;gBAC3B,IAAI,CAAC,WAAW,EAAE,CAAC;gBACnB,MAAM;aACP;YACD,KAAK,yBAAyB,CAAC,CAAC;gBAC9B,IAAI,CAAC,YAAY,CACf,iCAAiC,EACjC,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,KAAK,EAAE,WAAW,CAAC,CAC3C,CAAC;gBACF,IAAI,CAAC,YAAY,CACf,uCAAuC,EACvC,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,EAAE,UAAU,CAAC,CAC3C,CAAC;gBACF,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;gBAC3B,IAAI,CAAC,WAAW,EAAE,CAAC;gBACnB,MAAM;aACP;YACD,KAAK,YAAY,CAAC,CAAC;gBACjB,IAAI,CAAC,YAAY,CAAC,qBAAqB,EAAE,GAAG,CAAC,CAAC;gBAC9C,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;gBAC3B,MAAM;aACP;YACD,KAAK,WAAW,CAAC,CAAC;gBAChB,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,GAAG,CAAC,CAAC;gBACpC,IAAI,CAAC,YAAY,CAAC,cAAc,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;gBAC7C,IAAI,CAAC,YAAY,CAAC,qBAAqB,EAAE,GAAG,EAAE,WAAW,CAAC,CAAC;gBAC3D,IAAI,CAAC,UAAU,CAAC,kBAAkB,GAAG,GAAG,EAAE,WAAW,CAAC;gBACtD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;gBAC3B,MAAM;aACP;SACF;IACH,CAAC;IAED,MAAM,CAAC,GAAQ,EAAE,IAAS;QACxB,QAAQ,IAAI,EAAE;YACZ,KAAK,MAAM,CAAC,CAAC;gBACX,IAAI,GAAG,GAAG,EAAE,CAAC;gBACb,GAAG,GAAG,6DAA6D,CAAC;gBACpE,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,aAAa,EAAE,KAAK,EAAE,MAAM,CACvD,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,GAAG,KAAK,GAAG,EAAE,GAAG,CACpC,CAAC;gBACF,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;gBAC/B,IAAI,CAAC,YAAY,CAAC,eAAe,EAAE,KAAK,CAAC,CAAC;gBAC1C,MAAM;aACP;YACD,KAAK,IAAI,CAAC,CAAC;gBACT,MAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,CAC1C,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,OAAO,KAAK,GAAG,EAAE,OAAO,CAC5C,CAAC;gBACF,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;gBAC7B,MAAM;aACP;YACD,KAAK,OAAO,CAAC,CAAC;gBACZ,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,EAAE,cAAc,EAAE,KAAK,EAAE,MAAM,CACzD,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,GAAG,KAAK,GAAG,EAAE,GAAG,CACpC,CAAC;gBACF,IAAI,CAAC,YAAY,CAAC,gBAAgB,EAAE,MAAM,CAAC,CAAC;gBAC5C,MAAM;aACP;YACD,KAAK,aAAa,CAAC,CAAC;gBAClB,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,EAAE,oBAAoB,EAAE,KAAK,EAAE,MAAM,CACrE,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,QAAQ,KAAK,GAAG,EAAE,QAAQ,CAC9C,CAAC;gBACF,IAAI,CAAC,YAAY,CAAC,sBAAsB,EAAE,YAAY,CAAC,CAAC;gBACxD,MAAM;aACP;YACD,KAAK,UAAU,CAAC,CAAC;gBACf,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,EAAE,gBAAgB,EAAE,KAAK,EAAE,MAAM,CAC7D,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,SAAS,KAAK,GAAG,EAAE,SAAS,CAChD,CAAC;gBACF,IAAI,CAAC,YAAY,CAAC,kBAAkB,EAAE,QAAQ,CAAC,CAAC;gBAChD,MAAM;aACP;YACD,KAAK,UAAU,CAAC,CAAC;gBACf,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,EAAE,gBAAgB,EAAE,KAAK,EAAE,MAAM,CAC7D,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,SAAS,KAAK,GAAG,EAAE,SAAS,CAChD,CAAC;gBACF,IAAI,CAAC,YAAY,CAAC,kBAAkB,EAAE,QAAQ,CAAC,CAAC;gBAChD,IAAI,CAAC,0BAA0B,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;gBAC3C,MAAM;aACP;YACD,KAAK,gBAAgB,CAAC,CAAC;gBACrB,MAAM,cAAc,GAClB,IAAI,CAAC,QAAQ,EAAE,sBAAsB,EAAE,KAAK,EAAE,MAAM,CAClD,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,QAAQ,KAAK,GAAG,EAAE,QAAQ,CAC9C,CAAC;gBACJ,IAAI,CAAC,YAAY,CAAC,wBAAwB,EAAE,cAAc,CAAC,CAAC;gBAC5D,IAAI,CAAC,0BAA0B,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;gBAC3C,MAAM;aACP;YACD,KAAK,kBAAkB,CAAC,CAAC;gBACvB,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,EAAE,wBAAwB,EAAE,KAAK,EAAE,MAAM,CACrE,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,SAAS,KAAK,GAAG,EAAE,SAAS,CAChD,CAAC;gBACF,IAAI,CAAC,YAAY,CAAC,0BAA0B,EAAE,QAAQ,CAAC,CAAC;gBACxD,IAAI,CAAC,WAAW,EAAE,CAAC;gBACnB,MAAM;aACP;YACD,KAAK,wBAAwB,CAAC,CAAC;gBAC7B,MAAM,cAAc,GAClB,IAAI,CAAC,QAAQ,EAAE,8BAA8B,EAAE,KAAK,EAAE,MAAM,CAC1D,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,QAAQ,KAAK,GAAG,EAAE,QAAQ,CAC9C,CAAC;gBACJ,IAAI,CAAC,YAAY,CAAC,gCAAgC,EAAE,cAAc,CAAC,CAAC;gBACpE,MAAM;aACP;YACD,KAAK,UAAU,CAAC,CAAC;gBACf,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,EAAE,gBAAgB,EAAE,KAAK,EAAE,MAAM,CAC7D,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,SAAS,KAAK,GAAG,EAAE,SAAS,CAChD,CAAC;gBACF,IAAI,CAAC,YAAY,CAAC,kBAAkB,EAAE,QAAQ,CAAC,CAAC;gBAChD,IAAI,CAAC,0BAA0B,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;gBAC3C,MAAM;aACP;YACD,KAAK,gBAAgB,CAAC,CAAC;gBACrB,MAAM,cAAc,GAClB,IAAI,CAAC,QAAQ,EAAE,sBAAsB,EAAE,KAAK,EAAE,MAAM,CAClD,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,QAAQ,KAAK,GAAG,EAAE,QAAQ,CAC9C,CAAC;gBACJ,IAAI,CAAC,YAAY,CAAC,wBAAwB,EAAE,cAAc,CAAC,CAAC;gBAC5D,IAAI,CAAC,0BAA0B,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;gBAC3C,MAAM;aACP;YACD,KAAK,kBAAkB,CAAC,CAAC;gBACvB,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,EAAE,wBAAwB,EAAE,KAAK,EAAE,MAAM,CACrE,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,SAAS,KAAK,GAAG,EAAE,SAAS,CAChD,CAAC;gBACF,IAAI,CAAC,YAAY,CAAC,0BAA0B,EAAE,QAAQ,CAAC,CAAC;gBACxD,IAAI,CAAC,WAAW,EAAE,CAAC;gBACnB,MAAM;aACP;YACD,KAAK,wBAAwB,CAAC,CAAC;gBAC7B,MAAM,cAAc,GAClB,IAAI,CAAC,QAAQ,EAAE,8BAA8B,EAAE,KAAK,EAAE,MAAM,CAC1D,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,QAAQ,KAAK,GAAG,EAAE,QAAQ,CAC9C,CAAC;gBACJ,IAAI,CAAC,YAAY,CAAC,gCAAgC,EAAE,cAAc,CAAC,CAAC;gBACpE,IAAI,CAAC,QAAQ,CAAC,4BAA4B,CAAC,KAAK;oBAC9C,IAAI,CAAC,QAAQ,EAAE,8BAA8B,EAAE,KAAK,EAAE,MAAM,GAAG,CAAC;wBAC9D,CAAC,CAAC,QAAQ;wBACV,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,4BAA4B,EAAE,KAAK,CAAC;gBACzD,MAAM;aACP;YACD,KAAK,UAAU,CAAC,CAAC;gBACf,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,EAAE,gBAAgB,EAAE,KAAK,EAAE,MAAM,CAC7D,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,SAAS,KAAK,GAAG,EAAE,SAAS,CAChD,CAAC;gBACF,IAAI,CAAC,YAAY,CAAC,kBAAkB,EAAE,QAAQ,CAAC,CAAC;gBAChD,IAAI,CAAC,0BAA0B,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;gBAC3C,MAAM;aACP;YACD,KAAK,gBAAgB,CAAC,CAAC;gBACrB,MAAM,cAAc,GAClB,IAAI,CAAC,QAAQ,EAAE,sBAAsB,EAAE,KAAK,EAAE,MAAM,CAClD,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,QAAQ,KAAK,GAAG,EAAE,QAAQ,CAC9C,CAAC;gBACJ,IAAI,CAAC,YAAY,CAAC,wBAAwB,EAAE,cAAc,CAAC,CAAC;gBAC5D,IAAI,CAAC,0BAA0B,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;gBAC3C,MAAM;aACP;YACD,KAAK,kBAAkB,CAAC,CAAC;gBACvB,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,EAAE,wBAAwB,EAAE,KAAK,EAAE,MAAM,CACrE,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,SAAS,KAAK,GAAG,EAAE,SAAS,CAChD,CAAC;gBACF,IAAI,CAAC,YAAY,CAAC,0BAA0B,EAAE,QAAQ,CAAC,CAAC;gBACxD,IAAI,CAAC,WAAW,EAAE,CAAC;gBACnB,MAAM;aACP;YACD,KAAK,wBAAwB,CAAC,CAAC;gBAC7B,MAAM,cAAc,GAClB,IAAI,CAAC,QAAQ,EAAE,8BAA8B,EAAE,KAAK,EAAE,MAAM,CAC1D,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,QAAQ,KAAK,GAAG,EAAE,QAAQ,CAC9C,CAAC;gBACJ,IAAI,CAAC,YAAY,CAAC,gCAAgC,EAAE,cAAc,CAAC,CAAC;gBACpE,MAAM;aACP;YACD,KAAK,yBAAyB,CAAC,CAAC;gBAC9B,MAAM,QAAQ,GACZ,IAAI,CAAC,QAAQ,EAAE,+BAA+B,EAAE,KAAK,EAAE,MAAM,CAC3D,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,SAAS,KAAK,GAAG,EAAE,SAAS,CAChD,CAAC;gBACJ,IAAI,CAAC,YAAY,CAAC,iCAAiC,EAAE,QAAQ,CAAC,CAAC;gBAC/D,IAAI,CAAC,WAAW,EAAE,CAAC;gBACnB,MAAM;aACP;YACD,KAAK,+BAA+B,CAAC,CAAC;gBACpC,MAAM,cAAc,GAClB,IAAI,CAAC,QAAQ,EAAE,qCAAqC,EAAE,KAAK,EAAE,MAAM,CACjE,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,QAAQ,KAAK,GAAG,EAAE,QAAQ,CAC9C,CAAC;gBACJ,IAAI,CAAC,YAAY,CACf,uCAAuC,EACvC,cAAc,CACf,CAAC;gBACF,MAAM;aACP;YACD,KAAK,YAAY,CAAC,CAAC;gBACjB,IAAI,OAAO,GAAG,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,mBAAmB,EAAE,KAAK,CAAC,CAAC;gBAClE,MAAM,KAAK,GAAG,OAAO,CAAC,SAAS,CAC7B,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,CAAC,WAAW,IAAI,GAAG,CAAC,WAAW,CACjD,CAAC;gBACF,OAAO,CAAC,KAAK,CAAC,CAAC,aAAa,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,aAAa,CAAC,MAAM,CAChE,CAAC,UAAe,EAAE,EAAE,CAAC,UAAU,CAAC,EAAE,KAAK,GAAG,CAAC,EAAE,CAC9C,CAAC;gBACF,IAAI,OAAO,CAAC,KAAK,CAAC,CAAC,aAAa,CAAC,MAAM,KAAK,CAAC;oBAAE,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;gBACxE,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC;gBACvC,MAAM;aACP;YACD,KAAK,WAAW,CAAC,CAAC;gBAChB,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;gBACrC,MAAM;aACP;SACF;IACH,CAAC;IAED,SAAS,CAAC,IAAW,EAAE,GAAW;QAChC,OAAO,IAAI;YACT,EAAE,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE;YACZ,IAAI,GAAG,CAAC,GAAG,CAAC,EAAE;gBACZ,OAAO,GAAG,CAAC,GAAG,CAAC,CAAC;aACjB;QACH,CAAC,CAAC;aACD,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC;IAC1B,CAAC;IAED,WAAW;QACT,IAAI,CAAC,mBAAmB,GAAG,EAAE,CAAC;QAC9B,IAAI,CAAC,mBAAmB,GAAG,EAAE,CAAC;QAC9B,IAAI,CAAC,mBAAmB,GAAG,EAAE,CAAC;QAC9B,IAAI,uBAAuB,GAAQ,EAAE,CAAC;QACtC,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QACrB,IAAI,gBAAgB,GAAG,IAAI,CAAC,QAAQ,EAAE,wBAAwB,EAAE,KAAK,CAAC;QACtE,IAAI,gBAAgB,GAAG,IAAI,CAAC,QAAQ,EAAE,wBAAwB,EAAE,KAAK,CAAC;QACtE,IAAI,oBAAoB,GAAG,IAAI,CAAC,QAAQ,EAAE,wBAAwB,EAAE,KAAK,CAAC;QAC1E,IAAI,2BAA2B,GAC7B,IAAI,CAAC,QAAQ,EAAE,+BAA+B,EAAE,KAAK,CAAC;QACxD,IAAI,QAAQ,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;QAClC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;QAC1C,uBAAuB,CAAC,IAAI,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;QAClD,gBAAgB,EAAE,OAAO,CAAC,CAAC,IAAS,EAAE,EAAE;YACtC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;YAC/C,uBAAuB,CAAC,IAAI,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;QAChD,CAAC,CAAC,CAAC;QACH,gBAAgB,EAAE,OAAO,CAAC,CAAC,IAAS,EAAE,EAAE;YACtC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;QACjD,CAAC,CAAC,CAAC;QACH,oBAAoB,EAAE,OAAO,CAAC,CAAC,IAAS,EAAE,EAAE;YAC1C,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;QACjD,CAAC,CAAC,CAAC;QACH,2BAA2B,EAAE,OAAO,CAAC,CAAC,IAAS,EAAE,EAAE;YACjD,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;QACjD,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,mBAAmB,GAAG,CAAC,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC;QAClE,IAAI,CAAC,mBAAmB,GAAG,CAAC,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC;QAClE,IAAI,CAAC,mBAAmB,GAAG,CAAC,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC;QAClE,IAAI,mBAAmB,GAAG,IAAI,CAAC,KAAK,EAAE,QAAQ,EAAE,MAAM,CACpD,CAAC,IAAS,EAAE,EAAE,CACZ,IAAI,CAAC,mBAAmB,EAAE,QAAQ,CAAC,IAAI,EAAE,SAAS,CAAC;YACnD,IAAI,CAAC,mBAAmB,EAAE,QAAQ,CAAC,IAAI,EAAE,SAAS,CAAC,CACtD,CAAC;QACF,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,SAAS,CAAC,mBAAmB,EAAE,WAAW,CAAC,CAAC;QAC5E,IAAI,mBAAmB,GAAG,IAAI,CAAC,KAAK,EAAE,QAAQ,EAAE,MAAM,CACpD,CAAC,IAAS,EAAE,EAAE,CACZ,IAAI,CAAC,mBAAmB,EAAE,QAAQ,CAAC,IAAI,EAAE,SAAS,CAAC;YACnD,IAAI,CAAC,mBAAmB,EAAE,QAAQ,CAAC,IAAI,EAAE,SAAS,CAAC,CACtD,CAAC;QACF,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,SAAS,CAAC,mBAAmB,EAAE,WAAW,CAAC,CAAC;QAC3E,IAAI,mBAAmB,GAAG,IAAI,CAAC,KAAK,EAAE,QAAQ,EAAE,MAAM,CACpD,CAAC,IAAS,EAAE,EAAE,CACZ,uBAAuB,EAAE,QAAQ,CAAC,IAAI,EAAE,SAAS,CAAC;YAClD,IAAI,CAAC,mBAAmB,EAAE,QAAQ,CAAC,IAAI,EAAE,SAAS,CAAC,CACtD,CAAC;QACF,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,SAAS,CAAC,mBAAmB,EAAE,WAAW,CAAC,CAAC;IAC7E,CAAC;IAED,UAAU,CAAC,GAAQ;QACjB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAChC,CAAC;IAED,0BAA0B,CAAC,GAAQ,EAAE,IAAS;QAC5C,QAAQ,IAAI,EAAE;YACZ,KAAK,UAAU,CAAC,CAAC;gBACf,IAAI,CAAC,KAAK,CAAC,iBAAiB,GAAG,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,MAAM,CAChE,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,SAAS,KAAK,GAAG,EAAE,SAAS,CAChD,CAAC;gBACF,MAAM,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,wBAAwB,EAAE,KAAK,CAAC;gBACtE,MAAM,QAAQ,GAAG,eAAe,CAAC,MAAM,CACrC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,SAAS,KAAK,GAAG,EAAE,SAAS,CAChD,CAAC;gBACF,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE;oBACrB,IAAI,CAAC,KAAK,CAAC,iBAAiB,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;iBACpD;gBACD,IAAI,CAAC,YAAY,CAAC,0BAA0B,EAAE,QAAQ,CAAC,CAAC;gBAExD,MAAM;aACP;YACD,KAAK,gBAAgB,CAAC,CAAC;gBACrB,IAAI,CAAC,KAAK,CAAC,uBAAuB;oBAChC,IAAI,CAAC,KAAK,CAAC,uBAAuB,CAAC,MAAM,CACvC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,QAAQ,KAAK,GAAG,EAAE,QAAQ,CAC9C,CAAC;gBACJ,MAAM,oBAAoB,GACxB,IAAI,CAAC,QAAQ,CAAC,8BAA8B,EAAE,KAAK,CAAC;gBACtD,MAAM,aAAa,GAAG,oBAAoB,CAAC,MAAM,CAC/C,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,QAAQ,KAAK,GAAG,EAAE,QAAQ,CAC9C,CAAC;gBACF,IAAI,CAAC,aAAa,EAAE,MAAM,EAAE;oBAC1B,IAAI,CAAC,KAAK,CAAC,uBAAuB,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC;iBAC3D;gBACD,IAAI,CAAC,YAAY,CAAC,gCAAgC,EAAE,aAAa,CAAC,CAAC;aACpE;SACF;IACH,CAAC;IAED,kBAAkB,CAAC,GAAQ;QACzB,IAAI,GAAG,EAAE,KAAK,EAAE,MAAM,IAAI,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE;YAC7C,IAAI,CAAC,KAAK,CAAC,iBAAiB,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,KAAK,EAAE,WAAW,CAAC,CAAC;YAC1E,IAAI,CAAC,KAAK,CAAC,uBAAuB,GAAG,IAAI,CAAC,YAAY,CACpD,GAAG,EAAE,MAAM,EACX,UAAU,CACX,CAAC;SACH;aAAM;YACL,IAAI,CAAC,KAAK,CAAC,iBAAiB,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;YACnD,IAAI,CAAC,KAAK,CAAC,uBAAuB,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC;SAC3D;QACD,MAAM,WAAW,GAAG,GAAG,EAAE,KAAK,EAAE,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;QAClE,IAAI,sBAAsB,GAAG,IAAI,CAAC,QAAQ,CAAC,wBAAwB,EAAE,KAAK,CAAC;QAC3E,sBAAsB,GAAG,sBAAsB,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CAClE,WAAW,CAAC,QAAQ,CAAC,GAAG,EAAE,SAAS,CAAC,CACrC,CAAC;QACF,IAAI,CAAC,YAAY,CAAC,0BAA0B,EAAE,sBAAsB,CAAC,CAAC;IACxE,CAAC;IAED,kBAAkB,CAAC,GAAQ;QACzB,IAAI,GAAG,EAAE,KAAK,EAAE,MAAM,IAAI,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE;YAC7C,IAAI,CAAC,KAAK,CAAC,iBAAiB,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,KAAK,EAAE,WAAW,CAAC,CAAC;YAC1E,IAAI,CAAC,KAAK,CAAC,uBAAuB,GAAG,IAAI,CAAC,YAAY,CACpD,GAAG,EAAE,MAAM,EACX,UAAU,CACX,CAAC;SACH;aAAM;YACL,IAAI,CAAC,KAAK,CAAC,iBAAiB,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;YACnD,IAAI,CAAC,KAAK,CAAC,uBAAuB,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC;SAC3D;QACD,MAAM,WAAW,GAAG,GAAG,EAAE,KAAK,EAAE,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;QAClE,IAAI,sBAAsB,GAAG,IAAI,CAAC,QAAQ,CAAC,wBAAwB,EAAE,KAAK,CAAC;QAC3E,IAAI,0BAA0B,GAC5B,IAAI,CAAC,QAAQ,CAAC,+BAA+B,EAAE,KAAK,CAAC;QACvD,sBAAsB,GAAG,sBAAsB,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CAClE,WAAW,CAAC,QAAQ,CAAC,GAAG,EAAE,SAAS,CAAC,CACrC,CAAC;QACF,0BAA0B,GAAG,sBAAsB,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CACtE,WAAW,CAAC,QAAQ,CAAC,GAAG,EAAE,SAAS,CAAC,CACrC,CAAC;QACF,IAAI,CAAC,YAAY,CAAC,0BAA0B,EAAE,sBAAsB,CAAC,CAAC;QACtE,IAAI,CAAC,YAAY,CACf,iCAAiC,EACjC,0BAA0B,CAC3B,CAAC;IACJ,CAAC;IAED,0BAA0B,CAAC,GAAQ,EAAE,IAAS;QAC5C,QAAQ,IAAI,EAAE;YACZ,KAAK,UAAU,CAAC,CAAC;gBACf,IAAI,CAAC,KAAK,CAAC,iBAAiB,GAAG,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,MAAM,CAChE,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,SAAS,KAAK,GAAG,EAAE,SAAS,CAChD,CAAC;gBACF,MAAM,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,wBAAwB,EAAE,KAAK,CAAC;gBACtE,MAAM,QAAQ,GAAG,eAAe,CAAC,MAAM,CACrC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,SAAS,KAAK,GAAG,EAAE,SAAS,CAChD,CAAC;gBACF,IAAI,CAAC,YAAY,CAAC,0BAA0B,EAAE,QAAQ,CAAC,CAAC;gBAExD,MAAM;aACP;YACD,KAAK,gBAAgB,CAAC,CAAC;gBACrB,IAAI,CAAC,KAAK,CAAC,uBAAuB;oBAChC,IAAI,CAAC,KAAK,CAAC,uBAAuB,CAAC,MAAM,CACvC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,QAAQ,KAAK,GAAG,EAAE,QAAQ,CAC9C,CAAC;gBACJ,MAAM,oBAAoB,GACxB,IAAI,CAAC,QAAQ,CAAC,8BAA8B,EAAE,KAAK,CAAC;gBACtD,MAAM,aAAa,GAAG,oBAAoB,CAAC,MAAM,CAC/C,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,QAAQ,KAAK,GAAG,EAAE,QAAQ,CAC9C,CAAC;gBACF,IAAI,CAAC,YAAY,CAAC,gCAAgC,EAAE,aAAa,CAAC,CAAC;aACpE;SACF;IACH,CAAC;IAED,0BAA0B,CAAC,GAAQ,EAAE,IAAS;QAC5C,QAAQ,IAAI,EAAE;YACZ,KAAK,UAAU,CAAC,CAAC;gBACf,IAAI,CAAC,KAAK,CAAC,iBAAiB,GAAG,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,MAAM,CAChE,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,SAAS,KAAK,GAAG,EAAE,SAAS,CAChD,CAAC;gBACF,MAAM,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,wBAAwB,EAAE,KAAK,CAAC;gBACtE,MAAM,QAAQ,GAAG,eAAe,CAAC,MAAM,CACrC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,SAAS,KAAK,GAAG,EAAE,SAAS,CAChD,CAAC;gBACF,IAAI,CAAC,YAAY,CAAC,0BAA0B,EAAE,QAAQ,CAAC,CAAC;gBAExD,MAAM,mBAAmB,GACvB,IAAI,CAAC,QAAQ,CAAC,+BAA+B,EAAE,KAAK,CAAC;gBACvD,MAAM,YAAY,GAAG,mBAAmB,CAAC,MAAM,CAC7C,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,SAAS,KAAK,GAAG,EAAE,SAAS,CAChD,CAAC;gBACF,IAAI,CAAC,YAAY,CAAC,iCAAiC,EAAE,YAAY,CAAC,CAAC;gBAEnE,MAAM;aACP;YACD,KAAK,gBAAgB,CAAC,CAAC;gBACrB,IAAI,CAAC,KAAK,CAAC,uBAAuB;oBAChC,IAAI,CAAC,KAAK,CAAC,uBAAuB,CAAC,MAAM,CACvC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,QAAQ,KAAK,GAAG,EAAE,QAAQ,CAC9C,CAAC;gBACJ,MAAM,oBAAoB,GACxB,IAAI,CAAC,QAAQ,CAAC,8BAA8B,EAAE,KAAK,CAAC;gBACtD,MAAM,aAAa,GAAG,oBAAoB,CAAC,MAAM,CAC/C,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,QAAQ,KAAK,GAAG,EAAE,QAAQ,CAC9C,CAAC;gBACF,IAAI,CAAC,YAAY,CAAC,gCAAgC,EAAE,aAAa,CAAC,CAAC;gBAEnE,MAAM,0BAA0B,GAC9B,IAAI,CAAC,QAAQ,CAAC,qCAAqC,EAAE,KAAK,CAAC;gBAC7D,MAAM,mBAAmB,GAAG,0BAA0B,CAAC,MAAM,CAC3D,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,QAAQ,KAAK,GAAG,EAAE,QAAQ,CAC9C,CAAC;gBACF,IAAI,CAAC,YAAY,CACf,uCAAuC,EACvC,mBAAmB,CACpB,CAAC;aACH;SACF;IACH,CAAC;IAED,eAAe,CAAC,IAAS;QACvB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QACrB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC/B,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;IACnC,CAAC;IAED,qBAAqB,CAAC,SAAc;QAClC,MAAM,SAAS,GAAQ;YACrB,IAAI,EAAE,eAAe;YACrB,QAAQ,EAAE,kBAAkB;YAC5B,KAAK,EAAE,gBAAgB;YACvB,WAAW,EAAE,sBAAsB;SACpC,CAAC;QACF,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,EAAE,aAAa,EAAE,CAAC;IACvD,CAAC;IAED,UAAU;QACR,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,CAAC,SAAS,CAAC;YACvC,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,CAAC;gBACvB,MAAM,gBAAgB,GAAG,IAAI,CAAC,KAAK,EAAE,KAAK,EAAE,IAAI;oBAC9C,EAAE,MAAM,CACN,CAAC,GAAQ,EAAE,EAAE,CACX,GAAG,EAAE,QAAQ,EAAE,WAAW,EAAE,KAAK,WAAW;oBAC5C,GAAG,EAAE,QAAQ,EAAE,WAAW,EAAE,KAAK,OAAO,CAC3C;oBACD,EAAE,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;gBAChC,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,CAChD,CAAC,GAAQ,EAAE,EAAE,CACX,GAAG,EAAE,QAAQ,EAAE,WAAW,EAAE,KAAK,WAAW;oBAC5C,GAAG,EAAE,QAAQ,EAAE,WAAW,EAAE,KAAK,OAAO,CAC3C,CAAC;gBACF,IAAI,CAAC,KAAK,CAAC,eAAe,GAAG,gBAAgB,CAAC;gBAC9C,IAAI,IAAI,CAAC,IAAI,KAAK,MAAM,EAAE;oBACxB,IAAI,CAAC,YAAY,CAAC,eAAe,EAAE,UAAU,CAAC,CAAC;iBAEhD;gBACD,IAAI,CAAC,6BAA6B,EAAE,CAAC;gBACrC,IAAI,CAAC,8BAA8B,EAAE,CAAC;YACxC,CAAC;YACD,KAAK,EAAE,CAAC,GAAQ,EAAE,EAAE,GAAG,CAAC;SACzB,CAAC,CAAC;IACL,CAAC;IACD,2CAA2C;IAC3C,OAAO;QACL,IAAI,CAAC,cAAc,CAAC,2BAA2B,EAAE,CAAC,SAAS,CAAC;YAC1D,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,IAAI,CAAC,KAAK,CAAC,EAAE,GAAG,GAAG,CAAC;YACtB,CAAC;YACD,KAAK,EAAE,CAAC,GAAQ,EAAE,EAAE,GAAG,CAAC;SACzB,CAAC,CAAC;IACL,CAAC;IAED,6BAA6B,CAAC,UAAgB;QAC5C,MAAM,YAAY,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;QACxC,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,IAAI,EAAE,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QACpE,kBAAkB;QAClB,IAAI,CAAC,cAAc,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC;YACvD,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,MAAM,UAAU,GAAG,GAAG,EAAE,IAAI,EAAE,IAAI,CAChC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,SAAS,KAAK,YAAY,EAAE,SAAS,CACzD,CAAC;gBACF,IAAI,CAAC,UAAU,EAAE;oBACf,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;oBAC9B,GAAG,CAAC,WAAW,GAAG,GAAG,EAAE,WAAW,GAAG,CAAC,CAAC;iBACxC;gBACD,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,CAAC;gBACxB,IAAI,IAAI,CAAC,QAAQ,EAAE,gBAAgB,EAAE,KAAK,EAAE;oBAC1C,IAAI,CAAC,YAAY,CAAC,gBAAgB,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;iBAChD;YACH,CAAC;YACD,KAAK,EAAE,CAAC,GAAQ,EAAE,EAAE,GAAG,CAAC;SACzB,CAAC,CAAC;IACL,CAAC;IAED,8BAA8B;QAC5B,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,EAAE,KAAK,EAAE,GAAG,CACrD,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,GAAG,CACvB,CAAC;QACF,IAAI,CAAC,cAAc,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC;YACxD,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,IAAI,CAAC,KAAK,CAAC,aAAa,GAAG,GAAG,CAAC;gBAC/B,MAAM,OAAO,GAAkB,IAAI,CAAC,QAAQ,CAAC,aAAa,EAAE,KAAK,CAAC,GAAG,CACnE,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,CAAC,GAAG,CACtB,CAAC;gBACF,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,oBAAoB,EAAE,KAAK,CAAC,MAAM,CACnE,CAAC,MAAW,EAAE,EAAE;oBACd,IAAI,MAAM,CAAC,KAAK,CAAC,MAAM,EAAE;wBACvB,IAAI,UAAU,GAAG,KAAK,CAAC;wBACvB,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAS,EAAE,EAAE;4BACjC,IAAI,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE;gCACjC,UAAU,GAAG,IAAI,CAAC;6BACnB;wBACH,CAAC,CAAC,CAAC;wBAEH,IAAI,UAAU,EAAE;4BACd,OAAO,MAAM,CAAC;yBACf;qBACF;gBACH,CAAC,CACF,CAAC;gBACF,IAAI,CAAC,YAAY,CAAC,sBAAsB,EAAE,YAAY,CAAC,CAAC;YAC1D,CAAC;SACF,CAAC,CAAC;IACL,CAAC;IAED,gBAAgB,CAAC,QAAa,EAAE,UAAgB;QAC9C,MAAM,YAAY,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;QACxC,MAAM,YAAY,GAAG,QAAQ,CAAC,MAAM,CAClC,CAAC,GAAQ,EAAE,EAAE,CACX,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC,QAAQ,CAAC,GAAG,EAAE,SAAS,CAAC;YAC/C,GAAG,EAAE,SAAS,IAAI,YAAY,EAAE,SAAS,CAC5C,CAAC;QACF,IAAI,CAAC,KAAK,CAAC,oBAAoB,GAAG,IAAI,CAAC,YAAY,CACjD,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE,GAAG,YAAY,CAAC,EACpC,WAAW,CACZ,CAAC;QACF,wEAAwE;QACxE,MAAM,gBAAgB,GAAG,IAAI,CAAC,oBAAoB,CAChD,IAAI,CAAC,QAAQ,EAAE,cAAc,EAAE,KAAK,EACpC,QAAQ,CACT,CAAC;QACF,IAAI,UAAU,KAAK,mBAAmB,EAAE;YACtC,IAAI,CAAC,YAAY,CACf,gBAAgB,EAChB,gBAAgB,EAAE,MAAM;gBACtB,CAAC,CAAC,gBAAgB;gBAClB,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,oBAAoB,CACpC,CAAC;SACH;IACH,CAAC;IAED,oBAAoB,CAAC,qBAA0B,EAAE,YAAiB;QAChE,IAAI,UAAU,GAAG,EAAE,CAAC;QACpB,UAAU,GAAG,qBAAqB,EAAE,MAAM,CAAC,CAAC,QAAa,EAAE,EAAE,CAC3D,YAAY,EAAE,IAAI,CAChB,CAAC,OAAY,EAAE,EAAE,CAAC,QAAQ,EAAE,SAAS,KAAK,OAAO,EAAE,SAAS,CAC7D,CACF,CAAC;QACF,OAAO,UAAU,CAAC;IACpB,CAAC;IAED,sBAAsB,CAAC,IAAU;QAC/B,IAAI,CAAC,gBAAgB,CAAC,KAAK,GAAG,IAAI,CAAC;QACnC,IAAI,CAAC,cAAc,CAAC,eAAe,EAAE,CAAC,SAAS,CAAC;YAC9C,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,GAAG,CAAC;gBAC1B,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,GAAG,CAAC;gBAE3B,IAAI,CAAC,gBAAgB,CAAC,KAAK,GAAG,KAAK,CAAC;gBACpC,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,CAAC;YACD,KAAK,EAAE,GAAG,EAAE;gBACV,IAAI,CAAC,gBAAgB,CAAC,KAAK,GAAG,KAAK,CAAC;YACtC,CAAC;SACF,CAAC,CAAC;IACL,CAAC;IAED,sBAAsB,CAAC,IAAU;QAC/B,IAAI,CAAC,cAAc,CAAC,qBAAqB,EAAE,CAAC,SAAS,CAAC;YACpD,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,GAAG,CAAC;gBAE3B,IAAI,CAAC,KAAK,CAAC,eAAe,GAAG,GAAG,CAAC;gBACjC,IAAG,IAAI,EAAE;oBAET,IAAI,CAAC,mBAAmB,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;oBACzC,IAAI,CAAC,mBAAmB,CAAC,IAAI,EAAE,eAAe,CAAC,CAAC;iBAC/C;YACH,CAAC;YACD,KAAK,EAAE,CAAC,GAAQ,EAAE,EAAE,GAAG,CAAC;SACzB,CAAC,CAAC;IACL,CAAC;IAOD,UAAU,CAAC,IAAS,EAAE,KAAU;QAC9B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;YAC1C,MAAM,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC;YACtC,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;SACvC;IACH,CAAC;IAED,WAAW,CAAC,IAAiC,EAAE,IAAS;QACtD,MAAM,QAAQ,GAAG,IAAI,QAAQ,EAAE,CAAC;QAChC,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QAC9B,MAAM,iBAAiB,GAAG,IAAI,CAAC,WAAW,CAAC,iBAAiB,EAAE,CAAC,QAAQ,EAAE,CAAC;QAC1E,MAAM,SAAS,GAAG;YAChB,aAAa,EAAE,GAAG,IAAI,EAAE,IAAI,EAAE;YAC9B,IAAI,EAAE,GAAG,IAAI,EAAE,IAAI,EAAE;YACrB,SAAS,EAAE,IAAI;YACf,QAAQ,EAAE,GAAG,IAAI,EAAE,IAAI,EAAE;SAC1B,CAAC;QACF,IAAI,IAAI,KAAK,aAAa,EAAE;YAC1B,IAAI,WAAW,GAAG,IAAI,CAAC,QAAQ,EAAE,sBAAsB,EAAE,KAAK,IAAI,EAAE,CAAC;YACrE,IAAI,CAAC,YAAY,CAAC,iCAAiC,EAAE;gBACnD,GAAG,WAAW;gBACd,GAAG,CAAC,SAAS,CAAC;aACf,CAAC,CAAC;YACH,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,QAAQ,EAAE,iBAAiB,CAAC,CAAC,SAAS,CAAC;gBACrE,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;oBACjB,WAAW,GAAG,IAAI,CAAC,QAAQ,EAAE,sBAAsB,EAAE,KAAK,IAAI,EAAE,CAAC;oBACjE,IAAI,gBAAgB,GAAG,WAAW,CAAC,SAAS,CAC1C,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,QAAQ,KAAK,GAAG,EAAE,QAAQ,CAC9C,CAAC;oBACF,WAAW,CAAC,gBAAgB,CAAC,GAAG,GAAG,CAAC;oBACpC,IAAI,CAAC,YAAY,CACf,iCAAiC,EACjC,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,UAAU,CAAC,CAC3C,CAAC;gBACJ,CAAC;gBACD,KAAK,EAAE,CAAC,GAAQ,EAAE,EAAE;oBAClB,WAAW,GAAG,IAAI,CAAC,QAAQ,EAAE,sBAAsB,EAAE,KAAK,IAAI,EAAE,CAAC;oBACjE,WAAW,GAAG,WAAW,CAAC,MAAM,CAC9B,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,QAAQ,KAAK,IAAI,EAAE,IAAI,CAC3C,CAAC;oBACF,IAAI,CAAC,YAAY,CACf,iCAAiC,EACjC,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,UAAU,CAAC,CAC3C,CAAC;gBACJ,CAAC;aACF,CAAC,CAAC;SACJ;aAAM,IAAI,IAAI,KAAK,WAAW,EAAE;YAC/B,IAAI,WAAW,GAAG,IAAI,CAAC,QAAQ,EAAE,sBAAsB,EAAE,KAAK,IAAI,EAAE,CAAC;YACrE,IAAI,CAAC,YAAY,CAAC,iCAAiC,EAAE;gBACnD,GAAG,WAAW;gBACd,GAAG,CAAC,SAAS,CAAC;aACf,CAAC,CAAC;YACH,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,QAAQ,EAAE,iBAAiB,CAAC,CAAC,SAAS,CAAC;gBACrE,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;oBACjB,WAAW,GAAG,IAAI,CAAC,QAAQ,EAAE,sBAAsB,EAAE,KAAK,IAAI,EAAE,CAAC;oBACjE,IAAI,gBAAgB,GAAG,WAAW,CAAC,SAAS,CAC1C,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,QAAQ,KAAK,GAAG,EAAE,QAAQ,CAC9C,CAAC;oBACF,WAAW,CAAC,gBAAgB,CAAC,GAAG,GAAG,CAAC;oBACpC,IAAI,CAAC,YAAY,CACf,iCAAiC,EACjC,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,UAAU,CAAC,CAC3C,CAAC;gBACJ,CAAC;gBACD,KAAK,EAAE,CAAC,GAAQ,EAAE,EAAE;oBAClB,WAAW,GAAG,IAAI,CAAC,QAAQ,EAAE,sBAAsB,EAAE,KAAK,IAAI,EAAE,CAAC;oBACjE,WAAW,GAAG,WAAW,CAAC,MAAM,CAC9B,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,QAAQ,KAAK,IAAI,EAAE,IAAI,CAC3C,CAAC;oBACF,IAAI,CAAC,YAAY,CACf,iCAAiC,EACjC,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,UAAU,CAAC,CAC3C,CAAC;gBACJ,CAAC;aACF,CAAC,CAAC;SACJ;IACH,CAAC;IAED,gBAAgB,CAAC,IAAiC,EAAE,IAAS;QAC3D,IAAI,IAAI,KAAK,aAAa,EAAE;YAC1B,IAAI,WAAW,GAAG,IAAI,CAAC,QAAQ,EAAE,sBAAsB,EAAE,KAAK,IAAI,EAAE,CAAC;YACrE,IAAI,WAAW,EAAE;gBACf,WAAW,GAAG,WAAW,CAAC,MAAM,CAC9B,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,QAAQ,KAAK,IAAI,EAAE,QAAQ,CAC/C,CAAC;gBACF,IAAI,CAAC,YAAY,CAAC,iCAAiC,EAAE,WAAW,CAAC,CAAC;aACnE;SACF;aAAM,IAAI,IAAI,KAAK,WAAW,EAAE;YAC/B,IAAI,SAAS,GAAG,IAAI,CAAC,QAAQ,EAAE,qBAAqB,EAAE,KAAK,IAAI,EAAE,CAAC;YAClE,IAAI,SAAS,EAAE;gBACb,SAAS,GAAG,SAAS,CAAC,MAAM,CAC1B,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,QAAQ,KAAK,IAAI,EAAE,QAAQ,CAC/C,CAAC;gBACF,IAAI,CAAC,YAAY,CAAC,iCAAiC,EAAE,SAAS,CAAC,CAAC;aACjE;SACF;IACH,CAAC;IAED,kBAAkB,CAAC,GAAQ;QACzB,wDAAwD;QACxD,MAAM,YAAY,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;QACxC,IAAI,MAAM,GAAG,EAAE,CAAC;QAChB,IAAI,IAAS,CAAC;QACd,IAAI,GAAG,EAAE,MAAM,EAAE,OAAO,EAAE;YACxB,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,EAAE,KAAK,EAAE,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;YACzE,IAAI,IAAI,CAAC,iBAAiB,EAAE;gBAC1B,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,EAAE,KAAK,EAAE,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;gBACvE,IAAI,CAAC,QAAQ,CAAC,oBAAoB,CAAC,KAAK,GAAG,IAAI,CAAC;aACjD;SACF;aAAM;YACL,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,EAAE,KAAK,EAAE,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE;gBAC5D,IAAI,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC,EAAE;oBAC/D,OAAO,GAAG,EAAE,GAAG,CAAC;iBACjB;YACH,CAAC,CAAC,CAAC;SACJ;QACD,IAAI,CAAC,cAAc,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC;YACtD,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,MAAM,IAAI,GAAG,IAAI,CAAC,YAAY,CAC5B,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE,GAAG,GAAG,EAAE,IAAI,CAAC,EACjC,WAAW,CACZ,CAAC;gBACF,IAAI,CAAC,YAAY,CAAC,gBAAgB,EAAE,IAAI,CAAC,CAAC;YAC5C,CAAC;YACD,KAAK,EAAE,CAAC,GAAQ,EAAE,EAAE,GAAG,CAAC;SACzB,CAAC,CAAC;QACH,IAAI,CAAC,cAAc,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC;YACrD,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,MAAM,IAAI,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,GAAG,GAAG,EAAE,IAAI,CAAC,EAAE,UAAU,CAAC,CAAC;gBAC3D,IAAI,CAAC,YAAY,CAAC,sBAAsB,EAAE,IAAI,CAAC,CAAC;YAClD,CAAC;SACF,CAAC,CAAC;IACL,CAAC;IAED;;;;;;;OAOG;IACH,YAAY,CAAC,KAAU,EAAE,GAAW;QAClC,OAAO,KAAK,CAAC,IAAI,CACf,KAAK;aACF,MAAM,CACL,CAAC,GAAQ,EAAE,IAAS,EAAE,EAAE,CAAC,CACvB,IAAI,IAAI,IAAI,CAAC,GAAG,CAAC,IAAI,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,EAAE,GAAG,CACnD,EACD,IAAI,GAAG,EAAE,CACV;aACA,MAAM,EAAE,CACZ,CAAC;IACJ,CAAC;IAED,OAAO,CAAC,IAAW,EAAE,GAAU,EAAE,GAAW;QAC1C,MAAM,IAAI,GAAQ,EAAE,CAAC;QACrB,GAAG,CAAC,OAAO,CAAC,CAAC,OAAY,EAAE,EAAE;YAC3B,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAC1B,CAAC,WAAgB,EAAE,EAAE,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,OAAO,CAClD,CAAC;YACF,IAAI,KAAK,KAAK,CAAC,CAAC,EAAE;gBAChB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;aACxB;QACH,CAAC,CAAC,CAAC;QACH,OAAO,IAAI,CAAC;IACd,CAAC;IAED,WAAW;QACT,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,IAAI,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;QACvE,IAAI,OAAO,IAAI,IAAI,CAAC,IAAI,KAAK,QAAQ,EAAE;YACrC,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC;gBACjD,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;oBACjB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;oBACpB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;oBACvB,IAAI,CAAC,YAAY,CAAC,UAAU,GAAG,IAAI,CAAC;oBACpC,IAAI,CAAC,gBAAgB,GAAG,GAAG,EAAE,IAAI,EAAE,OAAO,EAAE,EAAE,CAAC;oBAC/C,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,CAAC,eAAe,EAAE,GAAG,CAAC,CAAC;gBAChE,CAAC;gBACD,KAAK,EAAE,CAAC,GAAQ,EAAE,EAAE;oBAClB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;oBACpB,IAAI,CAAC,YAAY,CAAC,UAAU,GAAG,KAAK,CAAC;oBACrC,IAAI,GAAG,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,CAAC,wBAAwB,CAAC,EAAE;wBAC3D,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;qBAC1B;oBACD,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,CAAC,eAAe,EAAE,GAAG,CAAC,CAAC;gBAChE,CAAC;aACF,CAAC,CAAC;SACJ;QACD,IAAI,OAAO,IAAI,IAAI,CAAC,IAAI,KAAK,MAAM,EAAE;YACnC,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC;gBACnE,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;oBACjB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;oBACpB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;oBACvB,IAAI,CAAC,YAAY,CAAC,UAAU,GAAG,IAAI,CAAC;oBACpC,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,CAAC,eAAe,EAAE,GAAG,CAAC,CAAC;oBAC9D,IAAI,CAAC,gBAAgB,GAAG,GAAG,EAAE,IAAI,EAAE,OAAO,EAAE,EAAE,CAAC;gBAEjD,CAAC;gBACD,KAAK,EAAE,CAAC,GAAQ,EAAE,EAAE;oBAClB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;oBACpB,IAAI,CAAC,YAAY,CAAC,UAAU,GAAG,KAAK,CAAC;oBACrC,IAAI,GAAG,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,CAAC,wBAAwB,CAAC,EAAE;wBAC3D,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;qBAC1B;oBACD,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,CAAC,eAAe,EAAE,GAAG,CAAC,CAAC;gBAChE,CAAC;aACF,CAAC,CAAC;SACJ;IACH,CAAC;IAED,iBAAiB,CAAC,KAAa,EAAE,IAAS;QACxC,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,sBAAsB,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QACvE,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;IAC1C,CAAC;IAED,MAAM,CAAC,KAAa;QAClB,QAAQ,KAAK,EAAE;YACb,KAAK,SAAS;gBACZ,IAAI,CAAC,SAAS,EAAE,CAAC;gBACjB,IAAI,CAAC,sBAAsB,EAAE,CAAC;gBAC9B,MAAM;YACR,KAAK,aAAa;gBAChB,IAAI,CAAC,YAAY,EAAE,CAAC;gBACpB,MAAM;SACT;IACH,CAAC;IAED,YAAY;QACV,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACnC,IAAI,GAAW,CAAC;QAChB,IAAI,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,EAAE;YAChD,GAAG,GAAG,SAAS,GAAG,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC;SACxC;aAAM;YACL,GAAG,GAAG,UAAU,GAAG,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC;SACzC;QAED,IAAI,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,EAAE;YAChD,GAAG,IAAI,YAAY,GAAG,IAAI,CAAC,gBAAgB,CAAC;SAC7C;aAAM;YACL,GAAG,IAAI,uBAAuB,GAAG,IAAI,CAAC,gBAAgB,CAAC;SACxD;QAED,IAAI,CAAC,aAAa,CAAC,kBAAkB,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;IAEnD,CAAC;IAED,SAAS;QACP,IAAI,CAAC,YAAY,CAAC,UAAU,GAAG,KAAK,CAAC;QACrC,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;QAC5B,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,MAAM,cAAc,GAAG;YACrB,YAAY,EAAE,CAAC;YACf,YAAY,EAAE,EAAE;YAChB,mBAAmB,EAAE,EAAE;YACvB,+BAA+B,EAAE,EAAE;YACnC,iBAAiB,EAAE,EAAE;YACrB,6BAA6B,EAAE,EAAE;YACjC,aAAa,EAAE,EAAE;YACjB,gBAAgB,EAAE,KAAK;YACvB,cAAc,EAAE,EAAE;YAClB,oBAAoB,EAAE,EAAE;YACxB,gBAAgB,EAAE,EAAE;YACpB,uBAAuB,EAAE,YAAY;YACrC,mBAAmB,EAAE,KAAK;YAC1B,iBAAiB,EAAE,KAAK;YACxB,SAAS,EAAE,EAAE;YACb,EAAE,EAAE,EAAE;YACN,gBAAgB,EAAE,EAAE;YACpB,sBAAsB,EAAE,EAAE;YAC1B,wBAAwB,EAAE,EAAE;YAC5B,8BAA8B,EAAE,EAAE;YAClC,4BAA4B,EAAE,KAAK;YACnC,gBAAgB,EAAE,EAAE;YACpB,sBAAsB,EAAE,EAAE;YAC1B,wBAAwB,EAAE,EAAE;YAC5B,8BAA8B,EAAE,EAAE;YAClC,4BAA4B,EAAE,YAAY;YAC1C,gBAAgB,EAAE,EAAE;YACpB,sBAAsB,EAAE,EAAE;YAC1B,wBAAwB,EAAE,EAAE;YAC5B,8BAA8B,EAAE,EAAE;YAClC,+BAA+B,EAAE,EAAE;YACnC,qCAAqC,EAAE,EAAE;YACzC,mBAAmB,EAAE,EAAE;YACvB,iBAAiB,EAAE,KAAK;YACxB,2BAA2B,EAAE,KAAK;YAClC,aAAa,EAAE,EAAE;YACjB,aAAa,EAAE,CAAC;SACjB,CAAC;QACF,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC7B,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;QACzB,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC;QAC5C,IAAI,CAAC,UAAU,GAAG;YAChB,gBAAgB,EAAE,EAAE;YACpB,kBAAkB,EAAE,EAAE;SACvB,CAAC;QACF,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC5B,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC;YACrC,QAAQ,EAAE,QAAQ;YAClB,KAAK,EAAE,OAAO;SACf,CAAC,CAAC;IACL,CAAC;IAED,WAAW,CAAC,KAAU;QACpB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,YAAY,CAAC,UAAU,GAAG,KAAK,CAAC;QACrC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;IACvD,CAAC;IAED;;OAEG;IACH,iBAAiB;QACf,IAAI,CAAC,cAAc;aAChB,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC;aAC1B,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;aACb,SAAS,CAAC,CAAC,GAAQ,EAAE,EAAE;QAExB,CAAC,CAAC,CAAC;IACP,CAAC;IAED,sBAAsB,CAAC,GAAQ;QAC7B,IAAI,CAAC,SAAS,GAAG,GAAG,EAAE,EAAE,CAAC;QACzB,MAAM,WAAW,GAAG,cAAc,CAAC,GAAG,EAAE,IAAmC,CAAC,IAAI,cAAc,CAAC,MAAM,CAAC;QACtG,IAAI,CAAC,YAAY,CAAC,cAAc,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;QAC7C,IAAI,CAAC,YAAY,CAAC,cAAc,EAAE,WAAW,CAAC,CAAC;QAC/C,IAAI,CAAC,YAAY,CAAC,mBAAmB,EAAE,GAAG,EAAE,WAAW,CAAC,CAAC;QACzD,IAAI,CAAC,UAAU,CAAC,gBAAgB,GAAG,GAAG,EAAE,WAAW,CAAC;QACpD,IAAI,GAAG,EAAE,KAAK,IAAI,GAAG,EAAE,KAAK,EAAE,MAAM,IAAI,IAAI,CAAC,IAAI,KAAK,MAAM,EAAE;YAC5D,IAAI,CAAC,gBAAgB,CAAC,KAAK,GAAG,IAAI,CAAC;SACpC;QAGD,IAAI,GAAG,CAAC,YAAY,CAAC,MAAM,EAAE;YAC3B,IAAI,CAAC,YAAY,CAAC,eAAe,EAAE,GAAG,CAAC,YAAY,CAAC,CAAC;YACrD,IAAI,CAAC,gBAAgB,CAAC,aAAa,GAAG,IAAI,CAAC;YAC3C,IAAI,CAAC,sBAAsB,EAAE,CAAC;SAC/B;QAED,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC;QAC1B,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;QACzB,IAAI,CAAC,6BAA6B,CAAC,mBAAmB,CAAC,CAAC;QACxD,IAAI,CAAC,8BAA8B,EAAE,CAAC;QACtC,IAAI,CAAC,sBAAsB,CAAC,GAAG,CAAC,CAAC;QACjC,IAAI,CAAC,sBAAsB,EAAE,CAAC;IAChC,CAAC;IAGD,eAAe,CAAC,GAAQ;QACtB,MAAM,GAAG,GAAG;YACV,GAAG,IAAI,GAAG,CAAC;gBACT,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,IAAI,EAAE,CAAC;gBACrC,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,IAAI,EAAE,CAAC;aACxC,CAAC;SACH,CAAC;QACF,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC;YAClD,IAAI,EAAE,CAAC,QAAa,EAAE,EAAE;gBACtB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;gBACpB,MAAM,cAAc,GAAG,GAAG,CAAC,MAAM,EAAE,MAAM,CAAA;gBACzC,MAAM,qBAAqB,GAAG,GAAG,CAAC,MAAM,EAAE,QAAQ,CAAA;gBAElD,IAAI,cAAc,EAAE,KAAK,EAAE,MAAM,EAAE;oBACjC,MAAM,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CAC1C,cAAc,EAAE,KAAK,CAAC,QAAQ,CAAC,GAAG,EAAE,GAAG,CAAC,CACzC,CAAC;oBACF,IAAI,CAAC,YAAY,CAAC,gBAAgB,EAAE,MAAM,CAAC,CAAC;oBAC5C,IAAI,IAAI,CAAC,IAAI,KAAK,MAAM,EAAE;wBACxB,IAAI,CAAC,gBAAgB,CAAC,MAAM,GAAG,IAAI,CAAC;wBACpC,IAAI,CAAC,sBAAsB,EAAE,CAAC;qBAC/B;iBACF;gBACD,IAAI,qBAAqB,EAAE,KAAK,EAAE,MAAM,EAAE;oBACxC,MAAM,aAAa,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CACjD,qBAAqB,EAAE,KAAK,EAAE,QAAQ,CAAC,GAAG,EAAE,GAAG,CAAC,CACjD,CAAC;oBACF,IAAI,CAAC,YAAY,CAAC,eAAe,EAAE,aAAa,CAAC,CAAC;oBAClD,IAAI,CAAC,gBAAgB,CAAC,aAAa,GAAG,IAAI,CAAC;oBAC3C,IAAI,CAAC,sBAAsB,EAAE,CAAC;iBAC/B;gBACD,IAAI,GAAG,EAAE,oBAAoB,IAAI,GAAG,EAAE,oBAAoB,EAAE,MAAM,EAAE;oBAClE,MAAM,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CAC5C,GAAG,EAAE,oBAAoB,CAAC,QAAQ,CAAC,GAAG,EAAE,SAAS,CAAC,CACnD,CAAC;oBACF,IAAI,CAAC,YAAY,CAAC,0BAA0B,EAAE,QAAQ,CAAC,CAAC;oBACxD,IACE,IAAI,CAAC,UAAU,EAAE,wBAAwB;wBACzC,CAAC,IAAI,CAAC,mBAAmB,EACzB;wBACA,IAAI,CAAC,gBAAgB,CAAC,SAAS,GAAG,IAAI,CAAC;wBACvC,IAAI,CAAC,sBAAsB,EAAE,CAAC;qBAC/B;iBACF;YACH,CAAC;SACF,CAAC,CAAC;QACH,IAAI,CAAC,uBAAuB,EAAE,CAAC;IACjC,CAAC;IAED,cAAc,CAAC,GAAQ;QACrB,MAAM,GAAG,GAAG;YACV,GAAG,IAAI,GAAG,CAAC;gBACT,GAAG,CAAC,GAAG,EAAE,YAAY,IAAI,EAAE,CAAC;gBAC5B,GAAG,CAAC,GAAG,EAAE,kBAAkB,IAAI,EAAE,CAAC;gBAClC,GAAG,CAAC,GAAG,EAAE,0BAA0B,IAAI,EAAE,CAAC;gBAC1C,GAAG,CAAC,GAAG,EAAE,SAAS,EAAE,eAAe,IAAI,EAAE,CAAC;gBAC1C,GAAG,CAAC,GAAG,EAAE,kBAAkB,IAAI,EAAE,CAAC;gBAClC,GAAG,CAAC,GAAG,EAAE,0BAA0B,IAAI,EAAE,CAAC;gBAC1C,GAAG,CAAC,GAAG,EAAE,iBAAiB,EAAE,eAAe,IAAI,EAAE,CAAC;gBAClD,GAAG,CAAC,GAAG,EAAE,iBAAiB,EAAE,uBAAuB,IAAI,EAAE,CAAC;aAC3D,CAAC;SACH,CAAC;QACF,IAAI,CAAC,cAAc,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC;YACnD,IAAI,EAAE,CAAC,IAAS,EAAE,EAAE;gBAClB,MAAM,QAAQ,GAAG,IAAI,EAAE,IAAI,CAAC;gBAC5B,IAAK,GAAG,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE;oBACpC,MAAM,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CAC1C,GAAG,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,CAAC,GAAG,EAAE,IAAI,CAAC,CAC7C,CAAC;oBACF,IAAI,CAAC,gBAAgB,CAAC,MAAM,GAAG,IAAI,CAAC;oBACpC,IAAI,CAAC,sBAAsB,EAAE,CAAC;oBAC9B,IAAI,CAAC,YAAY,CAAC,sBAAsB,EAAE,MAAM,CAAC,CAAC;iBACnD;gBACD,IAAI,GAAG,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,EAAE;oBACrC,MAAM,aAAa,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CACjD,GAAG,EAAE,QAAQ,EAAE,UAAU,EAAE,QAAQ,CAAC,GAAG,EAAE,IAAI,CAAC,CAC/C,CAAC;oBACF,IAAI,CAAC,YAAY,CAAC,qBAAqB,EAAE,aAAa,CAAC,CAAC;oBACxD,IAAI,CAAC,gBAAgB,CAAC,aAAa,GAAG,IAAI,CAAC;oBAC3C,IAAI,CAAC,sBAAsB,EAAE,CAAC;oBAC9B,IAAI,CAAC,KAAK,CAAC,eAAe,GAAG,aAAa,CAAC;iBAE5C;YACH,CAAC;YACD,0GAA0G;YAC1G,gFAAgF;SACjF,CAAC,CAAC;QACH,IAAI,CAAC,uBAAuB,EAAE,CAAC;IACjC,CAAC;IAED,mBAAmB,CAAC,cAAmB,EAAE,IAAY;QAEnD,QAAO,IAAI,EAAE;YACX,KAAK,QAAQ;gBACX,MAAM,UAAU,GAAG,cAAc,EAAE,MAAM,EAAE,MAAM,EAAE,UAAU,CAAC;gBAC9D,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC,CAAC;gBACpG,MAAM,cAAc,GAAG,WAAW,CAAC,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;gBAEpE,IAAI,CAAC,YAAY,CAAC,sBAAsB,EAAE,WAAW,CAAC,CAAC;gBACvD,IAAI,CAAC,gBAAgB,CAAC,MAAM,GAAG,IAAI,CAAC;gBACpC,IAAI,CAAC,sBAAsB,EAAE,CAAC;gBAC9B,MAAM;YACR,KAAK,eAAe;gBAClB,MAAM,iBAAiB,GAAG,cAAc,EAAE,MAAM,EAAE,QAAQ,EAAE,UAAU,CAAC;gBAEvE,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,iBAAiB,CAAC,QAAQ,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC,CAAC;gBACzG,IAAI,CAAC,YAAY,CAAC,qBAAqB,EAAE,SAAS,CAAC,CAAC;gBACpD,IAAI,CAAC,gBAAgB,CAAC,aAAa,GAAG,IAAI,CAAC;gBAC3C,IAAI,CAAC,sBAAsB,EAAE,CAAC;gBAC9B,MAAM;YACR;gBACE,MAAM;SACT;IAEH,CAAC;IAED,qBAAqB;QACnB,IAAI,CAAC,gBAAgB,CAAC,KAAK,GAAG,KAAK,CAAC;QACpC,IAAI,CAAC,gBAAgB,CAAC,MAAM,GAAG,KAAK,CAAC;QACrC,IAAI,CAAC,gBAAgB,CAAC,QAAQ,GAAG,KAAK,CAAC;QACvC,IAAI,CAAC,gBAAgB,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAChD,IAAI,CAAC,gBAAgB,CAAC,aAAa,GAAG,KAAK,CAAC;QAC5C,IAAI,CAAC,gBAAgB,CAAC,EAAE,GAAG,KAAK,CAAC;QACjC,IAAI,CAAC,gBAAgB,CAAC,SAAS,GAAG,KAAK,CAAC;QACxC,IAAI,CAAC,gBAAgB,CAAC,QAAQ,GAAG,KAAK,CAAC;QACvC,IAAI,CAAC,gBAAgB,CAAC,QAAQ,GAAG,KAAK,CAAC;QACvC,IAAI,CAAC,gBAAgB,CAAC,UAAU,GAAG,KAAK,CAAC;QACzC,IAAI,CAAC,gBAAgB,CAAC,gBAAgB,GAAG,KAAK,CAAC;QAC/C,IAAI,CAAC,gBAAgB,CAAC,aAAa,GAAG,KAAK,CAAC;IAC9C,CAAC;IAED,uBAAuB;QACrB,MAAM,IAAI,GAAG;YACX,mBAAmB;YACnB,eAAe;YACf,IAAI;YACJ,WAAW;YACX,UAAU;YACV,UAAU;YACV,YAAY;YACZ,kBAAkB;YAClB,eAAe;SAChB,CAAC;QACF,IAAI,YAAY,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,OAAO,CAAC,CAAC,GAAW,EAAE,EAAE;YAC3B,IAAI,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,EAAE;gBAC9B,YAAY,GAAG,IAAI,CAAC;aACrB;QACH,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,cAAc,GAAG,YAAY,CAAC;IACrC,CAAC;IAED,aAAa;QACX,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,cAAc,CAAC,gBAAgB,CACzD,sBAAsB,CACvB,CAAC;QACF,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,cAAc,CAAC,gBAAgB,CACzD,yBAAyB,CAC1B,CAAC;QACF,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAC7D,qBAAqB,CACtB,CAAC;QACF,IAAI,CAAC,iBAAiB;YACpB,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,mBAAmB,CAAC,CAAC;QAC5D,IAAI,CAAC,WAAW,CAAC,KAAK,GAAG,IAAI,CAAC,eAAe;YAC3C,CAAC,CAAC,+QAA+Q;YACjR,CAAC,CAAC,0QAA0Q,CAAC;QAC/Q,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,eAAe,CAAC,CAAC;IAC7E,CAAC;IAED,oBAAoB;QAClB,IAAI,IAAI,CAAC,IAAI,KAAK,MAAM,EAAE;YACvB,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,cAAc,CAAC,CAAA;SAClD;IACH,CAAC;+GAtlDU,wBAAwB;mGAAxB,wBAAwB,0wBAMR,UAAU,wHCtCvC,2puGAu5EsB;;4FDv3ET,wBAAwB;kBALpC,SAAS;+BACE,sBAAsB;wPAUS,IAAI;sBAA5C,SAAS;uBAAC,MAAM,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;gBAEd,UAAU;sBAAlC,SAAS;uBAAC,YAAY;gBACb,aAAa;sBAAtB,MAAM;gBACG,cAAc;sBAAvB,MAAM;gBACG,aAAa;sBAAtB,MAAM;gBACG,qBAAqB;sBAA9B,MAAM;gBACG,iBAAiB;sBAA1B,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACG,2BAA2B;sBAApC,MAAM;gBACG,cAAc;sBAAvB,MAAM;gBACG,8BAA8B;sBAAvC,MAAM;gBAEE,kBAAkB;sBAA1B,KAAK;gBAIG,IAAI;sBAAZ,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,cAAc;sBAAtB,KAAK","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport {\n  UntypedFormBuilder,\n  UntypedFormControl,\n  Validators,\n} from '@angular/forms';\nimport { cloneDeep, isEqual } from 'lodash';\nimport { DatePickerComponent } from 'ng2-date-picker';\nimport { distinctUntilChanged, take } from 'rxjs';\nimport { AuthService } from '../workflow-services/auth.service';\nimport { ProgramsService } from '../workflow-services/programs.service';\nimport { UiKitService } from '../workflow-services/ui-kit.service';\nimport { CONSTANTS } from './constants';\nimport { IframeService } from '../services/iframe.service';\nimport { ASSETS } from '../constants/assets.constants';\nimport { PostMessageEvent } from '../interfaces/iframe-type';\nimport { PROGRAM_OBJECT } from '../sharedComponents/program-list/constant';\n\n@Component({\n  selector: 'app-workflow-program',\n  templateUrl: './workflow-program.component.html',\n  styleUrls: ['./workflow-program.component.less', '../forms.less'],\n})\nexport class WorkflowProgramComponent implements OnInit {\n  ASSETS = ASSETS;\n  constants = CONSTANTS;\n  showConfirmation: any;\n  isAscentAllowed: boolean = false;\n  ff_rc_listing: boolean = false;\n  @ViewChild('form', { read: ElementRef }) form!: ElementRef;\n  datePickerOverlay = false;\n  @ViewChild('datePicker') datePicker!: DatePickerComponent;\n  @Output() pickerChanged = new EventEmitter();\n  @Output() populateOption = new EventEmitter();\n  @Output() closeWorkflow = new EventEmitter();\n  @Output() showConfirmationAlert = new EventEmitter();\n  @Output() disconnectRefresh = new EventEmitter();\n  @Output() refreshForm = new EventEmitter();\n  @Output() hideElementsFromMoreOptions = new EventEmitter();\n  @Output() onRemovingRole: EventEmitter<any> = new EventEmitter();\n  @Output() disableElementsFromMoreOptions = new EventEmitter();\n  scrollToBottom!: boolean;\n  @Input() canFrameworkChange: boolean = true;\n  programSimplifyFlag: boolean = false;\n\n  // All Input fields\n  @Input() mode: string = '';\n  @Input() programId: string = '';\n  @Input() programType: number = 1;\n  @Input() allowedFeature!: any;\n  @Input() addToProgramDetails: any;\n  @Input() orgDetails: any;\n  @Input() programDetails: any;\n\n  panelTitleDefaultReviewer = 'Select Default Reviewer(s)';\n  panelTitleOwner = 'Select Owner(s)';\n  panelTitleReviewer = 'Select Reviewer(s)';\n  panelTitleAssignee = 'Select Collaborator(s)';\n  panelTitleApprover = 'Select  Approver';\n  isApproverDisabled: boolean = false;\n  isProgramScope: boolean = false;\n  toolTipData: any = {\n    owner:\n      'Owners are responsible for managing a Program. Only Owners can make changes to a Program and the responsibilities that are linked with the Program.<br>The <strong>Key Admin</strong> and all <b>Admin</b> users will be selected as the Owners of a Program by default.',\n    programScope: `A Program Scope can be used as follows:\n  <li>To specify the duration of the Program.</li>\n  <li>To pre-select certain options that are available when creating a responsibility, thereby decreasing the time required to create a responsibility.</li>\n  <li>To limit the options available for selection when creating a responsibility, thereby making it easier to create a responsibility and reducing the likelihood of an incorrect option being selected.</li>\n    `,\n    collaborators: `Collaborators are required to complete the responsibilities that have been assigned to them. Where Collaborators are selected when creating a Program, only those Collaborators will be available for selection when creating a responsibility linked with the Program.`,\n  };\n  businessCycle: any;\n  featureflagrole: boolean = false;\n  featureflagGroups: boolean = false;\n  disabledAssigneeIds: any[] = [];\n  selectedReviewerIds: any[] = [];\n  selectedAssigneeIds: any[] = [];\n  selectedOverseerIds: any[] = [];\n  assignorId: number[] = [];\n  disableReviewerIds: any[] = [];\n  disableOverseerIds: any[] = [];\n\n  constructor(\n    private fb: UntypedFormBuilder,\n    private programService: ProgramsService,\n    private authService: AuthService,\n    private uiKitService: UiKitService,\n    private changeRef: ChangeDetectorRef,\n    private iframeService: IframeService,\n\n  ) {\n    this.businessCycle = JSON.parse(\n      localStorage.getItem('businessCycle') ?? '{}'\n    );\n  }\n  public noWhitespaceValidator(control: UntypedFormControl) {\n    const isWhitespace = (control.value || '').trim().length === 0;\n    const isValid = !isWhitespace;\n    return isValid ? null : { whitespace: true };\n  }\n  public blankArrayValidator(control: UntypedFormControl) {\n    const isBlank = control.value?.filter((ele: any) => ele)?.length === 0;\n    const isValid = !isBlank;\n    return isValid ? null : { blank: true };\n  }\n  loader = false;\n  showSmiley = false;\n  actionButtons = [\n    { buttonText: 'Add More Programs', class: 'white-btn', id: 'addMore' },\n    { buttonText: 'View Program', class: 'blue-btn', id: 'viewProgram' },\n  ];\n  smileyMessage = `You're All Set!`;\n  createdProgramId = '';\n  isObjectiveValid: boolean = true;\n  isNameExists: boolean = false;\n  //form body for program meta data\n  programForm = this.fb.group({\n    program_type: [\n      this.programType ?? 1,\n      [Validators.required, Validators.min(0), Validators.max(3)],\n    ],\n    program_name: ['', [Validators.required, this.noWhitespaceValidator]],\n    program_description: [''],\n    program_description_attachments: [[]],\n    program_objective: [''],\n    // program_objective: ['', [Validators.required, this.noWhitespaceValidator]],\n    program_objective_attachments: [[]],\n    all_user_in_role: [false],\n    program_owners: [[]],\n    program_owners_group: [[]],\n    program_approver: [[]],\n    framework: [],\n    rc: [[]],\n    program_assignee: [[]],\n    program_assignee_group: [[]],\n    program_default_assignee: [[]],\n    program_default_assignee_group: [[]],\n    assignee_completion_criteria: ['ALL'],\n    program_reviewer: [[]],\n    program_reviewer_group: [[]],\n    program_default_reviewer: [[]],\n    program_default_reviewer_group: [[]],\n    reviewer_completion_criteria: ['SEQUENTIAL'],\n    program_overseer: [[]],\n    program_overseer_group: [[]],\n    program_default_overseer: [[]],\n    program_default_overseer_group: [[]],\n    program_default_failed_overseer: [[]],\n    program_default_failed_overseer_group: [[]],\n    program_assessments: [[]],\n    evidence_required: [false],\n    allow_any_file_key_evidence: [false],\n    custom_fields: [[]],\n    program_state: 0,\n    collaborators: [[]],\n    collaborators_group: [[]],\n  });\n\n  //exceptional handling of custom fields\n\n  showAddCustomField = true;\n  //Program objective and descripion are explectly declared as they are using marx editor which does not supports Reactive forms binding\n  editorData = {\n    programObjective: '',\n    programDescription: '',\n  };\n\n  selectedAssessment!: any;\n\n  currentUser() {\n    const user = this.authService.tokenInfo();\n    return {\n      member_email: user?.email,\n      member_id: user?.id,\n      member_name: user?.name,\n      user_role: 'LOGGED_IN',\n      _id: '',\n    };\n  }\n  //Sets the value of a form control\n  setFormField(controlName: string, value: any, isFromForm?: boolean) {\n    let patch: any = {};\n    patch[controlName] = value;\n    this.programForm.patchValue(patch);\n    this.controls[controlName]?.markAsTouched();\n    if (\n      isFromForm &&\n      controlName === 'program_objective' &&\n      !value.replace(/&nbsp;/g, ' ').trim()\n    )\n      this.isObjectiveValid = false;\n    else this.isObjectiveValid = true;\n  }\n\n  //Returns weather the form is valid or not\n  get formValid() {\n    if (\n      this.programForm.valid &&\n      this.editorData?.programObjective?.replace(/&nbsp;/g, ' ')?.trim()?.length\n    ) {\n      return true;\n    } else {\n      return false;\n    }\n  }\n\n  controls: any = {\n    program_name: this.programForm.get('program_name'),\n    program_type: this.programForm.get('program_type'),\n    program_objective: this.programForm.get('program_objective'),\n    program_roles: this.programForm.get('program_roles'),\n    program_owners: this.programForm.get('program_owners'),\n    program_owners_group: this.programForm.get('program_owners_group'),\n    all_user_in_role: this.programForm.get('all_user_in_role'),\n    program_approver: this.programForm.get('program_approver'),\n    description_attachment: this.programForm.get(\n      'program_description_attachments'\n    ),\n    objective_attachments: this.programForm.get(\n      'program_objective_attachments'\n    ),\n    performance_calculation: this.programForm.get('performance_calculation'),\n    recurring_frequency: this.programForm.get('recurring_frequency'),\n    lock_scope_change: this.programForm.get('lock_scope_change'),\n    rc: this.programForm.get('rc'),\n    evidence_required: this.programForm.get('evidence_required'),\n    framework: this.programForm.get('framework'),\n    allow_any_file_key_evidence: this.programForm.get(\n      'allow_any_file_key_evidence'\n    ),\n    program_assignee: this.programForm.get('program_assignee'),\n    program_assignee_group: this.programForm.get('program_assignee_group'),\n    program_default_assignee: this.programForm.get('program_default_assignee'),\n    program_default_assignee_group: this.programForm.get(\n      'program_default_assignee_group'\n    ),\n    assignee_completion_criteria: this.programForm.get(\n      'assignee_completion_criteria'\n    ),\n    program_default_reviewer: this.programForm.get('program_default_reviewer'),\n    program_default_reviewer_group: this.programForm.get(\n      'program_default_reviewer_group'\n    ),\n    program_reviewer: this.programForm.get('program_reviewer'),\n    program_reviewer_group: this.programForm.get('program_reviewer_group'),\n    program_overseer: this.programForm.get('program_overseer'),\n    program_overseer_group: this.programForm.get('program_overseer_group'),\n    program_default_overseer: this.programForm.get('program_default_overseer'),\n    program_default_overseer_group: this.programForm.get(\n      'program_default_overseer_group'\n    ),\n    program_default_failed_overseer: this.programForm.get(\n      'program_default_failed_overseer'\n    ),\n    program_default_failed_overseer_group: this.programForm.get(\n      'program_default_failed_overseer_group'\n    ),\n    reviewer_completion_criteria: this.programForm.get(\n      'reviewer_completion_criteria'\n    ),\n    program_assessments: this.programForm.get('program_assessments'),\n    custom_fields: this.programForm.get('custom_fields'),\n    isApproverDisabled: this.programForm.get('isApproverDisabled'),\n    collaborators: this.programForm.get('collaborators'),\n    collaborators_group: this.programForm.get('collaborators_group'),\n  };\n\n  lists: any = {\n    ROLES: [],\n    OWNERS: [],\n    OWNERS_GROUPS: [],\n    APPROVERS: [],\n    REVIEWERS: [],\n    REVIEWERS_GROUP: [],\n    ASSIGNEES: [],\n    ASSIGNEES_GROUP: [],\n    DEFAULT_ASSIGNEES: [],\n    DEFAULT_ASSIGNEES_GROUP: [],\n    DEFAULT_REVIEWERS: [],\n    DEFAULT_REVIEWERS_GROUP: [],\n    OVERSEERS: [],\n    OVERSEERS_GROUP: [],\n    DEFAULT_OVERSEERS: [],\n    DEFAULT_OVERSEERS_GROUP: [],\n    RC: [],\n    NON_REMOVABLE_OWNERS: [],\n    ALL_USER: [],\n    ALL_GROUP: [],\n    SYSTEM_ROLE_IDS: [],\n  };\n\n  listLoadingState = {\n    ROLES: false,\n    USERS: false,\n    GROUP: false,\n    RC: false,\n  };\n  sideElements = [\n    'ROLE',\n    'RC',\n    'OWNER',\n    'ASSIGNEE',\n    'APPROVER',\n    'DEFAULT_ASSIGNEE',\n    'REVIEWER',\n    'DEFAULT_REVIEWER',\n    'ASSESSMENT',\n    'FRAMEWORK',\n    'OVERSEER',\n    'DEFAULT_FAILED_OVERSEER',\n    'DEFAULT_OVERSEER',\n    'OVERSEER',\n  ];\n\n  ngOnInit(): void {\n    this.setFormField('program_type', this.programType ?? 1);\n    this.fetchOrganizationUsers();\n    this.fetchOrganizationGroup();\n    this.fetchRoles();\n    this.fetchRC();\n    this.handleDataPopulation();\n    if (this.addToProgramDetails?._id) {\n      this.listAction(this.addToProgramDetails, 'FRAMEWORK');\n    }\n    this.enablefeature();\n    this.handleDataPopulation();\n    this.changeRef.detectChanges();\n  }\n  get valid() {\n    return this.programForm.valid;\n  }\n\n  additionalOption: any = { ...CONSTANTS.additionalOption };\n  activeList = '';\n  /**\n   * #### Description\n   * Populates optional fields status for the optional fields\n   */\n  populateOptionalFields() {\n    const activatedOptions = [];\n    for (const key of Object.keys(this.additionalOption)) {\n      if (this.additionalOption[key] === true) {\n        activatedOptions.push(key);\n      }\n    }\n    this.populateOption.emit(activatedOptions);\n  }\n  addMoreInfo(event: any) {\n    this.additionalOption[event.code] = event.checked;\n    this.scrollToBottom = true;\n    this.checkProgramOptionField();\n  }\n\n  // function to automate form value change handng\n  formChangeListner() {\n    const fields = Object.keys(this.controls);\n    fields.forEach((ele: any) => {\n      this.controls[ele]?.valueChanges.pipe(distinctUntilChanged()).subscribe({\n        next: (res: any) => {\n          this.handleFormFieldChange(ele, res);\n        },\n      });\n    });\n  }\n\n  handleFormFieldChange(control: string, payload?: any) {\n    switch (control) {\n      case 'program_roles': {\n        this.fetchUsersAssociatedWithRoles();\n      }\n    }\n  }\n\n  activateList(evt: string) {\n    if (evt === 'FRAMEWORK' && !this.canFrameworkChange) return;\n    this.activeList = evt;\n    this.pickerChanged.emit(true);\n  }\n\n  listAction(evt: any, type: any) {\n    switch (type) {\n      case 'ROLE': {\n        this.showConfirmation = true;\n        const systemRoles = evt?.filter(\n          (ele: any) =>\n            ele?.roleName?.toLowerCase() === 'key admin' ||\n            ele?.roleName?.toLowerCase() === 'admin'\n        );\n        const patchVal = this.uniqueByProp([...systemRoles, ...evt], '_id');\n        if (\n          !isEqual(this.controls.program_roles.value.sort(), patchVal.sort())\n        ) {\n          this.setFormField('program_roles', patchVal);\n          this.fetchUsersAssociatedWithRoles();\n          this.fetchGroupsAssociatedWithRoles();\n        }\n        this.fieldDeselector(type);\n        break;\n      }\n      case 'RC': {\n        const rc = this.setList(this.lists.RC, evt, 'item_id');\n        this.setFormField('rc', this.uniqueByProp(rc, 'item_id'));\n        this.fieldDeselector(type);\n        break;\n      }\n      case 'OWNER': {\n        this.setFormField(\n          'program_owners',\n          this.uniqueByProp(evt?.users, 'uid')\n        );\n        this.setFormField(\n          'program_owners_group',\n          this.uniqueByProp(evt?.groups, 'ugid')\n        );\n        this.fieldDeselector(type);\n        break;\n      }\n      case 'APPROVER': {\n        this.setFormField(\n          'program_approver',\n          this.uniqueByProp(evt?.users, 'member_id')\n        );\n        this.fieldDeselector(type);\n        break;\n      }\n      case 'COLLABORATORS': {\n        this.setFormField(\n          'collaborators',\n          this.uniqueByProp(evt?.users, 'uid')\n        );\n        this.setFormField(\n          'collaborators_group',\n          this.uniqueByProp(evt?.groups, 'ugid')\n        );\n        this.fieldDeselector(type);\n        break;\n      }\n      case 'DEFAULT_ASSIGNEE': {\n        this.setFormField(\n          'program_default_assignee',\n          this.uniqueByProp(evt?.users, 'member_id')\n        );\n        this.setFormField(\n          'program_default_assignee_group',\n          this.uniqueByProp(evt?.groups, 'group_id')\n        );\n        this.fieldDeselector(type);\n        this.refreshList();\n        break;\n      }\n      case 'REVIEWER': {\n        this.setFormField(\n          'program_reviewer',\n          this.uniqueByProp(evt?.users, 'member_id')\n        );\n        this.setFormField(\n          'program_reviewer_group',\n          this.uniqueByProp(evt?.groups, 'group_id')\n        );\n        this.fieldDeselector(type);\n        this.setDefaultReviewer(evt);\n        break;\n      }\n      case 'DEFAULT_REVIEWER': {\n        this.setFormField(\n          'program_default_reviewer',\n          this.uniqueByProp(evt?.users, 'member_id')\n        );\n        this.setFormField(\n          'program_default_reviewer_group',\n          this.uniqueByProp(evt?.groups, 'group_id')\n        );\n        this.fieldDeselector(type);\n        this.controls.reviewer_completion_criteria.value =\n          this.controls?.program_default_reviewer_group?.value?.length > 0\n            ? 'ANYONE'\n            : this.controls?.reviewer_completion_criteria?.value;\n        this.refreshList();\n        break;\n      }\n      case 'OVERSEER': {\n        this.setFormField(\n          'program_overseer',\n          this.uniqueByProp(evt?.users, 'member_id')\n        );\n        this.setFormField(\n          'program_overseer_group',\n          this.uniqueByProp(evt?.groups, 'group_id')\n        );\n        this.fieldDeselector(type);\n        this.setDefaultOverseer(evt);\n        break;\n      }\n      case 'DEFAULT_OVERSEER': {\n        this.setFormField(\n          'program_default_overseer',\n          this.uniqueByProp(evt?.users, 'member_id')\n        );\n        this.setFormField(\n          'program_default_overseer_group',\n          this.uniqueByProp(evt?.groups, 'group_id')\n        );\n        this.fieldDeselector(type);\n        this.refreshList();\n        break;\n      }\n      case 'DEFAULT_FAILED_OVERSEER': {\n        this.setFormField(\n          'program_default_failed_overseer',\n          this.uniqueByProp(evt?.users, 'member_id')\n        );\n        this.setFormField(\n          'program_default_failed_overseer_group',\n          this.uniqueByProp(evt?.groups, 'group_id')\n        );\n        this.fieldDeselector(type);\n        this.refreshList();\n        break;\n      }\n      case 'ASSESSMENT': {\n        this.setFormField('program_assessments', evt);\n        this.fieldDeselector(type);\n        break;\n      }\n      case 'FRAMEWORK': {\n        this.setFormField('framework', evt);\n        this.setFormField('program_name', evt?.name);\n        this.setFormField('program_description', evt?.description);\n        this.editorData.programDescription = evt?.description;\n        this.fieldDeselector(type);\n        break;\n      }\n    }\n  }\n\n  remove(evt: any, type: any) {\n    switch (type) {\n      case 'ROLE': {\n        let msg = '';\n        msg = 'If you change the roles, any unsaved changes would be lost.';\n        const roles = this.controls?.program_roles?.value?.filter(\n          (ele: any) => ele?._id !== evt?._id\n        );\n        this.listAction(roles, 'ROLE');\n        this.setFormField('program_roles', roles);\n        break;\n      }\n      case 'RC': {\n        const rcs = this.controls?.rc?.value?.filter(\n          (ele: any) => ele?.item_id !== evt?.item_id\n        );\n        this.setFormField('rc', rcs);\n        break;\n      }\n      case 'OWNER': {\n        const owners = this.controls?.program_owners?.value?.filter(\n          (ele: any) => ele?.uid !== evt?.uid\n        );\n        this.setFormField('program_owners', owners);\n        break;\n      }\n      case 'OWNER_GROUP': {\n        const owners_group = this.controls?.program_owners_group?.value?.filter(\n          (ele: any) => ele?.group_id !== evt?.group_id\n        );\n        this.setFormField('program_owners_group', owners_group);\n        break;\n      }\n      case 'APPROVER': {\n        const approver = this.controls?.program_approver?.value?.filter(\n          (ele: any) => ele?.member_id !== evt?.member_id\n        );\n        this.setFormField('program_approver', approver);\n        break;\n      }\n      case 'ASSIGNEE': {\n        const assignee = this.controls?.program_assignee?.value?.filter(\n          (ele: any) => ele?.member_id !== evt?.member_id\n        );\n        this.setFormField('program_assignee', assignee);\n        this.setDefaultAssigneeOnRemove(evt, type);\n        break;\n      }\n      case 'ASSIGNEE_GROUP': {\n        const assignee_group =\n          this.controls?.program_assignee_group?.value?.filter(\n            (ele: any) => ele?.group_id !== evt?.group_id\n          );\n        this.setFormField('program_assignee_group', assignee_group);\n        this.setDefaultAssigneeOnRemove(evt, type);\n        break;\n      }\n      case 'DEFAULT_ASSIGNEE': {\n        const assignee = this.controls?.program_default_assignee?.value?.filter(\n          (ele: any) => ele?.member_id !== evt?.member_id\n        );\n        this.setFormField('program_default_assignee', assignee);\n        this.refreshList();\n        break;\n      }\n      case 'DEFAULT_ASSIGNEE_GROUP': {\n        const assignee_group =\n          this.controls?.program_default_assignee_group?.value?.filter(\n            (ele: any) => ele?.group_id !== evt?.group_id\n          );\n        this.setFormField('program_default_assignee_group', assignee_group);\n        break;\n      }\n      case 'REVIEWER': {\n        const reviewer = this.controls?.program_reviewer?.value?.filter(\n          (ele: any) => ele?.member_id !== evt?.member_id\n        );\n        this.setFormField('program_reviewer', reviewer);\n        this.setDefaultReviewerOnRemove(evt, type);\n        break;\n      }\n      case 'REVIEWER_GROUP': {\n        const reviewer_group =\n          this.controls?.program_reviewer_group?.value?.filter(\n            (ele: any) => ele?.group_id !== evt?.group_id\n          );\n        this.setFormField('program_reviewer_group', reviewer_group);\n        this.setDefaultReviewerOnRemove(evt, type);\n        break;\n      }\n      case 'DEFAULT_REVIEWER': {\n        const reviewer = this.controls?.program_default_reviewer?.value?.filter(\n          (ele: any) => ele?.member_id !== evt?.member_id\n        );\n        this.setFormField('program_default_reviewer', reviewer);\n        this.refreshList();\n        break;\n      }\n      case 'DEFAULT_REVIEWER_GROUP': {\n        const reviewer_group =\n          this.controls?.program_default_reviewer_group?.value?.filter(\n            (ele: any) => ele?.group_id !== evt?.group_id\n          );\n        this.setFormField('program_default_reviewer_group', reviewer_group);\n        this.controls.reviewer_completion_criteria.value =\n          this.controls?.program_default_reviewer_group?.value?.length > 0\n            ? 'ANYONE'\n            : this.controls?.reviewer_completion_criteria?.value;\n        break;\n      }\n      case 'OVERSEER': {\n        const overseer = this.controls?.program_overseer?.value?.filter(\n          (ele: any) => ele?.member_id !== evt?.member_id\n        );\n        this.setFormField('program_overseer', overseer);\n        this.setDefaultOverseerOnRemove(evt, type);\n        break;\n      }\n      case 'OVERSEER_GROUP': {\n        const overseer_group =\n          this.controls?.program_overseer_group?.value?.filter(\n            (ele: any) => ele?.group_id !== evt?.group_id\n          );\n        this.setFormField('program_overseer_group', overseer_group);\n        this.setDefaultOverseerOnRemove(evt, type);\n        break;\n      }\n      case 'DEFAULT_OVERSEER': {\n        const overseer = this.controls?.program_default_overseer?.value?.filter(\n          (ele: any) => ele?.member_id !== evt?.member_id\n        );\n        this.setFormField('program_default_overseer', overseer);\n        this.refreshList();\n        break;\n      }\n      case 'DEFAULT_OVERSEER_GROUP': {\n        const overseer_group =\n          this.controls?.program_default_overseer_group?.value?.filter(\n            (ele: any) => ele?.group_id !== evt?.group_id\n          );\n        this.setFormField('program_default_overseer_group', overseer_group);\n        break;\n      }\n      case 'DEFAULT_FAILED_OVERSEER': {\n        const overseer =\n          this.controls?.program_default_failed_overseer?.value?.filter(\n            (ele: any) => ele?.member_id !== evt?.member_id\n          );\n        this.setFormField('program_default_failed_overseer', overseer);\n        this.refreshList();\n        break;\n      }\n      case 'DEFAULT_FAILED_OVERSEER_GROUP': {\n        const overseer_group =\n          this.controls?.program_default_failed_overseer_group?.value?.filter(\n            (ele: any) => ele?.group_id !== evt?.group_id\n          );\n        this.setFormField(\n          'program_default_failed_overseer_group',\n          overseer_group\n        );\n        break;\n      }\n      case 'ASSESSMENT': {\n        let current = cloneDeep(this.controls.program_assessments?.value);\n        const index = current.findIndex(\n          (ele: any) => ele.category_id == evt.category_id\n        );\n        current[index].assessmentIds = current[index].assessmentIds.filter(\n          (assessment: any) => assessment.id !== evt.id\n        );\n        if (current[index].assessmentIds.length === 0) current.splice(index, 1);\n        this.listAction(current, 'ASSESSMENT');\n        break;\n      }\n      case 'FRAMEWORK': {\n        this.setFormField('framework', null);\n        break;\n      }\n    }\n  }\n\n  returnIds(list: any[], key: string) {\n    return list\n      ?.map((ele) => {\n        if (ele[key]) {\n          return ele[key];\n        }\n      })\n      .filter((ele) => ele);\n  }\n\n  refreshList() {\n    this.selectedAssigneeIds = [];\n    this.selectedReviewerIds = [];\n    this.selectedOverseerIds = [];\n    let assignorAndAssigneesIds: any = [];\n    this.assignorId = [];\n    let selectedAssignee = this.controls?.program_default_assignee?.value;\n    let selectedReviewer = this.controls?.program_default_reviewer?.value;\n    let selectedOverseerList = this.controls?.program_default_overseer?.value;\n    let selectedOverseerFailureList =\n      this.controls?.program_default_failed_overseer?.value;\n    let assignor = this.currentUser();\n    this.assignorId.push(assignor?.member_id);\n    assignorAndAssigneesIds.push(assignor?.member_id);\n    selectedAssignee?.forEach((user: any) => {\n      this.selectedAssigneeIds.push(user?.member_id);\n      assignorAndAssigneesIds.push(user?.member_id);\n    });\n    selectedReviewer?.forEach((user: any) => {\n      this.selectedReviewerIds.push(user?.member_id);\n    });\n    selectedOverseerList?.forEach((user: any) => {\n      this.selectedOverseerIds.push(user?.member_id);\n    });\n    selectedOverseerFailureList?.forEach((user: any) => {\n      this.selectedOverseerIds.push(user?.member_id);\n    });\n    this.selectedReviewerIds = [...new Set(this.selectedReviewerIds)];\n    this.selectedAssigneeIds = [...new Set(this.selectedAssigneeIds)];\n    this.selectedOverseerIds = [...new Set(this.selectedOverseerIds)];\n    let disableAssigneeList = this.lists?.ALL_USER?.filter(\n      (user: any) =>\n        this.selectedReviewerIds?.includes(user?.member_id) ||\n        this.selectedOverseerIds?.includes(user?.member_id)\n    );\n    this.disabledAssigneeIds = this.returnIds(disableAssigneeList, 'member_id');\n    let disableReviewerList = this.lists?.ALL_USER?.filter(\n      (user: any) =>\n        this.selectedOverseerIds?.includes(user?.member_id) ||\n        this.selectedAssigneeIds?.includes(user?.member_id)\n    );\n    this.disableReviewerIds = this.returnIds(disableReviewerList, 'member_id');\n    let disableOverseerList = this.lists?.ALL_USER?.filter(\n      (user: any) =>\n        assignorAndAssigneesIds?.includes(user?.member_id) ||\n        this.selectedReviewerIds?.includes(user?.member_id)\n    );\n    this.disableOverseerIds = this.returnIds(disableOverseerList, 'member_id');\n  }\n\n  removeRole(evt: any) {\n    this.onRemovingRole.emit(evt);\n  }  \n\n  setDefaultAssigneeOnRemove(evt: any, type: any) {\n    switch (type) {\n      case 'ASSIGNEE': {\n        this.lists.DEFAULT_ASSIGNEES = this.lists.DEFAULT_ASSIGNEES.filter(\n          (ele: any) => ele?.member_id !== evt?.member_id\n        );\n        const defaultAssignee = this.controls.program_default_assignee?.value;\n        const assignee = defaultAssignee.filter(\n          (ele: any) => ele?.member_id !== evt?.member_id\n        );\n        if (!assignee?.length) {\n          this.lists.DEFAULT_ASSIGNEES = this.lists.ALL_USER;\n        }\n        this.setFormField('program_default_assignee', assignee);\n\n        break;\n      }\n      case 'ASSIGNEE_GROUP': {\n        this.lists.DEFAULT_ASSIGNEES_GROUP =\n          this.lists.DEFAULT_ASSIGNEES_GROUP.filter(\n            (ele: any) => ele?.group_id !== evt?.group_id\n          );\n        const defaultAssigneeGroup =\n          this.controls.program_default_assignee_group?.value;\n        const assigneeGroup = defaultAssigneeGroup.filter(\n          (ele: any) => ele?.group_id !== evt?.group_id\n        );\n        if (!assigneeGroup?.length) {\n          this.lists.DEFAULT_ASSIGNEES_GROUP = this.lists.ALL_GROUP;\n        }\n        this.setFormField('program_default_assignee_group', assigneeGroup);\n      }\n    }\n  }\n\n  setDefaultReviewer(evt: any) {\n    if (evt?.users?.length || evt?.groups?.length) {\n      this.lists.DEFAULT_REVIEWERS = this.uniqueByProp(evt?.users, 'member_id');\n      this.lists.DEFAULT_REVIEWERS_GROUP = this.uniqueByProp(\n        evt?.groups,\n        'group_id'\n      );\n    } else {\n      this.lists.DEFAULT_REVIEWERS = this.lists.ALL_USER;\n      this.lists.DEFAULT_REVIEWERS_GROUP = this.lists.ALL_GROUP;\n    }\n    const reviewerMap = evt?.users?.map((ele: any) => ele?.member_id);\n    let currentDefaultReviewer = this.controls.program_default_reviewer?.value;\n    currentDefaultReviewer = currentDefaultReviewer.filter((ele: any) =>\n      reviewerMap.includes(ele?.member_id)\n    );\n    this.setFormField('program_default_reviewer', currentDefaultReviewer);\n  }\n\n  setDefaultOverseer(evt: any) {\n    if (evt?.users?.length || evt?.groups?.length) {\n      this.lists.DEFAULT_OVERSEERS = this.uniqueByProp(evt?.users, 'member_id');\n      this.lists.DEFAULT_OVERSEERS_GROUP = this.uniqueByProp(\n        evt?.groups,\n        'group_id'\n      );\n    } else {\n      this.lists.DEFAULT_OVERSEERS = this.lists.ALL_USER;\n      this.lists.DEFAULT_OVERSEERS_GROUP = this.lists.ALL_GROUP;\n    }\n    const overseerMap = evt?.users?.map((ele: any) => ele?.member_id);\n    let currentDefaultReviewer = this.controls.program_default_overseer?.value;\n    let currentDefaultFailReviewer =\n      this.controls.program_default_failed_overseer?.value;\n    currentDefaultReviewer = currentDefaultReviewer.filter((ele: any) =>\n      overseerMap.includes(ele?.member_id)\n    );\n    currentDefaultFailReviewer = currentDefaultReviewer.filter((ele: any) =>\n      overseerMap.includes(ele?.member_id)\n    );\n    this.setFormField('program_default_overseer', currentDefaultReviewer);\n    this.setFormField(\n      'program_default_failed_overseer',\n      currentDefaultFailReviewer\n    );\n  }\n\n  setDefaultReviewerOnRemove(evt: any, type: any) {\n    switch (type) {\n      case 'REVIEWER': {\n        this.lists.DEFAULT_REVIEWERS = this.lists.DEFAULT_REVIEWERS.filter(\n          (ele: any) => ele?.member_id !== evt?.member_id\n        );\n        const defaultReviewer = this.controls.program_default_reviewer?.value;\n        const reviewer = defaultReviewer.filter(\n          (ele: any) => ele?.member_id !== evt?.member_id\n        );\n        this.setFormField('program_default_reviewer', reviewer);\n\n        break;\n      }\n      case 'REVIEWER_GROUP': {\n        this.lists.DEFAULT_REVIEWERS_GROUP =\n          this.lists.DEFAULT_REVIEWERS_GROUP.filter(\n            (ele: any) => ele?.group_id !== evt?.group_id\n          );\n        const defaultReviewerGroup =\n          this.controls.program_default_reviewer_group?.value;\n        const reviewerGroup = defaultReviewerGroup.filter(\n          (ele: any) => ele?.group_id !== evt?.group_id\n        );\n        this.setFormField('program_default_reviewer_group', reviewerGroup);\n      }\n    }\n  }\n\n  setDefaultOverseerOnRemove(evt: any, type: any) {\n    switch (type) {\n      case 'OVERSEER': {\n        this.lists.DEFAULT_OVERSEERS = this.lists.DEFAULT_OVERSEERS.filter(\n          (ele: any) => ele?.member_id !== evt?.member_id\n        );\n        const defaultOverseer = this.controls.program_default_overseer?.value;\n        const overseer = defaultOverseer.filter(\n          (ele: any) => ele?.member_id !== evt?.member_id\n        );\n        this.setFormField('program_default_overseer', overseer);\n\n        const defaultFailOverseer =\n          this.controls.program_default_failed_overseer?.value;\n        const overseerFail = defaultFailOverseer.filter(\n          (ele: any) => ele?.member_id !== evt?.member_id\n        );\n        this.setFormField('program_default_failed_overseer', overseerFail);\n\n        break;\n      }\n      case 'OVERSEER_GROUP': {\n        this.lists.DEFAULT_OVERSEERS_GROUP =\n          this.lists.DEFAULT_OVERSEERS_GROUP.filter(\n            (ele: any) => ele?.group_id !== evt?.group_id\n          );\n        const defaultOverseerGroup =\n          this.controls.program_default_overseer_group?.value;\n        const overseerGroup = defaultOverseerGroup.filter(\n          (ele: any) => ele?.group_id !== evt?.group_id\n        );\n        this.setFormField('program_default_overseer_group', overseerGroup);\n\n        const defaultOverseerFailedGroup =\n          this.controls.program_default_failed_overseer_group?.value;\n        const overseerFailedGroup = defaultOverseerFailedGroup.filter(\n          (ele: any) => ele?.group_id !== evt?.group_id\n        );\n        this.setFormField(\n          'program_default_failed_overseer_group',\n          overseerFailedGroup\n        );\n      }\n    }\n  }\n\n  fieldDeselector(type: any) {\n    this.activeList = '';\n    this.pickerChanged.emit(false);\n    this.markasTouchedSelector(type);\n  }\n\n  markasTouchedSelector(fieldName: any) {\n    const typeField: any = {\n      ROLE: 'program_roles',\n      APPROVER: 'program_approver',\n      OWNER: 'program_owners',\n      OWNER_GROUP: 'program_owners_group',\n    };\n    this.controls[typeField[fieldName]]?.markAsTouched();\n  }\n\n  fetchRoles() {\n    this.programService.getRoles().subscribe({\n      next: (res: any) => {\n        this.lists.ROLES = res;\n        const defaultSystemVal = this.lists?.ROLES?.data\n          ?.filter(\n            (ele: any) =>\n              ele?.roleName?.toLowerCase() === 'key admin' ||\n              ele?.roleName?.toLowerCase() === 'admin'\n          )\n          ?.map((ele: any) => ele?._id);\n        const defaultVal = this.lists?.ROLES?.data?.filter(\n          (ele: any) =>\n            ele?.roleName?.toLowerCase() === 'key admin' ||\n            ele?.roleName?.toLowerCase() === 'admin'\n        );\n        this.lists.SYSTEM_ROLE_IDS = defaultSystemVal;\n        if (this.mode !== 'EDIT') {\n          this.setFormField('program_roles', defaultVal);\n        \n        }\n        this.fetchUsersAssociatedWithRoles();\n        this.fetchGroupsAssociatedWithRoles();\n      },\n      error: (err: any) => { },\n    });\n  }\n  //fetch the list of responsibilities center\n  fetchRC() {\n    this.programService.getResponsibilityCenterList().subscribe({\n      next: (res: any) => {\n        this.lists.RC = res;\n      },\n      error: (err: any) => { },\n    });\n  }\n\n  fetchUsersAssociatedWithRoles(calledFrom?: any) {\n    const loggedInUser = this.currentUser();\n    const roleIds = this.lists.ROLES?.data?.map((ele: any) => ele?._id);\n    // if (fetchAll) {\n    this.programService.fetchAllRoleUsers(roleIds).subscribe({\n      next: (res: any) => {\n        const isUserFind = res?.data?.some(\n          (res: any) => res?.member_id === loggedInUser?.member_id\n        );\n        if (!isUserFind) {\n          res?.data?.push(loggedInUser);\n          res.total_items = res?.total_items + 1;\n        }\n        this.lists.OWNERS = res;\n        if (this.controls?.all_user_in_role?.value) {\n          this.setFormField('program_owners', res?.data);\n        } \n      },\n      error: (err: any) => { },\n    });\n  }\n\n  fetchGroupsAssociatedWithRoles() {\n    const roleIds = this.controls.program_roles?.value?.map(\n      (ele: any) => ele?._id\n    );\n    this.programService.fetchAllRoleGroups(roleIds).subscribe({\n      next: (res: any) => {\n        this.lists.OWNERS_GROUPS = res;\n        const roleIds: Array<string> = this.controls.program_roles?.value.map(\n          (ele: any) => ele._id\n        );\n        const groupDetails = this.controls.program_owners_group?.value.filter(\n          (roleId: any) => {\n            if (roleId.roles.length) {\n              let isSameRole = false;\n              roleId.roles.forEach((role: any) => {\n                if (roleIds.includes(role.roleId)) {\n                  isSameRole = true;\n                }\n              });\n\n              if (isSameRole) {\n                return roleId;\n              }\n            }\n          }\n        );\n        this.setFormField('program_owners_group', groupDetails);\n      },\n    });\n  }\n\n  setDefaultOwners(userList: any, calledFrom?: any) {\n    const loggedInuser = this.currentUser();\n    const defaultOwner = userList.filter(\n      (ele: any) =>\n        ['ADMIN', 'KEY_ADMIN'].includes(ele?.user_role) &&\n        ele?.member_id != loggedInuser?.member_id\n    );\n    this.lists.NON_REMOVABLE_OWNERS = this.uniqueByProp(\n      [...[loggedInuser], ...defaultOwner],\n      'member_id'\n    );\n    // this.setFormField('program_owners', this.lists.NON_REMOVABLE_OWNERS);\n    const preSelectedUsers = this.getPreSelectedOwners(\n      this.controls?.program_owners?.value,\n      userList\n    );\n    if (calledFrom !== 'getProgramDetails') {\n      this.setFormField(\n        'program_owners',\n        preSelectedUsers?.length\n          ? preSelectedUsers\n          : this.lists.NON_REMOVABLE_OWNERS\n      );\n    }\n  }\n\n  getPreSelectedOwners(previousSelectedUsers: any, currentUsers: any) {\n    let finalUsers = [];\n    finalUsers = previousSelectedUsers?.filter((previous: any) =>\n      currentUsers?.some(\n        (current: any) => previous?.member_id === current?.member_id\n      )\n    );\n    return finalUsers;\n  }\n\n  fetchOrganizationUsers(data?: any) {\n    this.listLoadingState.USERS = true;\n    this.programService.fetchAllOrgUser().subscribe({\n      next: (res: any) => {\n        this.lists.ALL_USER = res;\n        this.lists.ASSIGNEES = res;\n\n        this.listLoadingState.USERS = false;\n        this.refreshList();\n      },\n      error: () => {\n        this.listLoadingState.USERS = false;\n      },\n    });\n  }\n\n  fetchOrganizationGroup(data?: any) {\n    this.programService.fetchComplianceGroups().subscribe({\n      next: (res: any) => {\n        this.lists.ALL_GROUP = res;\n\n        this.lists.ASSIGNEES_GROUP = res;\n        if(data) {\n\n        this.populateGroupsByGID(data, 'owners');\n        this.populateGroupsByGID(data, 'collaborators');\n        }\n      },\n      error: (err: any) => { },\n    });\n  }\n\n  fileUploadTracker = {\n    description: [],\n    objective: [],\n  };\n\n  selectFile(type: any, files: any) {\n    for (let i = 0; i <= files.length - 1; i++) {\n      const name = files[i].file.name ?? '';\n      this.uploadFiles(type, files[i].file);\n    }\n  }\n\n  uploadFiles(type: 'DESCRIPTION' | 'OBJECTIVE', file: any) {\n    const formData = new FormData();\n    formData.append('file', file);\n    const destinationString = this.authService.getOrganizationId().toString();\n    const dummyFile = {\n      file_url_path: `${file?.name}`,\n      name: `${file?.name}`,\n      uploading: true,\n      org_file: `${file?.name}`,\n    };\n    if (type === 'DESCRIPTION') {\n      let description = this.controls?.description_attachment?.value ?? [];\n      this.setFormField('program_description_attachments', [\n        ...description,\n        ...[dummyFile],\n      ]);\n      this.programService.uploadFiles(formData, destinationString).subscribe({\n        next: (res: any) => {\n          description = this.controls?.description_attachment?.value ?? [];\n          let descriptionIndex = description.findIndex(\n            (ele: any) => ele?.org_file === res?.org_file\n          );\n          description[descriptionIndex] = res;\n          this.setFormField(\n            'program_description_attachments',\n            this.uniqueByProp(description, 'org_file')\n          );\n        },\n        error: (err: any) => {\n          description = this.controls?.description_attachment?.value ?? [];\n          description = description.filter(\n            (ele: any) => ele?.org_file !== file?.name\n          );\n          this.setFormField(\n            'program_description_attachments',\n            this.uniqueByProp(description, 'org_file')\n          );\n        },\n      });\n    } else if (type === 'OBJECTIVE') {\n      let description = this.controls?.description_attachment?.value ?? [];\n      this.setFormField('program_description_attachments', [\n        ...description,\n        ...[dummyFile],\n      ]);\n      this.programService.uploadFiles(formData, destinationString).subscribe({\n        next: (res: any) => {\n          description = this.controls?.description_attachment?.value ?? [];\n          let descriptionIndex = description.findIndex(\n            (ele: any) => ele?.org_file === res?.org_file\n          );\n          description[descriptionIndex] = res;\n          this.setFormField(\n            'program_description_attachments',\n            this.uniqueByProp(description, 'org_file')\n          );\n        },\n        error: (err: any) => {\n          description = this.controls?.description_attachment?.value ?? [];\n          description = description.filter(\n            (ele: any) => ele?.org_file !== file?.name\n          );\n          this.setFormField(\n            'program_description_attachments',\n            this.uniqueByProp(description, 'org_file')\n          );\n        },\n      });\n    }\n  }\n\n  deleteAttachment(type: 'DESCRIPTION' | 'OBJECTIVE', file: any) {\n    if (type === 'DESCRIPTION') {\n      let description = this.controls?.description_attachment?.value ?? [];\n      if (description) {\n        description = description.filter(\n          (ele: any) => ele?.org_file !== file?.org_file\n        );\n        this.setFormField('program_description_attachments', description);\n      }\n    } else if (type === 'OBJECTIVE') {\n      let objective = this.controls?.objective_attachments?.value ?? [];\n      if (objective) {\n        objective = objective.filter(\n          (ele: any) => ele?.org_file !== file?.org_file\n        );\n        this.setFormField('program_description_attachments', objective);\n      }\n    }\n  }\n\n  selectAllRoleOwner(evt: any) {\n    //need to fetch all the users for all the selected roles\n    const loggedInUser = this.currentUser();\n    let roleId = [];\n    let user: any;\n    if (evt?.target?.checked) {\n      roleId = this.controls.program_roles?.value?.map((ele: any) => ele?._id);\n      if (this.featureflagGroups) {\n        user = this.controls.program_roles?.value?.map((ele: any) => ele?._id);\n        this.controls.program_owners_group.value = user;\n      }\n    } else {\n      roleId = this.controls.program_roles?.value?.map((ele: any) => {\n        if (['key admin', 'admin'].includes(ele.roleName.toLowerCase())) {\n          return ele?._id;\n        }\n      });\n    }\n    this.programService.fetchAllRoleUsers(roleId).subscribe({\n      next: (res: any) => {\n        const user = this.uniqueByProp(\n          [...[loggedInUser], ...res?.data],\n          'member_id'\n        );\n        this.setFormField('program_owners', user);\n      },\n      error: (err: any) => { },\n    });\n    this.programService.fetchAllRoleGroups(user).subscribe({\n      next: (res: any) => {\n        const user = this.uniqueByProp([...res?.data], 'group_id');\n        this.setFormField('program_owners_group', user);\n      },\n    });\n  }\n\n  /**\n   * #### Description\n   *\n   * Returns the unique array of object based on unique key\n   * @param array\n   * @param key\n   * @returns\n   */\n  uniqueByProp(array: any, key: string) {\n    return Array.from(\n      array\n        .reduce(\n          (acc: any, item: any) => (\n            item && item[key] && acc.set(item[key], item), acc\n          ),\n          new Map()\n        )\n        .values()\n    );\n  }\n\n  setList(list: any[], ids: any[], key: string) {\n    const data: any = [];\n    ids.forEach((element: any) => {\n      const index = list.findIndex(\n        (listElement: any) => listElement[key] == element\n      );\n      if (index !== -1) {\n        data.push(list[index]);\n      }\n    });\n    return data;\n  }\n\n  saveProgram() {\n    this.loader = true;\n    let payload = this.programService.buildPayload(this.programForm, this);\n    if (payload && this.mode === 'CREATE') {\n      this.programService.saveProgram(payload).subscribe({\n        next: (res: any) => {\n          this.loader = false;\n          this.showSmiley = true;\n          this.uiKitService.isSmileyOn = true;\n          this.createdProgramId = res?.data?.program?.id;\n          this.postIframeMessage(PostMessageEvent.PROGRAM_CREATED, res);\n        },\n        error: (err: any) => {\n          this.loader = false;\n          this.uiKitService.isSmileyOn = false;\n          if (err?.error?.message?.includes('Category already exist')) {\n            this.isNameExists = true;\n          }\n          this.postIframeMessage(PostMessageEvent.PROGRAM_CREATED, err);\n        },\n      });\n    }\n    if (payload && this.mode === 'EDIT') {\n      this.programService.updateProgram(payload, this.programId).subscribe({\n        next: (res: any) => {\n          this.loader = false;\n          this.showSmiley = true;\n          this.uiKitService.isSmileyOn = true;\n          this.postIframeMessage(PostMessageEvent.PROGRAM_UPDATED, res);\n          this.createdProgramId = res?.data?.program?.id;\n\n        },\n        error: (err: any) => {\n          this.loader = false;\n          this.uiKitService.isSmileyOn = false;\n          if (err?.error?.message?.includes('Category already exist')) {\n            this.isNameExists = true;\n          }\n          this.postIframeMessage(PostMessageEvent.PROGRAM_UPDATED, err);\n        },\n      });\n    }\n  }\n\n  postIframeMessage(event: string, data: any) {\n    const message = this.iframeService.getCloseWebviewMessage(event, data);\n    this.iframeService.postMessage(message);\n  }\n\n  action(event: string) {\n    switch (event) {\n      case 'addMore':\n        this.resetForm();\n        this.populateOptionalFields();\n        break;\n      case 'viewProgram':\n        this.viewPrograms();\n        break;\n    }\n  }\n\n  viewPrograms(): void {\n    this.disconnectRefresh.emit(false);\n    let url: string;\n    if (window.location.host.startsWith('localhost')) {\n      url = 'http://' + window.location.host;\n    } else {\n      url = 'https://' + window.location.host;\n    }\n\n    if (window.location.host.startsWith('localhost')) {\n      url += '/programs/' + this.createdProgramId;\n    } else {\n      url += '/compliance/programs/' + this.createdProgramId;\n    }\n\n    this.iframeService.redirectIfInIframe(url, true);\n\n  }\n\n  resetForm() {\n    this.uiKitService.isSmileyOn = false;\n    this.scrollToBottom = false;\n    this.showSmiley = false;\n    this.loader = true;\n    const DEFAULT_VALUES = {\n      program_type: 1,\n      program_name: '',\n      program_description: '',\n      program_description_attachments: [],\n      program_objective: '',\n      program_objective_attachments: [],\n      program_roles: [],\n      all_user_in_role: false,\n      program_owners: [],\n      program_owners_group: [],\n      program_approver: [],\n      performance_calculation: 'PAST_EVENT',\n      recurring_frequency: false,\n      lock_scope_change: false,\n      framework: [],\n      rc: [],\n      program_assignee: [],\n      program_assignee_group: [],\n      program_default_assignee: [],\n      program_default_assignee_group: [],\n      assignee_completion_criteria: 'ALL',\n      program_reviewer: [],\n      program_reviewer_group: [],\n      program_default_reviewer: [],\n      program_default_reviewer_group: [],\n      reviewer_completion_criteria: 'SEQUENTIAL',\n      program_overseer: [],\n      program_overseer_group: [],\n      program_default_overseer: [],\n      program_default_overseer_group: [],\n      program_default_failed_overseer: [],\n      program_default_failed_overseer_group: [],\n      program_assessments: [],\n      evidence_required: false,\n      allow_any_file_key_evidence: false,\n      custom_fields: [],\n      program_state: 0,\n    };\n    this.resetAdditionalOption();\n    this.programForm.reset();\n    this.programForm.patchValue(DEFAULT_VALUES);\n    this.editorData = {\n      programObjective: '',\n      programDescription: '',\n    };\n    this.loader = false;\n    this.isNameExists = false;\n    this.fetchRoles();\n    this.refreshForm.emit(true);\n    this.form.nativeElement.scrollIntoView({\n      behavior: 'smooth',\n      block: 'start',\n    });\n  }\n\n  closeSmiley(event: any) {\n    this.showSmiley = false;\n    this.uiKitService.isSmileyOn = false;\n    this.closeWorkflow.emit({ evt: '', confirm: false });\n  }\n\n  /**\n   * Get program details when user is trying to edit program\n   */\n  getProgramDetails() {\n    this.programService\n      .getProgram(this.programId)\n      .pipe(take(1))\n      .subscribe((res: any) => {\n       \n      });\n  }\n\n  populateProgramDetails(res: any) {\n    this.programId = res?.id;\n    const programType = PROGRAM_OBJECT[res?.type as keyof typeof PROGRAM_OBJECT] ?? PROGRAM_OBJECT.others;\n    this.setFormField('program_name', res?.name);\n    this.setFormField('program_type', programType);\n    this.setFormField('program_objective', res?.description);\n    this.editorData.programObjective = res?.description;\n    if (res?.roles && res?.roles?.length && this.mode === 'EDIT') {\n      this.additionalOption.ROLES = true;\n    }\n    \n\n    if (res.customFields.length) {\n      this.setFormField('custom_fields', res.customFields);\n      this.additionalOption.CUSTOM_FIELDS = true;\n      this.populateOptionalFields();\n    }\n\n    this.populateMembers(res);\n    this.populateGroups(res);\n    this.fetchUsersAssociatedWithRoles('getProgramDetails');\n    this.fetchGroupsAssociatedWithRoles();\n    this.fetchOrganizationGroup(res);\n    this.fetchOrganizationUsers();\n  }\n\n\n  populateMembers(res: any) {\n    const ids = [\n      ...new Set([\n        ...(res?.owners?.admins?.users ?? []),\n        ...(res?.owners?.managers?.users ?? []),\n      ]),\n    ];\n    this.programService.getMemeberByUIds(ids).subscribe({\n      next: (response: any) => {\n        this.loader = false;\n        const selectedOwners = res.owners?.admins\n        const selectedCollaborators = res.owners?.managers\n\n        if (selectedOwners?.users?.length) {\n          const owners = response.filter((ele: any) =>\n            selectedOwners?.users.includes(ele?.uid)\n          );\n          this.setFormField('program_owners', owners);\n          if (this.mode === 'EDIT') {\n            this.additionalOption.OWNERS = true;\n            this.populateOptionalFields();\n          }\n        }\n        if (selectedCollaborators?.users?.length) {\n          const collaborators = response.filter((ele: any) =>\n            selectedCollaborators?.users?.includes(ele?.uid)\n          );\n          this.setFormField('collaborators', collaborators);\n          this.additionalOption.COLLABORATORS = true;\n          this.populateOptionalFields();\n        }\n        if (res?.default_assignee_ids && res?.default_assignee_ids?.length) {\n          const assignee = response.filter((ele: any) =>\n            res?.default_assignee_ids.includes(ele?.member_id)\n          );\n          this.setFormField('program_default_assignee', assignee);\n          if (\n            this.orgDetails?.hasProgramFullPermission ||\n            !this.programSimplifyFlag\n          ) {\n            this.additionalOption.ASSIGNEES = true;\n            this.populateOptionalFields();\n          }\n        }\n      },\n    });\n    this.checkProgramOptionField();\n  }\n\n  populateGroups(res: any) {\n    const ids = [\n      ...new Set([\n        ...(res?.owners_group ?? []),\n        ...(res?.assignee_group_ids ?? []),\n        ...(res?.default_assignee_group_ids ?? []),\n        ...(res?.overseers?.cc_email_groups ?? []),\n        ...(res?.reviewer_group_ids ?? []),\n        ...(res?.default_reviewer_group_ids ?? []),\n        ...(res?.default_overseers?.cc_email_groups ?? []),\n        ...(res?.default_overseers?.failure_cc_email_groups ?? []),\n      ]),\n    ];\n    this.programService.getMemberByGroups(ids).subscribe({\n      next: (resp: any) => {\n        const response = resp?.data;\n        if ( res?.owners?.userGroups?.length) {\n          const owners = response.filter((ele: any) =>\n            res?.owners?.userGroups?.includes(ele?.ugid)\n          );\n          this.additionalOption.OWNERS = true;\n          this.populateOptionalFields();\n          this.setFormField('program_owners_group', owners);\n        }\n        if (res?.managers?.userGroups?.length) {\n          const collaborators = response.filter((ele: any) =>\n            res?.managers?.userGroups?.includes(ele?.ugid)\n          );\n          this.setFormField('collaborators_group', collaborators);\n          this.additionalOption.COLLABORATORS = true;\n          this.populateOptionalFields();\n          this.lists.ASSIGNEES_GROUP = collaborators;\n         \n        }\n      },\n      // As of now groups has been removed from reviewer and overseeer if this group feature gets incoperated in\n      //future need to add group condition here to prepopulate the data while editing.\n    });\n    this.checkProgramOptionField();\n  }\n\n  populateGroupsByGID(programDetails: any, type: string) {\n    \n    switch(type) {\n      case 'owners':\n        const owner_ugid = programDetails?.owners?.admins?.userGroups;\n        const ownersGroup = this.lists.ASSIGNEES_GROUP.filter((ele: any) => owner_ugid.includes(ele?.ugid));\n        const ownersGroupIds = ownersGroup.map((ele: any) => ele?.group_id);\n\n        this.setFormField('program_owners_group', ownersGroup);\n        this.additionalOption.OWNERS = true;\n        this.populateOptionalFields();\n        break;\n      case 'collaborators':\n        const collaborator_ugid = programDetails?.owners?.managers?.userGroups;\n\n        const groupList = this.lists.ASSIGNEES_GROUP.filter((ele: any) => collaborator_ugid.includes(ele?.ugid));\n        this.setFormField('collaborators_group', groupList);\n        this.additionalOption.COLLABORATORS = true;\n        this.populateOptionalFields();\n        break;\n      default:\n        break;\n    }\n\n  }\n\n  resetAdditionalOption() {\n    this.additionalOption.ROLES = false;\n    this.additionalOption.OWNERS = false;\n    this.additionalOption.APPROVER = false;\n    this.additionalOption.PROGRAM_FREQUENCY = false;\n    this.additionalOption.SCOPE_CHANGES = false;\n    this.additionalOption.RC = false;\n    this.additionalOption.ASSIGNEES = false;\n    this.additionalOption.REVIEWER = false;\n    this.additionalOption.OVERSEER = false;\n    this.additionalOption.ASSESSMENT = false;\n    this.additionalOption.FORMATE_EVIDENCE = false;\n    this.additionalOption.CUSTOM_FIELDS = false;\n  }\n\n  checkProgramOptionField(): any {\n    const code = [\n      'PROGRAM_FREQUENCY',\n      'SCOPE_CHANGES',\n      'RC',\n      'ASSIGNEES',\n      'REVIEWER',\n      'OVERSEER',\n      'ASSESSMENT',\n      'FORMATE_EVIDENCE',\n      'CUSTOM_FIELDS',\n    ];\n    let isMoreOption = false;\n    code.forEach((key: string) => {\n      if (this.additionalOption[key]) {\n        isMoreOption = true;\n      }\n    });\n    this.isProgramScope = isMoreOption;\n  }\n\n  enablefeature() {\n    this.featureflagrole = this.allowedFeature.isFeatureEnabled(\n      'ff_role_improvements'\n    );\n    this.isAscentAllowed = this.allowedFeature.isFeatureEnabled(\n      'ff_compliance_framework'\n    );\n    this.programSimplifyFlag = this.allowedFeature.isFeatureEnabled(\n      'ff_program_simplify'\n    );\n    this.featureflagGroups =\n      this.allowedFeature.isFeatureEnabled('ff_program_groups');\n    this.toolTipData.owner = this.featureflagrole\n      ? 'Owners are responsible for managing a Program. Only Owners can make changes to a Program and the responsibilities that are linked with the Program.<br>The <strong>Key Power User</strong> and all <b>Power Users</b> will be selected as the Owners of a Program by default.'\n      : 'Owners are responsible for managing a Program. Only Owners can make changes to a Program and the responsibilities that are linked with the Program.<br>The <strong>Key Admin</strong> and all <b>Admin</b> users will be selected as the Owners of a Program by default.';\n    this.ff_rc_listing = this.allowedFeature.isFeatureEnabled('ff_rc_listing');\n  }\n\n  handleDataPopulation() {\n    if (this.mode === 'EDIT') {\n       this.populateProgramDetails(this.programDetails)\n    }\n  }\n}","<div class=\"workflow-program\" #form>\n  <form novalidate [formGroup]=\"programForm\">\n    <!-- Program Category Type -->\n    <form-field\n      [checked]=\"controls?.program_type?.value > -1\"\n      [active]=\"false\"\n      [disabled]=\"sideElements.includes(activeList)\"\n      [img]=\"ASSETS.issue_type\"\n    >\n      <label class=\"vx-control-panel\"\n        >PROGRAM TYPE <span class=\"required\">*</span></label\n      >\n      <tab-selector\n        formControlName=\"program_type\"\n        [displayArray]=\"constants?.categoryType\"\n      ></tab-selector>\n      <!-- <p *ngIf=\"program_name?.invalid\" class=\"error-message\">Add a program type</p> -->\n    </form-field>\n\n    <!-- Framework -->\n    <form-field\n      *ngIf=\"isAscentAllowed\"\n      [checked]=\"false\"\n      [active]=\"false\"\n      [disabled]=\"false\"\n      [img]=\"ASSETS.case_category\"\n    >\n      <label class=\"vx-control-panel\">FRAMEWORK</label>\n      <!-- [selectDiv]=\"true\" -->\n      <input-with-pill\n        [placeholder]=\"'Select a framework that this Program relates to'\"\n        (select)=\"activateList('FRAMEWORK')\"\n      >\n        <div class=\"selected\" *ngIf=\"controls?.framework.value?.name\">\n          <div class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\">\n            <i\n              class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n              *ngIf=\"canFrameworkChange\"\n              (click)=\"remove('', 'FRAMEWORK')\"\n              >&#xe9ae;</i\n            >\n            <span\n              class=\"chipName vx-fs-11 vx-label-txt\"\n              [appTooltip]=\"controls?.framework.value?.name\"\n              placement=\"bottom-left\"\n              delay=\"0\"\n              type=\"black\"\n              [tooltipMandatory]=\"false\"\n              >{{ controls?.framework.value?.name }}</span\n            >\n          </div>\n\n          <!-- <div class=\"chip-container\">\n                        <div class=\"chip-inner\">\n                            <span class=\"chip\"><i (click)=\"remove('', 'FRAMEWORK')\" *ngIf=\"canFrameworkChange\" class=\"icons\" >&#xe90d;</i> {{controls?.framework.value?.name}}</span>\n                        </div>\n                    </div> -->\n          <button\n            *ngIf=\"canFrameworkChange\"\n            class=\"edit\"\n            type=\"button\"\n            (click)=\"activateList('FRAMEWORK')\"\n          >\n            <i class=\"icons\">&#xe9ba;</i> Edit\n          </button>\n        </div>\n      </input-with-pill>\n    </form-field>\n\n    <!-- Program Category Name -->\n    <form-field\n      [checked]=\"controls?.program_name?.value?.trim()?.length\"\n      [active]=\"false\"\n      [disabled]=\"sideElements.includes(activeList)\"\n      [img]=\"ASSETS.what\"\n    >\n      <label class=\"vx-control-panel\"\n        >PROGRAM NAME <span class=\"required\">*</span></label\n      >\n      <input\n        InputTrim\n        formControlName=\"program_name\"\n        type=\"text\"\n        placeholder=\"What is the Program name?\"\n      />\n\n      <p\n        *ngIf=\"\n          controls?.program_name?.errors && controls?.program_name?.touched\n        \"\n        class=\"error-message\"\n      >\n        Enter a name for this Program.\n      </p>\n      <p *ngIf=\"isNameExists\" class=\"error-message\">\n        Program name already exists.\n      </p>\n      <vcomply-editor\n      [(ngModel)]=\"editorData.programObjective\"\n      [ngModelOptions]=\"{ standalone: true }\"\n      (sendSavedFiles)=\"selectFile('OBJECTIVE', $event)\"\n      (ngModelChange)=\"setFormField('program_objective', $event, true)\"\n      [editorConfig]=\"constants?.description\"\n    >\n    </vcomply-editor>\n    </form-field>\n\n\n\n    <!-- Owners -->\n    <form-field\n      *ngIf=\"additionalOption?.OWNERS\"\n      [checked]=\"\n        controls?.program_owners?.value?.length > 0 ||\n        controls?.program_owners_group?.value?.length > 0\n      \"\n      [active]=\"activeList === 'OWNER'\"\n      [disabled]=\"sideElements.includes(activeList) && activeList !== 'OWNER'\"\n      [img]=\"ASSETS.case_owners\"\n    >\n      <label class=\"vx-control-panel\"\n        >OWNER(S) \n        <span\n          class=\"icon\"\n          *ngIf=\"toolTipData.owner !== ''\"\n          libPopoverHover\n          (mouseover)=\"dataTooltip.popover()\"\n          (mouseleave)=\"dataTooltip.closePopover()\"\n          placement=\"right\"\n          ><i class=\"icons\">&#xe91f;</i></span\n        >\n        <popover-hover #dataTooltip>\n          <div class=\"vx-info-card\">\n            <div\n              class=\"vx-info-card-body\"\n              [innerHTML]=\"toolTipData.owner\"\n              id=\"OwnerHelpText\"\n            ></div>\n          </div>\n        </popover-hover>\n      </label>\n      <input-with-pill\n        [placeholder]=\"'Who is responsible for managing this program?'\"\n        (select)=\"activateList('OWNER')\"\n      >\n        <div class=\"selected\" *ngIf=\"controls?.program_owners?.value[0]\">\n          <div class=\"vx-d-flex vx-align-center\">\n            <div\n              class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n            >\n              <span\n                class=\"chipName vx-fs-11 vx-label-txt\"\n                [appTooltip]=\"controls?.program_owners?.value[0]?.member_name\"\n                placement=\"bottom-left\"\n                delay=\"0\"\n                type=\"black\"\n                [tooltipMandatory]=\"false\"\n                >{{ controls?.program_owners?.value[0]?.member_name }}</span\n              >\n              <button\n                class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4 greenBg\"\n                appPopover\n                (click)=\"owner.popover()\"\n                placement=\"right\"\n                *ngIf=\"controls?.program_owners?.value?.length > 1\"\n              >\n                +{{ controls?.program_owners?.value?.length - 1 }}\n              </button>\n            </div>\n            <span\n              class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n              *ngIf=\"\n                controls?.program_owners_group?.value?.length &&\n                controls?.program_owners?.value?.length\n              \"\n              >&</span\n            >\n            <div\n              class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n              *ngIf=\"controls?.program_owners_group?.value?.length\"\n            >\n              <i\n                class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                *ngIf=\"\n                  !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n                    owner?.user_role\n                  )\n                \"\n                (click)=\"\n                  remove(\n                    controls?.program_owners_group?.value[0],\n                    'OWNER_GROUP'\n                  )\n                \"\n                >&#xe9ae;</i\n              >\n              <span\n                class=\"chipName vx-fs-11 vx-label-txt\"\n                [appTooltip]=\"\n                  controls?.program_owners_group?.value[0]?.group_name\n                \"\n                placement=\"bottom-left\"\n                delay=\"0\"\n                type=\"black\"\n                [tooltipMandatory]=\"false\"\n                >{{\n                  controls?.program_owners_group?.value[0]?.group_name\n                }}</span\n              >\n              <button\n                class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                appPopover\n                (click)=\"group.popover()\"\n                placement=\"right\"\n                *ngIf=\"controls?.program_owners_group?.value?.length > 1\"\n              >\n                +{{ controls?.program_owners_group?.value?.length - 1 }}\n              </button>\n            </div>\n          </div>\n          <button\n            *ngIf=\"activeList !== 'OWNER'\"\n            [class.disabled]=\"controls?.all_user_in_role?.value\"\n            (click)=\"activateList('OWNER')\"\n            class=\"edit\"\n            type=\"button\"\n          >\n            <i class=\"icons\">&#xe9ba;</i>Edit\n          </button>\n        </div>\n      </input-with-pill>\n      <app-popover #owner [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li\n              *ngFor=\"let owner of controls?.program_owners?.value | slice : 1\"\n            >\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i\n                    *ngIf=\"\n                      !(\n                        lists.NON_REMOVABLE_OWNERS | listToId : 'member_id'\n                      ).includes(owner?.member_id)\n                    \"\n                    class=\"icons\"\n                    (click)=\"remove(owner, 'OWNER')\"\n                    >&#xe90d;</i\n                  >\n                  {{ owner?.member_name }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n      <app-popover #group [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li\n              *ngFor=\"\n                let owner of controls?.program_owners_group?.value | slice : 1\n              \"\n            >\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i\n                    *ngIf=\"\n                      !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n                        owner?.user_role\n                      )\n                    \"\n                    class=\"icons\"\n                    (click)=\"remove(owner, 'OWNER_GROUP')\"\n                    >&#xe90d;</i\n                  >\n                  {{ owner?.group_name }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n    </form-field>\n\n    <!-- Collaborators   -->\n    <form-field\n    *ngIf=\"additionalOption?.COLLABORATORS\"\n    [checked]=\"\n      controls?.collaborators?.value?.length > 0 ||\n      controls?.collaborators_group?.value?.length > 0\n    \"\n    [active]=\"activeList === 'COLLABORATORS'\"\n    [disabled]=\"sideElements.includes(activeList) && activeList !== 'COLLABORATORS'\"\n    [img]=\"\n      'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/owner.svg'\n    \"\n  >\n    <label class=\"vx-control-panel\"\n      >COLLABORATORS \n      <span\n        class=\"icon\"\n        *ngIf=\"toolTipData.collaborators !== ''\"\n        libPopoverHover\n        (mouseover)=\"dataTooltip.popover()\"\n        (mouseleave)=\"dataTooltip.closePopover()\"\n        placement=\"right\"\n        ><i class=\"icons\">&#xe91f;</i></span\n      >\n      <popover-hover #dataTooltip>\n        <div class=\"vx-info-card\">\n          <div\n            class=\"vx-info-card-body\"\n            [innerHTML]=\"toolTipData.collaborators\"\n            id=\"CollaboratorsHelpText\"\n          ></div>\n        </div>\n      </popover-hover>\n    </label>\n    <input-with-pill\n      [placeholder]=\"'Who is responsible for managing this program?'\"\n      (select)=\"activateList('COLLABORATORS')\"\n    >\n      <div class=\"selected\" *ngIf=\"controls?.collaborators?.value[0] || controls?.collaborators_group?.value[0]\">\n        <div class=\"vx-d-flex vx-align-center\">\n          <!-- Users -->\n          <div \n            class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n            *ngIf=\"controls?.collaborators?.value[0]\"\n          >\n            <span\n              class=\"chipName vx-fs-11 vx-label-txt\"\n              [appTooltip]=\"controls?.collaborators?.value[0]?.member_name\"\n              placement=\"bottom-left\"\n              delay=\"0\"\n              type=\"black\"\n              [tooltipMandatory]=\"false\"\n              >{{ controls?.collaborators?.value[0]?.member_name }}</span\n            >\n            <button\n              class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4 greenBg\"\n              appPopover\n              (click)=\"owner.popover()\"\n              placement=\"right\"\n              *ngIf=\"controls?.collaborators?.value?.length > 1\"\n            >\n              +{{ controls?.collaborators?.value?.length - 1 }}\n            </button>\n          </div>\n          <span\n            class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n            *ngIf=\" \n              controls?.collaborators_group?.value?.length &&\n              controls?.collaborators?.value?.length\n            \"\n            >&</span\n          >\n          <!-- Groups -->\n          <div\n            class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n            *ngIf=\"controls?.collaborators_group?.value?.length\"\n          >\n            <i\n              class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n              *ngIf=\"\n                !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n                  owner?.user_role\n                )\n              \"\n              (click)=\"\n                remove(\n                  controls?.collaborators_group?.value[0],\n                  'COLLABORATORS_GROUP'\n                )\n              \"\n              >&#xe9ae;</i\n            >\n            <span\n              class=\"chipName vx-fs-11 vx-label-txt\"\n              [appTooltip]=\"\n                controls?.collaborators_group?.value[0]?.group_name\n              \"\n              placement=\"bottom-left\"\n              delay=\"0\"\n              type=\"black\"\n              [tooltipMandatory]=\"false\"\n              >{{\n                controls?.collaborators_group?.value[0]?.group_name\n              }}</span\n            >\n            <button\n              class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n              appPopover\n              (click)=\"group.popover()\"\n              placement=\"right\"\n              *ngIf=\"controls?.program_owners_group?.value?.length > 1\"\n            >\n              +{{ controls?.collaborators_group?.value?.length - 1 }}\n            </button>\n          </div>\n        </div>\n\n        <!-- <div class=\"chip-container\">\n                      <div class=\"chip-inner\">\n                          <span class=\"chip\" [appTooltip]=\"controls?.program_owners?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n                            <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\" >{{controls?.program_owners?.value[0]?.member_name}}</span></span>\n                          <button *ngIf=\"controls?.program_owners?.value?.length > 1\" class=\"count user\" appPopover (click)=\"owner.popover()\" placement=\"right\">+{{controls?.program_owners?.value?.length -1}}</button>\n                      </div>\n                      <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_owners_group?.value?.length && controls?.program_owners?.value?.length\">&</span>\n                      <div class=\"chip-inner\" *ngIf=\"controls?.program_owners_group?.value?.length\">\n                        <i class=\"icons cross vx-mr-1\" *ngIf=\"!['ADMIN','KEY_ADMIN','LOGGED_IN'].includes(owner?.user_role)\" (click)=\"remove(owner,'OWNER_GROUP')\">&#xe90d;</i>\n                          <span class=\"chip\" [appTooltip]=\"controls?.program_owners_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n                            <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_owners_group?.value[0]?.group_name}}</span></span>\n                          <button *ngIf=\"controls?.program_owners_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"group.popover()\" placement=\"right\">+{{controls?.program_owners_group?.value?.length -1}}</button>\n                      </div>\n                  </div> -->\n        <button\n          *ngIf=\"activeList !== 'COLLABORATORS'\"\n          [class.disabled]=\"controls?.all_user_in_role?.value\"\n          (click)=\"activateList('COLLABORATORS')\"\n          class=\"edit\"\n          type=\"button\"\n        >\n          <i class=\"icons\">&#xe9ba;</i>Edit\n        </button>\n      </div>\n    </input-with-pill>\n    <app-popover #owner [dontCloseonClick]=\"true\">\n      <div class=\"wf-action-list\">\n        <ul class=\"action-item\">\n          <li\n            *ngFor=\"let owner of controls?.collaborators?.value | slice : 1\"\n          >\n            <div class=\"avatar-card\">\n              <span class=\"value\">\n                <i\n\n                  class=\"icons\"\n                  (click)=\"remove(owner, 'COLLABORATORS')\"\n                  >&#xe90d;</i\n                >\n                {{ owner?.member_name }}\n              </span>\n            </div>\n          </li>\n        </ul>\n      </div>\n    </app-popover>\n    <app-popover #group [dontCloseonClick]=\"true\">\n      <div class=\"wf-action-list\">\n        <ul class=\"action-item\">\n          <li\n            *ngFor=\"\n              let owner of controls?.collaborators_group?.value | slice : 1\n            \"\n          >\n            <div class=\"avatar-card\">\n              <span class=\"value\">\n                <i\n                  *ngIf=\"\n                    !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n                      owner?.user_role\n                    )\n                  \"\n                  class=\"icons\"\n                  (click)=\"remove(owner, 'COLLABORATORS_GROUP')\"\n                  >&#xe90d;</i\n                >\n                {{ owner?.group_name }}\n              </span>\n            </div>\n          </li>\n        </ul>\n      </div>\n    </app-popover>\n  </form-field>\n\n    <!-- Performance Calculated -->\n    <!-- <form-field [checked]=\"controls?.performance_calculation?.value\" [active]=\"activeList === 'PERFORMANCE'\" [disabled]=\"sideElements.includes(activeList) && activeList !== 'PERFORMANCE'\"\n            [img]=\"'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/performance-calc.svg'\">\n            <label class=\"vx-control-panel\">HOW SHOULD THE PERFORMANCE OF THIS PROGRAM BE CALCULATED?</label>\n            <tab-selector formControlName=\"performance_calculation\" [displayArray]=\"constants?.performanceCalculation\">\n            </tab-selector>\n        </form-field> -->\n    <ng-container *ngIf=\"isProgramScope && false\">\n      <div\n        class=\"scope-label vx-fs-10 vx-txt-white vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mb-5 vx-lh-4 vx-d-inline-block\"\n      >\n        PROGRAM SCOPE\n      </div>\n      <!-- <i  class=\"icons info-icon vx-fs-12 vx-txt-blue vx-ml-1\" [appTooltip]=\"tooltip.programScope\" placement=\"bottom\" delay=\"0\" type=\"white\" [tooltipMandatory]=\"true\">&#xe91f;</i> -->\n      <span\n        class=\"icon info-icon vx-fs-12 vx-txt-blue vx-ml-1\"\n        *ngIf=\"toolTipData.programScop !== ''\"\n        libPopoverHover\n        (mouseover)=\"dataTooltip.popover()\"\n        (mouseleave)=\"dataTooltip.closePopover()\"\n        placement=\"right\"\n        ><i class=\"icons\">&#xe91f;</i></span\n      >\n      <popover-hover #dataTooltip>\n        <div class=\"vx-info-card\">\n          <div\n            class=\"vx-info-card-body\"\n            [innerHTML]=\"toolTipData.programScope\"\n            id=\"PSHelpText\"\n          ></div>\n        </div>\n      </popover-hover>\n    </ng-container>\n\n    <!-- Program Frequency -->\n    <form-field\n      *ngIf=\"additionalOption?.PROGRAM_FREQUENCY\"\n      [checked]=\"[true, false].includes(controls?.recurring_frequency?.value)\"\n      [active]=\"activeList === 'FREQUENCY'\"\n      [disabled]=\"\n        sideElements.includes(activeList) && activeList !== 'FREQUENCY'\n      \"\n      [img]=\"ASSETS.recurring\"\n    >\n      <label class=\"vx-control-panel\" id=\"PDChange\"\n        >PROGRAM DURATION\n        <i\n          class=\"icons\"\n          [appTooltip]=\"\n            'Program Duration refers to the duration of the Program. A Program can occur in perpetuity, or it can occur until the end of the current business cycle that has been specified in ' +\n            businessCycle.selectedCycle.business_cycle +\n            '.  All responsibilities linked with that Program will also have the same Program Duration.'\n          \"\n          placement=\"bottom\"\n          delay=\"0\"\n          type=\"white\"\n          [tooltipMandatory]=\"true\"\n          id=\"ProgramDurationHelpText\"\n          >&#xeb16;</i\n        ></label\n      >\n      <div class=\"upload-format\">\n        <div class=\"vx-d-flex vx-align-center vx-justify-between\">\n          <span class=\"text vx-mb-0\">Is this program recurring?</span>\n          <div class=\"radio-group program\">\n            <app-cs-radio\n              [name]=\"'recurring_frequency'\"\n              [checked]=\"controls?.recurring_frequency?.value\"\n              (checkedEvent)=\"setFormField('recurring_frequency', true)\"\n              >YES</app-cs-radio\n            >\n            <app-cs-radio\n              [name]=\"'recurring_frequency'\"\n              [checked]=\"!controls?.recurring_frequency?.value\"\n              (checkedEvent)=\"setFormField('recurring_frequency', false)\"\n              >NO</app-cs-radio\n            >\n          </div>\n        </div>\n      </div>\n    </form-field>\n\n    <!-- Scope Changes -->\n    <form-field\n      *ngIf=\"additionalOption?.SCOPE_CHANGES\"\n      [checked]=\"[true, false].includes(controls?.lock_scope_change?.value)\"\n      [active]=\"activeList === 'SCOPE'\"\n      [disabled]=\"sideElements.includes(activeList) && activeList !== 'SCOPE'\"\n      [img]=\"ASSETS.lock_scope\"\n    >\n      <label class=\"vx-control-panel\"\n        >Lock the Program Scope\n        <i\n          class=\"icons\"\n          [appTooltip]=\"\n            'If the Program Scope is locked, neither the Program nor the responsibilities linked with the Program can be edited once the Program begins. In order to edit the Program or the linked responsibilities, the Program details will need to be edited.'\n          \"\n          placement=\"bottom\"\n          delay=\"0\"\n          type=\"white\"\n          [tooltipMandatory]=\"true\"\n          id=\"ScopeChangesHelpText\"\n          >&#xeb16;</i\n        ></label\n      >\n      <div class=\"upload-format\">\n        <span class=\"text\"\n          >Would you like to\n          <span class=\"vx-label-txt vx-fw-500\">lock changes</span> to the\n          program scope?</span\n        >\n        <div class=\"radio-group program\">\n          <app-cs-radio\n            [name]=\"'lock_scope_change'\"\n            [checked]=\"controls?.lock_scope_change?.value\"\n            (checkedEvent)=\"setFormField('lock_scope_change', true)\"\n            >YES</app-cs-radio\n          >\n          <app-cs-radio\n            [name]=\"'lock_scope_change'\"\n            [checked]=\"!controls?.lock_scope_change?.value\"\n            (checkedEvent)=\"setFormField('lock_scope_change', false)\"\n            >NO</app-cs-radio\n          >\n        </div>\n      </div>\n    </form-field>\n\n    <!-- Framework -->\n    <!-- <form-field [checked]=\"false\" [active]=\"activeList === 'FRAMEWORK'\" [disabled]=\"sideElements.includes(activeList) && activeList !== 'FRAMEWORK'\"\n            [img]=\"'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/category.svg'\">\n            <label class=\"vx-control-panel\">FRAMEWORK</label>\n            <input-with-pill [placeholder]=\"'Select a framework that this Program relates to'\" (select)=\"activateList('FRAMEWORK')\">\n                <div class=\"selected\" *ngIf=\"controls?.framework?.value?.framework_name\">\n                    <div class=\"chip-container\">\n                        <div class=\"chip-inner\">\n                            <span class=\"chip\"><i (click)=\"remove(controls?.framework.value,'FRAMEWORK')\" class=\"icons\">&#xe90d;</i>{{controls?.framework?.value?.framework_name}}</span>\n                            <button class=\"count\" appPopover (click)=\"framework.popover()\" placement=\"right\">+5</button>\n                        </div>\n                    </div>\n                    <button *ngIf=\"activeList!=='FRAMEWORK'\" (click)=\"activateList('FRAMEWORK')\" class=\"edit\" type=\"button\"><i class=\"icons\">&#xe9ba;</i> Edit</button>\n                </div>\n            </input-with-pill>\n            <app-popover #framework [dontCloseonClick]=\"true\">\n                <div class=\"wf-action-list\">\n                    <ul class=\"action-item\">\n                        <li *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\n                            <div class=\"avatar-card\">\n                                <span class=\"value\">\n                                    <i class=\"icons\">&#xe90d;</i>\n                                    Manage framework name\n                                </span>\n                            </div>\n                        </li>\n                    </ul>\n                </div>\n            </app-popover>\n        </form-field> -->\n\n    <!-- Responsibility Center -->\n    <form-field\n      *ngIf=\"additionalOption?.RC\"\n      [checked]=\"controls?.rc?.value?.length\"\n      [active]=\"activeList === 'RC'\"\n      [disabled]=\"sideElements.includes(activeList) && activeList !== 'RC'\"\n      [img]=\"ASSETS.responsibility_center\"\n    >\n      <label class=\"vx-control-panel\"\n        >RESPONSIBILITY CENTER\n        <i\n          class=\"icons\"\n          [appTooltip]=\"\n            'Responsibility Centers represent your organizational and operational infrastructure. Where Responsibility Centers are selected when creating a Program, only those Responsibilities Centers will be available for selection when creating a responsibility linked with the Program.'\n          \"\n          placement=\"bottom\"\n          delay=\"0\"\n          type=\"white\"\n          [tooltipMandatory]=\"true\"\n          id=\"RCHelpText\"\n          >&#xeb16;</i\n        ></label\n      >\n      <input-with-pill\n        [selectDiv]=\"true\"\n        (select)=\"activateList('RC')\"\n        [placeholder]=\"\n          'Which Responsibility Center(s) can be linked to the responsibilities associated with this Program?'\n        \"\n      >\n        <div\n          class=\"selected\"\n          *ngIf=\"controls?.rc?.value && controls?.rc?.value?.length\"\n        >\n          <div class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\">\n            <i\n              class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n              (click)=\"remove(controls?.rc?.value[0], 'RC')\"\n              >&#xe9ae;</i\n            >\n            <span\n              class=\"chipName vx-fs-11 vx-label-txt\"\n              [appTooltip]=\"controls?.rc?.value[0]?.item_name\"\n              placement=\"bottom-left\"\n              delay=\"0\"\n              type=\"black\"\n              [tooltipMandatory]=\"false\"\n              >{{ controls?.rc?.value[0]?.item_name }}</span\n            >\n            <button\n              class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n              appPopover\n              (click)=\"rc.popover()\"\n              placement=\"right\"\n              *ngIf=\"controls?.rc?.value?.length > 1\"\n            >\n              +{{ controls?.rc?.value?.length - 1 }}\n            </button>\n          </div>\n\n          <!-- <div class=\"chip-container\">\n                        <div class=\"chip-inner\">\n                            <span class=\"chip\"><i class=\"icons\" (click)=\"remove(controls?.rc?.value[0],'RC')\">&#xe90d;</i>{{controls?.rc?.value[0]?.item_name}}</span>\n                            <button *ngIf=\"controls?.rc?.value?.length  > 1\" class=\"count\" appPopover (click)=\"rc.popover()\" placement=\"right\">+{{controls?.rc?.value?.length -1 }}</button>\n                        </div>\n                    </div> -->\n          <button\n            *ngIf=\"activeList !== 'RC'\"\n            class=\"edit\"\n            type=\"button\"\n            (click)=\"activateList('RC')\"\n          >\n            <i class=\"icons\">&#xe9ba;</i> Edit\n          </button>\n        </div>\n      </input-with-pill>\n      <app-popover #rc [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li *ngFor=\"let rc of controls?.rc?.value | slice : 1\">\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i class=\"icons\" (click)=\"remove(rc, 'RC')\">&#xe90d;</i>\n                  {{ rc?.item_name }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n    </form-field>\n\n    <!-- Assignee -->\n    <form-field\n      *ngIf=\"additionalOption?.ASSIGNEES\"\n      [checked]=\"\n        controls?.program_assignee?.value?.length ||\n        controls?.program_default_assignee?.value?.length ||\n        controls?.program_default_assignee?.value?.length ||\n        controls?.program_default_assignee_group?.value?.length\n      \"\n      [active]=\"['ASSIGNEE', 'DEFAULT_ASSIGNEE']?.includes(activeList)\"\n      [disabled]=\"\n        sideElements?.includes(activeList) &&\n        !['ASSIGNEE', 'DEFAULT_ASSIGNEE'].includes(activeList)\n      \"\n      [img]=\"ASSETS.case_assignees\"\n    >\n      <label\n        class=\"vx-control-panel\"\n        [class.disabled]=\"activeList === 'DEFAULT_ASSIGNEE'\"\n        >ASSIGNEES\n        <i\n          class=\"icons\"\n          [appTooltip]=\"\n            'Assignees are required to complete the responsibilities that have been assigned to them. Where Assignees are selected when creating a Program, only those Assignees will be available for selection when creating a responsibility linked with the Program.'\n          \"\n          placement=\"bottom\"\n          delay=\"0\"\n          type=\"white\"\n          [tooltipMandatory]=\"true\"\n          id=\"AssigneeHelpText\"\n          >&#xeb16;</i\n        >\n      </label>\n      <input-with-pill\n        [selectDiv]=\"true\"\n        [disabled]=\"activeList === 'DEFAULT_ASSIGNEE'\"\n        [placeholder]=\"\n          'Who is responsible for completing the responsibilities within this Program?'\n        \"\n        (select)=\"activateList('ASSIGNEE')\"\n      >\n        <div\n          class=\"selected\"\n          *ngIf=\"\n            controls?.program_assignee?.value?.length ||\n            controls?.program_assignee_group?.value?.length\n          \"\n        >\n          <div class=\"vx-d-flex vx-align-center\">\n            <div\n              class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n              *ngIf=\"controls?.program_assignee?.value?.length\"\n            >\n              <i\n                class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                (click)=\"\n                  remove(controls?.program_assignee?.value[0], 'ASSIGNEE')\n                \"\n                >&#xe9ae;</i\n              >\n              <span\n                class=\"chipName vx-fs-11 vx-label-txt\"\n                [appTooltip]=\"controls?.program_assignee?.value[0]?.member_name\"\n                placement=\"bottom-left\"\n                delay=\"0\"\n                type=\"black\"\n                [tooltipMandatory]=\"false\"\n                >{{ controls?.program_assignee?.value[0]?.member_name }}</span\n              >\n              <button\n                class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                appPopover\n                (click)=\"assignee.popover()\"\n                placement=\"right\"\n                *ngIf=\"controls?.program_assignee?.value?.length > 1\"\n              >\n                +{{ controls?.program_assignee?.value?.length - 1 }}\n              </button>\n            </div>\n            <span\n              class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n              *ngIf=\"\n                controls?.program_assignee_group?.value?.length &&\n                controls?.program_assignee?.value?.length\n              \"\n              >&</span\n            >\n            <div\n              class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n              *ngIf=\"controls?.program_assignee_group?.value?.length\"\n            >\n              <i\n                class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                (click)=\"\n                  remove(\n                    controls?.program_assignee_group?.value[0],\n                    'ASSIGNEE_GROUP'\n                  )\n                \"\n                >&#xe9ae;</i\n              >\n              <span\n                class=\"chipName vx-fs-11 vx-label-txt\"\n                [appTooltip]=\"\n                  controls?.program_assignee_group?.value[0]?.group_name\n                \"\n                placement=\"bottom-left\"\n                delay=\"0\"\n                type=\"black\"\n                [tooltipMandatory]=\"false\"\n                >{{\n                  controls?.program_assignee_group?.value[0]?.group_name\n                }}</span\n              >\n              <button\n                class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                appPopover\n                (click)=\"assignee_group.popover()\"\n                placement=\"right\"\n                *ngIf=\"controls?.program_assignee_group?.value?.length > 1\"\n              >\n                +{{ controls?.program_assignee_group?.value?.length - 1 }}\n              </button>\n            </div>\n          </div>\n\n          <!-- <div class=\"chip-container\">\n                        <div class=\"chip-inner\" *ngIf=\"controls?.program_assignee?.value?.length\">\n                          <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_assignee?.value[0],'ASSIGNEE')\" >&#xe90d;</i>\n                            <span class=\"chip\" [appTooltip]=\"controls?.program_assignee?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n                              <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_assignee?.value[0]?.member_name}}</span>\n                            </span>\n                            <button *ngIf=\"controls?.program_assignee?.value?.length > 1\" class=\"count user\" appPopover (click)=\"assignee.popover()\" placement=\"right\">+{{controls?.program_assignee?.value?.length -1}}</button>\n                        </div>\n                        <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_assignee_group?.value?.length && controls?.program_assignee?.value?.length\">&</span>\n                        <div class=\"chip-inner\" *ngIf=\"controls?.program_assignee_group?.value?.length\">\n                          <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_assignee_group?.value[0],'ASSIGNEE_GROUP')\" >&#xe90d;</i>\n                            <span class=\"chip\" [appTooltip]=\"controls?.program_assignee_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n                              <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_assignee_group?.value[0]?.group_name}}</span>\n                            </span>\n                            <button *ngIf=\"controls?.program_assignee_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"assignee_group.popover()\" placement=\"right\">+{{controls?.program_assignee_group?.value?.length -1 }}</button>\n                        </div>\n                    </div> -->\n          <button\n            *ngIf=\"activeList !== 'ASSIGNEE'\"\n            class=\"edit\"\n            type=\"button\"\n            (click)=\"activateList('ASSIGNEE')\"\n          >\n            <i class=\"icons\">&#xe9ba;</i> Edit\n          </button>\n        </div>\n      </input-with-pill>\n      <app-popover #assignee [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li\n              *ngFor=\"\n                let assignee of controls?.program_assignee?.value | slice : 1\n              \"\n            >\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i (click)=\"remove(assignee, 'ASSIGNEE')\" class=\"icons\"\n                    >&#xe90d;</i\n                  >\n                  {{ assignee?.member_name }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n      <app-popover #assignee_group [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li\n              *ngFor=\"\n                let group of controls?.program_assignee_group?.value | slice : 1\n              \"\n            >\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i (click)=\"remove(group, 'ASSIGNEE_GROUP')\" class=\"icons\"\n                    >&#xe90d;</i\n                  >\n                  {{ group?.group_name }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n      <label\n        class=\"vx-control-panel\"\n        [class.disabled]=\"activeList === 'ASSIGNEE'\"\n        >DEFAULT ASSIGNEE\n        <i\n          class=\"icons\"\n          [appTooltip]=\"\n            'This option lets you specify the Default Assignees for all new responsibilities linked with a Program. If a Default Assignees is selected, the user will automatically be selected the Assignee when creating a responsibility linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility. '\n          \"\n          placement=\"bottom\"\n          delay=\"0\"\n          type=\"white\"\n          [tooltipMandatory]=\"true\"\n          id=\"DAHelpText\"\n          >&#xeb16;</i\n        ></label\n      >\n      <input-with-pill\n        [selectDiv]=\"true\"\n        [disabled]=\"activeList === 'ASSIGNEE'\"\n        [placeholder]=\"\n          'Which persons will be selected as the default assignees for the responsibilities within this Program?'\n        \"\n        (select)=\"activateList('DEFAULT_ASSIGNEE')\"\n      >\n        <div\n          class=\"selected\"\n          *ngIf=\"\n            controls?.program_default_assignee?.value?.length ||\n            controls?.program_default_assignee_group?.value?.length\n          \"\n        >\n          <div class=\"vx-d-flex vx-align-center\">\n            <div\n              class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n              *ngIf=\"controls?.program_default_assignee?.value?.length\"\n            >\n              <i\n                class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                (click)=\"\n                  remove(\n                    controls?.program_default_assignee?.value[0],\n                    'DEFAULT_ASSIGNEE'\n                  )\n                \"\n                >&#xe9ae;</i\n              >\n              <span\n                class=\"chipName vx-fs-11 vx-label-txt\"\n                [appTooltip]=\"\n                  controls?.program_default_assignee?.value[0]?.member_name\n                \"\n                placement=\"bottom-left\"\n                delay=\"0\"\n                type=\"black\"\n                [tooltipMandatory]=\"false\"\n                >{{\n                  controls?.program_default_assignee?.value[0]?.member_name\n                }}</span\n              >\n              <button\n                class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                appPopover\n                (click)=\"defaultAssignee.popover()\"\n                placement=\"right\"\n                *ngIf=\"controls?.program_default_assignee?.value?.length > 1\"\n              >\n                +{{ controls?.program_default_assignee?.value?.length - 1 }}\n              </button>\n            </div>\n            <span\n              class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n              *ngIf=\"\n                controls?.program_default_assignee_group?.value?.length &&\n                controls?.program_default_assignee?.value?.length\n              \"\n              >&</span\n            >\n            <div\n              class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n              *ngIf=\"controls?.program_default_assignee_group?.value?.length\"\n            >\n              <i\n                class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                (click)=\"\n                  remove(\n                    controls?.program_default_assignee_group?.value[0],\n                    'DEFAULT_ASSIGNEE_GROUP'\n                  )\n                \"\n                >&#xe9ae;</i\n              >\n              <span\n                class=\"chipName vx-fs-11 vx-label-txt\"\n                [appTooltip]=\"\n                  controls?.program_default_assignee_group?.value[0]?.group_name\n                \"\n                placement=\"bottom-left\"\n                delay=\"0\"\n                type=\"black\"\n                [tooltipMandatory]=\"false\"\n                >{{\n                  controls?.program_default_assignee_group?.value[0]?.group_name\n                }}</span\n              >\n              <button\n                class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                appPopover\n                (click)=\"defaultAssigneeGroup.popover()\"\n                placement=\"right\"\n                *ngIf=\"\n                  controls?.program_default_assignee_group?.value?.length > 1\n                \"\n              >\n                +{{\n                  controls?.program_default_assignee_group?.value?.length - 1\n                }}\n              </button>\n            </div>\n          </div>\n\n          <!-- <div class=\"chip-container\">\n                        <div class=\"chip-inner\" *ngIf=\"controls?.program_default_assignee?.value?.length\">\n                          <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_assignee?.value[0],'DEFAULT_ASSIGNEE')\" >&#xe90d;</i>\n                            <span class=\"chip\" [appTooltip]=\"controls?.program_default_assignee?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n                              <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{ controls?.program_default_assignee?.value[0]?.member_name}}</span>\n                            </span>\n                            <button *ngIf=\"controls?.program_default_assignee?.value?.length > 1\" class=\"count user\" appPopover (click)=\"defaultAssignee.popover()\" placement=\"right\">+{{controls?.program_default_assignee?.value?.length - 1}}</button>\n                        </div>\n                        <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_default_assignee_group?.value?.length && controls?.program_default_assignee?.value?.length\">&</span>\n                        <div class=\"chip-inner\" *ngIf=\"controls?.program_default_assignee_group?.value?.length\">\n                          <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_assignee_group?.value[0],'DEFAULT_ASSIGNEE_GROUP')\" >&#xe90d;</i>\n                            <span class=\"chip\">\n                              <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_assignee_group?.value[0]?.group_name }}</span>\n                            </span>\n                            <button *ngIf=\"controls?.program_default_assignee_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"defaultAssigneeGroup.popover()\" placement=\"right\">+{{controls?.program_default_assignee_group?.value?.length -1 }}</button>\n                        </div>\n                    </div> -->\n          <button\n            *ngIf=\"activeList !== 'DEFAULT_ASSIGNEE'\"\n            (click)=\"activateList('DEFAULT_ASSIGNEE')\"\n            class=\"edit\"\n            type=\"button\"\n          >\n            <i class=\"icons\">&#xe9ba;</i> Edit\n          </button>\n        </div>\n      </input-with-pill>\n      <app-popover #defaultAssignee [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li\n              *ngFor=\"\n                let assignee of controls?.program_default_assignee?.value\n                  | slice : 1\n              \"\n            >\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i\n                    (click)=\"remove(assignee, 'DEFAULT_ASSIGNEE')\"\n                    class=\"icons\"\n                    >&#xe90d;</i\n                  >\n                  {{ assignee?.member_name }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n      <app-popover #defaultAssigneeGroup [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li\n              *ngFor=\"\n                let group of controls?.program_default_assignee_group?.value\n                  | slice : 1\n              \"\n            >\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i\n                    (click)=\"remove(assignee, 'DEFAULT_ASSIGNEE_GROUP')\"\n                    class=\"icons\"\n                    >&#xe90d;</i\n                  >\n                  {{ group?.group_name }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n      <div\n        class=\"radio-group-selector\"\n        [class.disabled]=\"activeList === 'ASSIGNEE'\"\n      >\n        <app-cs-radio\n          [name]=\"'assignee'\"\n          [checked]=\"controls?.assignee_completion_criteria?.value === 'ALL'\"\n          (checkedEvent)=\"setFormField('assignee_completion_criteria', 'ALL')\"\n        >\n          ALL SELECTED PERSONS NEED TO COMPLETE THIS\n          <i\n            class=\"icons\"\n            [appTooltip]=\"\n              'If selected, separate responsibilities will be created for each person.'\n            \"\n            placement=\"bottom-right\"\n            delay=\"0\"\n            type=\"white\"\n            [tooltipMandatory]=\"true\"\n            >&#xe91f;</i\n          >\n        </app-cs-radio>\n        <app-cs-radio\n          [name]=\"'assignee'\"\n          [checked]=\"controls?.assignee_completion_criteria?.value === 'ANYONE'\"\n          (checkedEvent)=\"\n            setFormField('assignee_completion_criteria', 'ANYONE')\n          \"\n        >\n          ANY SELECTED PERSON CAN COMPLETE THIS\n          <i\n            class=\"icons\"\n            [appTooltip]=\"\n              'If selected, only one responsibility will be created.'\n            \"\n            placement=\"bottom-right\"\n            delay=\"0\"\n            type=\"white\"\n            [tooltipMandatory]=\"true\"\n            >&#xe91f;</i\n          >\n        </app-cs-radio>\n      </div>\n    </form-field>\n\n    <!-- Reviewer -->\n    <form-field\n      [appScrollInView]=\"scrollToBottom\"\n      *ngIf=\"additionalOption?.REVIEWER\"\n      [checked]=\"\n        controls?.program_reviewer?.value?.length ||\n        controls?.program_default_reviewer?.value?.length ||\n        controls?.program_default_reviewer?.value?.length ||\n        controls?.program_default_reviewer_group?.value?.length\n      \"\n      [active]=\"['REVIEWER', 'DEFAULT_REVIEWER']?.includes(activeList)\"\n      [disabled]=\"\n        sideElements?.includes(activeList) &&\n        !['REVIEWER', 'DEFAULT_REVIEWER'].includes(activeList)\n      \"\n      [img]=\"ASSETS.reviewer\"\n    >\n      <label\n        [class.disabled]=\"activeList === 'DEFAULT_REVIEWER'\"\n        class=\"vx-control-panel\"\n        >Reviewers\n        <i\n          class=\"icons\"\n          [appTooltip]=\"\n            'Reviewers are required to review responsibilities after they have been completed. Where Reviewers are selected when creating a Program, only those Reviewers will be available for selection when creating a responsibility linked with the Program.'\n          \"\n          placement=\"bottom\"\n          delay=\"0\"\n          type=\"white\"\n          [tooltipMandatory]=\"true\"\n          id=\"ReviewerHelpText\"\n          >&#xeb16;</i\n        ></label\n      >\n      <input-with-pill\n        [selectDiv]=\"true\"\n        [disabled]=\"activeList === 'DEFAULT_REVIEWER'\"\n        [placeholder]=\"\n          'Who is responsible for reviewing the responsibilities within this Program?'\n        \"\n        (select)=\"activateList('REVIEWER')\"\n      >\n        <div\n          class=\"selected\"\n          *ngIf=\"\n            controls?.program_reviewer?.value?.length ||\n            controls?.program_reviewer_group?.value?.length\n          \"\n        >\n          <div class=\"vx-d-flex vx-align-center\">\n            <div\n              class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n              *ngIf=\"controls?.program_reviewer?.value?.length\"\n            >\n              <i\n                class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                (click)=\"\n                  remove(controls?.program_reviewer?.value[0], 'REVIEWER')\n                \"\n                >&#xe9ae;</i\n              >\n              <span\n                class=\"chipName vx-fs-11 vx-label-txt\"\n                [appTooltip]=\"controls?.program_reviewer?.value[0]?.member_name\"\n                placement=\"bottom-left\"\n                delay=\"0\"\n                type=\"black\"\n                [tooltipMandatory]=\"false\"\n                >{{ controls?.program_reviewer?.value[0]?.member_name }}</span\n              >\n              <button\n                class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                appPopover\n                (click)=\"reviewer.popover()\"\n                placement=\"right\"\n                *ngIf=\"controls?.program_reviewer?.value?.length > 1\"\n              >\n                +{{ controls?.program_reviewer?.value?.length - 1 }}\n              </button>\n            </div>\n            <span\n              class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n              *ngIf=\"\n                controls?.program_reviewer_group?.value?.length &&\n                controls?.program_reviewer?.value?.length\n              \"\n              >&</span\n            >\n            <div\n              class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n              *ngIf=\"controls?.program_reviewer_group?.value?.length\"\n            >\n              <i\n                class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                (click)=\"\n                  remove(\n                    controls?.program_reviewer_group?.value[0],\n                    'REVIEWER_GROUP'\n                  )\n                \"\n                >&#xe9ae;</i\n              >\n              <span\n                class=\"chipName vx-fs-11 vx-label-txt\"\n                [appTooltip]=\"\n                  controls?.program_reviewer_group?.value[0]?.group_name\n                \"\n                placement=\"bottom-left\"\n                delay=\"0\"\n                type=\"black\"\n                [tooltipMandatory]=\"false\"\n                >{{\n                  controls?.program_reviewer_group?.value[0]?.group_name\n                }}</span\n              >\n              <button\n                class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                appPopover\n                (click)=\"reviewerGroup.popover()\"\n                placement=\"right\"\n                *ngIf=\"controls?.program_reviewer_group?.value?.length > 1\"\n              >\n                +{{ controls?.program_reviewer_group?.value?.length - 1 }}\n              </button>\n            </div>\n          </div>\n\n          <!-- <div class=\"chip-container\">\n                        <div class=\"chip-inner\" *ngIf=\"controls?.program_reviewer?.value?.length\">\n                          <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_reviewer?.value[0],'REVIEWER')\" >&#xe90d;</i>\n                            <span class=\"chip\" [appTooltip]=\"controls?.program_reviewer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n                              <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_reviewer?.value[0]?.member_name}}</span>\n                            </span>\n                            <button *ngIf=\"controls?.program_reviewer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"reviewer.popover()\" placement=\"right\">+{{controls?.program_reviewer?.value?.length -1}}</button>\n                        </div>\n                        <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_reviewer_group?.value?.length && controls?.program_reviewer?.value?.length\">&</span>\n                        <div class=\"chip-inner\" *ngIf=\"controls?.program_reviewer_group?.value?.length\">\n                          <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_reviewer_group?.value[0],'REVIEWER_GROUP')\" >&#xe90d;</i>\n                            <span class=\"chip\" [appTooltip]=\"controls?.program_reviewer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n                              <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_reviewer_group?.value[0]?.group_name}}\n                              </span>\n                            </span>\n                            <button *ngIf=\"controls?.program_reviewer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"reviewerGroup.popover()\" placement=\"right\">+{{controls?.program_reviewer_group?.value?.length - 1}}</button>\n                        </div>\n                    </div> -->\n          <button\n            *ngIf=\"activeList !== 'REVIEWER'\"\n            (click)=\"activateList('REVIEWER')\"\n            class=\"edit\"\n            type=\"button\"\n          >\n            <i class=\"icons\">&#xe9ba;</i> Edit\n          </button>\n        </div>\n      </input-with-pill>\n      <app-popover #reviewer [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li\n              *ngFor=\"\n                let reviewer of controls?.program_reviewer?.value | slice : 1\n              \"\n            >\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i (click)=\"remove(reviewer, 'REVIEWER')\" class=\"icons\"\n                    >&#xe90d;</i\n                  >\n                  {{ reviewer?.member_name }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n      <app-popover #reviewerGroup [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li\n              *ngFor=\"\n                let group of controls?.program_reviewer_group?.value | slice : 1\n              \"\n            >\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i (click)=\"remove(group, 'REVIEWER_GROUP')\" class=\"icons\"\n                    >&#xe90d;</i\n                  >\n                  {{ group?.group_name }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n      <label\n        [class.disabled]=\"activeList === 'REVIEWER'\"\n        class=\"vx-control-panel\"\n        >DEFAULT Reviewer\n        <i\n          class=\"icons\"\n          [appTooltip]=\"\n            'This option lets you specify the Default Reviewers for responsibilities linked with a Program. Where a user has been specified as a Default Reviewer, that user will automatically be selected as the Reviewer when creating a responsibility linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility.'\n          \"\n          placement=\"bottom\"\n          delay=\"0\"\n          type=\"white\"\n          [tooltipMandatory]=\"true\"\n          id=\"DRHelpText\"\n          >&#xeb16;</i\n        ></label\n      >\n      <input-with-pill\n        [selectDiv]=\"true\"\n        [disabled]=\"activeList === 'REVIEWER'\"\n        [placeholder]=\"\n          'Which persons will be selected as the default reviewers for the responsibilities within this Program?'\n        \"\n        (select)=\"activateList('DEFAULT_REVIEWER')\"\n      >\n        <div\n          class=\"selected\"\n          *ngIf=\"\n            controls?.program_default_reviewer?.value?.length ||\n            controls?.program_default_reviewer_group?.value?.length\n          \"\n        >\n          <div class=\"vx-d-flex vx-align-center\">\n            <div\n              class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n              *ngIf=\"controls?.program_default_reviewer?.value?.length\"\n            >\n              <i\n                class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                (click)=\"\n                  remove(\n                    controls?.program_default_reviewer?.value[0],\n                    'DEFAULT_REVIEWER'\n                  )\n                \"\n                >&#xe9ae;</i\n              >\n              <span\n                class=\"chipName vx-fs-11 vx-label-txt\"\n                [appTooltip]=\"\n                  controls?.program_default_reviewer?.value[0]?.member_name\n                \"\n                placement=\"bottom-left\"\n                delay=\"0\"\n                type=\"black\"\n                [tooltipMandatory]=\"false\"\n                >{{\n                  controls?.program_default_reviewer?.value[0]?.member_name\n                }}</span\n              >\n              <button\n                class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                appPopover\n                (click)=\"defaultReviewer.popover()\"\n                placement=\"right\"\n                *ngIf=\"controls?.program_default_reviewer?.value?.length > 1\"\n              >\n                +{{ controls?.program_default_reviewer?.value?.length - 1 }}\n              </button>\n            </div>\n            <span\n              class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n              *ngIf=\"\n                controls?.program_default_reviewer_group?.value?.length &&\n                controls?.program_default_reviewer?.value?.length\n              \"\n              >&</span\n            >\n            <div\n              class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n              *ngIf=\"controls?.program_default_reviewer_group?.value?.length\"\n            >\n              <i\n                class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                (click)=\"\n                  remove(\n                    controls?.program_default_reviewer_group?.value[0],\n                    'DEFAULT_REVIEWER_GROUP'\n                  )\n                \"\n                >&#xe9ae;</i\n              >\n              <span\n                class=\"chipName vx-fs-11 vx-label-txt\"\n                [appTooltip]=\"\n                  controls?.program_default_reviewer_group?.value[0]?.group_name\n                \"\n                placement=\"bottom-left\"\n                delay=\"0\"\n                type=\"black\"\n                [tooltipMandatory]=\"false\"\n                >{{\n                  controls?.program_default_reviewer_group?.value[0]?.group_name\n                }}</span\n              >\n              <button\n                class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                appPopover\n                (click)=\"defaultReviewerGroup.popover()\"\n                placement=\"right\"\n                *ngIf=\"\n                  controls?.program_default_reviewer_group?.value?.length > 1\n                \"\n              >\n                +{{\n                  controls?.program_default_reviewer_group?.value?.length - 1\n                }}\n              </button>\n            </div>\n          </div>\n\n          <!-- <div class=\"chip-container\">\n                        <div class=\"chip-inner\" *ngIf=\"controls?.program_default_reviewer?.value?.length\">\n                          <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_reviewer?.value[0],'DEFAULT_REVIEWER')\" >&#xe90d;</i>\n                            <span class=\"chip\" [appTooltip]=\"controls?.program_default_reviewer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n                              <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_reviewer?.value[0]?.member_name}}</span>\n                            </span>\n                            <button *ngIf=\"controls?.program_default_reviewer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"defaultReviewer.popover()\" placement=\"right\">+{{controls?.program_default_reviewer?.value?.length - 1}}</button>\n                        </div>\n                        <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_default_reviewer_group?.value?.length && controls?.program_default_reviewer?.value?.length\">&</span>\n                        <div class=\"chip-inner\" *ngIf=\"controls?.program_default_reviewer_group?.value?.length\">\n                          <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_reviewer_group?.value[0],'DEFAULT_REVIEWER_GROUP')\" >&#xe90d;</i>\n                            <span class=\"chip\" [appTooltip]=\"controls?.program_default_reviewer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n                              <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_reviewer_group?.value[0]?.group_name}}\n                              </span>\n                            </span>\n                            <button *ngIf=\"controls?.program_default_reviewer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"defaultReviewerGroup.popover()\" placement=\"right\">+{{controls?.program_default_reviewer_group?.value?.length -1}}</button>\n                        </div>\n                    </div> -->\n          <button\n            *ngIf=\"activeList !== 'DEFAULT_REVIEWER'\"\n            (click)=\"activateList('DEFAULT_REVIEWER')\"\n            class=\"edit\"\n            type=\"button\"\n          >\n            <i class=\"icons\">&#xe9ba;</i> Edit\n          </button>\n        </div>\n      </input-with-pill>\n      <app-popover #defaultReviewer [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li\n              *ngFor=\"\n                let reviewer of controls?.program_default_reviewer?.value\n                  | slice : 1\n              \"\n            >\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i\n                    (click)=\"remove(reviewer, 'DEFAULT_REVIEWER')\"\n                    class=\"icons\"\n                    >&#xe90d;</i\n                  >\n                  {{ reviewer?.member_name }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n      <app-popover #defaultReviewerGroup [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li\n              *ngFor=\"\n                let group of controls?.program_default_reviewer_group?.value\n                  | slice : 1\n              \"\n            >\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i\n                    (click)=\"remove(group, 'DEFAULT_REVIEWER_GROUP')\"\n                    class=\"icons\"\n                    >&#xe90d;</i\n                  >\n                  {{ group?.group_name }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n      <div\n        class=\"radio-group-selector\"\n        [class.disabled]=\"activeList === 'REVIEWER'\"\n      >\n        <app-cs-radio\n          [name]=\"'reviewer'\"\n          [checked]=\"\n            controls?.reviewer_completion_criteria?.value === 'SEQUENTIAL'\n          \"\n          (checkedEvent)=\"\n            setFormField('reviewer_completion_criteria', 'SEQUENTIAL')\n          \"\n          [class.disabled]=\"\n            controls?.program_default_reviewer_group?.value?.length > 0\n          \"\n        >\n          SEQUENTIAL\n          <i\n            class=\"icons\"\n            [appTooltip]=\"\n              'The responsibility will be sent for review one at a time in the sequence defined by you.'\n            \"\n            placement=\"bottom-right\"\n            delay=\"0\"\n            type=\"white\"\n            [tooltipMandatory]=\"true\"\n            >&#xe91f;</i\n          >\n        </app-cs-radio>\n        <app-cs-radio\n          [name]=\"'reviewer'\"\n          [checked]=\"\n            controls?.reviewer_completion_criteria?.value === 'ANYONE' ||\n            controls?.program_default_reviewer_group?.value?.length > 0\n          \"\n          (checkedEvent)=\"\n            setFormField('reviewer_completion_criteria', 'ANYONE')\n          \"\n        >\n          ANY REVIEWER CAN MARK THIS AS REVIEWED\n          <i\n            class=\"icons\"\n            [appTooltip]=\"\n              'The responsibility will be sent for review to all reviewers at the same time. If anyone of the reviewer reviews the responsibility, it will be considered as reviewed.'\n            \"\n            placement=\"bottom-right\"\n            delay=\"0\"\n            type=\"white\"\n            [tooltipMandatory]=\"true\"\n            >&#xe91f;</i\n          >\n        </app-cs-radio>\n      </div>\n    </form-field>\n\n    <!-- Overseer -->\n    <form-field\n      [appScrollInView]=\"scrollToBottom\"\n      *ngIf=\"additionalOption?.OVERSEER\"\n      [checked]=\"\n        controls?.program_overseer?.value?.length ||\n        controls?.program_default_overseer?.value?.length ||\n        controls?.program_default_overseer?.value?.length ||\n        controls?.program_default_overseer_group?.value?.length\n      \"\n      [active]=\"activeList === 'OVERSEER'\"\n      [disabled]=\"\n        sideElements?.includes(activeList) &&\n        !['OVERSEER', 'DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(\n          activeList\n        )\n      \"\n      [img]=\"ASSETS.oversight\"\n    >\n      <label\n        class=\"vx-control-panel\"\n        [class.disabled]=\"\n          ['DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n        \"\n        >Oversights\n        <i\n          class=\"icons\"\n          [appTooltip]=\"\n            'Oversights receive updates when a responsibility is completed, completed with delay or not completed. Where Oversights are selected when creating a Program, only those Oversights will be available for selection when creating a responsibility linked with the Program.'\n          \"\n          placement=\"bottom\"\n          delay=\"0\"\n          type=\"white\"\n          [tooltipMandatory]=\"true\"\n          id=\"overseerHelpText\"\n          >&#xeb16;</i\n        ></label\n      >\n      <input-with-pill\n        [selectDiv]=\"true\"\n        [disabled]=\"\n          ['DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n        \"\n        [placeholder]=\"\n          'Who is responsible for overseeing the responsibilities within this Program?'\n        \"\n        (select)=\"activateList('OVERSEER')\"\n      >\n        <div\n          class=\"selected\"\n          *ngIf=\"\n            controls?.program_overseer?.value?.length ||\n            controls?.program_overseer_group?.value?.length\n          \"\n        >\n          <div class=\"vx-d-flex vx-align-center\">\n            <div\n              class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n              *ngIf=\"controls?.program_overseer?.value?.length\"\n            >\n              <i\n                class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                (click)=\"\n                  remove(controls?.program_overseer?.value[0], 'OVERSEER')\n                \"\n                >&#xe9ae;</i\n              >\n              <span\n                class=\"chipName vx-fs-11 vx-label-txt\"\n                [appTooltip]=\"controls?.program_overseer?.value[0]?.member_name\"\n                placement=\"bottom-left\"\n                delay=\"0\"\n                type=\"black\"\n                [tooltipMandatory]=\"false\"\n                >{{ controls?.program_overseer?.value[0]?.member_name }}</span\n              >\n              <button\n                class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                appPopover\n                (click)=\"overseers.popover()\"\n                placement=\"right\"\n                *ngIf=\"controls?.program_overseer?.value?.length > 1\"\n              >\n                +{{ controls?.program_overseer?.value?.length - 1 }}\n              </button>\n            </div>\n            <span\n              *ngIf=\"\n                controls?.program_overseer_group?.value?.length &&\n                controls?.program_overseer?.value?.length\n              \"\n              class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n              >&</span\n            >\n            <div\n              class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n              *ngIf=\"controls?.program_overseer_group?.value?.length\"\n            >\n              <i\n                class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                (click)=\"\n                  remove(\n                    controls?.program_overseer_group?.value[0],\n                    'OVERSEER_GROUP'\n                  )\n                \"\n                >&#xe9ae;</i\n              >\n              <span\n                class=\"chipName vx-fs-11 vx-label-txt\"\n                [appTooltip]=\"\n                  controls?.program_overseer_group?.value[0]?.group_name\n                \"\n                placement=\"bottom-left\"\n                delay=\"0\"\n                type=\"black\"\n                [tooltipMandatory]=\"false\"\n                >{{\n                  controls?.program_overseer_group?.value[0]?.group_name\n                }}</span\n              >\n              <button\n                class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                appPopover\n                (click)=\"overseerGroup.popover()\"\n                placement=\"right\"\n                *ngIf=\"controls?.program_overseer_group?.value?.length > 1\"\n              >\n                +{{ controls?.program_overseer_group?.value?.length - 1 }}\n              </button>\n            </div>\n          </div>\n\n          <!-- <div class=\"chip-container\">\n                        <div class=\"chip-inner\" *ngIf=\"controls?.program_overseer?.value?.length\">\n                          <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_overseer?.value[0],'OVERSEER')\" >&#xe90d;</i>\n                            <span class=\"chip\" [appTooltip]=\"controls?.program_overseer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n                              <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">\n                                {{controls?.program_overseer?.value[0]?.member_name}}\n                              </span>\n                            </span>\n                            <button *ngIf=\"controls?.program_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseers.popover()\" placement=\"right\">+{{controls?.program_overseer?.value?.length -1}}</button>\n                        </div>\n                        <span *ngIf=\"controls?.program_overseer_group?.value?.length && controls?.program_overseer?.value?.length \" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n                        <div class=\"chip-inner\" *ngIf=\"controls?.program_overseer_group?.value?.length \">\n                            <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_overseer_group?.value[0],'OVERSEER_GROUP')\" >&#xe90d;</i>\n                            <span class=\"chip\" [appTooltip]=\"controls?.program_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n                                <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_overseer_group?.value[0]?.group_name}}</span></span>\n                            <button *ngIf=\"controls?.program_overseer_group?.value?.length> 1\" class=\"count\" appPopover (click)=\"overseerGroup.popover()\" placement=\"right\">+{{controls?.program_overseer_group?.value?.length -1}}</button>\n                        </div>\n                    </div> -->\n\n          <button\n            *ngIf=\"activeList !== 'OVERSEER'\"\n            (click)=\"activateList('OVERSEER')\"\n            class=\"edit\"\n            type=\"button\"\n          >\n            <i class=\"icons\">&#xe9ba;</i> Edit\n          </button>\n        </div>\n      </input-with-pill>\n      <app-popover #overseers [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li\n              *ngFor=\"\n                let overseer of controls?.program_overseer?.value | slice : 1\n              \"\n            >\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i class=\"icons\" (click)=\"remove(overseer, 'OVERSEER')\"\n                    >&#xe90d;</i\n                  >\n                  {{ overseer?.member_name }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n      <app-popover #overseerGroup [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li\n              *ngFor=\"\n                let group of controls?.program_overseer_group?.value | slice : 1\n              \"\n            >\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i (click)=\"remove(group, 'OVERSEER_GROUP')\" class=\"icons\"\n                    >&#xe90d;</i\n                  >\n                  {{ group?.group_name }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n      <ng-container [class.disabled]=\"activeList === 'OVERSEER'\">\n        <label\n          class=\"vx-control-panel\"\n          [class.disabled]=\"['OVERSEER'].includes(activeList)\"\n          >DEFAULT Oversight\n          <i\n            class=\"icons\"\n            [appTooltip]=\"\n              'This option lets you specify the Default Oversight for responsibilities linked with a Program. Where a user has been specified as a Default Oversight, that user will automatically be selected as the Oversight when creating a responsibility linked with the Program.'\n            \"\n            placement=\"bottom\"\n            delay=\"0\"\n            type=\"white\"\n            [tooltipMandatory]=\"true\"\n            id=\"DOHelpText\"\n            >&#xeb16;</i\n          ></label\n        >\n        <input-with-pill\n          [disabled]=\"\n            ['OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n          \"\n          [selectDiv]=\"true\"\n          [placeholder]=\"\n            'Which persons will be selected as the default overseers for the responsibilities within this Program?'\n          \"\n          (select)=\"activateList('DEFAULT_OVERSEER')\"\n        >\n          <div\n            class=\"selected\"\n            *ngIf=\"\n              controls?.program_default_overseer?.value?.length ||\n              controls?.program_default_overseer_group?.value?.length\n            \"\n          >\n            <div class=\"vx-d-flex vx-align-center\">\n              <div\n                class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n                *ngIf=\"controls?.program_default_overseer?.value?.length\"\n              >\n                <i\n                  class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                  (click)=\"\n                    remove(\n                      controls?.program_default_overseer?.value[0],\n                      'DEFAULT_OVERSEER'\n                    )\n                  \"\n                  >&#xe9ae;</i\n                >\n                <span\n                  class=\"chipName vx-fs-11 vx-label-txt\"\n                  [appTooltip]=\"\n                    controls?.program_default_overseer?.value[0]?.member_name\n                  \"\n                  placement=\"bottom-left\"\n                  delay=\"0\"\n                  type=\"black\"\n                  [tooltipMandatory]=\"false\"\n                  >{{\n                    controls?.program_default_overseer?.value[0]?.member_name\n                  }}</span\n                >\n                <button\n                  class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                  appPopover\n                  (click)=\"overseersDefault.popover()\"\n                  placement=\"right\"\n                  *ngIf=\"controls?.program_default_overseer?.value?.length > 1\"\n                >\n                  +{{ controls?.program_default_overseer?.value?.length - 1 }}\n                </button>\n              </div>\n              <span\n                *ngIf=\"\n                  controls?.program_default_overseer_group?.value?.length &&\n                  controls?.program_default_overseer?.value?.length\n                \"\n                class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n                >&</span\n              >\n              <div\n                class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n                *ngIf=\"controls?.program_default_overseer_group?.value?.length\"\n              >\n                <i\n                  class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                  (click)=\"\n                    remove(\n                      controls?.program_default_overseer_group?.value[0],\n                      'DEFAULT_OVERSEER_GROUP'\n                    )\n                  \"\n                  >&#xe9ae;</i\n                >\n                <span\n                  class=\"chipName vx-fs-11 vx-label-txt\"\n                  [appTooltip]=\"\n                    controls?.program_default_overseer_group?.value[0]\n                      ?.group_name\n                  \"\n                  placement=\"bottom-left\"\n                  delay=\"0\"\n                  type=\"black\"\n                  [tooltipMandatory]=\"false\"\n                  >{{\n                    controls?.program_default_overseer_group?.value[0]\n                      ?.group_name\n                  }}</span\n                >\n                <button\n                  class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                  appPopover\n                  (click)=\"overseerDefaultGroup.popover()\"\n                  placement=\"right\"\n                  *ngIf=\"\n                    controls?.program_default_overseer_group?.value?.length > 1\n                  \"\n                >\n                  +{{\n                    controls?.program_default_overseer_group?.value?.length - 1\n                  }}\n                </button>\n              </div>\n            </div>\n\n            <!-- <div class=\"chip-container\">\n                    <div class=\"chip-inner\" *ngIf=\"controls?.program_default_overseer?.value?.length\">\n                      <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_overseer?.value[0],'DEFAULT_OVERSEER')\" >&#xe90d;</i>\n                        <span class=\"chip\" [appTooltip]=\"controls?.program_default_overseer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n                          <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_overseer?.value[0]?.member_name}}</span></span>\n                        <button *ngIf=\"controls?.program_default_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseersDefault.popover()\" placement=\"right\">+{{controls?.program_default_overseer?.value?.length -1}}</button>\n                    </div>\n                    <span *ngIf=\"controls?.program_default_overseer_group?.value?.length && controls?.program_default_overseer?.value?.length\" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n                    <div class=\"chip-inner\" *ngIf=\"controls?.program_default_overseer_group?.value?.length \">\n                        <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_overseer_group?.value[0],'DEFAULT_OVERSEER_GROUP')\" >&#xe90d;</i>\n                        <span class=\"chip\"  [appTooltip]=\"controls?.program_default_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n                            <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_overseer_group?.value[0]?.group_name}}</span>\n                        </span>\n                        <button *ngIf=\"controls?.program_default_overseer_group?.value?.length >1\" class=\"count\" appPopover (click)=\"overseerDefaultGroup.popover()\" placement=\"right\">+{{controls?.program_default_overseer_group?.value?.length -1}}</button>\n                    </div>\n                </div> -->\n            <button\n              *ngIf=\"activeList !== 'DEFAULT_OVERSEER'\"\n              (click)=\"activateList('DEFAULT_OVERSEER')\"\n              class=\"edit\"\n              type=\"button\"\n            >\n              <i class=\"icons\">&#xe9ba;</i> Edit\n            </button>\n          </div>\n        </input-with-pill>\n        <app-popover #overseersDefault [dontCloseonClick]=\"true\">\n          <div class=\"wf-action-list\">\n            <ul class=\"action-item\">\n              <li\n                *ngFor=\"\n                  let overseer of controls?.program_default_overseer?.value\n                    | slice : 1\n                \"\n              >\n                <div class=\"avatar-card\">\n                  <span class=\"value\">\n                    <i\n                      class=\"icons\"\n                      (click)=\"remove(overseer, 'DEFAULT_OVERSEER')\"\n                      >&#xe90d;</i\n                    >\n                    {{ overseer?.member_name }}\n                  </span>\n                </div>\n              </li>\n            </ul>\n          </div>\n        </app-popover>\n        <app-popover #overseerDefaultGroup [dontCloseonClick]=\"true\">\n          <div class=\"wf-action-list\">\n            <ul class=\"action-item\">\n              <li\n                *ngFor=\"\n                  let group of controls?.program_default_overseer_group?.value\n                    | slice : 1\n                \"\n              >\n                <div class=\"avatar-card\">\n                  <span class=\"value\">\n                    <i\n                      (click)=\"remove(group, 'DEFAULT_OVERSEER_GROUP')\"\n                      class=\"icons\"\n                      >&#xe90d;</i\n                    >\n                    {{ group?.group_name }}\n                  </span>\n                </div>\n              </li>\n            </ul>\n          </div>\n        </app-popover>\n        <label class=\"vx-control-panel\"> </label>\n        <input-with-pill\n          class=\"vx-mt-2\"\n          [selectDiv]=\"true\"\n          [line]=\"3\"\n          [disabled]=\"['OVERSEER', 'DEFAULT_OVERSEER'].includes(activeList)\"\n          [placeholder]=\"\n            'Which persons will be selected as the default overseers for responsibilities that are not completed within this Program?'\n          \"\n          (select)=\"activateList('DEFAULT_FAILED_OVERSEER')\"\n        >\n          <div\n            class=\"selected\"\n            *ngIf=\"\n              controls?.program_default_failed_overseer?.value?.length ||\n              controls?.program_default_failed_overseer_group?.value?.length\n            \"\n          >\n            <div class=\"vx-d-flex vx-align-center\">\n              <div\n                class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n                *ngIf=\"controls?.program_default_failed_overseer?.value?.length\"\n              >\n                <i\n                  class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                  (click)=\"\n                    remove(\n                      controls?.program_default_failed_overseer?.value[0],\n                      'DEFAULT_FAILED_OVERSEER'\n                    )\n                  \"\n                  >&#xe9ae;</i\n                >\n                <span\n                  class=\"chipName vx-fs-11 vx-label-txt\"\n                  [appTooltip]=\"\n                    controls?.program_default_failed_overseer?.value[0]\n                      ?.member_name\n                  \"\n                  placement=\"bottom-left\"\n                  delay=\"0\"\n                  type=\"black\"\n                  [tooltipMandatory]=\"false\"\n                  >{{\n                    controls?.program_default_failed_overseer?.value[0]\n                      ?.member_name\n                  }}</span\n                >\n                <button\n                  class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                  appPopover\n                  (click)=\"overseersDefaultFail.popover()\"\n                  placement=\"right\"\n                  *ngIf=\"\n                    controls?.program_default_failed_overseer?.value?.length > 1\n                  \"\n                >\n                  +{{\n                    controls?.program_default_failed_overseer?.value?.length - 1\n                  }}\n                </button>\n              </div>\n              <span\n                *ngIf=\"\n                  controls?.program_default_failed_overseer_group?.value\n                    ?.length &&\n                  controls?.program_default_failed_overseer?.value?.length\n                \"\n                class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n                >&</span\n              >\n              <div\n                class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n                *ngIf=\"\n                  controls?.program_default_failed_overseer_group?.value?.length\n                \"\n              >\n                <i\n                  class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                  (click)=\"\n                    remove(\n                      controls?.program_default_failed_overseer_group?.value[0],\n                      'DEFAULT_FAILED_OVERSEER_GROUP'\n                    )\n                  \"\n                  >&#xe9ae;</i\n                >\n                <span\n                  class=\"chipName vx-fs-11 vx-label-txt\"\n                  [appTooltip]=\"\n                    controls?.program_default_failed_overseer_group?.value[0]\n                      ?.group_name\n                  \"\n                  placement=\"bottom-left\"\n                  delay=\"0\"\n                  type=\"black\"\n                  [tooltipMandatory]=\"false\"\n                  >{{\n                    controls?.program_default_failed_overseer_group?.value[0]\n                      ?.group_name\n                  }}</span\n                >\n                <button\n                  class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                  appPopover\n                  (click)=\"overseerDefaultFailGroup.popover()\"\n                  placement=\"right\"\n                  *ngIf=\"\n                    controls?.program_default_failed_overseer_group?.value\n                      ?.length > 1\n                  \"\n                >\n                  +{{\n                    controls?.program_default_failed_overseer_group?.value\n                      ?.length - 1\n                  }}\n                </button>\n              </div>\n            </div>\n\n            <!-- <div class=\"chip-container\">\n                <div class=\"chip-inner\" *ngIf=\"controls?.program_default_failed_overseer?.value?.length\">\n                  <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_failed_overseer?.value[0],'DEFAULT_FAILED_OVERSEER')\" >&#xe90d;</i>\n                    <span class=\"chip\">\n                      <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_failed_overseer?.value[0]?.member_name}}</span>\n                    </span>\n                    <button *ngIf=\"controls?.program_default_failed_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseersDefaultFail.popover()\" placement=\"right\">+{{controls?.program_default_failed_overseer?.value?.length -1}}</button>\n                </div>\n                <span *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length && controls?.program_default_failed_overseer?.value?.length\" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n                <div class=\"chip-inner\" *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length \">\n                    <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_failed_overseer_group?.value[0],'DEFAULT_FAILED_OVERSEER_GROUP')\" >&#xe90d;</i>\n                    <span class=\"chip\" [appTooltip]=\"controls?.program_default_failed_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n                        <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_failed_overseer_group?.value[0]?.group_name}}</span>\n                    </span>\n                    <button *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"overseerDefaultFailGroup.popover()\" placement=\"right\">+{{controls?.program_default_failed_overseer_group?.value?.length -1}}</button>\n                </div>\n            </div> -->\n            <button\n              *ngIf=\"activeList !== 'DEFAULT_FAILED_OVERSEER'\"\n              (click)=\"activateList('DEFAULT_FAILED_OVERSEER')\"\n              class=\"edit\"\n              type=\"button\"\n            >\n              <i class=\"icons\">&#xe9ba;</i> Edit\n            </button>\n          </div>\n        </input-with-pill>\n        <app-popover #overseersDefaultFail [dontCloseonClick]=\"true\">\n          <div class=\"wf-action-list\">\n            <ul class=\"action-item\">\n              <li\n                *ngFor=\"\n                  let overseer of controls?.program_default_failed_overseer\n                    ?.value | slice : 1\n                \"\n              >\n                <div class=\"avatar-card\">\n                  <span class=\"value\">\n                    <i\n                      class=\"icons\"\n                      (click)=\"remove(overseer, 'DEFAULT_FAILED_OVERSEER')\"\n                      >&#xe90d;</i\n                    >\n                    {{ overseer?.member_name }}\n                  </span>\n                </div>\n              </li>\n            </ul>\n          </div>\n        </app-popover>\n        <app-popover #overseerDefaultFailGroup [dontCloseonClick]=\"true\">\n          <div class=\"wf-action-list\">\n            <ul class=\"action-item\">\n              <li\n                *ngFor=\"\n                  let group of controls?.program_default_failed_overseer_group\n                    ?.value | slice : 1\n                \"\n              >\n                <div class=\"avatar-card\">\n                  <span class=\"value\">\n                    <i\n                      (click)=\"remove(group, 'DEFAULT_FAILED_OVERSEER_GROUP')\"\n                      class=\"icons\"\n                      >&#xe90d;</i\n                    >\n                    {{ group?.group_name }}\n                  </span>\n                </div>\n              </li>\n            </ul>\n          </div>\n        </app-popover>\n      </ng-container>\n    </form-field>\n\n    <!-- Assessment -->\n    <form-field\n      [appScrollInView]=\"scrollToBottom\"\n      *ngIf=\"additionalOption?.ASSESSMENT\"\n      [checked]=\"controls?.program_assessments?.value?.length\"\n      [active]=\"activeList === 'ASSESSMENT'\"\n      [disabled]=\"\n        sideElements.includes(activeList) && activeList !== 'ASSESSMENT'\n      \"\n      [img]=\"ASSETS.assessments\"\n    >\n      <label class=\"vx-control-panel\"\n        >ASSESSMENTS\n        <i\n          class=\"icons\"\n          [appTooltip]=\"\n            'Assessments are a digital form that are created in “Assessment” within the Compliance Module. Where Assessments are selected when creating a Program, only those Assessments will be available for selection when creating a responsibility linked with the Program.'\n          \"\n          placement=\"bottom\"\n          delay=\"0\"\n          type=\"white\"\n          [tooltipMandatory]=\"true\"\n          id=\"AssessmentHelpText\"\n          >&#xeb16;</i\n        ></label\n      >\n      <input-with-pill\n        [selectDiv]=\"true\"\n        [placeholder]=\"\n          'Which assessments can be linked to the responsibilities within this Program?'\n        \"\n        (select)=\"activateList('ASSESSMENT')\"\n      >\n        <div\n          class=\"selected\"\n          *ngIf=\"controls?.program_assessments?.value?.length\"\n        >\n          <div\n            class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n            *ngIf=\"\n              controls?.program_assessments?.value\n                | assessmentResolver as assessments\n            \"\n          >\n            <i\n              class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n              (click)=\"remove(assessments[0], 'ASSESSMENT')\"\n              >&#xe9ae;</i\n            >\n            <span\n              class=\"chipName vx-fs-11 vx-label-txt\"\n              [appTooltip]=\"assessments[0]?.assessment_name\"\n              placement=\"bottom-left\"\n              delay=\"0\"\n              type=\"black\"\n              [tooltipMandatory]=\"false\"\n              >{{ assessments[0]?.assessment_name }}</span\n            >\n            <button\n              class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n              appPopover\n              (click)=\"program_assessments.popover()\"\n              placement=\"right\"\n              *ngIf=\"assessments?.length > 1\"\n            >\n              +{{ assessments?.length - 1 }}\n            </button>\n          </div>\n\n          <!-- <div class=\"chip-container\">\n                        <ng-container *ngIf=\"(controls?.program_assessments?.value | assessmentResolver) as assessments\">\n                            <div class=\"chip-inner\">\n                                <span class=\"chip\"><i class=\"icons\" (click)=\"remove(assessments[0],'ASSESSMENT')\">&#xe90d;</i>{{assessments[0]?.assessment_name}} </span>\n                                <button *ngIf=\"assessments?.length > 1\" class=\"count\" appPopover (click)=\"program_assessments.popover()\" placement=\"right\">+{{assessments?.length -1 }}</button>\n                            </div>\n                        </ng-container>\n                    </div> -->\n          <button\n            *ngIf=\"activeList !== 'ASSESSMENT'\"\n            class=\"edit\"\n            type=\"button\"\n            (click)=\"activateList('ASSESSMENT')\"\n          >\n            <i class=\"icons\">&#xe9ba;</i> Edit\n          </button>\n        </div>\n      </input-with-pill>\n      <app-popover #program_assessments [dontCloseonClick]=\"true\">\n        <ng-container>\n          <div class=\"wf-action-list\">\n            <ul class=\"action-item\">\n              <li\n                *ngFor=\"\n                  let assessment of controls?.program_assessments?.value\n                    | assessmentResolver\n                    | slice : 1\n                \"\n              >\n                <div class=\"avatar-card\">\n                  <span class=\"value\">\n                    <i (click)=\"remove(assessment, 'ASSESSMENT')\" class=\"icons\"\n                      >&#xe90d;</i\n                    >\n                    {{ assessment?.assessment_name }}\n                  </span>\n                </div>\n              </li>\n            </ul>\n          </div>\n        </ng-container>\n      </app-popover>\n    </form-field>\n\n    <!-- Format & Evidence -->\n    <form-field\n      [appScrollInView]=\"scrollToBottom\"\n      *ngIf=\"additionalOption?.FORMATE_EVIDENCE\"\n      [checked]=\"[true, false].includes(controls?.evidence_required?.value)\"\n      [active]=\"false\"\n      [disabled]=\"sideElements.includes(activeList)\"\n      [img]=\"ASSETS.format_evidence\"\n    >\n      <label class=\"vx-control-panel\"\n        >Evidence\n        <i\n          class=\"icons\"\n          [appTooltip]=\"\n            'If selected, evidence of completion of a responsibility will be required for all responsibilities that are linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility.'\n          \"\n          placement=\"bottom\"\n          delay=\"0\"\n          type=\"white\"\n          [tooltipMandatory]=\"true\"\n          id=\"EvidenceHelpText\"\n          >&#xeb16;</i\n        ></label\n      >\n      <div class=\"upload-format\">\n        <span class=\"text\"\n          >Do all responsibilities within this program require evidence?</span\n        >\n        <div class=\"radio-group program\">\n          <app-cs-radio\n            [name]=\"'evidence_required'\"\n            [checked]=\"controls?.evidence_required?.value\"\n            (checkedEvent)=\"setFormField('evidence_required', true)\"\n            >YES</app-cs-radio\n          >\n          <app-cs-radio\n            [name]=\"'evidence_required'\"\n            [checked]=\"!controls?.evidence_required?.value\"\n            (checkedEvent)=\"setFormField('evidence_required', false)\"\n            >NO</app-cs-radio\n          >\n        </div>\n      </div>\n      <!-- <div class=\"vx-d-flex vx-align-center vx-justify-end vx-mt-2\">\n                <div class=\"vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase vx-mr-2\">Allow any file to be marked as\n                    key\n                    evidence</div>\n                <switch formControlName=\"allow_any_file_key_evidence\"\n                    (change)=\"setFormField('allow_any_file_key_evidence',$event?.target?.checked)\"></switch>\n            </div> -->\n    </form-field>\n\n    <!-- Custom Field -->\n    <form-field\n      [appScrollInView]=\"scrollToBottom\"\n      *ngIf=\"additionalOption?.CUSTOM_FIELDS\"\n      [checked]=\"controls?.custom_fields?.value?.length\"\n      [active]=\"false\"\n      [disabled]=\"sideElements.includes(activeList)\"\n      [img]=\"ASSETS.custom_fields\"\n    >\n      <label class=\"vx-control-panel\"\n        >CUSTOM FIELD\n        <i\n          class=\"icons\"\n          [appTooltip]=\"\n            'Where a custom field is specified, all responsibilities linked with a Program will contain that custom field. Custom fields enable the collection of additional meta data.'\n          \"\n          placement=\"bottom\"\n          delay=\"0\"\n          type=\"white\"\n          [tooltipMandatory]=\"true\"\n          id=\"CFHelpText\"\n          >&#xeb16;</i\n        ></label\n      >\n      <custom-field formControlName=\"custom_fields\"></custom-field>\n    </form-field>\n  </form>\n</div>\n\n\n<!-- render userlist with group -->\n<user-group-list\n  *ngIf=\"activeList === 'OWNER'\"\n  [groupEnabled]=\"true\"\n  [singleSelect]=\"false\"\n  [loading]=\"listLoadingState.USERS\"\n  [userlist]=\"lists?.OWNERS?.data ?? []\"\n  [selectedUsers]=\"controls?.program_owners?.value | refDisconnect\"\n  (fetchUserData)=\"fetchUsersAssociatedWithRoles(false, $event)\"\n  [userListInfo]=\"lists?.OWNERS\"\n  [groupListInfo]=\"lists?.OWNERS_GROUPS\"\n  [groupList]=\"lists?.OWNERS_GROUPS?.data ?? []\"\n  [selectedGroups]=\"controls?.program_owners_group?.value | refDisconnect\"\n  (save)=\"listAction($event, 'OWNER')\"\n  (cancel)=\"fieldDeselector('OWNER')\"\n  [panelTitle]=\"panelTitleOwner\"\n  [featureflag]=\"featureflagGroups\"\n></user-group-list>\n<user-group-list\n  *ngIf=\"activeList === 'COLLABORATORS'\"\n  [groupEnabled]=\"true\"\n  [singleSelect]=\"false\"\n  [loading]=\"listLoadingState.USERS\"\n  [userlist]=\"lists?.OWNERS?.data ?? []\"\n  [selectedUsers]=\"controls?.collaborators?.value | refDisconnect\"\n  [groupList]=\"lists?.OWNERS_GROUPS ?? []\"\n  [FromProgram]=\"true\"\n  [selectedGroups]=\"controls?.collaborators_group?.value | refDisconnect\"\n  [assignorId]=\"assignorId\"\n  [userListInfo]=\"lists?.ASSIGNEES\"\n  (save)=\"listAction($event, 'COLLABORATORS')\"\n  (cancel)=\"fieldDeselector('COLLABORATORS')\"\n  [panelTitle]=\"panelTitleAssignee\"\n  [defaultSelectedUsers]=\"\n    controls?.collaborators?.value | refDisconnect\n  \"\n  [userType]=\"'assignees'\"\n  [featureflag]=\"featureflagGroups\"\n>\n</user-group-list>\n<app-loader-inline *ngIf=\"loader\"></app-loader-inline>\n<app-smiley-dialog-inline\n  *ngIf=\"showSmiley\"\n  [message]=\"smileyMessage\"\n  [actionButtons]=\"actionButtons\"\n  (action)=\"action($event)\"\n  (closeSmiley)=\"closeSmiley($event)\"\n>\n</app-smiley-dialog-inline>\n\n<!-- Framework selector  -->\n<app-framework-list\n  *ngIf=\"activeList === 'FRAMEWORK'\"\n  [workflowPage]=\"['FRAMEWORK']\"\n  (assignControl)=\"listAction($event, 'FRAMEWORK')\"\n  (closeFramework)=\"fieldDeselector('FRAMEWORK')\"\n  [previousSelectedValues]=\"{ framework: controls?.framework.value }\"\n  (entrustFramework)=\"entrustFramework($event)\"\n  [headerText]=\"'Select a framework'\"\n></app-framework-list>"]}
1378
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow-program.component.js","sourceRoot":"","sources":["../../../../../projects/vx-workflow-engine/src/lib/workflow-program/workflow-program.component.ts","../../../../../projects/vx-workflow-engine/src/lib/workflow-program/workflow-program.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport {\n  UntypedFormBuilder,\n  UntypedFormControl,\n  Validators,\n} from '@angular/forms';\nimport { cloneDeep, isEqual } from 'lodash';\nimport { DatePickerComponent } from 'ng2-date-picker';\nimport { distinctUntilChanged, take } from 'rxjs';\nimport { AuthService } from '../workflow-services/auth.service';\nimport { ProgramsService } from '../workflow-services/programs.service';\nimport { UiKitService } from '../workflow-services/ui-kit.service';\nimport { CONSTANTS } from './constants';\nimport { IframeService } from '../services/iframe.service';\nimport { ASSETS } from '../constants/assets.constants';\n\n@Component({\n  selector: 'app-workflow-program',\n  templateUrl: './workflow-program.component.html',\n  styleUrls: ['./workflow-program.component.less', '../forms.less'],\n})\nexport class WorkflowProgramComponent implements OnInit {\n  ASSETS = ASSETS;\n  constants = CONSTANTS;\n  showConfirmation: any;\n  isAscentAllowed: boolean = false;\n  ff_rc_listing: boolean = false;\n  @ViewChild('form', { read: ElementRef }) form!: ElementRef;\n  datePickerOverlay = false;\n  @ViewChild('datePicker') datePicker!: DatePickerComponent;\n  @Output() pickerChanged = new EventEmitter();\n  @Output() populateOption = new EventEmitter();\n  @Output() closeWorkflow = new EventEmitter();\n  @Output() showConfirmationAlert = new EventEmitter();\n  @Output() disconnectRefresh = new EventEmitter();\n  @Output() refreshForm = new EventEmitter();\n  @Output() hideElementsFromMoreOptions = new EventEmitter();\n  @Output() onRemovingRole: EventEmitter<any> = new EventEmitter();\n  @Output() disableElementsFromMoreOptions = new EventEmitter();\n  scrollToBottom!: boolean;\n  @Input() canFrameworkChange: boolean = true;\n  programSimplifyFlag: boolean = false;\n\n  // All Input fields\n  @Input() mode: string = '';\n  @Input() programId: string = '';\n  @Input() programType: number = 1;\n  @Input() allowedFeature!: any;\n  @Input() addToProgramDetails: any;\n  @Input() orgDetails: any;\n  panelTitleDefaultReviewer = 'Select Default Reviewer(s)';\n  panelTitleOwner = 'Select Owner(s)';\n  panelTitleReviewer = 'Select Reviewer(s)';\n  panelTitleAssignee = 'Select Assignee(s)';\n  panelTitleCollaborator = 'Select Collaborator(s)';\n  panelTitleApprover = 'Select  Approver';\n  isApproverDisabled: boolean = false;\n  isProgramScope: boolean = false;\n  toolTipData: any = {\n    owner:\n      'Owners are responsible for managing a Program. Only Owners can make changes to a Program and the responsibilities that are linked with the Program.<br>The <strong>Key Admin</strong> and all <b>Admin</b> users will be selected as the Owners of a Program by default.',\n    programScope: `A Program Scope can be used as follows:\n  <li>To specify the duration of the Program.</li>\n  <li>To pre-select certain options that are available when creating a responsibility, thereby decreasing the time required to create a responsibility.</li>\n  <li>To limit the options available for selection when creating a responsibility, thereby making it easier to create a responsibility and reducing the likelihood of an incorrect option being selected.</li>\n    `,\n  };\n  businessCycle: any;\n  featureflagrole: boolean = false;\n  featureflagGroups: boolean = false;\n  disableCollaboratorIds: any[] = [];\n  selectedReviewerIds: any[] = [];\n  selectedAssigneeIds: any[] = [];\n  selectedOverseerIds: any[] = [];\n  assignorId: number[] = [];\n  disableReviewerIds: any[] = [];\n  disableOverseerIds: any[] = [];\n\n  constructor(\n    private fb: UntypedFormBuilder,\n    private programService: ProgramsService,\n    private authService: AuthService,\n    private uiKitService: UiKitService,\n    private iframeService: IframeService,\n    private changeRef: ChangeDetectorRef\n  ) {\n    this.businessCycle = JSON.parse(\n      localStorage.getItem('businessCycle') ?? '{}'\n    );\n  }\n  public noWhitespaceValidator(control: UntypedFormControl) {\n    const isWhitespace = (control.value || '').trim().length === 0;\n    const isValid = !isWhitespace;\n    return isValid ? null : { whitespace: true };\n  }\n  public blankArrayValidator(control: UntypedFormControl) {\n    const isBlank = control.value?.filter((ele: any) => ele)?.length === 0;\n    const isValid = !isBlank;\n    return isValid ? null : { blank: true };\n  }\n  loader = false;\n  showSmiley = false;\n  actionButtons = [\n    { buttonText: 'Add More Programs', class: 'white-btn', id: 'addMore' },\n    { buttonText: 'View Program', class: 'blue-btn', id: 'viewProgram' },\n  ];\n  smileyMessage = `You're All Set!`;\n  createdProgramId = '';\n  isObjectiveValid: boolean = true;\n  isNameExists: boolean = false;\n  //form body for program meta data\n  programForm = this.fb.group({\n    program_type: [\n      this.programType,\n      [Validators.required, Validators.min(0), Validators.max(3)],\n    ],\n    program_name: ['', [Validators.required, this.noWhitespaceValidator]],\n    program_description: [''],\n    program_description_attachments: [[]],\n    program_objective: [''],\n    // program_objective: ['', [Validators.required, this.noWhitespaceValidator]],\n    program_objective_attachments: [[]],\n    program_roles: [[], [Validators.required, this.blankArrayValidator]],\n    all_user_in_role: [false],\n    program_owners: [[], [Validators.required, this.blankArrayValidator]],\n    program_owners_group: [[]],\n    program_approver: [[]],\n    performance_calculation: ['PAST_EVENT', [Validators.required]],\n    recurring_frequency: [true, [Validators.required]],\n    lock_scope_change: [false, [Validators.required]],\n    framework: [],\n    rc: [[]],\n    program_assignee: [[]],\n    program_assignee_group: [[]],\n    program_default_assignee: [[]],\n    program_default_assignee_group: [[]],\n    assignee_completion_criteria: ['ALL'],\n    program_reviewer: [[]],\n    program_reviewer_group: [[]],\n    program_default_reviewer: [[]],\n    program_default_reviewer_group: [[]],\n    reviewer_completion_criteria: ['SEQUENTIAL'],\n    program_overseer: [[]],\n    program_overseer_group: [[]],\n    program_default_overseer: [[]],\n    program_default_overseer_group: [[]],\n    program_default_failed_overseer: [[]],\n    program_default_failed_overseer_group: [[]],\n    program_assessments: [[]],\n    evidence_required: [false],\n    allow_any_file_key_evidence: [false],\n    custom_fields: [[]],\n    program_state: 0,\n    program_collaborator: [[]],\n  });\n\n  //exceptional handling of custom fields\n\n  showAddCustomField = true;\n  //Program objective and descripion are explectly declared as they are using marx editor which does not supports Reactive forms binding\n  editorData = {\n    programObjective: '',\n    programDescription: '',\n  };\n\n  selectedAssessment!: any;\n  manageProgramsRoleId: string[]= [];\n\n  currentUser() {\n    const user = this.authService.tokenInfo();\n    return {\n      member_email: user?.email,\n      member_id: user?.id,\n      member_name: user?.name,\n      user_role: 'LOGGED_IN',\n      _id: '',\n    };\n  }\n  //Sets the value of a form control\n  setFormField(controlName: string, value: any, isFromForm?: boolean) {\n    let patch: any = {};\n    patch[controlName] = value;\n    this.programForm.patchValue(patch);\n    this.controls[controlName]?.markAsTouched();\n    if (\n      isFromForm &&\n      controlName === 'program_objective' &&\n      !value.replace(/&nbsp;/g, ' ').trim()\n    )\n      this.isObjectiveValid = false;\n    else this.isObjectiveValid = true;\n  }\n\n  //Returns weather the form is valid or not\n  get formValid() {\n    if (\n      this.programForm.valid &&\n      this.editorData?.programObjective?.replace(/&nbsp;/g, ' ')?.trim()?.length\n    ) {\n      return true;\n    } else {\n      return false;\n    }\n  }\n\n  controls: any = {\n    program_name: this.programForm.get('program_name'),\n    program_type: this.programForm.get('program_type'),\n    program_objective: this.programForm.get('program_objective'),\n    program_roles: this.programForm.get('program_roles'),\n    program_owners: this.programForm.get('program_owners'),\n    program_owners_group: this.programForm.get('program_owners_group'),\n    all_user_in_role: this.programForm.get('all_user_in_role'),\n    program_approver: this.programForm.get('program_approver'),\n    description_attachment: this.programForm.get(\n      'program_description_attachments'\n    ),\n    objective_attachments: this.programForm.get(\n      'program_objective_attachments'\n    ),\n    performance_calculation: this.programForm.get('performance_calculation'),\n    recurring_frequency: this.programForm.get('recurring_frequency'),\n    lock_scope_change: this.programForm.get('lock_scope_change'),\n    rc: this.programForm.get('rc'),\n    evidence_required: this.programForm.get('evidence_required'),\n    framework: this.programForm.get('framework'),\n    allow_any_file_key_evidence: this.programForm.get(\n      'allow_any_file_key_evidence'\n    ),\n    program_assignee: this.programForm.get('program_assignee'),\n    program_assignee_group: this.programForm.get('program_assignee_group'),\n    program_default_assignee: this.programForm.get('program_default_assignee'),\n    program_default_assignee_group: this.programForm.get(\n      'program_default_assignee_group'\n    ),\n    assignee_completion_criteria: this.programForm.get(\n      'assignee_completion_criteria'\n    ),\n    program_default_reviewer: this.programForm.get('program_default_reviewer'),\n    program_default_reviewer_group: this.programForm.get(\n      'program_default_reviewer_group'\n    ),\n    program_reviewer: this.programForm.get('program_reviewer'),\n    program_reviewer_group: this.programForm.get('program_reviewer_group'),\n    program_overseer: this.programForm.get('program_overseer'),\n    program_overseer_group: this.programForm.get('program_overseer_group'),\n    program_default_overseer: this.programForm.get('program_default_overseer'),\n    program_default_overseer_group: this.programForm.get(\n      'program_default_overseer_group'\n    ),\n    program_default_failed_overseer: this.programForm.get(\n      'program_default_failed_overseer'\n    ),\n    program_default_failed_overseer_group: this.programForm.get(\n      'program_default_failed_overseer_group'\n    ),\n    reviewer_completion_criteria: this.programForm.get(\n      'reviewer_completion_criteria'\n    ),\n    program_assessments: this.programForm.get('program_assessments'),\n    custom_fields: this.programForm.get('custom_fields'),\n    isApproverDisabled: this.programForm.get('isApproverDisabled'),\n    program_collaborator: this.programForm.get('program_collaborator'),\n  };\n\n  lists: any = {\n    ROLES: [],\n    OWNERS: [],\n    OWNERS_GROUPS: [],\n    COLLABORATORS: [],\n    REVIEWERS: [],\n    REVIEWERS_GROUP: [],\n    ASSIGNEES: [],\n    ASSIGNEES_GROUP: [],\n    DEFAULT_ASSIGNEES: [],\n    DEFAULT_ASSIGNEES_GROUP: [],\n    DEFAULT_REVIEWERS: [],\n    DEFAULT_REVIEWERS_GROUP: [],\n    OVERSEERS: [],\n    OVERSEERS_GROUP: [],\n    DEFAULT_OVERSEERS: [],\n    DEFAULT_OVERSEERS_GROUP: [],\n    RC: [],\n    NON_REMOVABLE_OWNERS: [],\n    ALL_USER: [],\n    ALL_GROUP: [],\n    SYSTEM_ROLE_IDS: [],\n  };\n\n  listLoadingState = {\n    ROLES: false,\n    USERS: false,\n    GROUP: false,\n    RC: false,\n  };\n  sideElements = [\n    'ROLE',\n    'RC',\n    'OWNER',\n    'ASSIGNEE',\n    'APPROVER',\n    'DEFAULT_ASSIGNEE',\n    'REVIEWER',\n    'DEFAULT_REVIEWER',\n    'ASSESSMENT',\n    'FRAMEWORK',\n    'OVERSEER',\n    'DEFAULT_FAILED_OVERSEER',\n    'DEFAULT_OVERSEER',\n    'OVERSEER',\n  ];\n\n  ngOnInit(): void {\n    this.setFormField('program_type', this.programType);\n    if (this.mode === 'EDIT') {\n      this.getProgramDetails();\n    } else {\n      this.fetchOrganizationUsers();\n      this.fetchOrganizationGroup();\n    }\n    this.fetchRoles();\n    this.fetchRC();\n    if (this.addToProgramDetails?._id) {\n      this.listAction(this.addToProgramDetails, 'FRAMEWORK');\n    }\n    this.enablefeature();\n    this.changeRef.detectChanges();\n  }\n  get valid() {\n    return this.programForm.valid;\n  }\n\n  additionalOption: any = { ...CONSTANTS.additionalOption };\n  activeList = '';\n  /**\n   * #### Description\n   * Populates optional fields status for the optional fields\n   */\n  populateOptionalFields() {\n    const activatedOptions = [];\n    for (const key of Object.keys(this.additionalOption)) {\n      if (this.additionalOption[key] === true) {\n        activatedOptions.push(key);\n      }\n    }\n    this.populateOption.emit(activatedOptions);\n  }\n  addMoreInfo(event: any) {\n    this.additionalOption[event.code] = event.checked;\n    this.scrollToBottom = true;\n    this.checkProgramOptionField();\n  }\n\n  // function to automate form value change handng\n  formChangeListner() {\n    const fields = Object.keys(this.controls);\n    fields.forEach((ele: any) => {\n      this.controls[ele]?.valueChanges.pipe(distinctUntilChanged()).subscribe({\n        next: (res: any) => {\n          this.handleFormFieldChange(ele, res);\n        },\n      });\n    });\n  }\n\n  handleFormFieldChange(control: string, payload?: any) {\n    switch (control) {\n      case 'program_roles': {\n        this.fetchUsersAssociatedWithRoles();\n      }\n    }\n  }\n\n  activateList(evt: string) {\n    if (evt === 'FRAMEWORK' && !this.canFrameworkChange) return;\n    this.activeList = evt;\n    this.pickerChanged.emit(true);\n  }\n\n  listAction(evt: any, type: any) {\n\n    switch (type) {\n      case 'ROLE': {\n        this.showConfirmation = true;\n        const systemRoles = evt?.filter(\n          (ele: any) =>\n            ele?.roleName?.toLowerCase() === 'key admin' ||\n            ele?.roleName?.toLowerCase() === 'admin'\n        );\n        const patchVal = this.uniqueByProp([...systemRoles, ...evt], '_id');\n        if (\n          !isEqual(this.controls.program_roles.value.sort(), patchVal.sort())\n        ) {\n          this.setFormField('program_roles', patchVal);\n          this.fetchUsersAssociatedWithRoles();\n          this.fetchGroupsAssociatedWithRoles();\n        }\n        this.fieldDeselector(type);\n        break;\n      }\n      case 'OWNER': {\n        this.setFormField(\n          'program_owners',\n          this.uniqueByProp(evt?.users, 'member_id')\n        );\n        this.setFormField(\n          'program_owners_group',\n          this.uniqueByProp(evt?.groups, 'group_id')\n        );\n        this.fieldDeselector(type);\n        this.refreshList();\n        break;\n      }\n      case 'COLLABORATOR': {\n        console.log(\"evt\", evt, type);\n\n        this.setFormField(\n          'program_collaborator',\n          this.uniqueByProp(evt?.users, 'member_id')\n        );\n\n        this.fieldDeselector(type);\n        break;\n      }\n     \n      case 'FRAMEWORK': {\n        this.setFormField('framework', evt);\n        this.setFormField('program_name', evt?.name);\n        this.setFormField('program_description', evt?.description);\n        this.editorData.programDescription = evt?.description;\n        this.fieldDeselector(type);\n        break;\n      }\n    }\n  }\n\n  remove(evt: any, type: any) {\n    switch (type) {\n      case 'ROLE': {\n        let msg = '';\n        msg = 'If you change the roles, any unsaved changes would be lost.';\n        const roles = this.controls?.program_roles?.value?.filter(\n          (ele: any) => ele?._id !== evt?._id\n        );\n        this.listAction(roles, 'ROLE');\n        this.setFormField('program_roles', roles);\n        break;\n      }\n      case 'OWNER': {\n        const owners = this.controls?.program_owners?.value?.filter(\n          (ele: any) => ele?.member_id !== evt?.member_id\n        );\n        this.setFormField('program_owners', owners);\n        break;\n      }\n      case 'OWNER_GROUP': {\n        const owners_group = this.controls?.program_owners_group?.value?.filter(\n          (ele: any) => ele?.group_id !== evt?.group_id\n        );\n        this.setFormField('program_owners_group', owners_group);\n        break;\n      }\n      case 'COLLABORATOR': {\n        const approver = this.controls?.program_collaborator?.value?.filter(\n          (ele: any) => ele?.member_id !== evt?.member_id\n        );\n        this.setFormField('program_collaborator', approver);\n        break;\n      }\n      case 'FRAMEWORK': {\n        this.setFormField('framework', null);\n        break;\n      }\n    }\n  }\n\n  returnIds(list: any[], key: string) {\n    return list\n      ?.map((ele) => {\n        if (ele[key]) {\n          return ele[key];\n        }\n      })\n      .filter((ele) => ele);\n  }\n\n  refreshList() {\n    let selectedOwner = this.controls?.program_owners?.value?.map((ele: any) => ele.member_id);\n    console.log(\"collaborators\", selectedOwner, this.controls)\n    let disableCollaborator = this.lists?.COLLABORATORS?.data?.filter(\n      (user: any) =>\n        selectedOwner?.includes(user?.member_id)\n    );\n    console.log(\"disableCollaborator ==>\", disableCollaborator)\n    this.disableCollaboratorIds = this.returnIds(disableCollaborator, 'member_id');\n  }\n\n  removeRole(evt: any) {\n    this.onRemovingRole.emit(evt);\n  }\n\n  //below 4 functions can be easilty combined into one as they follow same kind of pattern or can be offloaded to a external service\n  setDefaultAssignee(evt: any) {\n    if (evt?.users?.length || evt?.groups?.length) {\n      this.lists.DEFAULT_ASSIGNEES = this.uniqueByProp(evt?.users, 'member_id');\n      this.lists.DEFAULT_ASSIGNEES_GROUP = this.uniqueByProp(\n        evt?.groups,\n        'group_id'\n      );\n    } else {\n      this.lists.DEFAULT_ASSIGNEES = this.lists.ALL_USER;\n      this.lists.DEFAULT_ASSIGNEES_GROUP = this.lists.ALL_GROUP;\n    }\n    const assigneeMap = evt?.users?.map((ele: any) => ele?.member_id);\n    let currentDefaultAssignee = this.controls.program_default_assignee?.value;\n    currentDefaultAssignee = currentDefaultAssignee.filter((ele: any) =>\n      assigneeMap.includes(ele?.member_id)\n    );\n    this.setFormField('program_default_assignee', currentDefaultAssignee);\n  }\n\n  setDefaultAssigneeOnRemove(evt: any, type: any) {\n    switch (type) {\n      case 'ASSIGNEE': {\n        this.lists.DEFAULT_ASSIGNEES = this.lists.DEFAULT_ASSIGNEES.filter(\n          (ele: any) => ele?.member_id !== evt?.member_id\n        );\n        const defaultAssignee = this.controls.program_default_assignee?.value;\n        const assignee = defaultAssignee.filter(\n          (ele: any) => ele?.member_id !== evt?.member_id\n        );\n        if (!assignee?.length) {\n          this.lists.DEFAULT_ASSIGNEES = this.lists.ALL_USER;\n        }\n        this.setFormField('program_default_assignee', assignee);\n\n        break;\n      }\n      case 'ASSIGNEE_GROUP': {\n        this.lists.DEFAULT_ASSIGNEES_GROUP =\n          this.lists.DEFAULT_ASSIGNEES_GROUP.filter(\n            (ele: any) => ele?.group_id !== evt?.group_id\n          );\n        const defaultAssigneeGroup =\n          this.controls.program_default_assignee_group?.value;\n        const assigneeGroup = defaultAssigneeGroup.filter(\n          (ele: any) => ele?.group_id !== evt?.group_id\n        );\n        if (!assigneeGroup?.length) {\n          this.lists.DEFAULT_ASSIGNEES_GROUP = this.lists.ALL_GROUP;\n        }\n        this.setFormField('program_default_assignee_group', assigneeGroup);\n      }\n    }\n  }\n  setDefaultReviewer(evt: any) {\n    if (evt?.users?.length || evt?.groups?.length) {\n      this.lists.DEFAULT_REVIEWERS = this.uniqueByProp(evt?.users, 'member_id');\n      this.lists.DEFAULT_REVIEWERS_GROUP = this.uniqueByProp(\n        evt?.groups,\n        'group_id'\n      );\n    } else {\n      this.lists.DEFAULT_REVIEWERS = this.lists.ALL_USER;\n      this.lists.DEFAULT_REVIEWERS_GROUP = this.lists.ALL_GROUP;\n    }\n    const reviewerMap = evt?.users?.map((ele: any) => ele?.member_id);\n    let currentDefaultReviewer = this.controls.program_default_reviewer?.value;\n    currentDefaultReviewer = currentDefaultReviewer.filter((ele: any) =>\n      reviewerMap.includes(ele?.member_id)\n    );\n    this.setFormField('program_default_reviewer', currentDefaultReviewer);\n  }\n  setDefaultOverseer(evt: any) {\n    if (evt?.users?.length || evt?.groups?.length) {\n      this.lists.DEFAULT_OVERSEERS = this.uniqueByProp(evt?.users, 'member_id');\n      this.lists.DEFAULT_OVERSEERS_GROUP = this.uniqueByProp(\n        evt?.groups,\n        'group_id'\n      );\n    } else {\n      this.lists.DEFAULT_OVERSEERS = this.lists.ALL_USER;\n      this.lists.DEFAULT_OVERSEERS_GROUP = this.lists.ALL_GROUP;\n    }\n    const overseerMap = evt?.users?.map((ele: any) => ele?.member_id);\n    let currentDefaultReviewer = this.controls.program_default_overseer?.value;\n    let currentDefaultFailReviewer =\n      this.controls.program_default_failed_overseer?.value;\n    currentDefaultReviewer = currentDefaultReviewer.filter((ele: any) =>\n      overseerMap.includes(ele?.member_id)\n    );\n    currentDefaultFailReviewer = currentDefaultReviewer.filter((ele: any) =>\n      overseerMap.includes(ele?.member_id)\n    );\n    this.setFormField('program_default_overseer', currentDefaultReviewer);\n    this.setFormField(\n      'program_default_failed_overseer',\n      currentDefaultFailReviewer\n    );\n  }\n  setDefaultReviewerOnRemove(evt: any, type: any) {\n    switch (type) {\n      case 'REVIEWER': {\n        this.lists.DEFAULT_REVIEWERS = this.lists.DEFAULT_REVIEWERS.filter(\n          (ele: any) => ele?.member_id !== evt?.member_id\n        );\n        const defaultReviewer = this.controls.program_default_reviewer?.value;\n        const reviewer = defaultReviewer.filter(\n          (ele: any) => ele?.member_id !== evt?.member_id\n        );\n        this.setFormField('program_default_reviewer', reviewer);\n\n        break;\n      }\n      case 'REVIEWER_GROUP': {\n        this.lists.DEFAULT_REVIEWERS_GROUP =\n          this.lists.DEFAULT_REVIEWERS_GROUP.filter(\n            (ele: any) => ele?.group_id !== evt?.group_id\n          );\n        const defaultReviewerGroup =\n          this.controls.program_default_reviewer_group?.value;\n        const reviewerGroup = defaultReviewerGroup.filter(\n          (ele: any) => ele?.group_id !== evt?.group_id\n        );\n        this.setFormField('program_default_reviewer_group', reviewerGroup);\n      }\n    }\n  }\n  setDefaultOverseerOnRemove(evt: any, type: any) {\n    switch (type) {\n      case 'OVERSEER': {\n        this.lists.DEFAULT_OVERSEERS = this.lists.DEFAULT_OVERSEERS.filter(\n          (ele: any) => ele?.member_id !== evt?.member_id\n        );\n        const defaultOverseer = this.controls.program_default_overseer?.value;\n        const overseer = defaultOverseer.filter(\n          (ele: any) => ele?.member_id !== evt?.member_id\n        );\n        this.setFormField('program_default_overseer', overseer);\n\n        const defaultFailOverseer =\n          this.controls.program_default_failed_overseer?.value;\n        const overseerFail = defaultFailOverseer.filter(\n          (ele: any) => ele?.member_id !== evt?.member_id\n        );\n        this.setFormField('program_default_failed_overseer', overseerFail);\n\n        break;\n      }\n      case 'OVERSEER_GROUP': {\n        this.lists.DEFAULT_OVERSEERS_GROUP =\n          this.lists.DEFAULT_OVERSEERS_GROUP.filter(\n            (ele: any) => ele?.group_id !== evt?.group_id\n          );\n        const defaultOverseerGroup =\n          this.controls.program_default_overseer_group?.value;\n        const overseerGroup = defaultOverseerGroup.filter(\n          (ele: any) => ele?.group_id !== evt?.group_id\n        );\n        this.setFormField('program_default_overseer_group', overseerGroup);\n\n        const defaultOverseerFailedGroup =\n          this.controls.program_default_failed_overseer_group?.value;\n        const overseerFailedGroup = defaultOverseerFailedGroup.filter(\n          (ele: any) => ele?.group_id !== evt?.group_id\n        );\n        this.setFormField(\n          'program_default_failed_overseer_group',\n          overseerFailedGroup\n        );\n      }\n    }\n  }\n\n  fieldDeselector(type: any) {\n    this.activeList = '';\n    this.pickerChanged.emit(false);\n    this.markasTouchedSelector(type);\n  }\n  markasTouchedSelector(fieldName: any) {\n    const typeField: any = {\n      ROLE: 'program_roles',\n      APPROVER: 'program_approver',\n      OWNER: 'program_owners',\n      OWNER_GROUP: 'program_owners_group',\n    };\n    this.controls[typeField[fieldName]]?.markAsTouched();\n  }\n\n  fetchRoles() {\n    this.programService.getRoles().subscribe({\n      next: (res: any) => {\n        this.lists.ROLES = res;\n        const defaultSystemVal = this.lists?.ROLES?.data\n          ?.filter(\n            (ele: any) =>\n              ele?.roleName?.toLowerCase() === 'key admin' ||\n              ele?.roleName?.toLowerCase() === 'admin'\n          )\n          ?.map((ele: any) => ele?._id);\n        const defaultVal = this.lists?.ROLES?.data?.filter(\n          (ele: any) =>\n            ele?.roleName?.toLowerCase() === 'key admin' ||\n            ele?.roleName?.toLowerCase() === 'admin'\n        );\n\n        this.manageProgramsRoleId = this.getManageProgramsRoleId();\n        this.lists.SYSTEM_ROLE_IDS = defaultSystemVal;\n        if (this.mode !== 'EDIT') {\n          this.setFormField('program_roles', defaultVal);\n          this.fetchUsersAssociatedWithRoles();\n          this.fetchGroupsAssociatedWithRoles();\n          this.fetchUserWithManageProgramsRole();\n        }\n      },\n      error: (err: any) => { },\n    });\n  }\n\n  // Get Manage Programs roles Id:\n\n getManageProgramsRoleId() {\n  return this.lists?.ROLES?.data?.filter(\n    (ele: any) =>\n    !['key admin', 'admin'].includes(ele?.roleName?.toLowerCase())\n  ).map((ele: any) => ele?._id) ?? []\n }\n  //fetch the list of responsibilities center\n  fetchRC() {\n    this.programService.getResponsibilityCenterList().subscribe({\n      next: (res: any) => {\n        this.lists.RC = res;\n      },\n      error: (err: any) => { },\n    });\n  }\n\n  fetchUsersAssociatedWithRoles(calledFrom?: any) {\n    const loggedInUser = this.currentUser();\n    const roleIds = this.controls.program_roles?.value?.map(\n      (ele: any) => ele?._id\n    );\n    console.log(\"roleIds\", roleIds, this.controls.program_roles);\n    // if (fetchAll) {\n    this.programService.fetchAllRoleUsers(roleIds).subscribe({\n      next: (res: any) => {\n        const isUserFind = res?.data?.some(\n          (res: any) => res?.member_id === loggedInUser?.member_id\n        );\n        if (!isUserFind) {\n          res?.data?.push(loggedInUser);\n          res.total_items = res?.total_items + 1;\n        }\n        this.lists.OWNERS = res;\n        if (\n          !res?.data\n            ?.map((ele: any) => ele?.member_id)\n            ?.includes(this.controls.program_approver?.value[0]?.member_id)\n        ) {\n          this.setFormField('program_approver', []);\n        }\n        if (this.controls?.all_user_in_role?.value) {\n          this.setFormField('program_owners', res?.data);\n        } else {\n          this.setDefaultOwners(res?.data, calledFrom);\n        }\n      },\n      error: (err: any) => { },\n    });\n  }\n\n  fetchUserWithManageProgramsRole() {\n    this.programService.fetchAllRoleUsers(this.manageProgramsRoleId).subscribe({\n      next: (res: any) => {\n        this.lists.COLLABORATORS = res;\n      },\n    });\n  }\n\n  fetchGroupsAssociatedWithRoles() {\n    const roleIds = this.controls.program_roles?.value?.map(\n      (ele: any) => ele?._id\n    );\n    this.programService.fetchAllRoleGroups(roleIds).subscribe({\n      next: (res: any) => {\n        this.lists.OWNERS_GROUPS = res;\n        const roleIds: Array<string> = this.controls.program_roles?.value.map(\n          (ele: any) => ele._id\n        );\n        const groupDetails = this.controls.program_owners_group?.value.filter(\n          (roleId: any) => {\n            if (roleId.roles.length) {\n              let isSameRole = false;\n              roleId.roles.forEach((role: any) => {\n                if (roleIds.includes(role.roleId)) {\n                  isSameRole = true;\n                }\n              });\n\n              if (isSameRole) {\n                return roleId;\n              }\n            }\n          }\n        );\n        this.setFormField('program_owners_group', groupDetails);\n      },\n    });\n  }\n\n  setDefaultOwners(userList: any, calledFrom?: any) {\n    const loggedInuser = this.currentUser();\n    const defaultOwner = userList.filter(\n      (ele: any) =>\n        ['ADMIN', 'KEY_ADMIN'].includes(ele?.user_role) &&\n        ele?.member_id != loggedInuser?.member_id\n    );\n    this.lists.NON_REMOVABLE_OWNERS = this.uniqueByProp(\n      [...[loggedInuser], ...defaultOwner],\n      'member_id'\n    );\n    // this.setFormField('program_owners', this.lists.NON_REMOVABLE_OWNERS);\n    const preSelectedUsers = this.getPreSelectedOwners(\n      this.controls?.program_owners?.value,\n      userList\n    );\n    if (calledFrom !== 'getProgramDetails') {\n      this.setFormField(\n        'program_owners',\n        preSelectedUsers?.length\n          ? preSelectedUsers\n          : this.lists.NON_REMOVABLE_OWNERS\n      );\n    }\n  }\n\n  getPreSelectedOwners(previousSelectedUsers: any, currentUsers: any) {\n    let finalUsers = [];\n    finalUsers = previousSelectedUsers?.filter((previous: any) =>\n      currentUsers?.some(\n        (current: any) => previous?.member_id === current?.member_id\n      )\n    );\n    return finalUsers;\n  }\n\n  fetchOrganizationUsers(data?: any) {\n    this.listLoadingState.USERS = true;\n    this.programService.fetchAllOrgUser().subscribe({\n      next: (res: any) => {\n        this.lists.ALL_USER = res;\n        this.lists.ASSIGNEES = res;\n        this.lists.REVIEWERS = res;\n        this.lists.OVERSEERS = res;\n        if (this.mode !== 'EDIT') {\n          this.lists.DEFAULT_ASSIGNEES = res;\n          this.lists.DEFAULT_REVIEWERS = res;\n          this.lists.DEFAULT_OVERSEERS = res;\n        } else if (this.mode === 'EDIT') {\n          if (!this.controls.program_assignee?.value?.length) {\n            this.lists.DEFAULT_ASSIGNEES = res;\n          }\n          if (!this.controls.program_reviewer?.value?.length) {\n            this.lists.DEFAULT_REVIEWERS = res;\n          }\n          if (!this.controls.program_overseer?.value?.length) {\n            this.lists.DEFAULT_OVERSEERS = res;\n          }\n        }\n\n        this.listLoadingState.USERS = false;\n        this.refreshList();\n      },\n      error: () => {\n        this.listLoadingState.USERS = false;\n      },\n    });\n  }\n\n  fetchOrganizationGroup(data?: any) {\n    this.programService.fetchComplianceGroups().subscribe({\n      next: (res: any) => {\n        this.lists.ALL_GROUP = res;\n\n        this.lists.ASSIGNEES_GROUP = res;\n        this.lists.REVIEWERS_GROUP = res;\n\n        this.lists.OVERSEERS_GROUP = res;\n\n        if (this.mode !== 'EDIT') {\n          this.lists.DEFAULT_ASSIGNEES_GROUP = res;\n          this.lists.DEFAULT_REVIEWERS_GROUP = res;\n          this.lists.DEFAULT_OVERSEERS_GROUP = res;\n        }\n      },\n      error: (err: any) => { },\n    });\n  }\n\n  fileUploadTracker = {\n    description: [],\n    objective: [],\n  };\n\n  selectFile(type: any, files: any) {\n    for (let i = 0; i <= files.length - 1; i++) {\n      const name = files[i].file.name ?? '';\n      this.uploadFiles(type, files[i].file);\n    }\n  }\n\n  uploadFiles(type: 'DESCRIPTION' | 'OBJECTIVE', file: any) {\n    const formData = new FormData();\n    formData.append('file', file);\n    const destinationString = this.authService.getOrganizationId().toString();\n    const dummyFile = {\n      file_url_path: `${file?.name}`,\n      name: `${file?.name}`,\n      uploading: true,\n      org_file: `${file?.name}`,\n    };\n    if (type === 'DESCRIPTION') {\n      let description = this.controls?.description_attachment?.value ?? [];\n      this.setFormField('program_description_attachments', [\n        ...description,\n        ...[dummyFile],\n      ]);\n      this.programService.uploadFiles(formData, destinationString).subscribe({\n        next: (res: any) => {\n          description = this.controls?.description_attachment?.value ?? [];\n          let descriptionIndex = description.findIndex(\n            (ele: any) => ele?.org_file === res?.org_file\n          );\n          description[descriptionIndex] = res;\n          this.setFormField(\n            'program_description_attachments',\n            this.uniqueByProp(description, 'org_file')\n          );\n        },\n        error: (err: any) => {\n          description = this.controls?.description_attachment?.value ?? [];\n          description = description.filter(\n            (ele: any) => ele?.org_file !== file?.name\n          );\n          this.setFormField(\n            'program_description_attachments',\n            this.uniqueByProp(description, 'org_file')\n          );\n        },\n      });\n    } else if (type === 'OBJECTIVE') {\n      let description = this.controls?.description_attachment?.value ?? [];\n      this.setFormField('program_description_attachments', [\n        ...description,\n        ...[dummyFile],\n      ]);\n      this.programService.uploadFiles(formData, destinationString).subscribe({\n        next: (res: any) => {\n          description = this.controls?.description_attachment?.value ?? [];\n          let descriptionIndex = description.findIndex(\n            (ele: any) => ele?.org_file === res?.org_file\n          );\n          description[descriptionIndex] = res;\n          this.setFormField(\n            'program_description_attachments',\n            this.uniqueByProp(description, 'org_file')\n          );\n        },\n        error: (err: any) => {\n          description = this.controls?.description_attachment?.value ?? [];\n          description = description.filter(\n            (ele: any) => ele?.org_file !== file?.name\n          );\n          this.setFormField(\n            'program_description_attachments',\n            this.uniqueByProp(description, 'org_file')\n          );\n        },\n      });\n    }\n  }\n\n  deleteAttachment(type: 'DESCRIPTION' | 'OBJECTIVE', file: any) {\n    if (type === 'DESCRIPTION') {\n      let description = this.controls?.description_attachment?.value ?? [];\n      if (description) {\n        description = description.filter(\n          (ele: any) => ele?.org_file !== file?.org_file\n        );\n        this.setFormField('program_description_attachments', description);\n      }\n    } else if (type === 'OBJECTIVE') {\n      let objective = this.controls?.objective_attachments?.value ?? [];\n      if (objective) {\n        objective = objective.filter(\n          (ele: any) => ele?.org_file !== file?.org_file\n        );\n        this.setFormField('program_description_attachments', objective);\n      }\n    }\n  }\n\n  selectAllRoleOwner(evt: any) {\n    //need to fetch all the users for all the selected roles\n    const loggedInUser = this.currentUser();\n    let roleId = [];\n    let user: any;\n    if (evt?.target?.checked) {\n      roleId = this.controls.program_roles?.value?.map((ele: any) => ele?._id);\n      if (this.featureflagGroups) {\n        user = this.controls.program_roles?.value?.map((ele: any) => ele?._id);\n        this.controls.program_owners_group.value = user;\n      }\n    } else {\n      roleId = this.controls.program_roles?.value?.map((ele: any) => {\n        if (['key admin', 'admin'].includes(ele.roleName.toLowerCase())) {\n          return ele?._id;\n        }\n      });\n    }\n    this.programService.fetchAllRoleUsers(roleId).subscribe({\n      next: (res: any) => {\n        const user = this.uniqueByProp(\n          [...[loggedInUser], ...res?.data],\n          'member_id'\n        );\n        this.setFormField('program_owners', user);\n      },\n      error: (err: any) => { },\n    });\n    this.programService.fetchAllRoleGroups(user).subscribe({\n      next: (res: any) => {\n        const user = this.uniqueByProp([...res?.data], 'group_id');\n        this.setFormField('program_owners_group', user);\n      },\n    });\n  }\n\n  /**\n   * #### Description\n   *\n   * Returns the unique array of object based on unique key\n   * @param array\n   * @param key\n   * @returns\n   */\n  uniqueByProp(array: any, key: string) {\n    return Array.from(\n      array\n        .reduce(\n          (acc: any, item: any) => (\n            item && item[key] && acc.set(item[key], item), acc\n          ),\n          new Map()\n        )\n        .values()\n    );\n  }\n  setList(list: any[], ids: any[], key: string) {\n    const data: any = [];\n    ids.forEach((element: any) => {\n      const index = list.findIndex(\n        (listElement: any) => listElement[key] == element\n      );\n      if (index !== -1) {\n        data.push(list[index]);\n      }\n    });\n    return data;\n  }\n\n  saveProgram() {\n    this.loader = true;\n    let payload = this.programService.buildPayload(this.programForm, this);\n    if (payload && this.mode === 'CREATE') {\n      this.programService.saveProgram(payload).subscribe({\n        next: (res: any) => {\n          this.loader = false;\n          this.showSmiley = true;\n          this.uiKitService.isSmileyOn = true;\n          this.createdProgramId = res._id;\n        },\n        error: (err: any) => {\n          this.loader = false;\n          this.uiKitService.isSmileyOn = false;\n          if (err?.error?.message?.includes('Category already exist')) {\n            this.isNameExists = true;\n          }\n        },\n      });\n    }\n    if (payload && this.mode === 'EDIT') {\n      this.programService.updateProgram(payload, this.programId).subscribe({\n        next: (res: any) => {\n          this.loader = false;\n          this.showSmiley = true;\n          this.uiKitService.isSmileyOn = true;\n          this.createdProgramId = res._id;\n        },\n        error: (err: any) => {\n          this.loader = false;\n          this.uiKitService.isSmileyOn = false;\n          if (err?.error?.message?.includes('Category already exist')) {\n            this.isNameExists = true;\n          }\n        },\n      });\n    }\n  }\n\n  action(event: string) {\n    switch (event) {\n      case 'addMore':\n        this.resetForm();\n        this.populateOptionalFields();\n        break;\n      case 'viewProgram':\n        this.viewPrograms();\n        break;\n    }\n  }\n\n  viewPrograms(): void {\n    this.disconnectRefresh.emit(false);\n    let url: string;\n    if (window.location.host.startsWith('localhost')) {\n      url = 'http://' + window.location.host;\n    } else {\n      url = 'https://' + window.location.host;\n    }\n\n    if (window.location.host.startsWith('localhost')) {\n      url += '/program-workroom?id=' + this.createdProgramId;\n    } else {\n      url += '/program/program-workroom?id=' + this.createdProgramId;\n    }\n\n    this.iframeService.redirectIfInIframe(url, true);\n  }\n  resetForm() {\n    this.uiKitService.isSmileyOn = false;\n    this.scrollToBottom = false;\n    this.showSmiley = false;\n    this.loader = true;\n    const DEFAULT_VALUES = {\n      program_type: 1,\n      program_name: '',\n      program_description: '',\n      program_description_attachments: [],\n      program_objective: '',\n      program_objective_attachments: [],\n      program_roles: [],\n      all_user_in_role: false,\n      program_owners: [],\n      program_owners_group: [],\n      program_approver: [],\n      performance_calculation: 'PAST_EVENT',\n      recurring_frequency: false,\n      lock_scope_change: false,\n      framework: [],\n      rc: [],\n      program_assignee: [],\n      program_assignee_group: [],\n      program_default_assignee: [],\n      program_default_assignee_group: [],\n      assignee_completion_criteria: 'ALL',\n      program_reviewer: [],\n      program_reviewer_group: [],\n      program_default_reviewer: [],\n      program_default_reviewer_group: [],\n      reviewer_completion_criteria: 'SEQUENTIAL',\n      program_overseer: [],\n      program_overseer_group: [],\n      program_default_overseer: [],\n      program_default_overseer_group: [],\n      program_default_failed_overseer: [],\n      program_default_failed_overseer_group: [],\n      program_assessments: [],\n      evidence_required: false,\n      allow_any_file_key_evidence: false,\n      custom_fields: [],\n      program_state: 0,\n    };\n    this.resetAdditionalOption();\n    this.programForm.reset();\n    this.programForm.patchValue(DEFAULT_VALUES);\n    this.editorData = {\n      programObjective: '',\n      programDescription: '',\n    };\n    this.loader = false;\n    this.isNameExists = false;\n    this.fetchRoles();\n    this.refreshForm.emit(true);\n    this.form.nativeElement.scrollIntoView({\n      behavior: 'smooth',\n      block: 'start',\n    });\n  }\n\n  closeSmiley(event: any) {\n    this.showSmiley = false;\n    this.uiKitService.isSmileyOn = false;\n    this.closeWorkflow.emit({ evt: '', confirm: false });\n  }\n\n  /**\n   * Get program details when user is trying to edit program\n   */\n  getProgramDetails() {\n    this.programService\n      .getProgram(this.programId)\n      .pipe(take(1))\n      .subscribe((res: any) => {\n        this.setFormField('program_name', res?.name);\n        this.setFormField('program_type', res?.programType);\n        this.setFormField('program_objective', res?.program_objective?.text);\n        this.setFormField('all_user_in_role', res?.all_user_in_role);\n        this.setFormField(\n          'program_description_attachments',\n          res?.description?.attachments\n        );\n        this.setFormField(\n          'program_objective_attachments',\n          res?.program_objective?.attachments\n        );\n        this.setFormField(\n          'performance_calculation',\n          res?.calculate_past_upcoming_event\n        );\n        this.setFormField('recurring_frequency', res?.program_frequency);\n        if (\n          res?.program_frequency &&\n          this.mode === 'EDIT' &&\n          (this.orgDetails?.hasProgramFullPermission ||\n            !this.programSimplifyFlag)\n        ) {\n          this.additionalOption.PROGRAM_FREQUENCY = true;\n          this.populateOptionalFields();\n        }\n        this.setFormField('lock_scope_change', res?.lock_scope);\n        if (\n          res?.lock_scope &&\n          (this.orgDetails?.hasProgramFullPermission ||\n            !this.programSimplifyFlag)\n        ) {\n          this.additionalOption.SCOPE_CHANGES = true;\n          this.populateOptionalFields();\n        }\n        this.setFormField('program_state', res?.state);\n        const rc = res.rc_details.map((ele: any) => {\n          return { ...ele, item_name: ele?.rc_name, item_id: ele?.rc_id };\n        });\n        this.setFormField('rc', rc);\n        if (\n          res?.rc_details &&\n          res?.rc_details?.length &&\n          (this.orgDetails?.hasProgramFullPermission ||\n            !this.programSimplifyFlag)\n        ) {\n          this.additionalOption.RC = true;\n          this.populateOptionalFields();\n        }\n        this.setFormField('evidence_required', res?.evidence_upload_flag);\n        this.setFormField('allow_any_file_key_evidence', res?.is_key_evidence);\n        if (\n          (res?.evidence_upload_flag || res?.is_key_evidence) &&\n          (this.orgDetails?.hasProgramFullPermission ||\n            !this.programSimplifyFlag)\n        ) {\n          this.additionalOption.FORMATE_EVIDENCE = true;\n          this.populateOptionalFields();\n        }\n        this.setFormField(\n          'assignee_completion_criteria',\n          res.default_assignee_type\n        );\n        this.setFormField(\n          'reviewer_completion_criteria',\n          res.default_reviewers_type\n        );\n\n        this.editorData.programDescription = res.description?.text;\n        this.editorData.programObjective = res.program_objective?.text;\n        this.setFormField('framework', {\n          ...res.framework_details,\n          ...{ _id: res?.framework_details?.framework_id },\n        });\n        const role = res?.roles?.map((ele: any) => {\n          return {\n            _id: ele?.roleId,\n            roleName: ele?.roleName,\n            licenseType: ele?.licenseType,\n            permissionGroupName: ele?.permissionGroupName,\n          };\n        });\n        this.setFormField('program_roles', role);\n        if (res?.roles && res?.roles?.length && this.mode === 'EDIT') {\n          this.additionalOption.ROLES = true;\n        }\n        if (res.assessmentData.length) {\n          res.assessmentData = res.assessmentData.map((ele: any) => {\n            return {\n              ...ele,\n              assessmentIds: ele?.assessments.map((assess: any) => {\n                return { ...assess, id: assess?._id };\n              }),\n            };\n          });\n          this.setFormField('program_assessments', res.assessmentData);\n          if (\n            this.orgDetails?.hasProgramFullPermission ||\n            !this.programSimplifyFlag\n          ) {\n            this.additionalOption.ASSESSMENT = true;\n            this.populateOptionalFields();\n          }\n        }\n\n        if (res.custom_fields.length) {\n          this.setFormField('custom_fields', res.custom_fields);\n          this.additionalOption.CUSTOM_FIELDS = true;\n          this.populateOptionalFields();\n        }\n        this.isApproverDisabled = res?.isApproverDisabled ?? false;\n        if (this.isApproverDisabled) {\n          setTimeout(() => {\n            this.disableElementsFromMoreOptions.emit(['APPROVER']);\n          }, 500);\n        }\n\n        this.populateMembers(res);\n        this.populateGroups(res);\n        this.fetchUsersAssociatedWithRoles('getProgramDetails');\n        this.fetchGroupsAssociatedWithRoles();\n        this.fetchOrganizationGroup();\n        this.fetchOrganizationUsers();\n      });\n  }\n\n  populateMembers(res: any) {\n    this.loader = true;\n    const ids = [\n      ...new Set([\n        ...(res?.owners ?? []),\n        ...(res?.approvers ?? []),\n        ...(res?.assignee_ids ?? []),\n        ...(res?.default_assignee_ids ?? []),\n        ...(res?.reviewers ?? []),\n        ...(res?.default_reviewers ?? []),\n        ...(res?.overseers?.cc_email ?? []),\n        ...(res?.overseers?.failure_cc_email ?? []).filter((ele: any) => ele),\n        ...(res?.default_overseers?.cc_email ?? []),\n        ...(res?.default_overseers?.failure_cc_email ?? []).filter(\n          (ele: any) => ele\n        ),\n      ]),\n    ];\n    this.programService.getMemeberByIds(ids).subscribe({\n      next: (response: any) => {\n        this.loader = false;\n        if (res.owners && res?.owners?.length) {\n          const owners = response.filter((ele: any) =>\n            res?.owners.includes(ele?.member_id)\n          );\n          this.setFormField('program_owners', owners);\n          if (this.mode === 'EDIT') {\n            this.additionalOption.OWNERS = true;\n            this.populateOptionalFields();\n          }\n        }\n        if (\n          res.approvers &&\n          res?.approvers?.length &&\n          !this.programSimplifyFlag\n        ) {\n          const approvers = response.filter((ele: any) =>\n            res?.approvers.includes(ele?.member_id)\n          );\n          this.setFormField('program_approver', approvers);\n          this.additionalOption.APPROVER = true;\n          this.populateOptionalFields();\n        }\n        if (res?.assignee_ids && res?.assignee_ids?.length) {\n          const assignee = response.filter((ele: any) =>\n            res?.assignee_ids.includes(ele?.member_id)\n          );\n          this.setFormField('program_assignee', assignee);\n          this.lists.DEFAULT_ASSIGNEES = assignee;\n          if (\n            this.orgDetails?.hasProgramFullPermission ||\n            !this.programSimplifyFlag\n          ) {\n            this.additionalOption.ASSIGNEES = true;\n            this.populateOptionalFields();\n          }\n        }\n        if (res?.default_assignee_ids && res?.default_assignee_ids?.length) {\n          const assignee = response.filter((ele: any) =>\n            res?.default_assignee_ids.includes(ele?.member_id)\n          );\n          this.setFormField('program_default_assignee', assignee);\n          if (\n            this.orgDetails?.hasProgramFullPermission ||\n            !this.programSimplifyFlag\n          ) {\n            this.additionalOption.ASSIGNEES = true;\n            this.populateOptionalFields();\n          }\n        }\n        if (res?.reviewers && res?.reviewers?.length) {\n          const reviewers = response.filter((ele: any) =>\n            res?.reviewers.includes(ele?.member_id)\n          );\n          this.setFormField('program_reviewer', reviewers);\n          this.lists.DEFAULT_REVIEWERS = reviewers;\n          if (\n            this.orgDetails?.hasProgramFullPermission ||\n            !this.programSimplifyFlag\n          ) {\n            this.additionalOption.REVIEWER = true;\n            this.populateOptionalFields();\n          }\n        }\n        if (res?.default_reviewers && res?.default_reviewers?.length) {\n          const reviewers = response.filter((ele: any) =>\n            res?.default_reviewers.includes(ele?.member_id)\n          );\n          this.setFormField('program_default_reviewer', reviewers);\n          if (\n            this.orgDetails?.hasProgramFullPermission ||\n            !this.programSimplifyFlag\n          ) {\n            this.additionalOption.REVIEWER = true;\n            this.populateOptionalFields();\n          }\n        }\n        if (res?.overseers && res?.overseers?.cc_email?.length) {\n          const cc = response.filter((ele: any) =>\n            res?.overseers?.cc_email.includes(ele?.member_id)\n          );\n          this.setFormField('program_overseer', cc);\n          this.lists.DEFAULT_OVERSEERS = cc;\n          if (\n            this.orgDetails?.hasProgramFullPermission ||\n            !this.programSimplifyFlag\n          ) {\n            this.additionalOption.OVERSEER = true;\n            this.populateOptionalFields();\n          }\n        }\n\n        if (\n          res?.default_overseers &&\n          (res?.default_overseers?.cc_email?.length ||\n            res?.default_overseers?.failure_cc_email?.length)\n        ) {\n          if (res?.default_overseers?.cc_email?.length) {\n            const defaultCC = response.filter((ele: any) =>\n              res?.default_overseers?.cc_email.includes(ele?.member_id)\n            );\n            this.setFormField('program_default_overseer', defaultCC);\n          }\n          if (res?.default_overseers?.failure_cc_email?.length) {\n            const failCC = response.filter((ele: any) =>\n              res?.default_overseers?.failure_cc_email.includes(ele?.member_id)\n            );\n            this.setFormField('program_default_failed_overseer', failCC);\n          }\n          if (\n            this.orgDetails?.hasProgramFullPermission ||\n            !this.programSimplifyFlag\n          ) {\n            this.additionalOption.OVERSEER = true;\n            this.populateOptionalFields();\n          }\n        }\n      },\n    });\n    this.checkProgramOptionField();\n  }\n\n  populateGroups(res: any) {\n    const ids = [\n      ...new Set([\n        ...(res?.owners_group ?? []),\n        ...(res?.assignee_group_ids ?? []),\n        ...(res?.default_assignee_group_ids ?? []),\n        ...(res?.overseers?.cc_email_groups ?? []),\n        ...(res?.reviewer_group_ids ?? []),\n        ...(res?.default_reviewer_group_ids ?? []),\n        ...(res?.default_overseers?.cc_email_groups ?? []),\n        ...(res?.default_overseers?.failure_cc_email_groups ?? []),\n      ]),\n    ];\n    this.programService.getMemberByGroups(ids).subscribe({\n      next: (resp: any) => {\n        const response = resp?.data;\n        if (res.owners_group && res?.owners_group?.length) {\n          const owners = response.filter((ele: any) =>\n            res?.owners_group?.includes(ele?.group_id)\n          );\n          this.setFormField('program_owners_group', owners);\n        }\n        if (res.assignee_group_ids && res?.assignee_group_ids?.length) {\n          const assignee = response.filter((ele: any) =>\n            res?.assignee_group_ids?.includes(ele?.group_id)\n          );\n          this.setFormField('program_assignee_group', assignee);\n          this.lists.DEFAULT_ASSIGNEES_GROUP = assignee;\n          if (\n            this.orgDetails?.hasProgramFullPermission ||\n            !this.programSimplifyFlag\n          ) {\n            this.additionalOption.ASSIGNEES = true;\n          }\n        }\n        if (\n          res?.default_assignee_group_ids &&\n          res?.default_assignee_group_ids?.length\n        ) {\n          const assignee = response.filter((ele: any) =>\n            res?.default_assignee_group_ids?.includes(ele?.group_id)\n          );\n          this.setFormField('program_default_assignee_group', assignee);\n          if (\n            this.orgDetails?.hasProgramFullPermission ||\n            !this.programSimplifyFlag\n          ) {\n            this.additionalOption.ASSIGNEES = true;\n          }\n        }\n        if (res?.reviewer_group_ids && res?.reviewer_group_ids?.length) {\n          const reviewer = response.filter((ele: any) =>\n            res?.reviewer_group_ids?.includes(ele?.group_id)\n          );\n          this.setFormField('program_reviewer_group', reviewer);\n          this.lists.DEFAULT_REVIEWERS_GROUP = reviewer;\n          if (\n            this.orgDetails?.hasProgramFullPermission ||\n            !this.programSimplifyFlag\n          ) {\n            this.additionalOption.REVIEWER = true;\n          }\n        }\n        if (\n          res?.default_reviewer_group_ids &&\n          res?.default_reviewer_group_ids?.length\n        ) {\n          const reviewer = response?.filter((ele: any) =>\n            res?.default_reviewer_group_ids?.includes(ele?.group_id)\n          );\n          this.setFormField('program_default_reviewer_group', reviewer);\n          this.controls.reviewer_completion_criteria.value =\n            this.controls?.program_default_reviewer_group?.value?.length > 0\n              ? 'ANYONE'\n              : this.controls?.reviewer_completion_criteria?.value;\n          if (\n            this.orgDetails?.hasProgramFullPermission ||\n            !this.programSimplifyFlag\n          ) {\n            this.additionalOption.REVIEWER = true;\n          }\n        }\n        if (\n          res?.overseers?.cc_email_groups &&\n          res?.overseers?.cc_email_groups?.length\n        ) {\n          const overseerGroup = response.filter((ele: any) =>\n            res?.overseers?.cc_email_groups?.includes(ele?.group_id)\n          );\n          this.setFormField('program_overseer_group', overseerGroup);\n          this.lists.DEFAULT_OVERSEERS_GROUP = overseerGroup;\n          if (\n            this.orgDetails?.hasProgramFullPermission ||\n            !this.programSimplifyFlag\n          ) {\n            this.additionalOption.OVERSEER = true;\n          }\n        }\n        if (\n          res?.default_overseers?.cc_email_groups &&\n          res?.default_overseers?.cc_email_groups?.length\n        ) {\n          const defaultOverseerGroup = response.filter((ele: any) =>\n            res?.default_overseers?.cc_email_groups?.includes(ele?.group_id)\n          );\n          this.setFormField(\n            'program_default_overseer_group',\n            defaultOverseerGroup\n          );\n          if (\n            this.orgDetails?.hasProgramFullPermission ||\n            !this.programSimplifyFlag\n          ) {\n            this.additionalOption.OVERSEER = true;\n          }\n        }\n        if (\n          res?.default_overseers?.failure_cc_email_groups &&\n          res?.default_overseers?.failure_cc_email_groups?.length\n        ) {\n          const defaultOverseerFailureGroup = response.filter((ele: any) =>\n            res?.default_overseers?.failure_cc_email_groups?.includes(\n              ele?.group_id\n            )\n          );\n          this.setFormField(\n            'program_default_failed_overseer_group',\n            defaultOverseerFailureGroup\n          );\n          if (\n            this.orgDetails?.hasProgramFullPermission ||\n            !this.programSimplifyFlag\n          ) {\n            this.additionalOption.OVERSEER = true;\n          }\n        }\n      },\n      // As of now groups has been removed from reviewer and overseeer if this group feature gets incoperated in\n      //future need to add group condition here to prepopulate the data while editing.\n    });\n    this.checkProgramOptionField();\n  }\n\n  resetAdditionalOption() {\n    this.additionalOption.ROLES = false;\n    this.additionalOption.OWNERS = false;\n    this.additionalOption.APPROVER = false;\n    this.additionalOption.PROGRAM_FREQUENCY = false;\n    this.additionalOption.SCOPE_CHANGES = false;\n    this.additionalOption.RC = false;\n    this.additionalOption.ASSIGNEES = false;\n    this.additionalOption.REVIEWER = false;\n    this.additionalOption.OVERSEER = false;\n    this.additionalOption.ASSESSMENT = false;\n    this.additionalOption.FORMATE_EVIDENCE = false;\n    this.additionalOption.CUSTOM_FIELDS = false;\n  }\n\n  checkProgramOptionField(): any {\n    const code = [\n      'PROGRAM_FREQUENCY',\n      'SCOPE_CHANGES',\n      'RC',\n      'ASSIGNEES',\n      'REVIEWER',\n      'OVERSEER',\n      'ASSESSMENT',\n      'FORMATE_EVIDENCE',\n      'CUSTOM_FIELDS',\n    ];\n    let isMoreOption = false;\n    code.forEach((key: string) => {\n      if (this.additionalOption[key]) {\n        isMoreOption = true;\n      }\n    });\n    this.isProgramScope = isMoreOption;\n  }\n  enablefeature() {\n    this.featureflagrole = this.allowedFeature.isFeatureEnabled(\n      'ff_role_improvements'\n    );\n    this.isAscentAllowed = this.allowedFeature.isFeatureEnabled(\n      'ff_compliance_framework'\n    );\n    this.programSimplifyFlag = this.allowedFeature.isFeatureEnabled(\n      'ff_program_simplify'\n    );\n    this.featureflagGroups =\n      this.allowedFeature.isFeatureEnabled('ff_program_groups');\n    this.toolTipData.owner = this.featureflagrole\n      ? 'Owners are responsible for managing a Program. Only Owners can make changes to a Program and the responsibilities that are linked with the Program.<br>The <strong>Key Power User</strong> and all <b>Power Users</b> will be selected as the Owners of a Program by default.'\n      : 'Owners are responsible for managing a Program. Only Owners can make changes to a Program and the responsibilities that are linked with the Program.<br>The <strong>Key Admin</strong> and all <b>Admin</b> users will be selected as the Owners of a Program by default.';\n    this.ff_rc_listing = this.allowedFeature.isFeatureEnabled('ff_rc_listing');\n  }\n}\n","<div class=\"workflow-program\" #form>\n  <form novalidate [formGroup]=\"programForm\">\n    <!-- Program Category Type -->\n    <form-field\n      [checked]=\"controls?.program_type?.value > -1\"\n      [active]=\"false\"\n      [disabled]=\"sideElements.includes(activeList)\"\n      [img]=\"ASSETS.issue_type\"\n    >\n      <label class=\"vx-control-panel\"\n        >PROGRAM TYPE <span class=\"required\">*</span></label\n      >\n      <tab-selector\n        formControlName=\"program_type\"\n        [displayArray]=\"constants?.categoryType\"\n      ></tab-selector>\n      <!-- <p *ngIf=\"program_name?.invalid\" class=\"error-message\">Add a program type</p> -->\n    </form-field>\n\n    <!-- Framework -->\n    <form-field\n      *ngIf=\"isAscentAllowed\"\n      [checked]=\"false\"\n      [active]=\"false\"\n      [disabled]=\"false\"\n      [img]=\"ASSETS.case_category\"\n    >\n      <label class=\"vx-control-panel\">FRAMEWORK</label>\n      <!-- [selectDiv]=\"true\" -->\n      <input-with-pill\n        [placeholder]=\"'Select a framework that this Program relates to'\"\n        (select)=\"activateList('FRAMEWORK')\"\n      >\n        <div class=\"selected\" *ngIf=\"controls?.framework.value?.name\">\n          <div class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\">\n            <i\n              class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n              *ngIf=\"canFrameworkChange\"\n              (click)=\"remove('', 'FRAMEWORK')\"\n              >&#xe9ae;</i\n            >\n            <span\n              class=\"chipName vx-fs-11 vx-label-txt\"\n              [appTooltip]=\"controls?.framework.value?.name\"\n              placement=\"bottom-left\"\n              delay=\"0\"\n              type=\"black\"\n              [tooltipMandatory]=\"false\"\n              >{{ controls?.framework.value?.name }}</span\n            >\n          </div>\n\n          <!-- <div class=\"chip-container\">\n                        <div class=\"chip-inner\">\n                            <span class=\"chip\"><i (click)=\"remove('', 'FRAMEWORK')\" *ngIf=\"canFrameworkChange\" class=\"icons\" >&#xe90d;</i> {{controls?.framework.value?.name}}</span>\n                        </div>\n                    </div> -->\n          <button\n            *ngIf=\"canFrameworkChange\"\n            class=\"edit\"\n            type=\"button\"\n            (click)=\"activateList('FRAMEWORK')\"\n          >\n            <i class=\"icons\">&#xe9ba;</i> Edit\n          </button>\n        </div>\n      </input-with-pill>\n    </form-field>\n\n    <!-- Program Category Name -->\n    <form-field\n      [checked]=\"controls?.program_name?.value?.trim()?.length\"\n      [active]=\"false\"\n      [disabled]=\"sideElements.includes(activeList)\"\n      [img]=\"ASSETS.what\"\n    >\n      <label class=\"vx-control-panel\"\n        >PROGRAM NAME <span class=\"required\">*</span></label\n      >\n      <input\n        InputTrim\n        formControlName=\"program_name\"\n        type=\"text\"\n        placeholder=\"What is the Program name?\"\n      />\n\n      <p\n        *ngIf=\"\n          controls?.program_name?.errors && controls?.program_name?.touched\n        \"\n        class=\"error-message\"\n      >\n        Enter a name for this Program.\n      </p>\n      <p *ngIf=\"isNameExists\" class=\"error-message\">\n        Program name already exists.\n      </p>\n      <div class=\"upload-files vx-d-flex vx-align-center vx-flex-wrap vx-mt-1\">\n        <file-pill\n          *ngFor=\"\n            let attachment of controls?.description_attachment?.value\n              | slice : 0 : 2\n          \"\n          [extension]=\"attachment?.org_file?.split('.').pop()\"\n          [name]=\"attachment?.org_file\"\n          [disabled]=\"attachment?.uploading\"\n          (delete)=\"deleteAttachment('DESCRIPTION', attachment)\"\n        >\n        </file-pill>\n        <button\n          *ngIf=\"controls?.description_attachment?.value?.length > 2\"\n          class=\"file-count\"\n          appPopover\n          (click)=\"uploadFile.popover()\"\n          placement=\"right\"\n        >\n          +{{ controls?.description_attachment?.value?.length - 2 }}\n        </button>\n        <app-popover #uploadFile [dontCloseonClick]=\"true\">\n          <div class=\"wf-action-list\">\n            <ul class=\"action-item\">\n              <li\n                class=\"vx-p-2\"\n                *ngFor=\"\n                  let attachment of controls?.description_attachment?.value\n                    | slice : 2\n                \"\n              >\n                <file-pill\n                  [extension]=\"attachment?.org_file?.split('.').pop()\"\n                  [name]=\"attachment?.org_file\"\n                  [disabled]=\"attachment?.uploading\"\n                  (delete)=\"deleteAttachment('DESCRIPTION', attachment)\"\n                ></file-pill>\n              </li>\n            </ul>\n          </div>\n        </app-popover>\n      </div>\n      <vcomply-editor\n        [(ngModel)]=\"editorData.programDescription\"\n        [ngModelOptions]=\"{ standalone: true }\"\n        (sendSavedFiles)=\"selectFile('DESCRIPTION', $event)\"\n        (ngModelChange)=\"setFormField('program_description', $event)\"\n        [editorConfig]=\"constants?.description\"\n      >\n      </vcomply-editor>\n    </form-field>\n\n    <!-- Objective -->\n    <form-field\n      [checked]=\"controls?.program_objective?.value?.trim()?.length\"\n      [active]=\"activeList === 'OBJECTIVE'\"\n      [disabled]=\"\n        sideElements.includes(activeList) && activeList !== 'OBJECTIVE'\n      \"\n      [img]=\"ASSETS.objectives\"\n    >\n      <label class=\"vx-control-panel\"\n        >OBJECTIVE\n        <!-- <span class=\"required\">*</span> -->\n      </label>\n      <vcomply-editor\n        [(ngModel)]=\"editorData.programObjective\"\n        [ngModelOptions]=\"{ standalone: true }\"\n        (sendSavedFiles)=\"selectFile('OBJECTIVE', $event)\"\n        (ngModelChange)=\"setFormField('program_objective', $event, true)\"\n        [editorConfig]=\"constants?.objective\"\n      >\n      </vcomply-editor>\n      <!-- <p *ngIf=\"!isObjectiveValid\" class=\"error-message\">Specify the objective for this Program.</p> -->\n    </form-field>\n\n    <!-- Roles -->\n    <form-field\n      *ngIf=\"additionalOption?.ROLES\"\n      [checked]=\"controls?.program_roles?.value?.length\"\n      [active]=\"activeList === 'ROLE'\"\n      [disabled]=\"sideElements.includes(activeList) && activeList !== 'ROLE'\"\n      [img]=\"ASSETS.roles\"\n    >\n      <label class=\"vx-control-panel\" id=\"permissiongroup\"\n        >{{ ff_rc_listing ? \"PERMISSIONS\" : \"PERMISSION GROUP(S)\" }}\n        <span class=\"required\">*</span\n        ><i\n          class=\"icons\"\n          [appTooltip]=\"\n            ff_rc_listing\n              ? 'Permissions let you specify the users that can be “Owners”' +\n                (allowedFeature.isFeatureEnabled('ff_program_simplify')\n                  ? ' '\n                  : ' and “Approvers”') +\n                'of a Program.'\n              : 'Permission group(s) let you specify the users that can be “Owners”' +\n                (allowedFeature.isFeatureEnabled('ff_program_simplify')\n                  ? ' '\n                  : ' and “Approvers”') +\n                'of a Program.'\n          \"\n          placement=\"bottom\"\n          delay=\"0\"\n          type=\"white\"\n          [tooltipMandatory]=\"true\"\n          id=\"RoleHelpText\"\n          >&#xeb16;</i\n        ></label\n      >\n      <input-with-pill\n        id=\"placeholdername\"\n        [placeholder]=\"\n          ff_rc_listing\n            ? 'Which user permissions have access to this program?'\n            : 'Which user permission groups have access to this program?'\n        \"\n        (select)=\"activateList('ROLE')\"\n      >\n        <div class=\"selected\" *ngIf=\"controls?.program_roles?.value?.length\">\n          <div class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\">\n            <i\n              class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n              *ngIf=\"\n                !lists.SYSTEM_ROLE_IDS.includes(\n                  controls?.program_roles?.value[0]?._id\n                )\n              \"\n              (click)=\"remove(controls?.program_roles?.value[0], 'ROLE')\"\n              >&#xe9ae;</i\n            >\n            <span\n              class=\"chipName vx-fs-11 vx-label-txt\"\n              [appTooltip]=\"\n                featureflagrole &&\n                controls?.program_roles?.value[0]?.permissionGroupName\n                  ? controls?.program_roles?.value[0]?.permissionGroupName\n                  : controls?.program_roles?.value[0]?.roleName\n              \"\n              placement=\"bottom-left\"\n              delay=\"0\"\n              type=\"black\"\n              [tooltipMandatory]=\"false\"\n              >{{\n                featureflagrole &&\n                controls?.program_roles?.value[0]?.permissionGroupName\n                  ? controls?.program_roles?.value[0]?.permissionGroupName\n                  : controls?.program_roles?.value[0]?.roleName\n              }}</span\n            >\n            <button\n              class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n              appPopover\n              (click)=\"role.popover()\"\n              placement=\"right\"\n              *ngIf=\"controls?.program_roles?.value?.length > 1\"\n            >\n              +{{ controls?.program_roles?.value?.length - 1 }}\n            </button>\n          </div>\n\n          <!-- <div class=\"chip-container\">\n                        <div class=\"chip-inner\">\n                            <span class=\"chip\"><i *ngIf=\"!lists.SYSTEM_ROLE_IDS.includes(controls?.program_roles?.value[0]?._id)\" (click)=\"remove(controls?.program_roles?.value[0],'ROLE')\" class=\"icons\">&#xe90d;</i>{{featureflagrole && controls?.program_roles?.value[0]?.permissionGroupName ? controls?.program_roles?.value[0]?.permissionGroupName : controls?.program_roles?.value[0]?.roleName}}</span>\n                            <button *ngIf=\"controls?.program_roles?.value?.length > 1\" class=\"count\" appPopover (click)=\"role.popover()\" placement=\"right\">+{{controls?.program_roles?.value?.length - 1}}</button>\n                        </div>\n                    </div> -->\n          <button\n            *ngIf=\"activeList !== 'ROLE'\"\n            class=\"edit\"\n            type=\"button\"\n            (click)=\"activateList('ROLE')\"\n          >\n            <i class=\"icons\">&#xe9ba;</i> Edit\n          </button>\n        </div>\n      </input-with-pill>\n      <p *ngIf=\"false\" class=\"error-message\">\n        {{ featureflagrole ? \"Add a permission group(s)\" : \"Add a role(s)\" }}\n      </p>\n      <app-popover #role [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li *ngFor=\"let data of controls?.program_roles?.value | slice : 1\">\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i\n                    *ngIf=\"!lists.SYSTEM_ROLE_IDS.includes(data?._id)\"\n                    class=\"icons\"\n                    (click)=\"removeRole(data, 'ROLE')\"\n                    >&#xe90d;</i\n                  >\n                  {{\n                    featureflagrole && data?.permissionGroupName\n                      ? data?.permissionGroupName\n                      : data?.roleName\n                  }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n    </form-field>\n\n    <!-- Owners -->\n    <form-field\n      *ngIf=\"additionalOption?.OWNERS\"\n      [checked]=\"\n        controls?.program_owners.value?.length > 0 ||\n        controls?.program_owners_group.value?.length > 0\n      \"\n      [active]=\"activeList === 'OWNER'\"\n      [disabled]=\"sideElements.includes(activeList) && activeList !== 'OWNER'\"\n      [img]=\"ASSETS.case_owners\"\n    >\n      <label class=\"vx-control-panel\"\n        >OWNER(S)\n        <span\n          class=\"icon\"\n          *ngIf=\"toolTipData.owner !== ''\"\n          libPopoverHover\n          (mouseover)=\"dataTooltip.popover()\"\n          (mouseleave)=\"dataTooltip.closePopover()\"\n          placement=\"right\"\n          ><i class=\"icons\">&#xe91f;</i></span\n        >\n        <popover-hover #dataTooltip>\n          <div class=\"vx-info-card\">\n            <div\n              class=\"vx-info-card-body\"\n              [innerHTML]=\"toolTipData.owner\"\n              id=\"OwnerHelpText\"\n            ></div>\n          </div>\n        </popover-hover>\n      </label>\n      <input-with-pill\n        [placeholder]=\"'Who is responsible for managing this program?'\"\n        (select)=\"activateList('OWNER')\"\n      >\n        <div class=\"selected\" *ngIf=\"controls?.program_owners.value[0]\">\n          <div class=\"vx-d-flex vx-align-center\">\n            <div\n              class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n            >\n              <span\n                class=\"chipName vx-fs-11 vx-label-txt\"\n                [appTooltip]=\"controls?.program_owners?.value[0]?.member_name\"\n                placement=\"bottom-left\"\n                delay=\"0\"\n                type=\"black\"\n                [tooltipMandatory]=\"false\"\n                >{{ controls?.program_owners?.value[0]?.member_name }}</span\n              >\n              <button\n                class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4 greenBg\"\n                appPopover\n                (click)=\"owner.popover()\"\n                placement=\"right\"\n                *ngIf=\"controls?.program_owners?.value?.length > 1\"\n              >\n                +{{ controls?.program_owners?.value?.length - 1 }}\n              </button>\n            </div>\n            <span\n              class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n              *ngIf=\"\n                controls?.program_owners_group?.value?.length &&\n                controls?.program_owners?.value?.length\n              \"\n              >&</span\n            >\n            <div\n              class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n              *ngIf=\"controls?.program_owners_group?.value?.length\"\n            >\n              <i\n                class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                *ngIf=\"\n                  !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n                    owner?.user_role\n                  )\n                \"\n                (click)=\"\n                  remove(\n                    controls?.program_owners_group?.value[0],\n                    'OWNER_GROUP'\n                  )\n                \"\n                >&#xe9ae;</i\n              >\n              <span\n                class=\"chipName vx-fs-11 vx-label-txt\"\n                [appTooltip]=\"\n                  controls?.program_owners_group?.value[0]?.group_name\n                \"\n                placement=\"bottom-left\"\n                delay=\"0\"\n                type=\"black\"\n                [tooltipMandatory]=\"false\"\n                >{{\n                  controls?.program_owners_group?.value[0]?.group_name\n                }}</span\n              >\n              <button\n                class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                appPopover\n                (click)=\"group.popover()\"\n                placement=\"right\"\n                *ngIf=\"controls?.program_owners_group?.value?.length > 1\"\n              >\n                +{{ controls?.program_owners_group?.value?.length - 1 }}\n              </button>\n            </div>\n          </div>\n\n          <button\n            *ngIf=\"activeList !== 'OWNER'\"\n            [class.disabled]=\"controls?.all_user_in_role?.value\"\n            (click)=\"activateList('OWNER')\"\n            class=\"edit\"\n            type=\"button\"\n          >\n            <i class=\"icons\">&#xe9ba;</i>Edit\n          </button>\n        </div>\n      </input-with-pill>\n      <p *ngIf=\"false\" class=\"error-message\">Add a owner(s)</p>\n      <div class=\"vx-d-flex vx-align-center vx-justify-end vx-mt-2\">\n        <div\n          class=\"vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase vx-mr-2\"\n        >\n          {{\n            featureflagrole\n              ? \"ALL USERS ASSOCIATED WITH THE SELECTED PERMISSION GROUPS\"\n              : \"ALL USERS ASSOCIATED WITH THE SELECTED ROLES\"\n          }}\n        </div>\n        <switch\n          formControlName=\"all_user_in_role\"\n          (change)=\"selectAllRoleOwner($event)\"\n        ></switch>\n      </div>\n      <app-popover #owner [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li\n              *ngFor=\"let owner of controls?.program_owners?.value | slice : 1\"\n            >\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i\n                    *ngIf=\"\n                      !(\n                        lists.NON_REMOVABLE_OWNERS | listToId : 'member_id'\n                      ).includes(owner?.member_id)\n                    \"\n                    class=\"icons\"\n                    (click)=\"remove(owner, 'OWNER')\"\n                    >&#xe90d;</i\n                  >\n                  {{ owner?.member_name }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n      <app-popover #group [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li\n              *ngFor=\"\n                let owner of controls?.program_owners_group?.value | slice : 1\n              \"\n            >\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i\n                    *ngIf=\"\n                      !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n                        owner?.user_role\n                      )\n                    \"\n                    class=\"icons\"\n                    (click)=\"remove(owner, 'OWNER_GROUP')\"\n                    >&#xe90d;</i\n                  >\n                  {{ owner?.group_name }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n    </form-field>\n\n    <!-- Collaborator -->\n    <form-field\n      *ngIf=\"additionalOption?.COLLABORATOR\"\n      [checked]=\"\n        controls?.program_collaborator?.value?.length > 0\n      \"\n      [active]=\"activeList === 'COLLABORATOR'\"\n      [disabled]=\"sideElements.includes(activeList) && activeList !== 'COLLABORATOR'\"\n      [img]=\"ASSETS.case_owners\"\n    >\n      <label class=\"vx-control-panel\"\n        >Collaborator(S) <span class=\"required\">*</span>\n        <span\n          class=\"icon\"\n          libPopoverHover\n          (mouseover)=\"dataTooltip.popover()\"\n          (mouseleave)=\"dataTooltip.closePopover()\"\n          placement=\"right\"\n          ><i class=\"icons\">&#xe91f;</i></span\n        >\n        <popover-hover #dataTooltip>\n          <div class=\"vx-info-card\">\n            <div\n              class=\"vx-info-card-body\"\n              [innerHTML]=\"toolTipData.owner\"\n              id=\"OwnerHelpText\"\n            ></div>\n          </div>\n        </popover-hover>\n      </label>\n      <input-with-pill\n        [placeholder]=\"'Who is responsible for managing this program?'\"\n        (select)=\"activateList('COLLABORATOR')\"\n      >\n        <div class=\"selected\" *ngIf=\"controls?.program_collaborator?.value[0]\">\n          <div class=\"vx-d-flex vx-align-center\">\n            <div\n              class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n            >\n              <span\n                class=\"chipName vx-fs-11 vx-label-txt\"\n                [appTooltip]=\"controls?.program_collaborator?.value[0]?.member_name\"\n                placement=\"bottom-left\"\n                delay=\"0\"\n                type=\"black\"\n                [tooltipMandatory]=\"false\"\n                >{{ controls?.program_collaborator?.value[0]?.member_name }}</span\n              >\n              <button\n                class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4 greenBg\"\n                appPopover\n                (click)=\"collaborator.popover()\"\n                placement=\"right\"\n                *ngIf=\"controls?.program_collaborator?.value?.length > 1\"\n              >\n                +{{ controls?.program_collaborator?.value?.length - 1 }}\n              </button>\n            </div>\n            \n          </div>\n\n          <button\n            *ngIf=\"activeList !== 'COLLABORATOR'\"\n            [class.disabled]=\"controls?.all_user_in_role?.value\"\n            (click)=\"activateList('COLLABORATOR')\"\n            class=\"edit\"\n            type=\"button\"\n          >\n            <i class=\"icons\">&#xe9ba;</i>Edit\n          </button>\n        </div>\n      </input-with-pill>\n      <div class=\"vx-d-flex vx-align-center vx-justify-end vx-mt-2\">\n        <div\n          class=\"vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase vx-mr-2\"\n        >\n        </div>\n      </div>\n      <app-popover #collaborator [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li\n              *ngFor=\"let collaborator of controls?.program_collaborator?.value | slice : 1\"\n            >\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i\n                    class=\"icons\"\n                    (click)=\"remove(collaborator, 'COLLABORATOR')\"\n                    >&#xe90d;</i\n                  >\n                  {{ collaborator?.member_name }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n    </form-field>\n\n    <!-- Performance Calculated -->\n    <!-- <form-field [checked]=\"controls?.performance_calculation?.value\" [active]=\"activeList === 'PERFORMANCE'\" [disabled]=\"sideElements.includes(activeList) && activeList !== 'PERFORMANCE'\"\n            [img]=\"'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/performance-calc.svg'\">\n            <label class=\"vx-control-panel\">HOW SHOULD THE PERFORMANCE OF THIS PROGRAM BE CALCULATED?</label>\n            <tab-selector formControlName=\"performance_calculation\" [displayArray]=\"constants?.performanceCalculation\">\n            </tab-selector>\n        </form-field> -->\n    <ng-container *ngIf=\"isProgramScope\">\n      <div\n        class=\"scope-label vx-fs-10 vx-txt-white vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mb-5 vx-lh-4 vx-d-inline-block\"\n      >\n        PROGRAM SCOPE\n      </div>\n      <!-- <i  class=\"icons info-icon vx-fs-12 vx-txt-blue vx-ml-1\" [appTooltip]=\"tooltip.programScope\" placement=\"bottom\" delay=\"0\" type=\"white\" [tooltipMandatory]=\"true\">&#xe91f;</i> -->\n      <span\n        class=\"icon info-icon vx-fs-12 vx-txt-blue vx-ml-1\"\n        *ngIf=\"toolTipData.programScop !== ''\"\n        libPopoverHover\n        (mouseover)=\"dataTooltip.popover()\"\n        (mouseleave)=\"dataTooltip.closePopover()\"\n        placement=\"right\"\n        ><i class=\"icons\">&#xe91f;</i></span\n      >\n      <popover-hover #dataTooltip>\n        <div class=\"vx-info-card\">\n          <div\n            class=\"vx-info-card-body\"\n            [innerHTML]=\"toolTipData.programScope\"\n            id=\"PSHelpText\"\n          ></div>\n        </div>\n      </popover-hover>\n    </ng-container>\n\n    <!-- Program Frequency -->\n    <form-field\n      *ngIf=\"additionalOption?.PROGRAM_FREQUENCY\"\n      [checked]=\"[true, false].includes(controls?.recurring_frequency?.value)\"\n      [active]=\"activeList === 'FREQUENCY'\"\n      [disabled]=\"\n        sideElements.includes(activeList) && activeList !== 'FREQUENCY'\n      \"\n      [img]=\"ASSETS.recurring\"\n    >\n      <label class=\"vx-control-panel\" id=\"PDChange\"\n        >PROGRAM DURATION\n        <i\n          class=\"icons\"\n          [appTooltip]=\"\n            'Program Duration refers to the duration of the Program. A Program can occur in perpetuity, or it can occur until the end of the current business cycle that has been specified in ' +\n            businessCycle.selectedCycle.business_cycle +\n            '.  All responsibilities linked with that Program will also have the same Program Duration.'\n          \"\n          placement=\"bottom\"\n          delay=\"0\"\n          type=\"white\"\n          [tooltipMandatory]=\"true\"\n          id=\"ProgramDurationHelpText\"\n          >&#xeb16;</i\n        ></label\n      >\n      <div class=\"upload-format\">\n        <div class=\"vx-d-flex vx-align-center vx-justify-between\">\n          <span class=\"text vx-mb-0\">Is this program recurring?</span>\n          <div class=\"radio-group program\">\n            <app-cs-radio\n              [name]=\"'recurring_frequency'\"\n              [checked]=\"controls?.recurring_frequency?.value\"\n              (checkedEvent)=\"setFormField('recurring_frequency', true)\"\n              >YES</app-cs-radio\n            >\n            <app-cs-radio\n              [name]=\"'recurring_frequency'\"\n              [checked]=\"!controls?.recurring_frequency?.value\"\n              (checkedEvent)=\"setFormField('recurring_frequency', false)\"\n              >NO</app-cs-radio\n            >\n          </div>\n        </div>\n      </div>\n    </form-field>\n\n    <!-- Scope Changes -->\n    <form-field\n      *ngIf=\"additionalOption?.SCOPE_CHANGES\"\n      [checked]=\"[true, false].includes(controls?.lock_scope_change?.value)\"\n      [active]=\"activeList === 'SCOPE'\"\n      [disabled]=\"sideElements.includes(activeList) && activeList !== 'SCOPE'\"\n      [img]=\"ASSETS.lock_scope\"\n    >\n      <label class=\"vx-control-panel\"\n        >Lock the Program Scope\n        <i\n          class=\"icons\"\n          [appTooltip]=\"\n            'If the Program Scope is locked, neither the Program nor the responsibilities linked with the Program can be edited once the Program begins. In order to edit the Program or the linked responsibilities, the Program details will need to be edited.'\n          \"\n          placement=\"bottom\"\n          delay=\"0\"\n          type=\"white\"\n          [tooltipMandatory]=\"true\"\n          id=\"ScopeChangesHelpText\"\n          >&#xeb16;</i\n        ></label\n      >\n      <div class=\"upload-format\">\n        <span class=\"text\"\n          >Would you like to\n          <span class=\"vx-label-txt vx-fw-500\">lock changes</span> to the\n          program scope?</span\n        >\n        <div class=\"radio-group program\">\n          <app-cs-radio\n            [name]=\"'lock_scope_change'\"\n            [checked]=\"controls?.lock_scope_change?.value\"\n            (checkedEvent)=\"setFormField('lock_scope_change', true)\"\n            >YES</app-cs-radio\n          >\n          <app-cs-radio\n            [name]=\"'lock_scope_change'\"\n            [checked]=\"!controls?.lock_scope_change?.value\"\n            (checkedEvent)=\"setFormField('lock_scope_change', false)\"\n            >NO</app-cs-radio\n          >\n        </div>\n      </div>\n    </form-field>\n\n    <!-- Framework -->\n    <!-- <form-field [checked]=\"false\" [active]=\"activeList === 'FRAMEWORK'\" [disabled]=\"sideElements.includes(activeList) && activeList !== 'FRAMEWORK'\"\n            [img]=\"'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/category.svg'\">\n            <label class=\"vx-control-panel\">FRAMEWORK</label>\n            <input-with-pill [placeholder]=\"'Select a framework that this Program relates to'\" (select)=\"activateList('FRAMEWORK')\">\n                <div class=\"selected\" *ngIf=\"controls?.framework?.value?.framework_name\">\n                    <div class=\"chip-container\">\n                        <div class=\"chip-inner\">\n                            <span class=\"chip\"><i (click)=\"remove(controls?.framework.value,'FRAMEWORK')\" class=\"icons\">&#xe90d;</i>{{controls?.framework?.value?.framework_name}}</span>\n                            <button class=\"count\" appPopover (click)=\"framework.popover()\" placement=\"right\">+5</button>\n                        </div>\n                    </div>\n                    <button *ngIf=\"activeList!=='FRAMEWORK'\" (click)=\"activateList('FRAMEWORK')\" class=\"edit\" type=\"button\"><i class=\"icons\">&#xe9ba;</i> Edit</button>\n                </div>\n            </input-with-pill>\n            <app-popover #framework [dontCloseonClick]=\"true\">\n                <div class=\"wf-action-list\">\n                    <ul class=\"action-item\">\n                        <li *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\n                            <div class=\"avatar-card\">\n                                <span class=\"value\">\n                                    <i class=\"icons\">&#xe90d;</i>\n                                    Manage framework name\n                                </span>\n                            </div>\n                        </li>\n                    </ul>\n                </div>\n            </app-popover>\n        </form-field> -->\n\n    <!-- Responsibility Center -->\n    <form-field\n      *ngIf=\"additionalOption?.RC\"\n      [checked]=\"controls?.rc?.value?.length\"\n      [active]=\"activeList === 'RC'\"\n      [disabled]=\"sideElements.includes(activeList) && activeList !== 'RC'\"\n      [img]=\"ASSETS.responsibility_center\"\n    >\n      <label class=\"vx-control-panel\"\n        >RESPONSIBILITY CENTER\n        <i\n          class=\"icons\"\n          [appTooltip]=\"\n            'Responsibility Centers represent your organizational and operational infrastructure. Where Responsibility Centers are selected when creating a Program, only those Responsibilities Centers will be available for selection when creating a responsibility linked with the Program.'\n          \"\n          placement=\"bottom\"\n          delay=\"0\"\n          type=\"white\"\n          [tooltipMandatory]=\"true\"\n          id=\"RCHelpText\"\n          >&#xeb16;</i\n        ></label\n      >\n      <input-with-pill\n        [selectDiv]=\"true\"\n        (select)=\"activateList('RC')\"\n        [placeholder]=\"\n          'Which Responsibility Center(s) can be linked to the responsibilities associated with this Program?'\n        \"\n      >\n        <div\n          class=\"selected\"\n          *ngIf=\"controls?.rc?.value && controls?.rc?.value?.length\"\n        >\n          <div class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\">\n            <i\n              class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n              (click)=\"remove(controls?.rc?.value[0], 'RC')\"\n              >&#xe9ae;</i\n            >\n            <span\n              class=\"chipName vx-fs-11 vx-label-txt\"\n              [appTooltip]=\"controls?.rc?.value[0]?.item_name\"\n              placement=\"bottom-left\"\n              delay=\"0\"\n              type=\"black\"\n              [tooltipMandatory]=\"false\"\n              >{{ controls?.rc?.value[0]?.item_name }}</span\n            >\n            <button\n              class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n              appPopover\n              (click)=\"rc.popover()\"\n              placement=\"right\"\n              *ngIf=\"controls?.rc?.value?.length > 1\"\n            >\n              +{{ controls?.rc?.value?.length - 1 }}\n            </button>\n          </div>\n\n          <!-- <div class=\"chip-container\">\n                        <div class=\"chip-inner\">\n                            <span class=\"chip\"><i class=\"icons\" (click)=\"remove(controls?.rc?.value[0],'RC')\">&#xe90d;</i>{{controls?.rc?.value[0]?.item_name}}</span>\n                            <button *ngIf=\"controls?.rc?.value?.length  > 1\" class=\"count\" appPopover (click)=\"rc.popover()\" placement=\"right\">+{{controls?.rc?.value?.length -1 }}</button>\n                        </div>\n                    </div> -->\n          <button\n            *ngIf=\"activeList !== 'RC'\"\n            class=\"edit\"\n            type=\"button\"\n            (click)=\"activateList('RC')\"\n          >\n            <i class=\"icons\">&#xe9ba;</i> Edit\n          </button>\n        </div>\n      </input-with-pill>\n      <app-popover #rc [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li *ngFor=\"let rc of controls?.rc?.value | slice : 1\">\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i class=\"icons\" (click)=\"remove(rc, 'RC')\">&#xe90d;</i>\n                  {{ rc?.item_name }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n    </form-field>\n\n    <!-- Assignee -->\n    <form-field\n      *ngIf=\"additionalOption?.ASSIGNEES\"\n      [checked]=\"\n        controls?.program_assignee?.value?.length ||\n        controls?.program_default_assignee?.value?.length ||\n        controls?.program_default_assignee?.value?.length ||\n        controls?.program_default_assignee_group?.value?.length\n      \"\n      [active]=\"['ASSIGNEE', 'DEFAULT_ASSIGNEE']?.includes(activeList)\"\n      [disabled]=\"\n        sideElements?.includes(activeList) &&\n        !['ASSIGNEE', 'DEFAULT_ASSIGNEE'].includes(activeList)\n      \"\n      [img]=\"ASSETS.case_assignees\"\n    >\n      <label\n        class=\"vx-control-panel\"\n        [class.disabled]=\"activeList === 'DEFAULT_ASSIGNEE'\"\n        >ASSIGNEES\n        <i\n          class=\"icons\"\n          [appTooltip]=\"\n            'Assignees are required to complete the responsibilities that have been assigned to them. Where Assignees are selected when creating a Program, only those Assignees will be available for selection when creating a responsibility linked with the Program.'\n          \"\n          placement=\"bottom\"\n          delay=\"0\"\n          type=\"white\"\n          [tooltipMandatory]=\"true\"\n          id=\"AssigneeHelpText\"\n          >&#xeb16;</i\n        >\n      </label>\n      <input-with-pill\n        [selectDiv]=\"true\"\n        [disabled]=\"activeList === 'DEFAULT_ASSIGNEE'\"\n        [placeholder]=\"\n          'Who is responsible for completing the responsibilities within this Program?'\n        \"\n        (select)=\"activateList('ASSIGNEE')\"\n      >\n        <div\n          class=\"selected\"\n          *ngIf=\"\n            controls?.program_assignee?.value?.length ||\n            controls?.program_assignee_group?.value?.length\n          \"\n        >\n          <div class=\"vx-d-flex vx-align-center\">\n            <div\n              class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n              *ngIf=\"controls?.program_assignee?.value?.length\"\n            >\n              <i\n                class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                (click)=\"\n                  remove(controls?.program_assignee?.value[0], 'ASSIGNEE')\n                \"\n                >&#xe9ae;</i\n              >\n              <span\n                class=\"chipName vx-fs-11 vx-label-txt\"\n                [appTooltip]=\"controls?.program_assignee?.value[0]?.member_name\"\n                placement=\"bottom-left\"\n                delay=\"0\"\n                type=\"black\"\n                [tooltipMandatory]=\"false\"\n                >{{ controls?.program_assignee?.value[0]?.member_name }}</span\n              >\n              <button\n                class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                appPopover\n                (click)=\"assignee.popover()\"\n                placement=\"right\"\n                *ngIf=\"controls?.program_assignee?.value?.length > 1\"\n              >\n                +{{ controls?.program_assignee?.value?.length - 1 }}\n              </button>\n            </div>\n            <span\n              class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n              *ngIf=\"\n                controls?.program_assignee_group?.value?.length &&\n                controls?.program_assignee?.value?.length\n              \"\n              >&</span\n            >\n            <div\n              class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n              *ngIf=\"controls?.program_assignee_group?.value?.length\"\n            >\n              <i\n                class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                (click)=\"\n                  remove(\n                    controls?.program_assignee_group?.value[0],\n                    'ASSIGNEE_GROUP'\n                  )\n                \"\n                >&#xe9ae;</i\n              >\n              <span\n                class=\"chipName vx-fs-11 vx-label-txt\"\n                [appTooltip]=\"\n                  controls?.program_assignee_group?.value[0]?.group_name\n                \"\n                placement=\"bottom-left\"\n                delay=\"0\"\n                type=\"black\"\n                [tooltipMandatory]=\"false\"\n                >{{\n                  controls?.program_assignee_group?.value[0]?.group_name\n                }}</span\n              >\n              <button\n                class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                appPopover\n                (click)=\"assignee_group.popover()\"\n                placement=\"right\"\n                *ngIf=\"controls?.program_assignee_group?.value?.length > 1\"\n              >\n                +{{ controls?.program_assignee_group?.value?.length - 1 }}\n              </button>\n            </div>\n          </div>\n\n          <!-- <div class=\"chip-container\">\n                        <div class=\"chip-inner\" *ngIf=\"controls?.program_assignee?.value?.length\">\n                          <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_assignee?.value[0],'ASSIGNEE')\" >&#xe90d;</i>\n                            <span class=\"chip\" [appTooltip]=\"controls?.program_assignee?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n                              <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_assignee?.value[0]?.member_name}}</span>\n                            </span>\n                            <button *ngIf=\"controls?.program_assignee?.value?.length > 1\" class=\"count user\" appPopover (click)=\"assignee.popover()\" placement=\"right\">+{{controls?.program_assignee?.value?.length -1}}</button>\n                        </div>\n                        <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_assignee_group?.value?.length && controls?.program_assignee?.value?.length\">&</span>\n                        <div class=\"chip-inner\" *ngIf=\"controls?.program_assignee_group?.value?.length\">\n                          <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_assignee_group?.value[0],'ASSIGNEE_GROUP')\" >&#xe90d;</i>\n                            <span class=\"chip\" [appTooltip]=\"controls?.program_assignee_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n                              <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_assignee_group?.value[0]?.group_name}}</span>\n                            </span>\n                            <button *ngIf=\"controls?.program_assignee_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"assignee_group.popover()\" placement=\"right\">+{{controls?.program_assignee_group?.value?.length -1 }}</button>\n                        </div>\n                    </div> -->\n          <button\n            *ngIf=\"activeList !== 'ASSIGNEE'\"\n            class=\"edit\"\n            type=\"button\"\n            (click)=\"activateList('ASSIGNEE')\"\n          >\n            <i class=\"icons\">&#xe9ba;</i> Edit\n          </button>\n        </div>\n      </input-with-pill>\n      <app-popover #assignee [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li\n              *ngFor=\"\n                let assignee of controls?.program_assignee?.value | slice : 1\n              \"\n            >\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i (click)=\"remove(assignee, 'ASSIGNEE')\" class=\"icons\"\n                    >&#xe90d;</i\n                  >\n                  {{ assignee?.member_name }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n      <app-popover #assignee_group [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li\n              *ngFor=\"\n                let group of controls?.program_assignee_group?.value | slice : 1\n              \"\n            >\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i (click)=\"remove(group, 'ASSIGNEE_GROUP')\" class=\"icons\"\n                    >&#xe90d;</i\n                  >\n                  {{ group?.group_name }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n      <label\n        class=\"vx-control-panel\"\n        [class.disabled]=\"activeList === 'ASSIGNEE'\"\n        >DEFAULT ASSIGNEE\n        <i\n          class=\"icons\"\n          [appTooltip]=\"\n            'This option lets you specify the Default Assignees for all new responsibilities linked with a Program. If a Default Assignees is selected, the user will automatically be selected the Assignee when creating a responsibility linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility. '\n          \"\n          placement=\"bottom\"\n          delay=\"0\"\n          type=\"white\"\n          [tooltipMandatory]=\"true\"\n          id=\"DAHelpText\"\n          >&#xeb16;</i\n        ></label\n      >\n      <input-with-pill\n        [selectDiv]=\"true\"\n        [disabled]=\"activeList === 'ASSIGNEE'\"\n        [placeholder]=\"\n          'Which persons will be selected as the default assignees for the responsibilities within this Program?'\n        \"\n        (select)=\"activateList('DEFAULT_ASSIGNEE')\"\n      >\n        <div\n          class=\"selected\"\n          *ngIf=\"\n            controls?.program_default_assignee?.value?.length ||\n            controls?.program_default_assignee_group?.value?.length\n          \"\n        >\n          <div class=\"vx-d-flex vx-align-center\">\n            <div\n              class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n              *ngIf=\"controls?.program_default_assignee?.value?.length\"\n            >\n              <i\n                class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                (click)=\"\n                  remove(\n                    controls?.program_default_assignee?.value[0],\n                    'DEFAULT_ASSIGNEE'\n                  )\n                \"\n                >&#xe9ae;</i\n              >\n              <span\n                class=\"chipName vx-fs-11 vx-label-txt\"\n                [appTooltip]=\"\n                  controls?.program_default_assignee?.value[0]?.member_name\n                \"\n                placement=\"bottom-left\"\n                delay=\"0\"\n                type=\"black\"\n                [tooltipMandatory]=\"false\"\n                >{{\n                  controls?.program_default_assignee?.value[0]?.member_name\n                }}</span\n              >\n              <button\n                class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                appPopover\n                (click)=\"defaultAssignee.popover()\"\n                placement=\"right\"\n                *ngIf=\"controls?.program_default_assignee?.value?.length > 1\"\n              >\n                +{{ controls?.program_default_assignee?.value?.length - 1 }}\n              </button>\n            </div>\n            <span\n              class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n              *ngIf=\"\n                controls?.program_default_assignee_group?.value?.length &&\n                controls?.program_default_assignee?.value?.length\n              \"\n              >&</span\n            >\n            <div\n              class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n              *ngIf=\"controls?.program_default_assignee_group?.value?.length\"\n            >\n              <i\n                class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                (click)=\"\n                  remove(\n                    controls?.program_default_assignee_group?.value[0],\n                    'DEFAULT_ASSIGNEE_GROUP'\n                  )\n                \"\n                >&#xe9ae;</i\n              >\n              <span\n                class=\"chipName vx-fs-11 vx-label-txt\"\n                [appTooltip]=\"\n                  controls?.program_default_assignee_group?.value[0]?.group_name\n                \"\n                placement=\"bottom-left\"\n                delay=\"0\"\n                type=\"black\"\n                [tooltipMandatory]=\"false\"\n                >{{\n                  controls?.program_default_assignee_group?.value[0]?.group_name\n                }}</span\n              >\n              <button\n                class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                appPopover\n                (click)=\"defaultAssigneeGroup.popover()\"\n                placement=\"right\"\n                *ngIf=\"\n                  controls?.program_default_assignee_group?.value?.length > 1\n                \"\n              >\n                +{{\n                  controls?.program_default_assignee_group?.value?.length - 1\n                }}\n              </button>\n            </div>\n          </div>\n\n          <!-- <div class=\"chip-container\">\n                        <div class=\"chip-inner\" *ngIf=\"controls?.program_default_assignee?.value?.length\">\n                          <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_assignee?.value[0],'DEFAULT_ASSIGNEE')\" >&#xe90d;</i>\n                            <span class=\"chip\" [appTooltip]=\"controls?.program_default_assignee?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n                              <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{ controls?.program_default_assignee?.value[0]?.member_name}}</span>\n                            </span>\n                            <button *ngIf=\"controls?.program_default_assignee?.value?.length > 1\" class=\"count user\" appPopover (click)=\"defaultAssignee.popover()\" placement=\"right\">+{{controls?.program_default_assignee?.value?.length - 1}}</button>\n                        </div>\n                        <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_default_assignee_group?.value?.length && controls?.program_default_assignee?.value?.length\">&</span>\n                        <div class=\"chip-inner\" *ngIf=\"controls?.program_default_assignee_group?.value?.length\">\n                          <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_assignee_group?.value[0],'DEFAULT_ASSIGNEE_GROUP')\" >&#xe90d;</i>\n                            <span class=\"chip\">\n                              <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_assignee_group?.value[0]?.group_name }}</span>\n                            </span>\n                            <button *ngIf=\"controls?.program_default_assignee_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"defaultAssigneeGroup.popover()\" placement=\"right\">+{{controls?.program_default_assignee_group?.value?.length -1 }}</button>\n                        </div>\n                    </div> -->\n          <button\n            *ngIf=\"activeList !== 'DEFAULT_ASSIGNEE'\"\n            (click)=\"activateList('DEFAULT_ASSIGNEE')\"\n            class=\"edit\"\n            type=\"button\"\n          >\n            <i class=\"icons\">&#xe9ba;</i> Edit\n          </button>\n        </div>\n      </input-with-pill>\n      <app-popover #defaultAssignee [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li\n              *ngFor=\"\n                let assignee of controls?.program_default_assignee?.value\n                  | slice : 1\n              \"\n            >\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i\n                    (click)=\"remove(assignee, 'DEFAULT_ASSIGNEE')\"\n                    class=\"icons\"\n                    >&#xe90d;</i\n                  >\n                  {{ assignee?.member_name }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n      <app-popover #defaultAssigneeGroup [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li\n              *ngFor=\"\n                let group of controls?.program_default_assignee_group?.value\n                  | slice : 1\n              \"\n            >\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i\n                    (click)=\"remove(assignee, 'DEFAULT_ASSIGNEE_GROUP')\"\n                    class=\"icons\"\n                    >&#xe90d;</i\n                  >\n                  {{ group?.group_name }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n      <div\n        class=\"radio-group-selector\"\n        [class.disabled]=\"activeList === 'ASSIGNEE'\"\n      >\n        <app-cs-radio\n          [name]=\"'assignee'\"\n          [checked]=\"controls?.assignee_completion_criteria?.value === 'ALL'\"\n          (checkedEvent)=\"setFormField('assignee_completion_criteria', 'ALL')\"\n        >\n          ALL SELECTED PERSONS NEED TO COMPLETE THIS\n          <i\n            class=\"icons\"\n            [appTooltip]=\"\n              'If selected, separate responsibilities will be created for each person.'\n            \"\n            placement=\"bottom-right\"\n            delay=\"0\"\n            type=\"white\"\n            [tooltipMandatory]=\"true\"\n            >&#xe91f;</i\n          >\n        </app-cs-radio>\n        <app-cs-radio\n          [name]=\"'assignee'\"\n          [checked]=\"controls?.assignee_completion_criteria?.value === 'ANYONE'\"\n          (checkedEvent)=\"\n            setFormField('assignee_completion_criteria', 'ANYONE')\n          \"\n        >\n          ANY SELECTED PERSON CAN COMPLETE THIS\n          <i\n            class=\"icons\"\n            [appTooltip]=\"\n              'If selected, only one responsibility will be created.'\n            \"\n            placement=\"bottom-right\"\n            delay=\"0\"\n            type=\"white\"\n            [tooltipMandatory]=\"true\"\n            >&#xe91f;</i\n          >\n        </app-cs-radio>\n      </div>\n    </form-field>\n\n    <!-- Reviewer -->\n    <form-field\n      [appScrollInView]=\"scrollToBottom\"\n      *ngIf=\"additionalOption?.REVIEWER\"\n      [checked]=\"\n        controls?.program_reviewer?.value?.length ||\n        controls?.program_default_reviewer?.value?.length ||\n        controls?.program_default_reviewer?.value?.length ||\n        controls?.program_default_reviewer_group?.value?.length\n      \"\n      [active]=\"['REVIEWER', 'DEFAULT_REVIEWER']?.includes(activeList)\"\n      [disabled]=\"\n        sideElements?.includes(activeList) &&\n        !['REVIEWER', 'DEFAULT_REVIEWER'].includes(activeList)\n      \"\n      [img]=\"ASSETS.reviewer\"\n    >\n      <label\n        [class.disabled]=\"activeList === 'DEFAULT_REVIEWER'\"\n        class=\"vx-control-panel\"\n        >Reviewers\n        <i\n          class=\"icons\"\n          [appTooltip]=\"\n            'Reviewers are required to review responsibilities after they have been completed. Where Reviewers are selected when creating a Program, only those Reviewers will be available for selection when creating a responsibility linked with the Program.'\n          \"\n          placement=\"bottom\"\n          delay=\"0\"\n          type=\"white\"\n          [tooltipMandatory]=\"true\"\n          id=\"ReviewerHelpText\"\n          >&#xeb16;</i\n        ></label\n      >\n      <input-with-pill\n        [selectDiv]=\"true\"\n        [disabled]=\"activeList === 'DEFAULT_REVIEWER'\"\n        [placeholder]=\"\n          'Who is responsible for reviewing the responsibilities within this Program?'\n        \"\n        (select)=\"activateList('REVIEWER')\"\n      >\n        <div\n          class=\"selected\"\n          *ngIf=\"\n            controls?.program_reviewer?.value?.length ||\n            controls?.program_reviewer_group?.value?.length\n          \"\n        >\n          <div class=\"vx-d-flex vx-align-center\">\n            <div\n              class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n              *ngIf=\"controls?.program_reviewer?.value?.length\"\n            >\n              <i\n                class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                (click)=\"\n                  remove(controls?.program_reviewer?.value[0], 'REVIEWER')\n                \"\n                >&#xe9ae;</i\n              >\n              <span\n                class=\"chipName vx-fs-11 vx-label-txt\"\n                [appTooltip]=\"controls?.program_reviewer?.value[0]?.member_name\"\n                placement=\"bottom-left\"\n                delay=\"0\"\n                type=\"black\"\n                [tooltipMandatory]=\"false\"\n                >{{ controls?.program_reviewer?.value[0]?.member_name }}</span\n              >\n              <button\n                class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                appPopover\n                (click)=\"reviewer.popover()\"\n                placement=\"right\"\n                *ngIf=\"controls?.program_reviewer?.value?.length > 1\"\n              >\n                +{{ controls?.program_reviewer?.value?.length - 1 }}\n              </button>\n            </div>\n            <span\n              class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n              *ngIf=\"\n                controls?.program_reviewer_group?.value?.length &&\n                controls?.program_reviewer?.value?.length\n              \"\n              >&</span\n            >\n            <div\n              class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n              *ngIf=\"controls?.program_reviewer_group?.value?.length\"\n            >\n              <i\n                class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                (click)=\"\n                  remove(\n                    controls?.program_reviewer_group?.value[0],\n                    'REVIEWER_GROUP'\n                  )\n                \"\n                >&#xe9ae;</i\n              >\n              <span\n                class=\"chipName vx-fs-11 vx-label-txt\"\n                [appTooltip]=\"\n                  controls?.program_reviewer_group?.value[0]?.group_name\n                \"\n                placement=\"bottom-left\"\n                delay=\"0\"\n                type=\"black\"\n                [tooltipMandatory]=\"false\"\n                >{{\n                  controls?.program_reviewer_group?.value[0]?.group_name\n                }}</span\n              >\n              <button\n                class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                appPopover\n                (click)=\"reviewerGroup.popover()\"\n                placement=\"right\"\n                *ngIf=\"controls?.program_reviewer_group?.value?.length > 1\"\n              >\n                +{{ controls?.program_reviewer_group?.value?.length - 1 }}\n              </button>\n            </div>\n          </div>\n\n          <!-- <div class=\"chip-container\">\n                        <div class=\"chip-inner\" *ngIf=\"controls?.program_reviewer?.value?.length\">\n                          <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_reviewer?.value[0],'REVIEWER')\" >&#xe90d;</i>\n                            <span class=\"chip\" [appTooltip]=\"controls?.program_reviewer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n                              <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_reviewer?.value[0]?.member_name}}</span>\n                            </span>\n                            <button *ngIf=\"controls?.program_reviewer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"reviewer.popover()\" placement=\"right\">+{{controls?.program_reviewer?.value?.length -1}}</button>\n                        </div>\n                        <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_reviewer_group?.value?.length && controls?.program_reviewer?.value?.length\">&</span>\n                        <div class=\"chip-inner\" *ngIf=\"controls?.program_reviewer_group?.value?.length\">\n                          <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_reviewer_group?.value[0],'REVIEWER_GROUP')\" >&#xe90d;</i>\n                            <span class=\"chip\" [appTooltip]=\"controls?.program_reviewer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n                              <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_reviewer_group?.value[0]?.group_name}}\n                              </span>\n                            </span>\n                            <button *ngIf=\"controls?.program_reviewer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"reviewerGroup.popover()\" placement=\"right\">+{{controls?.program_reviewer_group?.value?.length - 1}}</button>\n                        </div>\n                    </div> -->\n          <button\n            *ngIf=\"activeList !== 'REVIEWER'\"\n            (click)=\"activateList('REVIEWER')\"\n            class=\"edit\"\n            type=\"button\"\n          >\n            <i class=\"icons\">&#xe9ba;</i> Edit\n          </button>\n        </div>\n      </input-with-pill>\n      <app-popover #reviewer [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li\n              *ngFor=\"\n                let reviewer of controls?.program_reviewer?.value | slice : 1\n              \"\n            >\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i (click)=\"remove(reviewer, 'REVIEWER')\" class=\"icons\"\n                    >&#xe90d;</i\n                  >\n                  {{ reviewer?.member_name }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n      <app-popover #reviewerGroup [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li\n              *ngFor=\"\n                let group of controls?.program_reviewer_group?.value | slice : 1\n              \"\n            >\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i (click)=\"remove(group, 'REVIEWER_GROUP')\" class=\"icons\"\n                    >&#xe90d;</i\n                  >\n                  {{ group?.group_name }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n      <label\n        [class.disabled]=\"activeList === 'REVIEWER'\"\n        class=\"vx-control-panel\"\n        >DEFAULT Reviewer\n        <i\n          class=\"icons\"\n          [appTooltip]=\"\n            'This option lets you specify the Default Reviewers for responsibilities linked with a Program. Where a user has been specified as a Default Reviewer, that user will automatically be selected as the Reviewer when creating a responsibility linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility.'\n          \"\n          placement=\"bottom\"\n          delay=\"0\"\n          type=\"white\"\n          [tooltipMandatory]=\"true\"\n          id=\"DRHelpText\"\n          >&#xeb16;</i\n        ></label\n      >\n      <input-with-pill\n        [selectDiv]=\"true\"\n        [disabled]=\"activeList === 'REVIEWER'\"\n        [placeholder]=\"\n          'Which persons will be selected as the default reviewers for the responsibilities within this Program?'\n        \"\n        (select)=\"activateList('DEFAULT_REVIEWER')\"\n      >\n        <div\n          class=\"selected\"\n          *ngIf=\"\n            controls?.program_default_reviewer?.value?.length ||\n            controls?.program_default_reviewer_group?.value?.length\n          \"\n        >\n          <div class=\"vx-d-flex vx-align-center\">\n            <div\n              class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n              *ngIf=\"controls?.program_default_reviewer?.value?.length\"\n            >\n              <i\n                class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                (click)=\"\n                  remove(\n                    controls?.program_default_reviewer?.value[0],\n                    'DEFAULT_REVIEWER'\n                  )\n                \"\n                >&#xe9ae;</i\n              >\n              <span\n                class=\"chipName vx-fs-11 vx-label-txt\"\n                [appTooltip]=\"\n                  controls?.program_default_reviewer?.value[0]?.member_name\n                \"\n                placement=\"bottom-left\"\n                delay=\"0\"\n                type=\"black\"\n                [tooltipMandatory]=\"false\"\n                >{{\n                  controls?.program_default_reviewer?.value[0]?.member_name\n                }}</span\n              >\n              <button\n                class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                appPopover\n                (click)=\"defaultReviewer.popover()\"\n                placement=\"right\"\n                *ngIf=\"controls?.program_default_reviewer?.value?.length > 1\"\n              >\n                +{{ controls?.program_default_reviewer?.value?.length - 1 }}\n              </button>\n            </div>\n            <span\n              class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n              *ngIf=\"\n                controls?.program_default_reviewer_group?.value?.length &&\n                controls?.program_default_reviewer?.value?.length\n              \"\n              >&</span\n            >\n            <div\n              class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n              *ngIf=\"controls?.program_default_reviewer_group?.value?.length\"\n            >\n              <i\n                class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                (click)=\"\n                  remove(\n                    controls?.program_default_reviewer_group?.value[0],\n                    'DEFAULT_REVIEWER_GROUP'\n                  )\n                \"\n                >&#xe9ae;</i\n              >\n              <span\n                class=\"chipName vx-fs-11 vx-label-txt\"\n                [appTooltip]=\"\n                  controls?.program_default_reviewer_group?.value[0]?.group_name\n                \"\n                placement=\"bottom-left\"\n                delay=\"0\"\n                type=\"black\"\n                [tooltipMandatory]=\"false\"\n                >{{\n                  controls?.program_default_reviewer_group?.value[0]?.group_name\n                }}</span\n              >\n              <button\n                class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                appPopover\n                (click)=\"defaultReviewerGroup.popover()\"\n                placement=\"right\"\n                *ngIf=\"\n                  controls?.program_default_reviewer_group?.value?.length > 1\n                \"\n              >\n                +{{\n                  controls?.program_default_reviewer_group?.value?.length - 1\n                }}\n              </button>\n            </div>\n          </div>\n\n          <!-- <div class=\"chip-container\">\n                        <div class=\"chip-inner\" *ngIf=\"controls?.program_default_reviewer?.value?.length\">\n                          <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_reviewer?.value[0],'DEFAULT_REVIEWER')\" >&#xe90d;</i>\n                            <span class=\"chip\" [appTooltip]=\"controls?.program_default_reviewer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n                              <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_reviewer?.value[0]?.member_name}}</span>\n                            </span>\n                            <button *ngIf=\"controls?.program_default_reviewer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"defaultReviewer.popover()\" placement=\"right\">+{{controls?.program_default_reviewer?.value?.length - 1}}</button>\n                        </div>\n                        <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_default_reviewer_group?.value?.length && controls?.program_default_reviewer?.value?.length\">&</span>\n                        <div class=\"chip-inner\" *ngIf=\"controls?.program_default_reviewer_group?.value?.length\">\n                          <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_reviewer_group?.value[0],'DEFAULT_REVIEWER_GROUP')\" >&#xe90d;</i>\n                            <span class=\"chip\" [appTooltip]=\"controls?.program_default_reviewer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n                              <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_reviewer_group?.value[0]?.group_name}}\n                              </span>\n                            </span>\n                            <button *ngIf=\"controls?.program_default_reviewer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"defaultReviewerGroup.popover()\" placement=\"right\">+{{controls?.program_default_reviewer_group?.value?.length -1}}</button>\n                        </div>\n                    </div> -->\n          <button\n            *ngIf=\"activeList !== 'DEFAULT_REVIEWER'\"\n            (click)=\"activateList('DEFAULT_REVIEWER')\"\n            class=\"edit\"\n            type=\"button\"\n          >\n            <i class=\"icons\">&#xe9ba;</i> Edit\n          </button>\n        </div>\n      </input-with-pill>\n      <app-popover #defaultReviewer [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li\n              *ngFor=\"\n                let reviewer of controls?.program_default_reviewer?.value\n                  | slice : 1\n              \"\n            >\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i\n                    (click)=\"remove(reviewer, 'DEFAULT_REVIEWER')\"\n                    class=\"icons\"\n                    >&#xe90d;</i\n                  >\n                  {{ reviewer?.member_name }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n      <app-popover #defaultReviewerGroup [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li\n              *ngFor=\"\n                let group of controls?.program_default_reviewer_group?.value\n                  | slice : 1\n              \"\n            >\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i\n                    (click)=\"remove(group, 'DEFAULT_REVIEWER_GROUP')\"\n                    class=\"icons\"\n                    >&#xe90d;</i\n                  >\n                  {{ group?.group_name }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n      <div\n        class=\"radio-group-selector\"\n        [class.disabled]=\"activeList === 'REVIEWER'\"\n      >\n        <app-cs-radio\n          [name]=\"'reviewer'\"\n          [checked]=\"\n            controls?.reviewer_completion_criteria?.value === 'SEQUENTIAL'\n          \"\n          (checkedEvent)=\"\n            setFormField('reviewer_completion_criteria', 'SEQUENTIAL')\n          \"\n          [class.disabled]=\"\n            controls?.program_default_reviewer_group?.value?.length > 0\n          \"\n        >\n          SEQUENTIAL\n          <i\n            class=\"icons\"\n            [appTooltip]=\"\n              'The responsibility will be sent for review one at a time in the sequence defined by you.'\n            \"\n            placement=\"bottom-right\"\n            delay=\"0\"\n            type=\"white\"\n            [tooltipMandatory]=\"true\"\n            >&#xe91f;</i\n          >\n        </app-cs-radio>\n        <app-cs-radio\n          [name]=\"'reviewer'\"\n          [checked]=\"\n            controls?.reviewer_completion_criteria?.value === 'ANYONE' ||\n            controls?.program_default_reviewer_group?.value?.length > 0\n          \"\n          (checkedEvent)=\"\n            setFormField('reviewer_completion_criteria', 'ANYONE')\n          \"\n        >\n          ANY REVIEWER CAN MARK THIS AS REVIEWED\n          <i\n            class=\"icons\"\n            [appTooltip]=\"\n              'The responsibility will be sent for review to all reviewers at the same time. If anyone of the reviewer reviews the responsibility, it will be considered as reviewed.'\n            \"\n            placement=\"bottom-right\"\n            delay=\"0\"\n            type=\"white\"\n            [tooltipMandatory]=\"true\"\n            >&#xe91f;</i\n          >\n        </app-cs-radio>\n      </div>\n    </form-field>\n\n    <!-- Overseer -->\n    <form-field\n      [appScrollInView]=\"scrollToBottom\"\n      *ngIf=\"additionalOption?.OVERSEER\"\n      [checked]=\"\n        controls?.program_overseer?.value?.length ||\n        controls?.program_default_overseer?.value?.length ||\n        controls?.program_default_overseer?.value?.length ||\n        controls?.program_default_overseer_group?.value?.length\n      \"\n      [active]=\"activeList === 'OVERSEER'\"\n      [disabled]=\"\n        sideElements?.includes(activeList) &&\n        !['OVERSEER', 'DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(\n          activeList\n        )\n      \"\n      [img]=\"ASSETS.oversight\"\n    >\n      <label\n        class=\"vx-control-panel\"\n        [class.disabled]=\"\n          ['DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n        \"\n        >Oversights\n        <i\n          class=\"icons\"\n          [appTooltip]=\"\n            'Oversights receive updates when a responsibility is completed, completed with delay or not completed. Where Oversights are selected when creating a Program, only those Oversights will be available for selection when creating a responsibility linked with the Program.'\n          \"\n          placement=\"bottom\"\n          delay=\"0\"\n          type=\"white\"\n          [tooltipMandatory]=\"true\"\n          id=\"overseerHelpText\"\n          >&#xeb16;</i\n        ></label\n      >\n      <input-with-pill\n        [selectDiv]=\"true\"\n        [disabled]=\"\n          ['DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n        \"\n        [placeholder]=\"\n          'Who is responsible for overseeing the responsibilities within this Program?'\n        \"\n        (select)=\"activateList('OVERSEER')\"\n      >\n        <div\n          class=\"selected\"\n          *ngIf=\"\n            controls?.program_overseer?.value?.length ||\n            controls?.program_overseer_group?.value?.length\n          \"\n        >\n          <div class=\"vx-d-flex vx-align-center\">\n            <div\n              class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n              *ngIf=\"controls?.program_overseer?.value?.length\"\n            >\n              <i\n                class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                (click)=\"\n                  remove(controls?.program_overseer?.value[0], 'OVERSEER')\n                \"\n                >&#xe9ae;</i\n              >\n              <span\n                class=\"chipName vx-fs-11 vx-label-txt\"\n                [appTooltip]=\"controls?.program_overseer?.value[0]?.member_name\"\n                placement=\"bottom-left\"\n                delay=\"0\"\n                type=\"black\"\n                [tooltipMandatory]=\"false\"\n                >{{ controls?.program_overseer?.value[0]?.member_name }}</span\n              >\n              <button\n                class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                appPopover\n                (click)=\"overseers.popover()\"\n                placement=\"right\"\n                *ngIf=\"controls?.program_overseer?.value?.length > 1\"\n              >\n                +{{ controls?.program_overseer?.value?.length - 1 }}\n              </button>\n            </div>\n            <span\n              *ngIf=\"\n                controls?.program_overseer_group?.value?.length &&\n                controls?.program_overseer?.value?.length\n              \"\n              class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n              >&</span\n            >\n            <div\n              class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n              *ngIf=\"controls?.program_overseer_group?.value?.length\"\n            >\n              <i\n                class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                (click)=\"\n                  remove(\n                    controls?.program_overseer_group?.value[0],\n                    'OVERSEER_GROUP'\n                  )\n                \"\n                >&#xe9ae;</i\n              >\n              <span\n                class=\"chipName vx-fs-11 vx-label-txt\"\n                [appTooltip]=\"\n                  controls?.program_overseer_group?.value[0]?.group_name\n                \"\n                placement=\"bottom-left\"\n                delay=\"0\"\n                type=\"black\"\n                [tooltipMandatory]=\"false\"\n                >{{\n                  controls?.program_overseer_group?.value[0]?.group_name\n                }}</span\n              >\n              <button\n                class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                appPopover\n                (click)=\"overseerGroup.popover()\"\n                placement=\"right\"\n                *ngIf=\"controls?.program_overseer_group?.value?.length > 1\"\n              >\n                +{{ controls?.program_overseer_group?.value?.length - 1 }}\n              </button>\n            </div>\n          </div>\n\n          <!-- <div class=\"chip-container\">\n                        <div class=\"chip-inner\" *ngIf=\"controls?.program_overseer?.value?.length\">\n                          <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_overseer?.value[0],'OVERSEER')\" >&#xe90d;</i>\n                            <span class=\"chip\" [appTooltip]=\"controls?.program_overseer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n                              <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">\n                                {{controls?.program_overseer?.value[0]?.member_name}}\n                              </span>\n                            </span>\n                            <button *ngIf=\"controls?.program_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseers.popover()\" placement=\"right\">+{{controls?.program_overseer?.value?.length -1}}</button>\n                        </div>\n                        <span *ngIf=\"controls?.program_overseer_group?.value?.length && controls?.program_overseer?.value?.length \" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n                        <div class=\"chip-inner\" *ngIf=\"controls?.program_overseer_group?.value?.length \">\n                            <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_overseer_group?.value[0],'OVERSEER_GROUP')\" >&#xe90d;</i>\n                            <span class=\"chip\" [appTooltip]=\"controls?.program_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n                                <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_overseer_group?.value[0]?.group_name}}</span></span>\n                            <button *ngIf=\"controls?.program_overseer_group?.value?.length> 1\" class=\"count\" appPopover (click)=\"overseerGroup.popover()\" placement=\"right\">+{{controls?.program_overseer_group?.value?.length -1}}</button>\n                        </div>\n                    </div> -->\n\n          <button\n            *ngIf=\"activeList !== 'OVERSEER'\"\n            (click)=\"activateList('OVERSEER')\"\n            class=\"edit\"\n            type=\"button\"\n          >\n            <i class=\"icons\">&#xe9ba;</i> Edit\n          </button>\n        </div>\n      </input-with-pill>\n      <app-popover #overseers [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li\n              *ngFor=\"\n                let overseer of controls?.program_overseer?.value | slice : 1\n              \"\n            >\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i class=\"icons\" (click)=\"remove(overseer, 'OVERSEER')\"\n                    >&#xe90d;</i\n                  >\n                  {{ overseer?.member_name }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n      <app-popover #overseerGroup [dontCloseonClick]=\"true\">\n        <div class=\"wf-action-list\">\n          <ul class=\"action-item\">\n            <li\n              *ngFor=\"\n                let group of controls?.program_overseer_group?.value | slice : 1\n              \"\n            >\n              <div class=\"avatar-card\">\n                <span class=\"value\">\n                  <i (click)=\"remove(group, 'OVERSEER_GROUP')\" class=\"icons\"\n                    >&#xe90d;</i\n                  >\n                  {{ group?.group_name }}\n                </span>\n              </div>\n            </li>\n          </ul>\n        </div>\n      </app-popover>\n      <ng-container [class.disabled]=\"activeList === 'OVERSEER'\">\n        <label\n          class=\"vx-control-panel\"\n          [class.disabled]=\"['OVERSEER'].includes(activeList)\"\n          >DEFAULT Oversight\n          <i\n            class=\"icons\"\n            [appTooltip]=\"\n              'This option lets you specify the Default Oversight for responsibilities linked with a Program. Where a user has been specified as a Default Oversight, that user will automatically be selected as the Oversight when creating a responsibility linked with the Program.'\n            \"\n            placement=\"bottom\"\n            delay=\"0\"\n            type=\"white\"\n            [tooltipMandatory]=\"true\"\n            id=\"DOHelpText\"\n            >&#xeb16;</i\n          ></label\n        >\n        <input-with-pill\n          [disabled]=\"\n            ['OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n          \"\n          [selectDiv]=\"true\"\n          [placeholder]=\"\n            'Which persons will be selected as the default overseers for the responsibilities within this Program?'\n          \"\n          (select)=\"activateList('DEFAULT_OVERSEER')\"\n        >\n          <div\n            class=\"selected\"\n            *ngIf=\"\n              controls?.program_default_overseer?.value?.length ||\n              controls?.program_default_overseer_group?.value?.length\n            \"\n          >\n            <div class=\"vx-d-flex vx-align-center\">\n              <div\n                class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n                *ngIf=\"controls?.program_default_overseer?.value?.length\"\n              >\n                <i\n                  class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                  (click)=\"\n                    remove(\n                      controls?.program_default_overseer?.value[0],\n                      'DEFAULT_OVERSEER'\n                    )\n                  \"\n                  >&#xe9ae;</i\n                >\n                <span\n                  class=\"chipName vx-fs-11 vx-label-txt\"\n                  [appTooltip]=\"\n                    controls?.program_default_overseer?.value[0]?.member_name\n                  \"\n                  placement=\"bottom-left\"\n                  delay=\"0\"\n                  type=\"black\"\n                  [tooltipMandatory]=\"false\"\n                  >{{\n                    controls?.program_default_overseer?.value[0]?.member_name\n                  }}</span\n                >\n                <button\n                  class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                  appPopover\n                  (click)=\"overseersDefault.popover()\"\n                  placement=\"right\"\n                  *ngIf=\"controls?.program_default_overseer?.value?.length > 1\"\n                >\n                  +{{ controls?.program_default_overseer?.value?.length - 1 }}\n                </button>\n              </div>\n              <span\n                *ngIf=\"\n                  controls?.program_default_overseer_group?.value?.length &&\n                  controls?.program_default_overseer?.value?.length\n                \"\n                class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n                >&</span\n              >\n              <div\n                class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n                *ngIf=\"controls?.program_default_overseer_group?.value?.length\"\n              >\n                <i\n                  class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                  (click)=\"\n                    remove(\n                      controls?.program_default_overseer_group?.value[0],\n                      'DEFAULT_OVERSEER_GROUP'\n                    )\n                  \"\n                  >&#xe9ae;</i\n                >\n                <span\n                  class=\"chipName vx-fs-11 vx-label-txt\"\n                  [appTooltip]=\"\n                    controls?.program_default_overseer_group?.value[0]\n                      ?.group_name\n                  \"\n                  placement=\"bottom-left\"\n                  delay=\"0\"\n                  type=\"black\"\n                  [tooltipMandatory]=\"false\"\n                  >{{\n                    controls?.program_default_overseer_group?.value[0]\n                      ?.group_name\n                  }}</span\n                >\n                <button\n                  class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                  appPopover\n                  (click)=\"overseerDefaultGroup.popover()\"\n                  placement=\"right\"\n                  *ngIf=\"\n                    controls?.program_default_overseer_group?.value?.length > 1\n                  \"\n                >\n                  +{{\n                    controls?.program_default_overseer_group?.value?.length - 1\n                  }}\n                </button>\n              </div>\n            </div>\n\n            <!-- <div class=\"chip-container\">\n                    <div class=\"chip-inner\" *ngIf=\"controls?.program_default_overseer?.value?.length\">\n                      <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_overseer?.value[0],'DEFAULT_OVERSEER')\" >&#xe90d;</i>\n                        <span class=\"chip\" [appTooltip]=\"controls?.program_default_overseer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n                          <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_overseer?.value[0]?.member_name}}</span></span>\n                        <button *ngIf=\"controls?.program_default_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseersDefault.popover()\" placement=\"right\">+{{controls?.program_default_overseer?.value?.length -1}}</button>\n                    </div>\n                    <span *ngIf=\"controls?.program_default_overseer_group?.value?.length && controls?.program_default_overseer?.value?.length\" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n                    <div class=\"chip-inner\" *ngIf=\"controls?.program_default_overseer_group?.value?.length \">\n                        <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_overseer_group?.value[0],'DEFAULT_OVERSEER_GROUP')\" >&#xe90d;</i>\n                        <span class=\"chip\"  [appTooltip]=\"controls?.program_default_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n                            <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_overseer_group?.value[0]?.group_name}}</span>\n                        </span>\n                        <button *ngIf=\"controls?.program_default_overseer_group?.value?.length >1\" class=\"count\" appPopover (click)=\"overseerDefaultGroup.popover()\" placement=\"right\">+{{controls?.program_default_overseer_group?.value?.length -1}}</button>\n                    </div>\n                </div> -->\n            <button\n              *ngIf=\"activeList !== 'DEFAULT_OVERSEER'\"\n              (click)=\"activateList('DEFAULT_OVERSEER')\"\n              class=\"edit\"\n              type=\"button\"\n            >\n              <i class=\"icons\">&#xe9ba;</i> Edit\n            </button>\n          </div>\n        </input-with-pill>\n        <app-popover #overseersDefault [dontCloseonClick]=\"true\">\n          <div class=\"wf-action-list\">\n            <ul class=\"action-item\">\n              <li\n                *ngFor=\"\n                  let overseer of controls?.program_default_overseer?.value\n                    | slice : 1\n                \"\n              >\n                <div class=\"avatar-card\">\n                  <span class=\"value\">\n                    <i\n                      class=\"icons\"\n                      (click)=\"remove(overseer, 'DEFAULT_OVERSEER')\"\n                      >&#xe90d;</i\n                    >\n                    {{ overseer?.member_name }}\n                  </span>\n                </div>\n              </li>\n            </ul>\n          </div>\n        </app-popover>\n        <app-popover #overseerDefaultGroup [dontCloseonClick]=\"true\">\n          <div class=\"wf-action-list\">\n            <ul class=\"action-item\">\n              <li\n                *ngFor=\"\n                  let group of controls?.program_default_overseer_group?.value\n                    | slice : 1\n                \"\n              >\n                <div class=\"avatar-card\">\n                  <span class=\"value\">\n                    <i\n                      (click)=\"remove(group, 'DEFAULT_OVERSEER_GROUP')\"\n                      class=\"icons\"\n                      >&#xe90d;</i\n                    >\n                    {{ group?.group_name }}\n                  </span>\n                </div>\n              </li>\n            </ul>\n          </div>\n        </app-popover>\n        <label class=\"vx-control-panel\"> </label>\n        <input-with-pill\n          class=\"vx-mt-2\"\n          [selectDiv]=\"true\"\n          [line]=\"3\"\n          [disabled]=\"['OVERSEER', 'DEFAULT_OVERSEER'].includes(activeList)\"\n          [placeholder]=\"\n            'Which persons will be selected as the default overseers for responsibilities that are not completed within this Program?'\n          \"\n          (select)=\"activateList('DEFAULT_FAILED_OVERSEER')\"\n        >\n          <div\n            class=\"selected\"\n            *ngIf=\"\n              controls?.program_default_failed_overseer?.value?.length ||\n              controls?.program_default_failed_overseer_group?.value?.length\n            \"\n          >\n            <div class=\"vx-d-flex vx-align-center\">\n              <div\n                class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n                *ngIf=\"controls?.program_default_failed_overseer?.value?.length\"\n              >\n                <i\n                  class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                  (click)=\"\n                    remove(\n                      controls?.program_default_failed_overseer?.value[0],\n                      'DEFAULT_FAILED_OVERSEER'\n                    )\n                  \"\n                  >&#xe9ae;</i\n                >\n                <span\n                  class=\"chipName vx-fs-11 vx-label-txt\"\n                  [appTooltip]=\"\n                    controls?.program_default_failed_overseer?.value[0]\n                      ?.member_name\n                  \"\n                  placement=\"bottom-left\"\n                  delay=\"0\"\n                  type=\"black\"\n                  [tooltipMandatory]=\"false\"\n                  >{{\n                    controls?.program_default_failed_overseer?.value[0]\n                      ?.member_name\n                  }}</span\n                >\n                <button\n                  class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                  appPopover\n                  (click)=\"overseersDefaultFail.popover()\"\n                  placement=\"right\"\n                  *ngIf=\"\n                    controls?.program_default_failed_overseer?.value?.length > 1\n                  \"\n                >\n                  +{{\n                    controls?.program_default_failed_overseer?.value?.length - 1\n                  }}\n                </button>\n              </div>\n              <span\n                *ngIf=\"\n                  controls?.program_default_failed_overseer_group?.value\n                    ?.length &&\n                  controls?.program_default_failed_overseer?.value?.length\n                \"\n                class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n                >&</span\n              >\n              <div\n                class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n                *ngIf=\"\n                  controls?.program_default_failed_overseer_group?.value?.length\n                \"\n              >\n                <i\n                  class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n                  (click)=\"\n                    remove(\n                      controls?.program_default_failed_overseer_group?.value[0],\n                      'DEFAULT_FAILED_OVERSEER_GROUP'\n                    )\n                  \"\n                  >&#xe9ae;</i\n                >\n                <span\n                  class=\"chipName vx-fs-11 vx-label-txt\"\n                  [appTooltip]=\"\n                    controls?.program_default_failed_overseer_group?.value[0]\n                      ?.group_name\n                  \"\n                  placement=\"bottom-left\"\n                  delay=\"0\"\n                  type=\"black\"\n                  [tooltipMandatory]=\"false\"\n                  >{{\n                    controls?.program_default_failed_overseer_group?.value[0]\n                      ?.group_name\n                  }}</span\n                >\n                <button\n                  class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n                  appPopover\n                  (click)=\"overseerDefaultFailGroup.popover()\"\n                  placement=\"right\"\n                  *ngIf=\"\n                    controls?.program_default_failed_overseer_group?.value\n                      ?.length > 1\n                  \"\n                >\n                  +{{\n                    controls?.program_default_failed_overseer_group?.value\n                      ?.length - 1\n                  }}\n                </button>\n              </div>\n            </div>\n\n            <!-- <div class=\"chip-container\">\n                <div class=\"chip-inner\" *ngIf=\"controls?.program_default_failed_overseer?.value?.length\">\n                  <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_failed_overseer?.value[0],'DEFAULT_FAILED_OVERSEER')\" >&#xe90d;</i>\n                    <span class=\"chip\">\n                      <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_failed_overseer?.value[0]?.member_name}}</span>\n                    </span>\n                    <button *ngIf=\"controls?.program_default_failed_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseersDefaultFail.popover()\" placement=\"right\">+{{controls?.program_default_failed_overseer?.value?.length -1}}</button>\n                </div>\n                <span *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length && controls?.program_default_failed_overseer?.value?.length\" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n                <div class=\"chip-inner\" *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length \">\n                    <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_failed_overseer_group?.value[0],'DEFAULT_FAILED_OVERSEER_GROUP')\" >&#xe90d;</i>\n                    <span class=\"chip\" [appTooltip]=\"controls?.program_default_failed_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n                        <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_failed_overseer_group?.value[0]?.group_name}}</span>\n                    </span>\n                    <button *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"overseerDefaultFailGroup.popover()\" placement=\"right\">+{{controls?.program_default_failed_overseer_group?.value?.length -1}}</button>\n                </div>\n            </div> -->\n            <button\n              *ngIf=\"activeList !== 'DEFAULT_FAILED_OVERSEER'\"\n              (click)=\"activateList('DEFAULT_FAILED_OVERSEER')\"\n              class=\"edit\"\n              type=\"button\"\n            >\n              <i class=\"icons\">&#xe9ba;</i> Edit\n            </button>\n          </div>\n        </input-with-pill>\n        <app-popover #overseersDefaultFail [dontCloseonClick]=\"true\">\n          <div class=\"wf-action-list\">\n            <ul class=\"action-item\">\n              <li\n                *ngFor=\"\n                  let overseer of controls?.program_default_failed_overseer\n                    ?.value | slice : 1\n                \"\n              >\n                <div class=\"avatar-card\">\n                  <span class=\"value\">\n                    <i\n                      class=\"icons\"\n                      (click)=\"remove(overseer, 'DEFAULT_FAILED_OVERSEER')\"\n                      >&#xe90d;</i\n                    >\n                    {{ overseer?.member_name }}\n                  </span>\n                </div>\n              </li>\n            </ul>\n          </div>\n        </app-popover>\n        <app-popover #overseerDefaultFailGroup [dontCloseonClick]=\"true\">\n          <div class=\"wf-action-list\">\n            <ul class=\"action-item\">\n              <li\n                *ngFor=\"\n                  let group of controls?.program_default_failed_overseer_group\n                    ?.value | slice : 1\n                \"\n              >\n                <div class=\"avatar-card\">\n                  <span class=\"value\">\n                    <i\n                      (click)=\"remove(group, 'DEFAULT_FAILED_OVERSEER_GROUP')\"\n                      class=\"icons\"\n                      >&#xe90d;</i\n                    >\n                    {{ group?.group_name }}\n                  </span>\n                </div>\n              </li>\n            </ul>\n          </div>\n        </app-popover>\n      </ng-container>\n    </form-field>\n\n    <!-- Assessment -->\n    <form-field\n      [appScrollInView]=\"scrollToBottom\"\n      *ngIf=\"additionalOption?.ASSESSMENT\"\n      [checked]=\"controls?.program_assessments?.value?.length\"\n      [active]=\"activeList === 'ASSESSMENT'\"\n      [disabled]=\"\n        sideElements.includes(activeList) && activeList !== 'ASSESSMENT'\n      \"\n      [img]=\"ASSETS.assessments\"\n    >\n      <label class=\"vx-control-panel\"\n        >ASSESSMENTS\n        <i\n          class=\"icons\"\n          [appTooltip]=\"\n            'Assessments are a digital form that are created in “Assessment” within the Compliance Module. Where Assessments are selected when creating a Program, only those Assessments will be available for selection when creating a responsibility linked with the Program.'\n          \"\n          placement=\"bottom\"\n          delay=\"0\"\n          type=\"white\"\n          [tooltipMandatory]=\"true\"\n          id=\"AssessmentHelpText\"\n          >&#xeb16;</i\n        ></label\n      >\n      <input-with-pill\n        [selectDiv]=\"true\"\n        [placeholder]=\"\n          'Which assessments can be linked to the responsibilities within this Program?'\n        \"\n        (select)=\"activateList('ASSESSMENT')\"\n      >\n        <div\n          class=\"selected\"\n          *ngIf=\"controls?.program_assessments?.value?.length\"\n        >\n          <div\n            class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n            *ngIf=\"\n              controls?.program_assessments?.value\n                | assessmentResolver as assessments\n            \"\n          >\n            <i\n              class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n              (click)=\"remove(assessments[0], 'ASSESSMENT')\"\n              >&#xe9ae;</i\n            >\n            <span\n              class=\"chipName vx-fs-11 vx-label-txt\"\n              [appTooltip]=\"assessments[0]?.assessment_name\"\n              placement=\"bottom-left\"\n              delay=\"0\"\n              type=\"black\"\n              [tooltipMandatory]=\"false\"\n              >{{ assessments[0]?.assessment_name }}</span\n            >\n            <button\n              class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n              appPopover\n              (click)=\"program_assessments.popover()\"\n              placement=\"right\"\n              *ngIf=\"assessments?.length > 1\"\n            >\n              +{{ assessments?.length - 1 }}\n            </button>\n          </div>\n\n          <!-- <div class=\"chip-container\">\n                        <ng-container *ngIf=\"(controls?.program_assessments?.value | assessmentResolver) as assessments\">\n                            <div class=\"chip-inner\">\n                                <span class=\"chip\"><i class=\"icons\" (click)=\"remove(assessments[0],'ASSESSMENT')\">&#xe90d;</i>{{assessments[0]?.assessment_name}} </span>\n                                <button *ngIf=\"assessments?.length > 1\" class=\"count\" appPopover (click)=\"program_assessments.popover()\" placement=\"right\">+{{assessments?.length -1 }}</button>\n                            </div>\n                        </ng-container>\n                    </div> -->\n          <button\n            *ngIf=\"activeList !== 'ASSESSMENT'\"\n            class=\"edit\"\n            type=\"button\"\n            (click)=\"activateList('ASSESSMENT')\"\n          >\n            <i class=\"icons\">&#xe9ba;</i> Edit\n          </button>\n        </div>\n      </input-with-pill>\n      <app-popover #program_assessments [dontCloseonClick]=\"true\">\n        <ng-container>\n          <div class=\"wf-action-list\">\n            <ul class=\"action-item\">\n              <li\n                *ngFor=\"\n                  let assessment of controls?.program_assessments?.value\n                    | assessmentResolver\n                    | slice : 1\n                \"\n              >\n                <div class=\"avatar-card\">\n                  <span class=\"value\">\n                    <i (click)=\"remove(assessment, 'ASSESSMENT')\" class=\"icons\"\n                      >&#xe90d;</i\n                    >\n                    {{ assessment?.assessment_name }}\n                  </span>\n                </div>\n              </li>\n            </ul>\n          </div>\n        </ng-container>\n      </app-popover>\n    </form-field>\n\n    <!-- Format & Evidence -->\n    <form-field\n      [appScrollInView]=\"scrollToBottom\"\n      *ngIf=\"additionalOption?.FORMATE_EVIDENCE\"\n      [checked]=\"[true, false].includes(controls?.evidence_required?.value)\"\n      [active]=\"false\"\n      [disabled]=\"sideElements.includes(activeList)\"\n      [img]=\"ASSETS.format_evidence\"\n    >\n      <label class=\"vx-control-panel\"\n        >Evidence\n        <i\n          class=\"icons\"\n          [appTooltip]=\"\n            'If selected, evidence of completion of a responsibility will be required for all responsibilities that are linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility.'\n          \"\n          placement=\"bottom\"\n          delay=\"0\"\n          type=\"white\"\n          [tooltipMandatory]=\"true\"\n          id=\"EvidenceHelpText\"\n          >&#xeb16;</i\n        ></label\n      >\n      <div class=\"upload-format\">\n        <span class=\"text\"\n          >Do all responsibilities within this program require evidence?</span\n        >\n        <div class=\"radio-group program\">\n          <app-cs-radio\n            [name]=\"'evidence_required'\"\n            [checked]=\"controls?.evidence_required?.value\"\n            (checkedEvent)=\"setFormField('evidence_required', true)\"\n            >YES</app-cs-radio\n          >\n          <app-cs-radio\n            [name]=\"'evidence_required'\"\n            [checked]=\"!controls?.evidence_required?.value\"\n            (checkedEvent)=\"setFormField('evidence_required', false)\"\n            >NO</app-cs-radio\n          >\n        </div>\n      </div>\n      <!-- <div class=\"vx-d-flex vx-align-center vx-justify-end vx-mt-2\">\n                <div class=\"vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase vx-mr-2\">Allow any file to be marked as\n                    key\n                    evidence</div>\n                <switch formControlName=\"allow_any_file_key_evidence\"\n                    (change)=\"setFormField('allow_any_file_key_evidence',$event?.target?.checked)\"></switch>\n            </div> -->\n    </form-field>\n\n    <!-- Custom Field -->\n    <form-field\n      [appScrollInView]=\"scrollToBottom\"\n      *ngIf=\"additionalOption?.CUSTOM_FIELDS\"\n      [checked]=\"controls?.custom_fields?.value?.length\"\n      [active]=\"false\"\n      [disabled]=\"sideElements.includes(activeList)\"\n      [img]=\"ASSETS.custom_fields\"\n    >\n      <label class=\"vx-control-panel\"\n        >CUSTOM FIELD\n        <i\n          class=\"icons\"\n          [appTooltip]=\"\n            'Where a custom field is specified, all responsibilities linked with a Program will contain that custom field. Custom fields enable the collection of additional meta data.'\n          \"\n          placement=\"bottom\"\n          delay=\"0\"\n          type=\"white\"\n          [tooltipMandatory]=\"true\"\n          id=\"CFHelpText\"\n          >&#xeb16;</i\n        ></label\n      >\n      <custom-field formControlName=\"custom_fields\"></custom-field>\n    </form-field>\n  </form>\n</div>\n\n<!-- list of roles -->\n<role-list\n  *ngIf=\"activeList === 'ROLE'\"\n  [selected]=\"controls?.program_roles?.value | refDisconnect\"\n  [loading]=\"listLoadingState.ROLES\"\n  [list]=\"lists?.ROLES?.data ?? []\"\n  (save)=\"listAction($event, 'ROLE')\"\n  (cancel)=\"fieldDeselector('ROLE')\"\n  [featureflagrole]=\"featureflagrole\"\n  [featureflagGroup]=\"featureflagGroups\"\n  [ff_rc_listing]=\"ff_rc_listing\"\n></role-list>\n\n<!-- list of frameworks -->\n<!-- <app-define-framework-listing *ngIf=\"activeList === 'FRAMEWORK'\" (cancel)=\"fieldDeselector('FRAMEWORK')\" (next)=\"listAction($event,'FRAMEWORK')\" [mode]=\"mode\" [selectedFramework]=\"controls?.framework?.value\"></app-define-framework-listing> -->\n<!-- list of responsibility center -->\n<app-responsibility-centers-list\n  *ngIf=\"activeList === 'RC'\"\n  [responsibilityCentersList]=\"lists?.RC ?? []\"\n  [radioSelection]=\"false\"\n  [rcIdKey]=\"'rc_id'\"\n  (closeRcList)=\"fieldDeselector('RC')\"\n  (saveSelectedList)=\"listAction($event, 'RC')\"\n  [selectedResponsibilityCenters]=\"controls?.rc?.value | refDisconnect\"\n>\n</app-responsibility-centers-list>\n<!-- render userlist with group -->\n\n<user-group-list\n  *ngIf=\"activeList === 'OWNER'\"\n  [groupEnabled]=\"true\"\n  [singleSelect]=\"false\"\n  [loading]=\"listLoadingState.USERS\"\n  [nonRemovableUserIds]=\"lists.NON_REMOVABLE_OWNERS | listToId : 'member_id'\"\n  [userlist]=\"lists?.OWNERS?.data ?? []\"\n  [selectedUsers]=\"controls?.program_owners?.value | refDisconnect\"\n  (fetchUserData)=\"fetchUsersAssociatedWithRoles(false, $event)\"\n  [userListInfo]=\"lists?.OWNERS\"\n  [groupListInfo]=\"lists?.OWNERS_GROUPS\"\n  [groupList]=\"lists?.OWNERS_GROUPS?.data ?? []\"\n  [selectedGroups]=\"controls?.program_owners_group?.value | refDisconnect\"\n  (save)=\"listAction($event, 'OWNER')\"\n  (cancel)=\"fieldDeselector('OWNER')\"\n  [panelTitle]=\"panelTitleOwner\"\n  [featureflag]=\"featureflagGroups\"\n></user-group-list>\n\n<user-group-list\n  *ngIf=\"activeList === 'COLLABORATOR'\"\n  [groupEnabled]=\"false\"\n  [singleSelect]=\"false\"\n  [userlist]=\"lists?.COLLABORATORS?.data ?? []\"\n  [disabledIds]=\"disableCollaboratorIds\"\n  [selectedUsers]=\"controls?.program_collaborator?.value | refDisconnect\"\n  [userListInfo]=\"lists?.COLLABORATORS\"\n  (save)=\"listAction($event, 'COLLABORATOR')\"\n  (cancel)=\"fieldDeselector('COLLABORATOR')\"\n  [panelTitle]=\"panelTitleCollaborator\"\n>\n</user-group-list>\n<user-group-list\n  *ngIf=\"activeList === 'ASSIGNEE'\"\n  [groupEnabled]=\"true\"\n  [singleSelect]=\"false\"\n  [loading]=\"listLoadingState.USERS\"\n  [userlist]=\"lists?.ASSIGNEES ?? []\"\n  [selectedUsers]=\"controls?.program_assignee?.value | refDisconnect\"\n  [groupList]=\"lists?.ASSIGNEES_GROUP ?? []\"\n  [FromProgram]=\"true\"\n  [selectedGroups]=\"controls?.program_assignee_group?.value | refDisconnect\"\n  [disabledIds]=\"disabledAssigneeIds\"\n  [fromResponsibility]=\"'Assignee'\"\n  [reviewerIds]=\"selectedReviewerIds\"\n  [overseerIds]=\"selectedOverseerIds\"\n  [assignorId]=\"assignorId\"\n  [userListInfo]=\"lists?.ASSIGNEES\"\n  (save)=\"listAction($event, 'ASSIGNEE')\"\n  (cancel)=\"fieldDeselector('ASSIGNEE')\"\n  [panelTitle]=\"panelTitleAssignee\"\n  [defaultSelectedUsers]=\"\n    controls?.program_default_assignee?.value | refDisconnect\n  \"\n  [userType]=\"'assignees'\"\n  [featureflag]=\"featureflagGroups\"\n>\n</user-group-list>\n<user-group-list\n  *ngIf=\"activeList === 'DEFAULT_ASSIGNEE'\"\n  [groupEnabled]=\"true\"\n  [singleSelect]=\"false\"\n  [loading]=\"listLoadingState.USERS\"\n  [userlist]=\"lists?.DEFAULT_ASSIGNEES ?? []\"\n  [selectedUsers]=\"controls?.program_default_assignee?.value | refDisconnect\"\n  [groupList]=\"lists?.DEFAULT_ASSIGNEES_GROUP ?? []\"\n  [FromProgram]=\"true\"\n  [selectedGroups]=\"\n    controls?.program_default_assignee_group?.value | refDisconnect\n  \"\n  [disabledIds]=\"disabledAssigneeIds\"\n  [fromResponsibility]=\"'Assignee'\"\n  [reviewerIds]=\"selectedReviewerIds\"\n  [overseerIds]=\"selectedOverseerIds\"\n  [assignorId]=\"assignorId\"\n  [userListInfo]=\"lists?.DEFAULT_ASSIGNEE\"\n  (save)=\"listAction($event, 'DEFAULT_ASSIGNEE')\"\n  (cancel)=\"fieldDeselector('DEFAULT_ASSIGNEE')\"\n  [featureflag]=\"featureflagGroups\"\n>\n</user-group-list>\n\n<user-group-list\n  *ngIf=\"activeList === 'REVIEWER' && (!featureflagGroups || featureflagGroups)\"\n  [groupEnabled]=\"featureflagGroups\"\n  [singleSelect]=\"false\"\n  [loading]=\"listLoadingState.USERS\"\n  [FromProgram]=\"true\"\n  [userlist]=\"lists?.REVIEWERS ?? []\"\n  [selectedUsers]=\"controls?.program_reviewer?.value | refDisconnect\"\n  [groupList]=\"lists?.REVIEWERS_GROUP ?? []\"\n  [featureflag]=\"featureflagGroups\"\n  [selectedGroups]=\"controls?.program_reviewer_group?.value | refDisconnect\"\n  [disabledIds]=\"disableReviewerIds\"\n  [fromResponsibility]=\"'Reviewer'\"\n  [assignorId]=\"assignorId\"\n  [assigneeIds]=\"selectedAssigneeIds\"\n  [overseerIds]=\"selectedOverseerIds\"\n  [userListInfo]=\"lists?.REVIEWERS\"\n  (save)=\"listAction($event, 'REVIEWER')\"\n  (cancel)=\"fieldDeselector('REVIEWER')\"\n  [panelTitle]=\"panelTitleReviewer\"\n  [defaultSelectedUsers]=\"\n    controls?.program_default_reviewer?.value | refDisconnect\n  \"\n  [userType]=\"'reviewers'\"\n>\n</user-group-list>\n<user-group-list\n  *ngIf=\"\n    activeList === 'DEFAULT_REVIEWER' &&\n    (!featureflagGroups || featureflagGroups)\n  \"\n  [groupEnabled]=\"featureflagGroups\"\n  [singleSelect]=\"false\"\n  [loading]=\"listLoadingState.USERS\"\n  [FromProgram]=\"true\"\n  [userlist]=\"lists?.DEFAULT_REVIEWERS ?? []\"\n  [selectedUsers]=\"controls?.program_default_reviewer?.value | refDisconnect\"\n  [groupList]=\"lists?.DEFAULT_REVIEWERS_GROUP ?? []\"\n  [featureflag]=\"featureflagGroups\"\n  [selectedGroups]=\"\n    controls?.program_default_reviewer_group?.value | refDisconnect\n  \"\n  [disabledIds]=\"disableReviewerIds\"\n  [fromResponsibility]=\"'Reviewer'\"\n  [assignorId]=\"assignorId\"\n  [assigneeIds]=\"selectedAssigneeIds\"\n  [overseerIds]=\"selectedOverseerIds\"\n  [userListInfo]=\"lists?.DEFAULT_REVIEWERS\"\n  (save)=\"listAction($event, 'DEFAULT_REVIEWER')\"\n  (cancel)=\"fieldDeselector('DEFAULT_REVIEWER')\"\n  [panelTitle]=\"panelTitleDefaultReviewer\"\n>\n</user-group-list>\n<user-group-list\n  *ngIf=\"activeList === 'OVERSEER' && (!featureflagGroups || featureflagGroups)\"\n  [groupEnabled]=\"featureflagGroups\"\n  [singleSelect]=\"false\"\n  [loading]=\"listLoadingState.USERS\"\n  [FromProgram]=\"true\"\n  [userlist]=\"lists?.OVERSEERS ?? []\"\n  [selectedUsers]=\"controls?.program_overseer?.value | refDisconnect\"\n  [groupList]=\"lists?.OVERSEERS_GROUP ?? []\"\n  [selectedGroups]=\"controls?.program_overseer_group?.value | refDisconnect\"\n  [featureflag]=\"featureflagGroups\"\n  [disabledIds]=\"disableOverseerIds\"\n  [fromResponsibility]=\"'Overseer'\"\n  [assignorId]=\"assignorId\"\n  [assigneeIds]=\"selectedAssigneeIds\"\n  [reviewerIds]=\"selectedReviewerIds\"\n  [userListInfo]=\"lists?.OVERSEES\"\n  (save)=\"listAction($event, 'OVERSEER')\"\n  (cancel)=\"fieldDeselector('OVERSEER')\"\n  [defaultSelectedUsers]=\"\n    controls?.program_default_overseer?.value\n      | refDisconnect\n      | arrayConcat : controls?.program_default_failed_overseer?.value\n  \"\n  [userType]=\"'overseers'\"\n>\n</user-group-list>\n<user-group-list\n  *ngIf=\"\n    activeList === 'DEFAULT_OVERSEER' &&\n    (!featureflagGroups || featureflagGroups)\n  \"\n  [groupEnabled]=\"featureflagGroups\"\n  [singleSelect]=\"false\"\n  [loading]=\"listLoadingState.USERS\"\n  [FromProgram]=\"true\"\n  [userlist]=\"lists?.DEFAULT_OVERSEERS ?? []\"\n  [selectedUsers]=\"controls?.program_default_overseer?.value | refDisconnect\"\n  [groupList]=\"lists?.DEFAULT_OVERSEERS_GROUP ?? []\"\n  [selectedGroups]=\"\n    controls?.program_default_overseer_group?.value | refDisconnect\n  \"\n  [featureflag]=\"featureflagGroups\"\n  [disabledIds]=\"disableOverseerIds\"\n  [fromResponsibility]=\"'Overseer'\"\n  [assignorId]=\"assignorId\"\n  [assigneeIds]=\"selectedAssigneeIds\"\n  [reviewerIds]=\"selectedReviewerIds\"\n  [userListInfo]=\"lists?.DEFAULT_OVERSEERS\"\n  (save)=\"listAction($event, 'DEFAULT_OVERSEER')\"\n  (cancel)=\"fieldDeselector('DEFAULT_OVERSEER')\"\n>\n</user-group-list>\n<user-group-list\n  *ngIf=\"\n    activeList === 'DEFAULT_FAILED_OVERSEER' &&\n    (!featureflagGroups || featureflagGroups)\n  \"\n  [groupEnabled]=\"featureflagGroups\"\n  [singleSelect]=\"false\"\n  [loading]=\"listLoadingState.USERS\"\n  [FromProgram]=\"true\"\n  [userlist]=\"lists?.DEFAULT_OVERSEERS ?? []\"\n  [selectedUsers]=\"\n    controls?.program_default_failed_overseer?.value | refDisconnect\n  \"\n  [groupList]=\"lists?.DEFAULT_OVERSEERS_GROUP ?? []\"\n  [selectedGroups]=\"\n    controls?.program_default_failed_overseer_group?.value | refDisconnect\n  \"\n  [featureflag]=\"featureflagGroups\"\n  [disabledIds]=\"disableOverseerIds\"\n  [fromResponsibility]=\"'Overseer'\"\n  [assignorId]=\"assignorId\"\n  [assigneeIds]=\"selectedAssigneeIds\"\n  [reviewerIds]=\"selectedReviewerIds\"\n  [userListInfo]=\"lists?.DEFAULT_OVERSEERS\"\n  (save)=\"listAction($event, 'DEFAULT_FAILED_OVERSEER')\"\n  (cancel)=\"fieldDeselector('DEFAULT_FAILED_OVERSEER')\"\n>\n</user-group-list>\n<assessment-picker\n  *ngIf=\"activeList === 'ASSESSMENT'\"\n  [selectedAssessment]=\"controls?.program_assessments?.value\"\n  (cancelAssessment)=\"fieldDeselector('ASSESSMENT')\"\n  (onAssessmentSelect)=\"listAction($event, 'ASSESSMENT')\"\n></assessment-picker>\n<app-loader-inline *ngIf=\"loader\"></app-loader-inline>\n<app-smiley-dialog-inline\n  *ngIf=\"showSmiley\"\n  [message]=\"smileyMessage\"\n  [actionButtons]=\"actionButtons\"\n  (action)=\"action($event)\"\n  (closeSmiley)=\"closeSmiley($event)\"\n>\n</app-smiley-dialog-inline>\n\n<!-- Framework selector  -->\n<app-framework-list\n  *ngIf=\"activeList === 'FRAMEWORK'\"\n  [workflowPage]=\"['FRAMEWORK']\"\n  (assignControl)=\"listAction($event, 'FRAMEWORK')\"\n  (closeFramework)=\"fieldDeselector('FRAMEWORK')\"\n  [previousSelectedValues]=\"{ framework: controls?.framework.value }\"\n  (entrustFramework)=\"entrustFramework($event)\"\n  [headerText]=\"'Select a framework'\"\n></app-framework-list>\n"]}