vcomply-workflow-engine 6.0.84 → 6.0.85

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 (97) hide show
  1. package/esm2022/lib/constants/api.constants.mjs +1 -6
  2. package/esm2022/lib/constants/policy.constant.mjs +6 -0
  3. package/esm2022/lib/interfaces/policy.interface.mjs +2 -0
  4. package/esm2022/lib/interfaces/responsibilty.interface.mjs +1 -1
  5. package/esm2022/lib/more-option/more-option.component.mjs +183 -17
  6. package/esm2022/lib/report-a-case/services/report-a-case.service.mjs +2 -3
  7. package/esm2022/lib/report-a-case/workflow-case/workflow-case.component.mjs +7 -4
  8. package/esm2022/lib/services/common.service.mjs +1 -40
  9. package/esm2022/lib/services/iframe.service.mjs +1 -14
  10. package/esm2022/lib/sharedComponents/format-and-evidence/format-and-evidence.component.mjs +21 -10
  11. package/esm2022/lib/sharedComponents/frequency/frequency-annual/frequency-annual.component.mjs +1 -5
  12. package/esm2022/lib/sharedComponents/frequency/frequency-biannual/frequency-biannual.component.mjs +1 -5
  13. package/esm2022/lib/sharedComponents/frequency/frequency-container/frequency-container.component.mjs +5 -5
  14. package/esm2022/lib/sharedComponents/frequency/frequency-daily/frequency-daily.component.mjs +1 -2
  15. package/esm2022/lib/sharedComponents/frequency/frequency-monthly/frequency-monthly.component.mjs +2 -6
  16. package/esm2022/lib/sharedComponents/frequency/frequency-one-time/frequency-one-time.component.mjs +2 -3
  17. package/esm2022/lib/sharedComponents/frequency/frequency-ongoing/frequency-ongoing.component.mjs +1 -3
  18. package/esm2022/lib/sharedComponents/frequency/frequency-quarterly/frequency-quarterly.component.mjs +1 -5
  19. package/esm2022/lib/sharedComponents/frequency/frequency-random/frequency-random.component.mjs +2 -9
  20. package/esm2022/lib/sharedComponents/frequency/frequency-weekly/frequency-weekly.component.mjs +2 -4
  21. package/esm2022/lib/sharedComponents/frequency/frequency.service.mjs +5 -267
  22. package/esm2022/lib/sharedComponents/link-responsibility/link-responsibility.component.mjs +16 -48
  23. package/esm2022/lib/sharedComponents/link-responsibility/link-responsibility.module.mjs +4 -8
  24. package/esm2022/lib/workflow/grc-object/grc-object-container/grc-object-container.component.mjs +17 -45
  25. package/esm2022/lib/workflow/shared/components/grc-category-listing/grc-category-listing.component.mjs +10 -13
  26. package/esm2022/lib/workflow/shared/components/program-responsibility-listing/program-responsibility-listing.component.mjs +35 -62
  27. package/esm2022/lib/workflow/shared/services/grc.service.mjs +2 -15
  28. package/esm2022/lib/workflow/shared/workflow-pipes/workflow-pipes.module.mjs +3 -8
  29. package/esm2022/lib/workflow-compliance/workflow-compliance.component.mjs +411 -283
  30. package/esm2022/lib/workflow-engine-container/api-constants.mjs +2 -3
  31. package/esm2022/lib/workflow-engine-container/workflow-engine-container.component.mjs +53 -32
  32. package/esm2022/lib/workflow-engine.module.mjs +6 -13
  33. package/esm2022/lib/workflow-policy/workflow-policy.component.mjs +29 -46
  34. package/esm2022/lib/workflow-program/constants.mjs +3 -3
  35. package/esm2022/lib/workflow-program/workflow-program.component.mjs +338 -123
  36. package/esm2022/lib/workflow-services/policy.service.mjs +9 -8
  37. package/esm2022/lib/workflow-services/programs.service.mjs +113 -26
  38. package/esm2022/lib/workflow-services/responsibility.service.mjs +56 -60
  39. package/fesm2022/vcomply-workflow-engine.mjs +14612 -14860
  40. package/fesm2022/vcomply-workflow-engine.mjs.map +1 -1
  41. package/lib/constants/api.constants.d.ts +0 -5
  42. package/lib/constants/policy.constant.d.ts +2 -0
  43. package/lib/interfaces/policy.interface.d.ts +5 -0
  44. package/lib/interfaces/responsibilty.interface.d.ts +13 -13
  45. package/lib/services/common.service.d.ts +0 -28
  46. package/lib/services/iframe.service.d.ts +0 -6
  47. package/lib/sharedComponents/format-and-evidence/format-and-evidence.component.d.ts +4 -1
  48. package/lib/sharedComponents/frequency/frequency-random/frequency-random.component.d.ts +0 -1
  49. package/lib/sharedComponents/frequency/frequency.service.d.ts +2 -92
  50. package/lib/sharedComponents/link-responsibility/link-responsibility.component.d.ts +1 -2
  51. package/lib/sharedComponents/link-responsibility/link-responsibility.module.d.ts +1 -2
  52. package/lib/workflow/grc-object/grc-object-container/grc-object-container.component.d.ts +1 -5
  53. package/lib/workflow/shared/components/grc-category-listing/grc-category-listing.component.d.ts +1 -3
  54. package/lib/workflow/shared/components/program-responsibility-listing/program-responsibility-listing.component.d.ts +2 -6
  55. package/lib/workflow/shared/services/grc.service.d.ts +0 -1
  56. package/lib/workflow/shared/workflow-pipes/workflow-pipes.module.d.ts +2 -3
  57. package/lib/workflow-compliance/workflow-compliance.component.d.ts +6 -32
  58. package/lib/workflow-engine-container/api-constants.d.ts +0 -1
  59. package/lib/workflow-engine-container/workflow-engine-container.component.d.ts +2 -5
  60. package/lib/workflow-engine.module.d.ts +40 -42
  61. package/lib/workflow-policy/workflow-policy.component.d.ts +0 -9
  62. package/lib/workflow-program/workflow-program.component.d.ts +4 -8
  63. package/lib/workflow-risk/workflow-risk.component.d.ts +1 -1
  64. package/lib/workflow-services/policy.service.d.ts +1 -1
  65. package/lib/workflow-services/programs.service.d.ts +53 -13
  66. package/lib/workflow-services/responsibility.service.d.ts +4 -17
  67. package/package.json +1 -1
  68. package/esm2022/lib/constants/mock.mjs +0 -152
  69. package/esm2022/lib/interfaces/frequency.interface.mjs +0 -2
  70. package/esm2022/lib/interfaces/iframe-type.mjs +0 -7
  71. package/esm2022/lib/sharedComponents/list-container/list-container.component.mjs +0 -52
  72. package/esm2022/lib/sharedComponents/program-list/constant.mjs +0 -16
  73. package/esm2022/lib/sharedComponents/program-list/interfaces/data-source.interface.mjs +0 -2
  74. package/esm2022/lib/sharedComponents/program-list/interfaces/list-item.interface.mjs +0 -2
  75. package/esm2022/lib/sharedComponents/program-list/pipes/check-selected-items.pipes.mjs +0 -23
  76. package/esm2022/lib/sharedComponents/program-list/program-list/program-list.component.mjs +0 -182
  77. package/esm2022/lib/sharedComponents/program-list/program-list.module.mjs +0 -47
  78. package/esm2022/lib/sharedComponents/program-list/services/list-utils.service.mjs +0 -27
  79. package/esm2022/lib/sharedComponents/program-list/services/program-list-api.service.mjs +0 -32
  80. package/esm2022/lib/ui-kit/loaders/loaders.module.mjs +0 -24
  81. package/esm2022/lib/ui-kit/loaders/table-loader/table-loader.component.mjs +0 -19
  82. package/esm2022/lib/workflow/shared/workflow-pipes/get-user-details.pipe.mjs +0 -26
  83. package/lib/constants/mock.d.ts +0 -15
  84. package/lib/interfaces/frequency.interface.d.ts +0 -37
  85. package/lib/interfaces/iframe-type.d.ts +0 -5
  86. package/lib/sharedComponents/list-container/list-container.component.d.ts +0 -9
  87. package/lib/sharedComponents/program-list/constant.d.ts +0 -9
  88. package/lib/sharedComponents/program-list/interfaces/data-source.interface.d.ts +0 -4
  89. package/lib/sharedComponents/program-list/interfaces/list-item.interface.d.ts +0 -5
  90. package/lib/sharedComponents/program-list/pipes/check-selected-items.pipes.d.ts +0 -7
  91. package/lib/sharedComponents/program-list/program-list/program-list.component.d.ts +0 -45
  92. package/lib/sharedComponents/program-list/program-list.module.d.ts +0 -14
  93. package/lib/sharedComponents/program-list/services/list-utils.service.d.ts +0 -7
  94. package/lib/sharedComponents/program-list/services/program-list-api.service.d.ts +0 -14
  95. package/lib/ui-kit/loaders/loaders.module.d.ts +0 -8
  96. package/lib/ui-kit/loaders/table-loader/table-loader.component.d.ts +0 -9
  97. package/lib/workflow/shared/workflow-pipes/get-user-details.pipe.d.ts +0 -7
@@ -4,7 +4,6 @@ import { cloneDeep, 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
7
  import * as i0 from "@angular/core";
9
8
  import * as i1 from "@angular/forms";
10
9
  import * as i2 from "../workflow-services/programs.service";
@@ -23,22 +22,28 @@ import * as i14 from "../ui-kit/popover-hover/popover-hover.component";
23
22
  import * as i15 from "../ui-kit/popover-hover/popover-hover.directive";
24
23
  import * as i16 from "./create-program-ui/tab-selector/tab-selector.component";
25
24
  import * as i17 from "./create-program-ui/form-field/form-field.component";
26
- import * as i18 from "./create-program-ui/input-with-pill/input-with-pill.component";
27
- import * as i19 from "./create-program-ui/directives/input-trim.directive";
28
- import * as i20 from "./create-program-ui/user-group-list/user-group-list.component";
29
- import * as i21 from "./create-program-ui/custom-field/custom-field.component";
30
- import * as i22 from "../sharedComponents/framework-list/framework-list.component";
31
- import * as i23 from "./create-program-ui/pipes/list-to-id.pipe";
32
- import * as i24 from "./create-program-ui/pipes/ref-disconnect.pipe";
33
- 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";
34
39
  export class WorkflowProgramComponent {
35
- constructor(fb, programService, authService, uiKitService, changeRef, iframeService) {
40
+ constructor(fb, programService, authService, uiKitService, iframeService, changeRef) {
36
41
  this.fb = fb;
37
42
  this.programService = programService;
38
43
  this.authService = authService;
39
44
  this.uiKitService = uiKitService;
40
- this.changeRef = changeRef;
41
45
  this.iframeService = iframeService;
46
+ this.changeRef = changeRef;
42
47
  this.ASSETS = ASSETS;
43
48
  this.constants = CONSTANTS;
44
49
  this.isAscentAllowed = false;
@@ -62,7 +67,7 @@ export class WorkflowProgramComponent {
62
67
  this.panelTitleDefaultReviewer = 'Select Default Reviewer(s)';
63
68
  this.panelTitleOwner = 'Select Owner(s)';
64
69
  this.panelTitleReviewer = 'Select Reviewer(s)';
65
- this.panelTitleAssignee = 'Select Collaborator(s)';
70
+ this.panelTitleAssignee = 'Select Assignee(s)';
66
71
  this.panelTitleApprover = 'Select Approver';
67
72
  this.isApproverDisabled = false;
68
73
  this.isProgramScope = false;
@@ -73,7 +78,6 @@ export class WorkflowProgramComponent {
73
78
  <li>To pre-select certain options that are available when creating a responsibility, thereby decreasing the time required to create a responsibility.</li>
74
79
  <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>
75
80
  `,
76
- 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.`,
77
81
  };
78
82
  this.featureflagrole = false;
79
83
  this.featureflagGroups = false;
@@ -97,7 +101,7 @@ export class WorkflowProgramComponent {
97
101
  //form body for program meta data
98
102
  this.programForm = this.fb.group({
99
103
  program_type: [
100
- this.programType ?? 1,
104
+ this.programType,
101
105
  [Validators.required, Validators.min(0), Validators.max(3)],
102
106
  ],
103
107
  program_name: ['', [Validators.required, this.noWhitespaceValidator]],
@@ -106,10 +110,14 @@ export class WorkflowProgramComponent {
106
110
  program_objective: [''],
107
111
  // program_objective: ['', [Validators.required, this.noWhitespaceValidator]],
108
112
  program_objective_attachments: [[]],
113
+ program_roles: [[], [Validators.required, this.blankArrayValidator]],
109
114
  all_user_in_role: [false],
110
- program_owners: [[]],
115
+ program_owners: [[], [Validators.required, this.blankArrayValidator]],
111
116
  program_owners_group: [[]],
112
117
  program_approver: [[]],
118
+ performance_calculation: ['PAST_EVENT', [Validators.required]],
119
+ recurring_frequency: [true, [Validators.required]],
120
+ lock_scope_change: [false, [Validators.required]],
113
121
  framework: [],
114
122
  rc: [[]],
115
123
  program_assignee: [[]],
@@ -133,8 +141,6 @@ export class WorkflowProgramComponent {
133
141
  allow_any_file_key_evidence: [false],
134
142
  custom_fields: [[]],
135
143
  program_state: 0,
136
- collaborators: [[]],
137
- collaborators_group: [[]],
138
144
  });
139
145
  //exceptional handling of custom fields
140
146
  this.showAddCustomField = true;
@@ -180,8 +186,6 @@ export class WorkflowProgramComponent {
180
186
  program_assessments: this.programForm.get('program_assessments'),
181
187
  custom_fields: this.programForm.get('custom_fields'),
182
188
  isApproverDisabled: this.programForm.get('isApproverDisabled'),
183
- collaborators: this.programForm.get('collaborators'),
184
- collaborators_group: this.programForm.get('collaborators_group'),
185
189
  };
186
190
  this.lists = {
187
191
  ROLES: [],
@@ -280,17 +284,20 @@ export class WorkflowProgramComponent {
280
284
  }
281
285
  }
282
286
  ngOnInit() {
283
- this.setFormField('program_type', this.programType ?? 1);
284
- this.fetchOrganizationUsers();
285
- this.fetchOrganizationGroup();
287
+ this.setFormField('program_type', this.programType);
288
+ if (this.mode === 'EDIT') {
289
+ this.getProgramDetails();
290
+ }
291
+ else {
292
+ this.fetchOrganizationUsers();
293
+ this.fetchOrganizationGroup();
294
+ }
286
295
  this.fetchRoles();
287
296
  this.fetchRC();
288
- this.handleDataPopulation();
289
297
  if (this.addToProgramDetails?._id) {
290
298
  this.listAction(this.addToProgramDetails, 'FRAMEWORK');
291
299
  }
292
300
  this.enablefeature();
293
- this.handleDataPopulation();
294
301
  this.changeRef.detectChanges();
295
302
  }
296
303
  get valid() {
@@ -360,8 +367,8 @@ export class WorkflowProgramComponent {
360
367
  break;
361
368
  }
362
369
  case 'OWNER': {
363
- this.setFormField('program_owners', this.uniqueByProp(evt?.users, 'uid'));
364
- this.setFormField('program_owners_group', this.uniqueByProp(evt?.groups, 'ugid'));
370
+ this.setFormField('program_owners', this.uniqueByProp(evt?.users, 'member_id'));
371
+ this.setFormField('program_owners_group', this.uniqueByProp(evt?.groups, 'group_id'));
365
372
  this.fieldDeselector(type);
366
373
  break;
367
374
  }
@@ -370,10 +377,11 @@ export class WorkflowProgramComponent {
370
377
  this.fieldDeselector(type);
371
378
  break;
372
379
  }
373
- case 'COLLABORATORS': {
374
- this.setFormField('collaborators', this.uniqueByProp(evt?.users, 'uid'));
375
- this.setFormField('collaborators_group', this.uniqueByProp(evt?.groups, 'ugid'));
380
+ case 'ASSIGNEE': {
381
+ this.setFormField('program_assignee', this.uniqueByProp(evt?.users, 'member_id'));
382
+ this.setFormField('program_assignee_group', this.uniqueByProp(evt?.groups, 'group_id'));
376
383
  this.fieldDeselector(type);
384
+ this.setDefaultAssignee(evt);
377
385
  break;
378
386
  }
379
387
  case 'DEFAULT_ASSIGNEE': {
@@ -453,7 +461,7 @@ export class WorkflowProgramComponent {
453
461
  break;
454
462
  }
455
463
  case 'OWNER': {
456
- const owners = this.controls?.program_owners?.value?.filter((ele) => ele?.uid !== evt?.uid);
464
+ const owners = this.controls?.program_owners?.value?.filter((ele) => ele?.member_id !== evt?.member_id);
457
465
  this.setFormField('program_owners', owners);
458
466
  break;
459
467
  }
@@ -617,6 +625,21 @@ export class WorkflowProgramComponent {
617
625
  removeRole(evt) {
618
626
  this.onRemovingRole.emit(evt);
619
627
  }
628
+ //below 4 functions can be easilty combined into one as they follow same kind of pattern or can be offloaded to a external service
629
+ setDefaultAssignee(evt) {
630
+ if (evt?.users?.length || evt?.groups?.length) {
631
+ this.lists.DEFAULT_ASSIGNEES = this.uniqueByProp(evt?.users, 'member_id');
632
+ this.lists.DEFAULT_ASSIGNEES_GROUP = this.uniqueByProp(evt?.groups, 'group_id');
633
+ }
634
+ else {
635
+ this.lists.DEFAULT_ASSIGNEES = this.lists.ALL_USER;
636
+ this.lists.DEFAULT_ASSIGNEES_GROUP = this.lists.ALL_GROUP;
637
+ }
638
+ const assigneeMap = evt?.users?.map((ele) => ele?.member_id);
639
+ let currentDefaultAssignee = this.controls.program_default_assignee?.value;
640
+ currentDefaultAssignee = currentDefaultAssignee.filter((ele) => assigneeMap.includes(ele?.member_id));
641
+ this.setFormField('program_default_assignee', currentDefaultAssignee);
642
+ }
620
643
  setDefaultAssigneeOnRemove(evt, type) {
621
644
  switch (type) {
622
645
  case 'ASSIGNEE': {
@@ -741,9 +764,9 @@ export class WorkflowProgramComponent {
741
764
  this.lists.SYSTEM_ROLE_IDS = defaultSystemVal;
742
765
  if (this.mode !== 'EDIT') {
743
766
  this.setFormField('program_roles', defaultVal);
767
+ this.fetchUsersAssociatedWithRoles();
768
+ this.fetchGroupsAssociatedWithRoles();
744
769
  }
745
- this.fetchUsersAssociatedWithRoles();
746
- this.fetchGroupsAssociatedWithRoles();
747
770
  },
748
771
  error: (err) => { },
749
772
  });
@@ -759,7 +782,7 @@ export class WorkflowProgramComponent {
759
782
  }
760
783
  fetchUsersAssociatedWithRoles(calledFrom) {
761
784
  const loggedInUser = this.currentUser();
762
- const roleIds = this.lists.ROLES?.data?.map((ele) => ele?._id);
785
+ const roleIds = this.controls.program_roles?.value?.map((ele) => ele?._id);
763
786
  // if (fetchAll) {
764
787
  this.programService.fetchAllRoleUsers(roleIds).subscribe({
765
788
  next: (res) => {
@@ -769,9 +792,18 @@ export class WorkflowProgramComponent {
769
792
  res.total_items = res?.total_items + 1;
770
793
  }
771
794
  this.lists.OWNERS = res;
795
+ this.lists.APPROVERS = res;
796
+ if (!res?.data
797
+ ?.map((ele) => ele?.member_id)
798
+ ?.includes(this.controls.program_approver?.value[0]?.member_id)) {
799
+ this.setFormField('program_approver', []);
800
+ }
772
801
  if (this.controls?.all_user_in_role?.value) {
773
802
  this.setFormField('program_owners', res?.data);
774
803
  }
804
+ else {
805
+ this.setDefaultOwners(res?.data, calledFrom);
806
+ }
775
807
  },
776
808
  error: (err) => { },
777
809
  });
@@ -823,6 +855,24 @@ export class WorkflowProgramComponent {
823
855
  next: (res) => {
824
856
  this.lists.ALL_USER = res;
825
857
  this.lists.ASSIGNEES = res;
858
+ this.lists.REVIEWERS = res;
859
+ this.lists.OVERSEERS = res;
860
+ if (this.mode !== 'EDIT') {
861
+ this.lists.DEFAULT_ASSIGNEES = res;
862
+ this.lists.DEFAULT_REVIEWERS = res;
863
+ this.lists.DEFAULT_OVERSEERS = res;
864
+ }
865
+ else if (this.mode === 'EDIT') {
866
+ if (!this.controls.program_assignee?.value?.length) {
867
+ this.lists.DEFAULT_ASSIGNEES = res;
868
+ }
869
+ if (!this.controls.program_reviewer?.value?.length) {
870
+ this.lists.DEFAULT_REVIEWERS = res;
871
+ }
872
+ if (!this.controls.program_overseer?.value?.length) {
873
+ this.lists.DEFAULT_OVERSEERS = res;
874
+ }
875
+ }
826
876
  this.listLoadingState.USERS = false;
827
877
  this.refreshList();
828
878
  },
@@ -836,9 +886,12 @@ export class WorkflowProgramComponent {
836
886
  next: (res) => {
837
887
  this.lists.ALL_GROUP = res;
838
888
  this.lists.ASSIGNEES_GROUP = res;
839
- if (data) {
840
- this.populateGroupsByGID(data, 'owners');
841
- this.populateGroupsByGID(data, 'collaborators');
889
+ this.lists.REVIEWERS_GROUP = res;
890
+ this.lists.OVERSEERS_GROUP = res;
891
+ if (this.mode !== 'EDIT') {
892
+ this.lists.DEFAULT_ASSIGNEES_GROUP = res;
893
+ this.lists.DEFAULT_REVIEWERS_GROUP = res;
894
+ this.lists.DEFAULT_OVERSEERS_GROUP = res;
842
895
  }
843
896
  },
844
897
  error: (err) => { },
@@ -982,8 +1035,7 @@ export class WorkflowProgramComponent {
982
1035
  this.loader = false;
983
1036
  this.showSmiley = true;
984
1037
  this.uiKitService.isSmileyOn = true;
985
- this.createdProgramId = res?.data?.program?.id;
986
- this.postIframeMessage(PostMessageEvent.PROGRAM_CREATED, res);
1038
+ this.createdProgramId = res._id;
987
1039
  },
988
1040
  error: (err) => {
989
1041
  this.loader = false;
@@ -991,7 +1043,6 @@ export class WorkflowProgramComponent {
991
1043
  if (err?.error?.message?.includes('Category already exist')) {
992
1044
  this.isNameExists = true;
993
1045
  }
994
- this.postIframeMessage(PostMessageEvent.PROGRAM_CREATED, err);
995
1046
  },
996
1047
  });
997
1048
  }
@@ -1001,8 +1052,7 @@ export class WorkflowProgramComponent {
1001
1052
  this.loader = false;
1002
1053
  this.showSmiley = true;
1003
1054
  this.uiKitService.isSmileyOn = true;
1004
- this.postIframeMessage(PostMessageEvent.PROGRAM_UPDATED, res);
1005
- this.createdProgramId = res?.data?.program?.id;
1055
+ this.createdProgramId = res._id;
1006
1056
  },
1007
1057
  error: (err) => {
1008
1058
  this.loader = false;
@@ -1010,15 +1060,10 @@ export class WorkflowProgramComponent {
1010
1060
  if (err?.error?.message?.includes('Category already exist')) {
1011
1061
  this.isNameExists = true;
1012
1062
  }
1013
- this.postIframeMessage(PostMessageEvent.PROGRAM_UPDATED, err);
1014
1063
  },
1015
1064
  });
1016
1065
  }
1017
1066
  }
1018
- postIframeMessage(event, data) {
1019
- const message = this.iframeService.getCloseWebviewMessage(event, data);
1020
- this.iframeService.postMessage(message);
1021
- }
1022
1067
  action(event) {
1023
1068
  switch (event) {
1024
1069
  case 'addMore':
@@ -1040,10 +1085,10 @@ export class WorkflowProgramComponent {
1040
1085
  url = 'https://' + window.location.host;
1041
1086
  }
1042
1087
  if (window.location.host.startsWith('localhost')) {
1043
- url += '/programs/' + this.createdProgramId;
1088
+ url += '/program-workroom?id=' + this.createdProgramId;
1044
1089
  }
1045
1090
  else {
1046
- url += '/compliance/programs/' + this.createdProgramId;
1091
+ url += '/program/program-workroom?id=' + this.createdProgramId;
1047
1092
  }
1048
1093
  this.iframeService.redirectIfInIframe(url, true);
1049
1094
  }
@@ -1120,55 +1165,148 @@ export class WorkflowProgramComponent {
1120
1165
  .getProgram(this.programId)
1121
1166
  .pipe(take(1))
1122
1167
  .subscribe((res) => {
1168
+ this.setFormField('program_name', res?.name);
1169
+ this.setFormField('program_type', res?.programType);
1170
+ this.setFormField('program_objective', res?.program_objective?.text);
1171
+ this.setFormField('all_user_in_role', res?.all_user_in_role);
1172
+ this.setFormField('program_description_attachments', res?.description?.attachments);
1173
+ this.setFormField('program_objective_attachments', res?.program_objective?.attachments);
1174
+ this.setFormField('performance_calculation', res?.calculate_past_upcoming_event);
1175
+ this.setFormField('recurring_frequency', res?.program_frequency);
1176
+ if (res?.program_frequency &&
1177
+ this.mode === 'EDIT' &&
1178
+ (this.orgDetails?.hasProgramFullPermission ||
1179
+ !this.programSimplifyFlag)) {
1180
+ this.additionalOption.PROGRAM_FREQUENCY = true;
1181
+ this.populateOptionalFields();
1182
+ }
1183
+ this.setFormField('lock_scope_change', res?.lock_scope);
1184
+ if (res?.lock_scope &&
1185
+ (this.orgDetails?.hasProgramFullPermission ||
1186
+ !this.programSimplifyFlag)) {
1187
+ this.additionalOption.SCOPE_CHANGES = true;
1188
+ this.populateOptionalFields();
1189
+ }
1190
+ this.setFormField('program_state', res?.state);
1191
+ const rc = res.rc_details.map((ele) => {
1192
+ return { ...ele, item_name: ele?.rc_name, item_id: ele?.rc_id };
1193
+ });
1194
+ this.setFormField('rc', rc);
1195
+ if (res?.rc_details &&
1196
+ res?.rc_details?.length &&
1197
+ (this.orgDetails?.hasProgramFullPermission ||
1198
+ !this.programSimplifyFlag)) {
1199
+ this.additionalOption.RC = true;
1200
+ this.populateOptionalFields();
1201
+ }
1202
+ this.setFormField('evidence_required', res?.evidence_upload_flag);
1203
+ this.setFormField('allow_any_file_key_evidence', res?.is_key_evidence);
1204
+ if ((res?.evidence_upload_flag || res?.is_key_evidence) &&
1205
+ (this.orgDetails?.hasProgramFullPermission ||
1206
+ !this.programSimplifyFlag)) {
1207
+ this.additionalOption.FORMATE_EVIDENCE = true;
1208
+ this.populateOptionalFields();
1209
+ }
1210
+ this.setFormField('assignee_completion_criteria', res.default_assignee_type);
1211
+ this.setFormField('reviewer_completion_criteria', res.default_reviewers_type);
1212
+ this.editorData.programDescription = res.description?.text;
1213
+ this.editorData.programObjective = res.program_objective?.text;
1214
+ this.setFormField('framework', {
1215
+ ...res.framework_details,
1216
+ ...{ _id: res?.framework_details?.framework_id },
1217
+ });
1218
+ const role = res?.roles?.map((ele) => {
1219
+ return {
1220
+ _id: ele?.roleId,
1221
+ roleName: ele?.roleName,
1222
+ licenseType: ele?.licenseType,
1223
+ permissionGroupName: ele?.permissionGroupName,
1224
+ };
1225
+ });
1226
+ this.setFormField('program_roles', role);
1227
+ if (res?.roles && res?.roles?.length && this.mode === 'EDIT') {
1228
+ this.additionalOption.ROLES = true;
1229
+ }
1230
+ if (res.assessmentData.length) {
1231
+ res.assessmentData = res.assessmentData.map((ele) => {
1232
+ return {
1233
+ ...ele,
1234
+ assessmentIds: ele?.assessments.map((assess) => {
1235
+ return { ...assess, id: assess?._id };
1236
+ }),
1237
+ };
1238
+ });
1239
+ this.setFormField('program_assessments', res.assessmentData);
1240
+ if (this.orgDetails?.hasProgramFullPermission ||
1241
+ !this.programSimplifyFlag) {
1242
+ this.additionalOption.ASSESSMENT = true;
1243
+ this.populateOptionalFields();
1244
+ }
1245
+ }
1246
+ if (res.custom_fields.length) {
1247
+ this.setFormField('custom_fields', res.custom_fields);
1248
+ this.additionalOption.CUSTOM_FIELDS = true;
1249
+ this.populateOptionalFields();
1250
+ }
1251
+ this.isApproverDisabled = res?.isApproverDisabled ?? false;
1252
+ if (this.isApproverDisabled) {
1253
+ setTimeout(() => {
1254
+ this.disableElementsFromMoreOptions.emit(['APPROVER']);
1255
+ }, 500);
1256
+ }
1257
+ this.populateMembers(res);
1258
+ this.populateGroups(res);
1259
+ this.fetchUsersAssociatedWithRoles('getProgramDetails');
1260
+ this.fetchGroupsAssociatedWithRoles();
1261
+ this.fetchOrganizationGroup();
1262
+ this.fetchOrganizationUsers();
1123
1263
  });
1124
1264
  }
1125
- populateProgramDetails(res) {
1126
- this.programId = res?.id;
1127
- this.setFormField('program_name', res?.name);
1128
- this.setFormField('program_type', res?.type);
1129
- this.setFormField('program_objective', res?.description);
1130
- this.editorData.programObjective = res?.description;
1131
- if (res?.roles && res?.roles?.length && this.mode === 'EDIT') {
1132
- this.additionalOption.ROLES = true;
1133
- }
1134
- if (res.customFields.length) {
1135
- this.setFormField('custom_fields', res.customFields);
1136
- this.additionalOption.CUSTOM_FIELDS = true;
1137
- this.populateOptionalFields();
1138
- }
1139
- this.populateMembers(res);
1140
- this.populateGroups(res);
1141
- this.fetchUsersAssociatedWithRoles('getProgramDetails');
1142
- this.fetchGroupsAssociatedWithRoles();
1143
- this.fetchOrganizationGroup(res);
1144
- this.fetchOrganizationUsers();
1145
- }
1146
1265
  populateMembers(res) {
1266
+ this.loader = true;
1147
1267
  const ids = [
1148
1268
  ...new Set([
1149
- ...(res?.owners?.admins?.users ?? []),
1150
- ...(res?.owners?.managers?.users ?? []),
1269
+ ...(res?.owners ?? []),
1270
+ ...(res?.approvers ?? []),
1271
+ ...(res?.assignee_ids ?? []),
1272
+ ...(res?.default_assignee_ids ?? []),
1273
+ ...(res?.reviewers ?? []),
1274
+ ...(res?.default_reviewers ?? []),
1275
+ ...(res?.overseers?.cc_email ?? []),
1276
+ ...(res?.overseers?.failure_cc_email ?? []).filter((ele) => ele),
1277
+ ...(res?.default_overseers?.cc_email ?? []),
1278
+ ...(res?.default_overseers?.failure_cc_email ?? []).filter((ele) => ele),
1151
1279
  ]),
1152
1280
  ];
1153
- this.programService.getMemeberByUIds(ids).subscribe({
1281
+ this.programService.getMemeberByIds(ids).subscribe({
1154
1282
  next: (response) => {
1155
1283
  this.loader = false;
1156
- const selectedOwners = res.owners?.admins;
1157
- const selectedCollaborators = res.owners?.managers;
1158
- if (selectedOwners?.users?.length) {
1159
- const owners = response.filter((ele) => selectedOwners?.users.includes(ele?.uid));
1284
+ if (res.owners && res?.owners?.length) {
1285
+ const owners = response.filter((ele) => res?.owners.includes(ele?.member_id));
1160
1286
  this.setFormField('program_owners', owners);
1161
1287
  if (this.mode === 'EDIT') {
1162
1288
  this.additionalOption.OWNERS = true;
1163
1289
  this.populateOptionalFields();
1164
1290
  }
1165
1291
  }
1166
- if (selectedCollaborators?.users?.length) {
1167
- const collaborators = response.filter((ele) => selectedCollaborators?.users?.includes(ele?.uid));
1168
- this.setFormField('collaborators', collaborators);
1169
- this.additionalOption.COLLABORATORS = true;
1292
+ if (res.approvers &&
1293
+ res?.approvers?.length &&
1294
+ !this.programSimplifyFlag) {
1295
+ const approvers = response.filter((ele) => res?.approvers.includes(ele?.member_id));
1296
+ this.setFormField('program_approver', approvers);
1297
+ this.additionalOption.APPROVER = true;
1170
1298
  this.populateOptionalFields();
1171
1299
  }
1300
+ if (res?.assignee_ids && res?.assignee_ids?.length) {
1301
+ const assignee = response.filter((ele) => res?.assignee_ids.includes(ele?.member_id));
1302
+ this.setFormField('program_assignee', assignee);
1303
+ this.lists.DEFAULT_ASSIGNEES = assignee;
1304
+ if (this.orgDetails?.hasProgramFullPermission ||
1305
+ !this.programSimplifyFlag) {
1306
+ this.additionalOption.ASSIGNEES = true;
1307
+ this.populateOptionalFields();
1308
+ }
1309
+ }
1172
1310
  if (res?.default_assignee_ids && res?.default_assignee_ids?.length) {
1173
1311
  const assignee = response.filter((ele) => res?.default_assignee_ids.includes(ele?.member_id));
1174
1312
  this.setFormField('program_default_assignee', assignee);
@@ -1178,6 +1316,52 @@ export class WorkflowProgramComponent {
1178
1316
  this.populateOptionalFields();
1179
1317
  }
1180
1318
  }
1319
+ if (res?.reviewers && res?.reviewers?.length) {
1320
+ const reviewers = response.filter((ele) => res?.reviewers.includes(ele?.member_id));
1321
+ this.setFormField('program_reviewer', reviewers);
1322
+ this.lists.DEFAULT_REVIEWERS = reviewers;
1323
+ if (this.orgDetails?.hasProgramFullPermission ||
1324
+ !this.programSimplifyFlag) {
1325
+ this.additionalOption.REVIEWER = true;
1326
+ this.populateOptionalFields();
1327
+ }
1328
+ }
1329
+ if (res?.default_reviewers && res?.default_reviewers?.length) {
1330
+ const reviewers = response.filter((ele) => res?.default_reviewers.includes(ele?.member_id));
1331
+ this.setFormField('program_default_reviewer', reviewers);
1332
+ if (this.orgDetails?.hasProgramFullPermission ||
1333
+ !this.programSimplifyFlag) {
1334
+ this.additionalOption.REVIEWER = true;
1335
+ this.populateOptionalFields();
1336
+ }
1337
+ }
1338
+ if (res?.overseers && res?.overseers?.cc_email?.length) {
1339
+ const cc = response.filter((ele) => res?.overseers?.cc_email.includes(ele?.member_id));
1340
+ this.setFormField('program_overseer', cc);
1341
+ this.lists.DEFAULT_OVERSEERS = cc;
1342
+ if (this.orgDetails?.hasProgramFullPermission ||
1343
+ !this.programSimplifyFlag) {
1344
+ this.additionalOption.OVERSEER = true;
1345
+ this.populateOptionalFields();
1346
+ }
1347
+ }
1348
+ if (res?.default_overseers &&
1349
+ (res?.default_overseers?.cc_email?.length ||
1350
+ res?.default_overseers?.failure_cc_email?.length)) {
1351
+ if (res?.default_overseers?.cc_email?.length) {
1352
+ const defaultCC = response.filter((ele) => res?.default_overseers?.cc_email.includes(ele?.member_id));
1353
+ this.setFormField('program_default_overseer', defaultCC);
1354
+ }
1355
+ if (res?.default_overseers?.failure_cc_email?.length) {
1356
+ const failCC = response.filter((ele) => res?.default_overseers?.failure_cc_email.includes(ele?.member_id));
1357
+ this.setFormField('program_default_failed_overseer', failCC);
1358
+ }
1359
+ if (this.orgDetails?.hasProgramFullPermission ||
1360
+ !this.programSimplifyFlag) {
1361
+ this.additionalOption.OVERSEER = true;
1362
+ this.populateOptionalFields();
1363
+ }
1364
+ }
1181
1365
  },
1182
1366
  });
1183
1367
  this.checkProgramOptionField();
@@ -1198,18 +1382,77 @@ export class WorkflowProgramComponent {
1198
1382
  this.programService.getMemberByGroups(ids).subscribe({
1199
1383
  next: (resp) => {
1200
1384
  const response = resp?.data;
1201
- if (res?.owners?.userGroups?.length) {
1202
- const owners = response.filter((ele) => res?.owners?.userGroups?.includes(ele?.ugid));
1203
- this.additionalOption.OWNERS = true;
1204
- this.populateOptionalFields();
1385
+ if (res.owners_group && res?.owners_group?.length) {
1386
+ const owners = response.filter((ele) => res?.owners_group?.includes(ele?.group_id));
1205
1387
  this.setFormField('program_owners_group', owners);
1206
1388
  }
1207
- if (res?.managers?.userGroups?.length) {
1208
- const collaborators = response.filter((ele) => res?.managers?.userGroups?.includes(ele?.ugid));
1209
- this.setFormField('collaborators_group', collaborators);
1210
- this.additionalOption.COLLABORATORS = true;
1211
- this.populateOptionalFields();
1212
- this.lists.ASSIGNEES_GROUP = collaborators;
1389
+ if (res.assignee_group_ids && res?.assignee_group_ids?.length) {
1390
+ const assignee = response.filter((ele) => res?.assignee_group_ids?.includes(ele?.group_id));
1391
+ this.setFormField('program_assignee_group', assignee);
1392
+ this.lists.DEFAULT_ASSIGNEES_GROUP = assignee;
1393
+ if (this.orgDetails?.hasProgramFullPermission ||
1394
+ !this.programSimplifyFlag) {
1395
+ this.additionalOption.ASSIGNEES = true;
1396
+ }
1397
+ }
1398
+ if (res?.default_assignee_group_ids &&
1399
+ res?.default_assignee_group_ids?.length) {
1400
+ const assignee = response.filter((ele) => res?.default_assignee_group_ids?.includes(ele?.group_id));
1401
+ this.setFormField('program_default_assignee_group', assignee);
1402
+ if (this.orgDetails?.hasProgramFullPermission ||
1403
+ !this.programSimplifyFlag) {
1404
+ this.additionalOption.ASSIGNEES = true;
1405
+ }
1406
+ }
1407
+ if (res?.reviewer_group_ids && res?.reviewer_group_ids?.length) {
1408
+ const reviewer = response.filter((ele) => res?.reviewer_group_ids?.includes(ele?.group_id));
1409
+ this.setFormField('program_reviewer_group', reviewer);
1410
+ this.lists.DEFAULT_REVIEWERS_GROUP = reviewer;
1411
+ if (this.orgDetails?.hasProgramFullPermission ||
1412
+ !this.programSimplifyFlag) {
1413
+ this.additionalOption.REVIEWER = true;
1414
+ }
1415
+ }
1416
+ if (res?.default_reviewer_group_ids &&
1417
+ res?.default_reviewer_group_ids?.length) {
1418
+ const reviewer = response?.filter((ele) => res?.default_reviewer_group_ids?.includes(ele?.group_id));
1419
+ this.setFormField('program_default_reviewer_group', reviewer);
1420
+ this.controls.reviewer_completion_criteria.value =
1421
+ this.controls?.program_default_reviewer_group?.value?.length > 0
1422
+ ? 'ANYONE'
1423
+ : this.controls?.reviewer_completion_criteria?.value;
1424
+ if (this.orgDetails?.hasProgramFullPermission ||
1425
+ !this.programSimplifyFlag) {
1426
+ this.additionalOption.REVIEWER = true;
1427
+ }
1428
+ }
1429
+ if (res?.overseers?.cc_email_groups &&
1430
+ res?.overseers?.cc_email_groups?.length) {
1431
+ const overseerGroup = response.filter((ele) => res?.overseers?.cc_email_groups?.includes(ele?.group_id));
1432
+ this.setFormField('program_overseer_group', overseerGroup);
1433
+ this.lists.DEFAULT_OVERSEERS_GROUP = overseerGroup;
1434
+ if (this.orgDetails?.hasProgramFullPermission ||
1435
+ !this.programSimplifyFlag) {
1436
+ this.additionalOption.OVERSEER = true;
1437
+ }
1438
+ }
1439
+ if (res?.default_overseers?.cc_email_groups &&
1440
+ res?.default_overseers?.cc_email_groups?.length) {
1441
+ const defaultOverseerGroup = response.filter((ele) => res?.default_overseers?.cc_email_groups?.includes(ele?.group_id));
1442
+ this.setFormField('program_default_overseer_group', defaultOverseerGroup);
1443
+ if (this.orgDetails?.hasProgramFullPermission ||
1444
+ !this.programSimplifyFlag) {
1445
+ this.additionalOption.OVERSEER = true;
1446
+ }
1447
+ }
1448
+ if (res?.default_overseers?.failure_cc_email_groups &&
1449
+ res?.default_overseers?.failure_cc_email_groups?.length) {
1450
+ const defaultOverseerFailureGroup = response.filter((ele) => res?.default_overseers?.failure_cc_email_groups?.includes(ele?.group_id));
1451
+ this.setFormField('program_default_failed_overseer_group', defaultOverseerFailureGroup);
1452
+ if (this.orgDetails?.hasProgramFullPermission ||
1453
+ !this.programSimplifyFlag) {
1454
+ this.additionalOption.OVERSEER = true;
1455
+ }
1213
1456
  }
1214
1457
  },
1215
1458
  // As of now groups has been removed from reviewer and overseeer if this group feature gets incoperated in
@@ -1217,27 +1460,6 @@ export class WorkflowProgramComponent {
1217
1460
  });
1218
1461
  this.checkProgramOptionField();
1219
1462
  }
1220
- populateGroupsByGID(programDetails, type) {
1221
- switch (type) {
1222
- case 'owners':
1223
- const owner_ugid = programDetails?.owners?.admins?.userGroups;
1224
- const ownersGroup = this.lists.ASSIGNEES_GROUP.filter((ele) => owner_ugid.includes(ele?.ugid));
1225
- const ownersGroupIds = ownersGroup.map((ele) => ele?.group_id);
1226
- this.setFormField('program_owners_group', ownersGroup);
1227
- this.additionalOption.OWNERS = true;
1228
- this.populateOptionalFields();
1229
- break;
1230
- case 'collaborators':
1231
- const collaborator_ugid = programDetails?.owners?.managers?.userGroups;
1232
- const groupList = this.lists.ASSIGNEES_GROUP.filter((ele) => collaborator_ugid.includes(ele?.ugid));
1233
- this.setFormField('collaborators_group', groupList);
1234
- this.additionalOption.COLLABORATORS = true;
1235
- this.populateOptionalFields();
1236
- break;
1237
- default:
1238
- break;
1239
- }
1240
- }
1241
1463
  resetAdditionalOption() {
1242
1464
  this.additionalOption.ROLES = false;
1243
1465
  this.additionalOption.OWNERS = false;
@@ -1283,18 +1505,13 @@ export class WorkflowProgramComponent {
1283
1505
  : '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.';
1284
1506
  this.ff_rc_listing = this.allowedFeature.isFeatureEnabled('ff_rc_listing');
1285
1507
  }
1286
- handleDataPopulation() {
1287
- if (this.mode === 'EDIT') {
1288
- this.populateProgramDetails(this.programDetails);
1289
- }
1290
- }
1291
- 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 }); }
1292
- 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) <span class=\"required\">*</span>\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" }] }); }
1508
+ 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 }); }
1509
+ 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) <span class=\"required\">*</span>\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 <!-- <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 !== '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 <!-- Approvers -->\n <!-- Removing this option in Program simplification -->\n <form-field\n *ngIf=\"additionalOption?.APPROVER && !programSimplifyFlag\"\n [checked]=\"controls?.program_approver?.value?.length\"\n [active]=\"activeList === 'APPROVER'\"\n [disabled]=\"\n sideElements.includes(activeList) && activeList !== 'APPROVER'\n \"\n [img]=\"ASSETS.approval\"\n >\n <label class=\"vx-control-panel\"\n >APPROVER\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'An Approver is responsible for approving a Program. Where an Approver is selected, the Program and all responsibilities linked with that Program will only commence once the Program has been approved.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"ApproverHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [placeholder]=\"'Who is responsible for approving this program?'\"\n [disabled]=\"isApproverDisabled\"\n (select)=\"activateList('APPROVER')\"\n >\n <div class=\"selected\" *ngIf=\"controls?.program_approver?.value[0]\">\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=\"isApproverDisabled === false\"\n (click)=\"remove(controls?.program_approver?.value[0], 'APPROVER')\"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_approver?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_approver?.value[0]?.member_name }}</span\n >\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <i *ngIf=\"isApproverDisabled === false\" (click)=\"remove(controls?.program_approver?.value[0],'APPROVER')\"\n class=\"icons vx-fs-9 vx-mr-1 cross\">&#xe90d;</i>{{controls?.program_approver?.value[0]?.member_name}}\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'APPROVER' && isApproverDisabled === false\"\n (click)=\"activateList('APPROVER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i>Edit\n </button>\n </div>\n </input-with-pill>\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<user-group-list\n *ngIf=\"activeList === 'APPROVER'\"\n [groupEnabled]=\"false\"\n [singleSelect]=\"true\"\n [userlist]=\"lists?.APPROVERS?.data ?? []\"\n [selectedUsers]=\"controls?.program_approver?.value | refDisconnect\"\n [userListInfo]=\"lists?.APPROVERS\"\n (save)=\"listAction($event, 'APPROVER')\"\n (cancel)=\"fieldDeselector('APPROVER')\"\n [panelTitle]=\"panelTitleApprover\"\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" }] }); }
1293
1510
  }
1294
1511
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: WorkflowProgramComponent, decorators: [{
1295
1512
  type: Component,
1296
- 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) <span class=\"required\">*</span>\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"] }]
1297
- }], ctorParameters: function () { return [{ type: i1.UntypedFormBuilder }, { type: i2.ProgramsService }, { type: i3.AuthService }, { type: i4.UiKitService }, { type: i0.ChangeDetectorRef }, { type: i5.IframeService }]; }, propDecorators: { form: [{
1513
+ 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) <span class=\"required\">*</span>\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 <!-- <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 !== '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 <!-- Approvers -->\n <!-- Removing this option in Program simplification -->\n <form-field\n *ngIf=\"additionalOption?.APPROVER && !programSimplifyFlag\"\n [checked]=\"controls?.program_approver?.value?.length\"\n [active]=\"activeList === 'APPROVER'\"\n [disabled]=\"\n sideElements.includes(activeList) && activeList !== 'APPROVER'\n \"\n [img]=\"ASSETS.approval\"\n >\n <label class=\"vx-control-panel\"\n >APPROVER\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'An Approver is responsible for approving a Program. Where an Approver is selected, the Program and all responsibilities linked with that Program will only commence once the Program has been approved.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"ApproverHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [placeholder]=\"'Who is responsible for approving this program?'\"\n [disabled]=\"isApproverDisabled\"\n (select)=\"activateList('APPROVER')\"\n >\n <div class=\"selected\" *ngIf=\"controls?.program_approver?.value[0]\">\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=\"isApproverDisabled === false\"\n (click)=\"remove(controls?.program_approver?.value[0], 'APPROVER')\"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_approver?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_approver?.value[0]?.member_name }}</span\n >\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <i *ngIf=\"isApproverDisabled === false\" (click)=\"remove(controls?.program_approver?.value[0],'APPROVER')\"\n class=\"icons vx-fs-9 vx-mr-1 cross\">&#xe90d;</i>{{controls?.program_approver?.value[0]?.member_name}}\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'APPROVER' && isApproverDisabled === false\"\n (click)=\"activateList('APPROVER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i>Edit\n </button>\n </div>\n </input-with-pill>\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<user-group-list\n *ngIf=\"activeList === 'APPROVER'\"\n [groupEnabled]=\"false\"\n [singleSelect]=\"true\"\n [userlist]=\"lists?.APPROVERS?.data ?? []\"\n [selectedUsers]=\"controls?.program_approver?.value | refDisconnect\"\n [userListInfo]=\"lists?.APPROVERS\"\n (save)=\"listAction($event, 'APPROVER')\"\n (cancel)=\"fieldDeselector('APPROVER')\"\n [panelTitle]=\"panelTitleApprover\"\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"] }]
1514
+ }], ctorParameters: function () { return [{ type: i1.UntypedFormBuilder }, { type: i2.ProgramsService }, { type: i3.AuthService }, { type: i4.UiKitService }, { type: i5.IframeService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { form: [{
1298
1515
  type: ViewChild,
1299
1516
  args: ['form', { read: ElementRef }]
1300
1517
  }], datePicker: [{
@@ -1332,7 +1549,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
1332
1549
  type: Input
1333
1550
  }], orgDetails: [{
1334
1551
  type: Input
1335
- }], programDetails: [{
1336
- type: Input
1337
1552
  }] } });
1338
- //# 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;;;;;;;;;;;;;;;;;;;;;;;;;;;AAO7D,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,IAAI,CAAC,YAAY,CAAC,cAAc,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;QAC7C,IAAI,CAAC,YAAY,CAAC,cAAc,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;QAC7C,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;+GArlDU,wBAAwB;mGAAxB,wBAAwB,0wBAMR,UAAU,wHCrCvC,4ruGAu5EsB;;4FDx3ET,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';\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    this.setFormField('program_name', res?.name);\n    this.setFormField('program_type', res?.type);\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) <span class=\"required\">*</span>\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>"]}
1553
+ //# 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,EAGL,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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAOvD,MAAM,OAAO,wBAAwB;IAwDnC,YACU,EAAsB,EACtB,cAA+B,EAC/B,WAAwB,EACxB,YAA0B,EAC1B,aAA4B,EAC5B,SAA4B;QAL5B,OAAE,GAAF,EAAE,CAAoB;QACtB,mBAAc,GAAd,cAAc,CAAiB;QAC/B,gBAAW,GAAX,WAAW,CAAa;QACxB,iBAAY,GAAZ,YAAY,CAAc;QAC1B,kBAAa,GAAb,aAAa,CAAe;QAC5B,cAAS,GAAT,SAAS,CAAmB;QA7DtC,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;QAIjC,8BAAyB,GAAG,4BAA4B,CAAC;QACzD,oBAAe,GAAG,iBAAiB,CAAC;QACpC,uBAAkB,GAAG,oBAAoB,CAAC;QAC1C,uBAAkB,GAAG,oBAAoB,CAAC;QAC1C,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;SACF,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;QAwB/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;gBAChB,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,aAAa,EAAE,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,QAAQ,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC;YACpE,gBAAgB,EAAE,CAAC,KAAK,CAAC;YACzB,cAAc,EAAE,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,QAAQ,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC;YACrE,oBAAoB,EAAE,CAAC,EAAE,CAAC;YAC1B,gBAAgB,EAAE,CAAC,EAAE,CAAC;YACtB,uBAAuB,EAAE,CAAC,YAAY,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;YAC9D,mBAAmB,EAAE,CAAC,IAAI,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;YAClD,iBAAiB,EAAE,CAAC,KAAK,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;YACjD,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;SACjB,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;SAC/D,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;QAsBF,qBAAgB,GAAQ,EAAE,GAAG,SAAS,CAAC,gBAAgB,EAAE,CAAC;QAC1D,eAAU,GAAG,EAAE,CAAC;QA2zBhB,sBAAiB,GAAG;YAClB,WAAW,EAAE,EAAE;YACf,SAAS,EAAE,EAAE;SACd,CAAC;QAljCA,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;IAmED,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;IA4GD,QAAQ;QACN,IAAI,CAAC,YAAY,CAAC,cAAc,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;QACpD,IAAI,IAAI,CAAC,IAAI,KAAK,MAAM,EAAE;YACxB,IAAI,CAAC,iBAAiB,EAAE,CAAC;SAC1B;aAAM;YACL,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAC9B,IAAI,CAAC,sBAAsB,EAAE,CAAC;SAC/B;QACD,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,CAAC,OAAO,EAAE,CAAC;QACf,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,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,WAAW,CAAC,CAC3C,CAAC;gBACF,IAAI,CAAC,YAAY,CACf,sBAAsB,EACtB,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,EAAE,UAAU,CAAC,CAC3C,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,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,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,SAAS,KAAK,GAAG,EAAE,SAAS,CAChD,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,kIAAkI;IAClI,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,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;IACD,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;IACD,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;IACD,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;IACD,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;IACD,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;oBAC/C,IAAI,CAAC,6BAA6B,EAAE,CAAC;oBACrC,IAAI,CAAC,8BAA8B,EAAE,CAAC;iBACvC;YACH,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,QAAQ,CAAC,aAAa,EAAE,KAAK,EAAE,GAAG,CACrD,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,GAAG,CACvB,CAAC;QACF,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,CAAC,KAAK,CAAC,SAAS,GAAG,GAAG,CAAC;gBAC3B,IACE,CAAC,GAAG,EAAE,IAAI;oBACR,EAAE,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,SAAS,CAAC;oBACnC,EAAE,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,gBAAgB,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,EACjE;oBACA,IAAI,CAAC,YAAY,CAAC,kBAAkB,EAAE,EAAE,CAAC,CAAC;iBAC3C;gBACD,IAAI,IAAI,CAAC,QAAQ,EAAE,gBAAgB,EAAE,KAAK,EAAE;oBAC1C,IAAI,CAAC,YAAY,CAAC,gBAAgB,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;iBAChD;qBAAM;oBACL,IAAI,CAAC,gBAAgB,CAAC,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC,CAAC;iBAC9C;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;gBAC3B,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,GAAG,CAAC;gBAC3B,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,GAAG,CAAC;gBAC3B,IAAI,IAAI,CAAC,IAAI,KAAK,MAAM,EAAE;oBACxB,IAAI,CAAC,KAAK,CAAC,iBAAiB,GAAG,GAAG,CAAC;oBACnC,IAAI,CAAC,KAAK,CAAC,iBAAiB,GAAG,GAAG,CAAC;oBACnC,IAAI,CAAC,KAAK,CAAC,iBAAiB,GAAG,GAAG,CAAC;iBACpC;qBAAM,IAAI,IAAI,CAAC,IAAI,KAAK,MAAM,EAAE;oBAC/B,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,gBAAgB,EAAE,KAAK,EAAE,MAAM,EAAE;wBAClD,IAAI,CAAC,KAAK,CAAC,iBAAiB,GAAG,GAAG,CAAC;qBACpC;oBACD,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,gBAAgB,EAAE,KAAK,EAAE,MAAM,EAAE;wBAClD,IAAI,CAAC,KAAK,CAAC,iBAAiB,GAAG,GAAG,CAAC;qBACpC;oBACD,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,gBAAgB,EAAE,KAAK,EAAE,MAAM,EAAE;wBAClD,IAAI,CAAC,KAAK,CAAC,iBAAiB,GAAG,GAAG,CAAC;qBACpC;iBACF;gBAED,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,IAAI,CAAC,KAAK,CAAC,eAAe,GAAG,GAAG,CAAC;gBAEjC,IAAI,CAAC,KAAK,CAAC,eAAe,GAAG,GAAG,CAAC;gBAEjC,IAAI,IAAI,CAAC,IAAI,KAAK,MAAM,EAAE;oBACxB,IAAI,CAAC,KAAK,CAAC,uBAAuB,GAAG,GAAG,CAAC;oBACzC,IAAI,CAAC,KAAK,CAAC,uBAAuB,GAAG,GAAG,CAAC;oBACzC,IAAI,CAAC,KAAK,CAAC,uBAAuB,GAAG,GAAG,CAAC;iBAC1C;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;IACD,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,CAAC,GAAG,CAAC;gBAClC,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;gBACH,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,gBAAgB,GAAG,GAAG,CAAC,GAAG,CAAC;gBAClC,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;gBACH,CAAC;aACF,CAAC,CAAC;SACJ;IACH,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,uBAAuB,GAAG,IAAI,CAAC,gBAAgB,CAAC;SACxD;aAAM;YACL,GAAG,IAAI,+BAA+B,GAAG,IAAI,CAAC,gBAAgB,CAAC;SAChE;QAED,IAAI,CAAC,aAAa,CAAC,kBAAkB,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;IACnD,CAAC;IACD,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;YACtB,IAAI,CAAC,YAAY,CAAC,cAAc,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;YAC7C,IAAI,CAAC,YAAY,CAAC,cAAc,EAAE,GAAG,EAAE,WAAW,CAAC,CAAC;YACpD,IAAI,CAAC,YAAY,CAAC,mBAAmB,EAAE,GAAG,EAAE,iBAAiB,EAAE,IAAI,CAAC,CAAC;YACrE,IAAI,CAAC,YAAY,CAAC,kBAAkB,EAAE,GAAG,EAAE,gBAAgB,CAAC,CAAC;YAC7D,IAAI,CAAC,YAAY,CACf,iCAAiC,EACjC,GAAG,EAAE,WAAW,EAAE,WAAW,CAC9B,CAAC;YACF,IAAI,CAAC,YAAY,CACf,+BAA+B,EAC/B,GAAG,EAAE,iBAAiB,EAAE,WAAW,CACpC,CAAC;YACF,IAAI,CAAC,YAAY,CACf,yBAAyB,EACzB,GAAG,EAAE,6BAA6B,CACnC,CAAC;YACF,IAAI,CAAC,YAAY,CAAC,qBAAqB,EAAE,GAAG,EAAE,iBAAiB,CAAC,CAAC;YACjE,IACE,GAAG,EAAE,iBAAiB;gBACtB,IAAI,CAAC,IAAI,KAAK,MAAM;gBACpB,CAAC,IAAI,CAAC,UAAU,EAAE,wBAAwB;oBACxC,CAAC,IAAI,CAAC,mBAAmB,CAAC,EAC5B;gBACA,IAAI,CAAC,gBAAgB,CAAC,iBAAiB,GAAG,IAAI,CAAC;gBAC/C,IAAI,CAAC,sBAAsB,EAAE,CAAC;aAC/B;YACD,IAAI,CAAC,YAAY,CAAC,mBAAmB,EAAE,GAAG,EAAE,UAAU,CAAC,CAAC;YACxD,IACE,GAAG,EAAE,UAAU;gBACf,CAAC,IAAI,CAAC,UAAU,EAAE,wBAAwB;oBACxC,CAAC,IAAI,CAAC,mBAAmB,CAAC,EAC5B;gBACA,IAAI,CAAC,gBAAgB,CAAC,aAAa,GAAG,IAAI,CAAC;gBAC3C,IAAI,CAAC,sBAAsB,EAAE,CAAC;aAC/B;YACD,IAAI,CAAC,YAAY,CAAC,eAAe,EAAE,GAAG,EAAE,KAAK,CAAC,CAAC;YAC/C,MAAM,EAAE,GAAG,GAAG,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE;gBACzC,OAAO,EAAE,GAAG,GAAG,EAAE,SAAS,EAAE,GAAG,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC;YAClE,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;YAC5B,IACE,GAAG,EAAE,UAAU;gBACf,GAAG,EAAE,UAAU,EAAE,MAAM;gBACvB,CAAC,IAAI,CAAC,UAAU,EAAE,wBAAwB;oBACxC,CAAC,IAAI,CAAC,mBAAmB,CAAC,EAC5B;gBACA,IAAI,CAAC,gBAAgB,CAAC,EAAE,GAAG,IAAI,CAAC;gBAChC,IAAI,CAAC,sBAAsB,EAAE,CAAC;aAC/B;YACD,IAAI,CAAC,YAAY,CAAC,mBAAmB,EAAE,GAAG,EAAE,oBAAoB,CAAC,CAAC;YAClE,IAAI,CAAC,YAAY,CAAC,6BAA6B,EAAE,GAAG,EAAE,eAAe,CAAC,CAAC;YACvE,IACE,CAAC,GAAG,EAAE,oBAAoB,IAAI,GAAG,EAAE,eAAe,CAAC;gBACnD,CAAC,IAAI,CAAC,UAAU,EAAE,wBAAwB;oBACxC,CAAC,IAAI,CAAC,mBAAmB,CAAC,EAC5B;gBACA,IAAI,CAAC,gBAAgB,CAAC,gBAAgB,GAAG,IAAI,CAAC;gBAC9C,IAAI,CAAC,sBAAsB,EAAE,CAAC;aAC/B;YACD,IAAI,CAAC,YAAY,CACf,8BAA8B,EAC9B,GAAG,CAAC,qBAAqB,CAC1B,CAAC;YACF,IAAI,CAAC,YAAY,CACf,8BAA8B,EAC9B,GAAG,CAAC,sBAAsB,CAC3B,CAAC;YAEF,IAAI,CAAC,UAAU,CAAC,kBAAkB,GAAG,GAAG,CAAC,WAAW,EAAE,IAAI,CAAC;YAC3D,IAAI,CAAC,UAAU,CAAC,gBAAgB,GAAG,GAAG,CAAC,iBAAiB,EAAE,IAAI,CAAC;YAC/D,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE;gBAC7B,GAAG,GAAG,CAAC,iBAAiB;gBACxB,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,iBAAiB,EAAE,YAAY,EAAE;aACjD,CAAC,CAAC;YACH,MAAM,IAAI,GAAG,GAAG,EAAE,KAAK,EAAE,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE;gBACxC,OAAO;oBACL,GAAG,EAAE,GAAG,EAAE,MAAM;oBAChB,QAAQ,EAAE,GAAG,EAAE,QAAQ;oBACvB,WAAW,EAAE,GAAG,EAAE,WAAW;oBAC7B,mBAAmB,EAAE,GAAG,EAAE,mBAAmB;iBAC9C,CAAC;YACJ,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,YAAY,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;YACzC,IAAI,GAAG,EAAE,KAAK,IAAI,GAAG,EAAE,KAAK,EAAE,MAAM,IAAI,IAAI,CAAC,IAAI,KAAK,MAAM,EAAE;gBAC5D,IAAI,CAAC,gBAAgB,CAAC,KAAK,GAAG,IAAI,CAAC;aACpC;YACD,IAAI,GAAG,CAAC,cAAc,CAAC,MAAM,EAAE;gBAC7B,GAAG,CAAC,cAAc,GAAG,GAAG,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE;oBACvD,OAAO;wBACL,GAAG,GAAG;wBACN,aAAa,EAAE,GAAG,EAAE,WAAW,CAAC,GAAG,CAAC,CAAC,MAAW,EAAE,EAAE;4BAClD,OAAO,EAAE,GAAG,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC;wBACxC,CAAC,CAAC;qBACH,CAAC;gBACJ,CAAC,CAAC,CAAC;gBACH,IAAI,CAAC,YAAY,CAAC,qBAAqB,EAAE,GAAG,CAAC,cAAc,CAAC,CAAC;gBAC7D,IACE,IAAI,CAAC,UAAU,EAAE,wBAAwB;oBACzC,CAAC,IAAI,CAAC,mBAAmB,EACzB;oBACA,IAAI,CAAC,gBAAgB,CAAC,UAAU,GAAG,IAAI,CAAC;oBACxC,IAAI,CAAC,sBAAsB,EAAE,CAAC;iBAC/B;aACF;YAED,IAAI,GAAG,CAAC,aAAa,CAAC,MAAM,EAAE;gBAC5B,IAAI,CAAC,YAAY,CAAC,eAAe,EAAE,GAAG,CAAC,aAAa,CAAC,CAAC;gBACtD,IAAI,CAAC,gBAAgB,CAAC,aAAa,GAAG,IAAI,CAAC;gBAC3C,IAAI,CAAC,sBAAsB,EAAE,CAAC;aAC/B;YACD,IAAI,CAAC,kBAAkB,GAAG,GAAG,EAAE,kBAAkB,IAAI,KAAK,CAAC;YAC3D,IAAI,IAAI,CAAC,kBAAkB,EAAE;gBAC3B,UAAU,CAAC,GAAG,EAAE;oBACd,IAAI,CAAC,8BAA8B,CAAC,IAAI,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC;gBACzD,CAAC,EAAE,GAAG,CAAC,CAAC;aACT;YAED,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC;YAC1B,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;YACzB,IAAI,CAAC,6BAA6B,CAAC,mBAAmB,CAAC,CAAC;YACxD,IAAI,CAAC,8BAA8B,EAAE,CAAC;YACtC,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAC9B,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAChC,CAAC,CAAC,CAAC;IACP,CAAC;IAED,eAAe,CAAC,GAAQ;QACtB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,MAAM,GAAG,GAAG;YACV,GAAG,IAAI,GAAG,CAAC;gBACT,GAAG,CAAC,GAAG,EAAE,MAAM,IAAI,EAAE,CAAC;gBACtB,GAAG,CAAC,GAAG,EAAE,SAAS,IAAI,EAAE,CAAC;gBACzB,GAAG,CAAC,GAAG,EAAE,YAAY,IAAI,EAAE,CAAC;gBAC5B,GAAG,CAAC,GAAG,EAAE,oBAAoB,IAAI,EAAE,CAAC;gBACpC,GAAG,CAAC,GAAG,EAAE,SAAS,IAAI,EAAE,CAAC;gBACzB,GAAG,CAAC,GAAG,EAAE,iBAAiB,IAAI,EAAE,CAAC;gBACjC,GAAG,CAAC,GAAG,EAAE,SAAS,EAAE,QAAQ,IAAI,EAAE,CAAC;gBACnC,GAAG,CAAC,GAAG,EAAE,SAAS,EAAE,gBAAgB,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,CAAC;gBACrE,GAAG,CAAC,GAAG,EAAE,iBAAiB,EAAE,QAAQ,IAAI,EAAE,CAAC;gBAC3C,GAAG,CAAC,GAAG,EAAE,iBAAiB,EAAE,gBAAgB,IAAI,EAAE,CAAC,CAAC,MAAM,CACxD,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,CAClB;aACF,CAAC;SACH,CAAC;QACF,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC;YACjD,IAAI,EAAE,CAAC,QAAa,EAAE,EAAE;gBACtB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;gBACpB,IAAI,GAAG,CAAC,MAAM,IAAI,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE;oBACrC,MAAM,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CAC1C,GAAG,EAAE,MAAM,CAAC,QAAQ,CAAC,GAAG,EAAE,SAAS,CAAC,CACrC,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,IACE,GAAG,CAAC,SAAS;oBACb,GAAG,EAAE,SAAS,EAAE,MAAM;oBACtB,CAAC,IAAI,CAAC,mBAAmB,EACzB;oBACA,MAAM,SAAS,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CAC7C,GAAG,EAAE,SAAS,CAAC,QAAQ,CAAC,GAAG,EAAE,SAAS,CAAC,CACxC,CAAC;oBACF,IAAI,CAAC,YAAY,CAAC,kBAAkB,EAAE,SAAS,CAAC,CAAC;oBACjD,IAAI,CAAC,gBAAgB,CAAC,QAAQ,GAAG,IAAI,CAAC;oBACtC,IAAI,CAAC,sBAAsB,EAAE,CAAC;iBAC/B;gBACD,IAAI,GAAG,EAAE,YAAY,IAAI,GAAG,EAAE,YAAY,EAAE,MAAM,EAAE;oBAClD,MAAM,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CAC5C,GAAG,EAAE,YAAY,CAAC,QAAQ,CAAC,GAAG,EAAE,SAAS,CAAC,CAC3C,CAAC;oBACF,IAAI,CAAC,YAAY,CAAC,kBAAkB,EAAE,QAAQ,CAAC,CAAC;oBAChD,IAAI,CAAC,KAAK,CAAC,iBAAiB,GAAG,QAAQ,CAAC;oBACxC,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;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;gBACD,IAAI,GAAG,EAAE,SAAS,IAAI,GAAG,EAAE,SAAS,EAAE,MAAM,EAAE;oBAC5C,MAAM,SAAS,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CAC7C,GAAG,EAAE,SAAS,CAAC,QAAQ,CAAC,GAAG,EAAE,SAAS,CAAC,CACxC,CAAC;oBACF,IAAI,CAAC,YAAY,CAAC,kBAAkB,EAAE,SAAS,CAAC,CAAC;oBACjD,IAAI,CAAC,KAAK,CAAC,iBAAiB,GAAG,SAAS,CAAC;oBACzC,IACE,IAAI,CAAC,UAAU,EAAE,wBAAwB;wBACzC,CAAC,IAAI,CAAC,mBAAmB,EACzB;wBACA,IAAI,CAAC,gBAAgB,CAAC,QAAQ,GAAG,IAAI,CAAC;wBACtC,IAAI,CAAC,sBAAsB,EAAE,CAAC;qBAC/B;iBACF;gBACD,IAAI,GAAG,EAAE,iBAAiB,IAAI,GAAG,EAAE,iBAAiB,EAAE,MAAM,EAAE;oBAC5D,MAAM,SAAS,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CAC7C,GAAG,EAAE,iBAAiB,CAAC,QAAQ,CAAC,GAAG,EAAE,SAAS,CAAC,CAChD,CAAC;oBACF,IAAI,CAAC,YAAY,CAAC,0BAA0B,EAAE,SAAS,CAAC,CAAC;oBACzD,IACE,IAAI,CAAC,UAAU,EAAE,wBAAwB;wBACzC,CAAC,IAAI,CAAC,mBAAmB,EACzB;wBACA,IAAI,CAAC,gBAAgB,CAAC,QAAQ,GAAG,IAAI,CAAC;wBACtC,IAAI,CAAC,sBAAsB,EAAE,CAAC;qBAC/B;iBACF;gBACD,IAAI,GAAG,EAAE,SAAS,IAAI,GAAG,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE;oBACtD,MAAM,EAAE,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CACtC,GAAG,EAAE,SAAS,EAAE,QAAQ,CAAC,QAAQ,CAAC,GAAG,EAAE,SAAS,CAAC,CAClD,CAAC;oBACF,IAAI,CAAC,YAAY,CAAC,kBAAkB,EAAE,EAAE,CAAC,CAAC;oBAC1C,IAAI,CAAC,KAAK,CAAC,iBAAiB,GAAG,EAAE,CAAC;oBAClC,IACE,IAAI,CAAC,UAAU,EAAE,wBAAwB;wBACzC,CAAC,IAAI,CAAC,mBAAmB,EACzB;wBACA,IAAI,CAAC,gBAAgB,CAAC,QAAQ,GAAG,IAAI,CAAC;wBACtC,IAAI,CAAC,sBAAsB,EAAE,CAAC;qBAC/B;iBACF;gBAED,IACE,GAAG,EAAE,iBAAiB;oBACtB,CAAC,GAAG,EAAE,iBAAiB,EAAE,QAAQ,EAAE,MAAM;wBACvC,GAAG,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,CAAC,EACnD;oBACA,IAAI,GAAG,EAAE,iBAAiB,EAAE,QAAQ,EAAE,MAAM,EAAE;wBAC5C,MAAM,SAAS,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CAC7C,GAAG,EAAE,iBAAiB,EAAE,QAAQ,CAAC,QAAQ,CAAC,GAAG,EAAE,SAAS,CAAC,CAC1D,CAAC;wBACF,IAAI,CAAC,YAAY,CAAC,0BAA0B,EAAE,SAAS,CAAC,CAAC;qBAC1D;oBACD,IAAI,GAAG,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,EAAE;wBACpD,MAAM,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CAC1C,GAAG,EAAE,iBAAiB,EAAE,gBAAgB,CAAC,QAAQ,CAAC,GAAG,EAAE,SAAS,CAAC,CAClE,CAAC;wBACF,IAAI,CAAC,YAAY,CAAC,iCAAiC,EAAE,MAAM,CAAC,CAAC;qBAC9D;oBACD,IACE,IAAI,CAAC,UAAU,EAAE,wBAAwB;wBACzC,CAAC,IAAI,CAAC,mBAAmB,EACzB;wBACA,IAAI,CAAC,gBAAgB,CAAC,QAAQ,GAAG,IAAI,CAAC;wBACtC,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,IAAI,GAAG,CAAC,YAAY,IAAI,GAAG,EAAE,YAAY,EAAE,MAAM,EAAE;oBACjD,MAAM,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CAC1C,GAAG,EAAE,YAAY,EAAE,QAAQ,CAAC,GAAG,EAAE,QAAQ,CAAC,CAC3C,CAAC;oBACF,IAAI,CAAC,YAAY,CAAC,sBAAsB,EAAE,MAAM,CAAC,CAAC;iBACnD;gBACD,IAAI,GAAG,CAAC,kBAAkB,IAAI,GAAG,EAAE,kBAAkB,EAAE,MAAM,EAAE;oBAC7D,MAAM,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CAC5C,GAAG,EAAE,kBAAkB,EAAE,QAAQ,CAAC,GAAG,EAAE,QAAQ,CAAC,CACjD,CAAC;oBACF,IAAI,CAAC,YAAY,CAAC,wBAAwB,EAAE,QAAQ,CAAC,CAAC;oBACtD,IAAI,CAAC,KAAK,CAAC,uBAAuB,GAAG,QAAQ,CAAC;oBAC9C,IACE,IAAI,CAAC,UAAU,EAAE,wBAAwB;wBACzC,CAAC,IAAI,CAAC,mBAAmB,EACzB;wBACA,IAAI,CAAC,gBAAgB,CAAC,SAAS,GAAG,IAAI,CAAC;qBACxC;iBACF;gBACD,IACE,GAAG,EAAE,0BAA0B;oBAC/B,GAAG,EAAE,0BAA0B,EAAE,MAAM,EACvC;oBACA,MAAM,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CAC5C,GAAG,EAAE,0BAA0B,EAAE,QAAQ,CAAC,GAAG,EAAE,QAAQ,CAAC,CACzD,CAAC;oBACF,IAAI,CAAC,YAAY,CAAC,gCAAgC,EAAE,QAAQ,CAAC,CAAC;oBAC9D,IACE,IAAI,CAAC,UAAU,EAAE,wBAAwB;wBACzC,CAAC,IAAI,CAAC,mBAAmB,EACzB;wBACA,IAAI,CAAC,gBAAgB,CAAC,SAAS,GAAG,IAAI,CAAC;qBACxC;iBACF;gBACD,IAAI,GAAG,EAAE,kBAAkB,IAAI,GAAG,EAAE,kBAAkB,EAAE,MAAM,EAAE;oBAC9D,MAAM,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CAC5C,GAAG,EAAE,kBAAkB,EAAE,QAAQ,CAAC,GAAG,EAAE,QAAQ,CAAC,CACjD,CAAC;oBACF,IAAI,CAAC,YAAY,CAAC,wBAAwB,EAAE,QAAQ,CAAC,CAAC;oBACtD,IAAI,CAAC,KAAK,CAAC,uBAAuB,GAAG,QAAQ,CAAC;oBAC9C,IACE,IAAI,CAAC,UAAU,EAAE,wBAAwB;wBACzC,CAAC,IAAI,CAAC,mBAAmB,EACzB;wBACA,IAAI,CAAC,gBAAgB,CAAC,QAAQ,GAAG,IAAI,CAAC;qBACvC;iBACF;gBACD,IACE,GAAG,EAAE,0BAA0B;oBAC/B,GAAG,EAAE,0BAA0B,EAAE,MAAM,EACvC;oBACA,MAAM,QAAQ,GAAG,QAAQ,EAAE,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CAC7C,GAAG,EAAE,0BAA0B,EAAE,QAAQ,CAAC,GAAG,EAAE,QAAQ,CAAC,CACzD,CAAC;oBACF,IAAI,CAAC,YAAY,CAAC,gCAAgC,EAAE,QAAQ,CAAC,CAAC;oBAC9D,IAAI,CAAC,QAAQ,CAAC,4BAA4B,CAAC,KAAK;wBAC9C,IAAI,CAAC,QAAQ,EAAE,8BAA8B,EAAE,KAAK,EAAE,MAAM,GAAG,CAAC;4BAC9D,CAAC,CAAC,QAAQ;4BACV,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,4BAA4B,EAAE,KAAK,CAAC;oBACzD,IACE,IAAI,CAAC,UAAU,EAAE,wBAAwB;wBACzC,CAAC,IAAI,CAAC,mBAAmB,EACzB;wBACA,IAAI,CAAC,gBAAgB,CAAC,QAAQ,GAAG,IAAI,CAAC;qBACvC;iBACF;gBACD,IACE,GAAG,EAAE,SAAS,EAAE,eAAe;oBAC/B,GAAG,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,EACvC;oBACA,MAAM,aAAa,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CACjD,GAAG,EAAE,SAAS,EAAE,eAAe,EAAE,QAAQ,CAAC,GAAG,EAAE,QAAQ,CAAC,CACzD,CAAC;oBACF,IAAI,CAAC,YAAY,CAAC,wBAAwB,EAAE,aAAa,CAAC,CAAC;oBAC3D,IAAI,CAAC,KAAK,CAAC,uBAAuB,GAAG,aAAa,CAAC;oBACnD,IACE,IAAI,CAAC,UAAU,EAAE,wBAAwB;wBACzC,CAAC,IAAI,CAAC,mBAAmB,EACzB;wBACA,IAAI,CAAC,gBAAgB,CAAC,QAAQ,GAAG,IAAI,CAAC;qBACvC;iBACF;gBACD,IACE,GAAG,EAAE,iBAAiB,EAAE,eAAe;oBACvC,GAAG,EAAE,iBAAiB,EAAE,eAAe,EAAE,MAAM,EAC/C;oBACA,MAAM,oBAAoB,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CACxD,GAAG,EAAE,iBAAiB,EAAE,eAAe,EAAE,QAAQ,CAAC,GAAG,EAAE,QAAQ,CAAC,CACjE,CAAC;oBACF,IAAI,CAAC,YAAY,CACf,gCAAgC,EAChC,oBAAoB,CACrB,CAAC;oBACF,IACE,IAAI,CAAC,UAAU,EAAE,wBAAwB;wBACzC,CAAC,IAAI,CAAC,mBAAmB,EACzB;wBACA,IAAI,CAAC,gBAAgB,CAAC,QAAQ,GAAG,IAAI,CAAC;qBACvC;iBACF;gBACD,IACE,GAAG,EAAE,iBAAiB,EAAE,uBAAuB;oBAC/C,GAAG,EAAE,iBAAiB,EAAE,uBAAuB,EAAE,MAAM,EACvD;oBACA,MAAM,2BAA2B,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CAC/D,GAAG,EAAE,iBAAiB,EAAE,uBAAuB,EAAE,QAAQ,CACvD,GAAG,EAAE,QAAQ,CACd,CACF,CAAC;oBACF,IAAI,CAAC,YAAY,CACf,uCAAuC,EACvC,2BAA2B,CAC5B,CAAC;oBACF,IACE,IAAI,CAAC,UAAU,EAAE,wBAAwB;wBACzC,CAAC,IAAI,CAAC,mBAAmB,EACzB;wBACA,IAAI,CAAC,gBAAgB,CAAC,QAAQ,GAAG,IAAI,CAAC;qBACvC;iBACF;YACH,CAAC;YACD,0GAA0G;YAC1G,gFAAgF;SACjF,CAAC,CAAC;QACH,IAAI,CAAC,uBAAuB,EAAE,CAAC;IACjC,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;IACD,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;+GAx3DU,wBAAwB;mGAAxB,wBAAwB,wuBAMR,UAAU,wHCrCvC,gsoHA2sFA;;4FD5qFa,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","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  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  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 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  });\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  };\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);\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    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, 'member_id')\n        );\n        this.setFormField(\n          'program_owners_group',\n          this.uniqueByProp(evt?.groups, 'group_id')\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 'ASSIGNEE': {\n        this.setFormField(\n          'program_assignee',\n          this.uniqueByProp(evt?.users, 'member_id')\n        );\n        this.setFormField(\n          'program_assignee_group',\n          this.uniqueByProp(evt?.groups, 'group_id')\n        );\n        this.fieldDeselector(type);\n        this.setDefaultAssignee(evt);\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?.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 '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  //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        this.lists.SYSTEM_ROLE_IDS = defaultSystemVal;\n        if (this.mode !== 'EDIT') {\n          this.setFormField('program_roles', defaultVal);\n          this.fetchUsersAssociatedWithRoles();\n          this.fetchGroupsAssociatedWithRoles();\n        }\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.controls.program_roles?.value?.map(\n      (ele: any) => ele?._id\n    );\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        this.lists.APPROVERS = 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  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) <span class=\"required\">*</span>\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          <!-- <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 !== '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    <!-- Approvers -->\n    <!-- Removing this option in Program simplification -->\n    <form-field\n      *ngIf=\"additionalOption?.APPROVER && !programSimplifyFlag\"\n      [checked]=\"controls?.program_approver?.value?.length\"\n      [active]=\"activeList === 'APPROVER'\"\n      [disabled]=\"\n        sideElements.includes(activeList) && activeList !== 'APPROVER'\n      \"\n      [img]=\"ASSETS.approval\"\n    >\n      <label class=\"vx-control-panel\"\n        >APPROVER\n        <i\n          class=\"icons\"\n          [appTooltip]=\"\n            'An Approver is responsible for approving a Program. Where an Approver is selected, the Program and all responsibilities linked with that Program will only commence once the Program has been approved.'\n          \"\n          placement=\"bottom\"\n          delay=\"0\"\n          type=\"white\"\n          [tooltipMandatory]=\"true\"\n          id=\"ApproverHelpText\"\n          >&#xeb16;</i\n        ></label\n      >\n      <input-with-pill\n        [placeholder]=\"'Who is responsible for approving this program?'\"\n        [disabled]=\"isApproverDisabled\"\n        (select)=\"activateList('APPROVER')\"\n      >\n        <div class=\"selected\" *ngIf=\"controls?.program_approver?.value[0]\">\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=\"isApproverDisabled === false\"\n              (click)=\"remove(controls?.program_approver?.value[0], 'APPROVER')\"\n              >&#xe9ae;</i\n            >\n            <span\n              class=\"chipName vx-fs-11 vx-label-txt\"\n              [appTooltip]=\"controls?.program_approver?.value[0]?.member_name\"\n              placement=\"bottom-left\"\n              delay=\"0\"\n              type=\"black\"\n              [tooltipMandatory]=\"false\"\n              >{{ controls?.program_approver?.value[0]?.member_name }}</span\n            >\n          </div>\n\n          <!-- <div class=\"chip-container\">\n                        <div class=\"chip-inner\">\n                            <i *ngIf=\"isApproverDisabled === false\" (click)=\"remove(controls?.program_approver?.value[0],'APPROVER')\"\n                            class=\"icons vx-fs-9 vx-mr-1 cross\">&#xe90d;</i>{{controls?.program_approver?.value[0]?.member_name}}\n                        </div>\n                    </div> -->\n          <button\n            *ngIf=\"activeList !== 'APPROVER' && isApproverDisabled === false\"\n            (click)=\"activateList('APPROVER')\"\n            class=\"edit\"\n            type=\"button\"\n          >\n            <i class=\"icons\">&#xe9ba;</i>Edit\n          </button>\n        </div>\n      </input-with-pill>\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<user-group-list\n  *ngIf=\"activeList === 'APPROVER'\"\n  [groupEnabled]=\"false\"\n  [singleSelect]=\"true\"\n  [userlist]=\"lists?.APPROVERS?.data ?? []\"\n  [selectedUsers]=\"controls?.program_approver?.value | refDisconnect\"\n  [userListInfo]=\"lists?.APPROVERS\"\n  (save)=\"listAction($event, 'APPROVER')\"\n  (cancel)=\"fieldDeselector('APPROVER')\"\n  [panelTitle]=\"panelTitleApprover\"\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"]}