vcomply-workflow-engine 6.0.72 → 6.0.73
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/workflow/grc-object/grc-object-container/grc-object-container.component.mjs +3 -3
- package/esm2022/lib/workflow/shared/components/program-responsibility-listing/program-responsibility-listing.component.mjs +62 -35
- package/esm2022/lib/workflow/shared/services/grc.service.mjs +5 -1
- package/esm2022/lib/workflow/shared/workflow-pipes/get-user-details.pipe.mjs +26 -0
- package/esm2022/lib/workflow/shared/workflow-pipes/workflow-pipes.module.mjs +8 -3
- package/esm2022/lib/workflow-program/workflow-program.component.mjs +9 -41
- package/fesm2022/vcomply-workflow-engine.mjs +879 -850
- package/fesm2022/vcomply-workflow-engine.mjs.map +1 -1
- package/lib/workflow/shared/components/program-responsibility-listing/program-responsibility-listing.component.d.ts +6 -2
- package/lib/workflow/shared/services/grc.service.d.ts +1 -0
- package/lib/workflow/shared/workflow-pipes/get-user-details.pipe.d.ts +7 -0
- package/lib/workflow/shared/workflow-pipes/workflow-pipes.module.d.ts +3 -2
- package/package.json +1 -1
|
@@ -14,6 +14,7 @@ import { cloneDeep, shuffle, some, uniqBy, isEqual } from 'lodash';
|
|
|
14
14
|
import * as i1$2 from '@angular/platform-browser';
|
|
15
15
|
import * as i4 from '@vcomply/editor';
|
|
16
16
|
import { VcomplyEditorModule } from '@vcomply/editor';
|
|
17
|
+
import * as i2$1 from 'projects/vx-workflow-engine/src/lib/workflow-services/responsibility.service';
|
|
17
18
|
import * as i5 from 'ng2-date-picker';
|
|
18
19
|
import { DpDatePickerModule } from 'ng2-date-picker';
|
|
19
20
|
import { nanoid } from 'nanoid';
|
|
@@ -1337,6 +1338,10 @@ class GrcService {
|
|
|
1337
1338
|
this.env = config.envConfig;
|
|
1338
1339
|
}
|
|
1339
1340
|
}
|
|
1341
|
+
getAllResponsibilities(pageNo) {
|
|
1342
|
+
const headers = new HttpHeaders().set('token', this.authService.getAuthorizationToken());
|
|
1343
|
+
return this.http.get(this.env.complianceGet + `sailsResponsibilitiesList&page=${pageNo}&limit=30`, { headers });
|
|
1344
|
+
}
|
|
1340
1345
|
getGRCList(event) {
|
|
1341
1346
|
const headers = new HttpHeaders().set('token', this.authService.getAuthorizationToken());
|
|
1342
1347
|
let params = new HttpParams();
|
|
@@ -5433,13 +5438,39 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
5433
5438
|
}]
|
|
5434
5439
|
}] });
|
|
5435
5440
|
|
|
5441
|
+
class GetUserDetailsPipe {
|
|
5442
|
+
transform(ids, list) {
|
|
5443
|
+
const userDetails = list
|
|
5444
|
+
.filter((item) => ids?.includes(item?.id))
|
|
5445
|
+
.map((item) => {
|
|
5446
|
+
return {
|
|
5447
|
+
name: item?.name,
|
|
5448
|
+
email: item?.email,
|
|
5449
|
+
short_name: item?.name?.split(' ').map((n) => n[0]).join(''),
|
|
5450
|
+
avatar: item?.imagePath || ''
|
|
5451
|
+
};
|
|
5452
|
+
});
|
|
5453
|
+
return userDetails;
|
|
5454
|
+
}
|
|
5455
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GetUserDetailsPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
5456
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: GetUserDetailsPipe, name: "getUserDetails" }); }
|
|
5457
|
+
}
|
|
5458
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GetUserDetailsPipe, decorators: [{
|
|
5459
|
+
type: Pipe,
|
|
5460
|
+
args: [{
|
|
5461
|
+
name: 'getUserDetails',
|
|
5462
|
+
}]
|
|
5463
|
+
}] });
|
|
5464
|
+
|
|
5436
5465
|
class WorkflowPipesModule {
|
|
5437
5466
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: WorkflowPipesModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
5438
5467
|
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: WorkflowPipesModule, declarations: [GetSelectedValuePipe,
|
|
5439
5468
|
IsAttributesValidPipe,
|
|
5440
|
-
UniqueResponsibilitiesPipe
|
|
5469
|
+
UniqueResponsibilitiesPipe,
|
|
5470
|
+
GetUserDetailsPipe], imports: [CommonModule], exports: [GetSelectedValuePipe,
|
|
5441
5471
|
IsAttributesValidPipe,
|
|
5442
|
-
UniqueResponsibilitiesPipe
|
|
5472
|
+
UniqueResponsibilitiesPipe,
|
|
5473
|
+
GetUserDetailsPipe] }); }
|
|
5443
5474
|
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: WorkflowPipesModule, imports: [CommonModule] }); }
|
|
5444
5475
|
}
|
|
5445
5476
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: WorkflowPipesModule, decorators: [{
|
|
@@ -5449,12 +5480,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
5449
5480
|
GetSelectedValuePipe,
|
|
5450
5481
|
IsAttributesValidPipe,
|
|
5451
5482
|
UniqueResponsibilitiesPipe,
|
|
5483
|
+
GetUserDetailsPipe
|
|
5452
5484
|
],
|
|
5453
5485
|
imports: [CommonModule],
|
|
5454
5486
|
exports: [
|
|
5455
5487
|
GetSelectedValuePipe,
|
|
5456
5488
|
IsAttributesValidPipe,
|
|
5457
5489
|
UniqueResponsibilitiesPipe,
|
|
5490
|
+
GetUserDetailsPipe
|
|
5458
5491
|
],
|
|
5459
5492
|
}]
|
|
5460
5493
|
}] });
|
|
@@ -5745,8 +5778,10 @@ class ProgramResponsibilityListingComponent {
|
|
|
5745
5778
|
this.getSelectedProgramIds(this.selectedProgramAndResp);
|
|
5746
5779
|
this.getAllSelectedResponsibilities(this.selectedProgramAndResp);
|
|
5747
5780
|
}
|
|
5748
|
-
constructor(grcService) {
|
|
5781
|
+
constructor(grcService, responsibilityService, getUserDetails) {
|
|
5749
5782
|
this.grcService = grcService;
|
|
5783
|
+
this.responsibilityService = responsibilityService;
|
|
5784
|
+
this.getUserDetails = getUserDetails;
|
|
5750
5785
|
this.programTypes = RESPONSIBILITY_TABLE_CARD;
|
|
5751
5786
|
this.CDN_LINK = LINKS;
|
|
5752
5787
|
this.selectedTab = 1;
|
|
@@ -5778,8 +5813,9 @@ class ProgramResponsibilityListingComponent {
|
|
|
5778
5813
|
setTimeout(() => {
|
|
5779
5814
|
this.animation = false;
|
|
5780
5815
|
}, 300);
|
|
5781
|
-
this.
|
|
5782
|
-
this.
|
|
5816
|
+
this.getResponsibilitiesList();
|
|
5817
|
+
// this.getProgramsList();
|
|
5818
|
+
// this.getProgramsCount();
|
|
5783
5819
|
}
|
|
5784
5820
|
close() {
|
|
5785
5821
|
this.closeList.emit(this.preSelectedProgramAndResp);
|
|
@@ -6006,12 +6042,23 @@ class ProgramResponsibilityListingComponent {
|
|
|
6006
6042
|
},
|
|
6007
6043
|
};
|
|
6008
6044
|
this.responsibilityCall = this.grcService
|
|
6009
|
-
.
|
|
6045
|
+
.getAllResponsibilities(this.responsibilityCurrentPage)
|
|
6010
6046
|
.subscribe({
|
|
6011
6047
|
next: (res) => {
|
|
6012
6048
|
this.categoryLoader = false;
|
|
6013
|
-
|
|
6014
|
-
|
|
6049
|
+
const pageSize = 30;
|
|
6050
|
+
const currentPage = res?.data?.page || 1;
|
|
6051
|
+
const startIndex = (currentPage - 1) * pageSize + 1;
|
|
6052
|
+
const endIndex = Math.min(startIndex + pageSize - 1, res?.data?.total || 0);
|
|
6053
|
+
this.responsibilityData = {
|
|
6054
|
+
data: this.setDataListStructure(res?.data?.responsibilities || [], res?.data?.users || [], res?.data?.responsibilityCenters || []),
|
|
6055
|
+
total_items: res?.data?.total || 0,
|
|
6056
|
+
total_pages: Math.ceil((res?.data?.total || 0) / pageSize),
|
|
6057
|
+
current_page: currentPage,
|
|
6058
|
+
per_page: pageSize,
|
|
6059
|
+
items_from: startIndex,
|
|
6060
|
+
items_to: endIndex
|
|
6061
|
+
};
|
|
6015
6062
|
this.responsibilityLoader = false;
|
|
6016
6063
|
},
|
|
6017
6064
|
error: (err) => {
|
|
@@ -6023,31 +6070,41 @@ class ProgramResponsibilityListingComponent {
|
|
|
6023
6070
|
this.responsibilityCurrentPage = event?.pageNo;
|
|
6024
6071
|
this.getResponsibilitiesList();
|
|
6025
6072
|
}
|
|
6026
|
-
setDataListStructure(
|
|
6027
|
-
const data =
|
|
6073
|
+
setDataListStructure(responsibilities, users, responsibilityCenters) {
|
|
6074
|
+
const data = responsibilities?.map((responsibility) => {
|
|
6075
|
+
const responsibilityCenterIds = responsibility?.responsibility_centers || [];
|
|
6076
|
+
const mappedResponsibilityCenters = responsibilityCenterIds.map((rcId) => {
|
|
6077
|
+
const rc = responsibilityCenters.find((center) => center?.id === rcId);
|
|
6078
|
+
return {
|
|
6079
|
+
name: rc?.name || '',
|
|
6080
|
+
id: rcId
|
|
6081
|
+
};
|
|
6082
|
+
});
|
|
6083
|
+
const assignorDetails = this.getUserDetails.transform([responsibility?.assignor], users)?.[0] || {};
|
|
6084
|
+
const assigneeDetails = this.getUserDetails.transform(responsibility?.assignees?.userId || [], users) || [];
|
|
6028
6085
|
return {
|
|
6029
6086
|
...responsibility,
|
|
6030
|
-
name: responsibility?.
|
|
6031
|
-
controlId: responsibility?.
|
|
6032
|
-
_id: responsibility?.
|
|
6087
|
+
name: responsibility?.title || '',
|
|
6088
|
+
controlId: responsibility?.key || '',
|
|
6089
|
+
_id: responsibility?.rid,
|
|
6033
6090
|
entrustedBy: {
|
|
6034
|
-
name:
|
|
6035
|
-
email:
|
|
6036
|
-
profilePic:
|
|
6037
|
-
shortName:
|
|
6091
|
+
name: assignorDetails?.name || '',
|
|
6092
|
+
email: assignorDetails?.email || '',
|
|
6093
|
+
profilePic: assignorDetails?.avatar || '',
|
|
6094
|
+
shortName: assignorDetails?.short_name || '',
|
|
6038
6095
|
},
|
|
6039
6096
|
entrustedTo: {
|
|
6040
|
-
name:
|
|
6041
|
-
email:
|
|
6042
|
-
profilePic:
|
|
6043
|
-
shortName:
|
|
6044
|
-
EntrustedToMembers:
|
|
6097
|
+
name: assigneeDetails[0]?.name || '',
|
|
6098
|
+
email: assigneeDetails[0]?.email || '',
|
|
6099
|
+
profilePic: assigneeDetails[0]?.avatar || '',
|
|
6100
|
+
shortName: assigneeDetails[0]?.short_name || '',
|
|
6101
|
+
EntrustedToMembers: assigneeDetails?.map((user) => ({
|
|
6102
|
+
member_name: user?.name,
|
|
6103
|
+
profile_pic: user?.avatar,
|
|
6104
|
+
member_short_name: user?.short_name
|
|
6105
|
+
})) || [],
|
|
6045
6106
|
},
|
|
6046
|
-
withinData:
|
|
6047
|
-
return {
|
|
6048
|
-
name: within?.rc_name,
|
|
6049
|
-
};
|
|
6050
|
-
}),
|
|
6107
|
+
withinData: mappedResponsibilityCenters,
|
|
6051
6108
|
subCategoryId: this.selectedCategory?.category_id,
|
|
6052
6109
|
};
|
|
6053
6110
|
});
|
|
@@ -6091,8 +6148,8 @@ class ProgramResponsibilityListingComponent {
|
|
|
6091
6148
|
selectedRCIds = selectedRC?.map((rc) => rc?.rc_id);
|
|
6092
6149
|
return selectedRCIds;
|
|
6093
6150
|
}
|
|
6094
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ProgramResponsibilityListingComponent, deps: [{ token: GrcService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
6095
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ProgramResponsibilityListingComponent, isStandalone: true, selector: "app-program-responsibility-listing", inputs: { getSelectedProgramAndResp: ["selectedProgramAndResp", "getSelectedProgramAndResp"], selectedRC: "selectedRC", MODE: "MODE" }, outputs: { closeList: "closeList" }, viewQueries: [{ propertyName: "responsibilityListingComponent", first: true, predicate: ["dataListing"], descendants: true }], ngImport: i0, template: "<div class=\"program-responsibility-listing\" [class.animate]=\"animation\">\n <div class=\"program-responsibility-listing-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\">\n <h3 class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Select Responsibilities</h3></div>\n <div class=\"program-responsibility-listing-body\">\n <app-table-card-loader *ngIf=\"programCountLoader\"></app-table-card-loader
|
|
6151
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ProgramResponsibilityListingComponent, deps: [{ token: GrcService }, { token: i2$1.ResponsibilityService }, { token: GetUserDetailsPipe }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
6152
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ProgramResponsibilityListingComponent, isStandalone: true, selector: "app-program-responsibility-listing", inputs: { getSelectedProgramAndResp: ["selectedProgramAndResp", "getSelectedProgramAndResp"], selectedRC: "selectedRC", MODE: "MODE" }, outputs: { closeList: "closeList" }, providers: [GetUserDetailsPipe], viewQueries: [{ propertyName: "responsibilityListingComponent", first: true, predicate: ["dataListing"], descendants: true }], ngImport: i0, template: "<div class=\"program-responsibility-listing\" [class.animate]=\"animation\">\n <div class=\"program-responsibility-listing-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\">\n <h3 class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Select Responsibilities</h3></div>\n <div class=\"program-responsibility-listing-body\">\n <!-- <app-table-card-loader *ngIf=\"programCountLoader\"></app-table-card-loader> -->\n <!-- <app-table-card\n *ngIf=\"!programCountLoader\"\n class=\"vx-w-100\"\n [tableCard]=\"programTypes\"\n [singleSelectedText]=\"'Responsibility Selected'\"\n [selectedTab]=\"selectedTab\"\n [multipleSelectedText]=\"'Responsibilities Selected'\"\n (setSelectedTab)=\"setSelectedTab($event)\">\n </app-table-card> -->\n <div class=\"search-block vx-mb-2\">\n <i class=\"icons\"></i>\n <input type=\"text\" #searchRiskCategory (keyup.enter)=\"handleSearch($event.target.value)\" placeholder=\"Search Responsibilities\" />\n </div>\n <div class=\"program-responsibility-listing-body-inner vx-mb-2 vx-d-flex\" [class.vx-justify-center]=\"(!responsibilityLoader && !responsibilityData?.data?.length)\">\n <ng-container *ngIf=\"(responsibilityLoader || responsibilityData?.data?.length)\">\n <!-- <div class=\"inner-item-left vx-pr-2\">\n\n <app-grc-category-listing *ngIf=\"!programLoader\" [headerText]=\"'Programs'\" [programData]=\"programData\" [selectedCatAndRisk]=\"selectedCatAndRisk\" [nameDisplayKey]=\"'item_name'\" [currentPage]=\"programCurrentPage\" [selectedTabIndex]=\"selectedTab\" [selectedCategoryIds]=\"selectedProgramIds\" (activeSelectedCategory)=\"activeSelectedProgram($event)\" (onCategoryPageChange)=\"onProgramPageChange($event)\"></app-grc-category-listing>\n \n <app-list-loader *ngIf=\"programLoader\"></app-list-loader>\n\n </div> -->\n\n <!-- <div class=\"inner-item-mid vx-pr-2\">\n <app-grc-sub-category-listing *ngIf=\"!categoryLoader && !programLoader\" [headerText]=\"'Programs'\" [categories]=\"categoryData\" [nameDisplayKey]=\"'item_name'\" [currentPage]=\"categoryCurrentPage\" [selectedCategoryIds]=\"selectedCategoryIds\" [activeProgram]=\"selectedProgram\" [selectedProgramAndResp]=\"selectedProgramAndResp\" (activeSelectedCategory)=\"activeSelectedSubCategory($event)\" (onCategoryPageChange)=\"onSubCategoryPageChange($event)\"></app-grc-sub-category-listing>\n <app-list-loader *ngIf=\"categoryLoader || programLoader\"></app-list-loader>\n </div> -->\n\n <div class=\"inner-item-right\">\n <!-- <app-grc-responsibility-listing></app-grc-responsibility-listing> -->\n\n <app-grc-responsibility-listing #dataListing *ngIf=\"!responsibilityLoader && !categoryLoader && !programLoader && responsibilityData?.data?.length !== 0\" [headerText]=\"'Responsibilities'\" [MODE]=\"MODE\" [responsibilityData]=\"responsibilityData\" [activeProgram]=\"selectedProgram\" [activeCategory]=\"selectedCategory\" [selectedProgramAndResp]=\"selectedProgramAndResp\" [allSelectedResponsibilityIds]=\"selectedResponsibilities | uniqueResponsibilities\" (changeSelectedProgramAndResp)=\"changeSelectedProgramAndResp($event)\" [currentPage]=\"responsibilityCurrentPage\" [perPageLimit]=\"30\" [totalListData]=\"responsibilityData?.total_items\" [totalPages]=\"responsibilityData?.total_pages\" (getUpdatedDataList)=\"getUpdatedDataList($event)\" ></app-grc-responsibility-listing>\n \n <app-list-loader *ngIf=\"responsibilityLoader || categoryLoader || programLoader\"></app-list-loader>\n \n <app-no-data *ngIf=\"responsibilityData?.data?.length === 0 && !(responsibilityLoader || categoryLoader || programLoader)\" [noDataImage]=\"CDN_LINK?.noData\" [noDataText]=\"'No data to display'\"></app-no-data>\n </div>\n </ng-container>\n <app-no-data *ngIf=\"(!responsibilityLoader && !responsibilityData?.data?.length)\" [noDataImage]=\"CDN_LINK?.noData\" [noDataText]=\"'No data to display'\"></app-no-data>\n </div>\n <app-floating-bar [selectedData]=\"selectedResponsibilities?.length ? (selectedResponsibilities | uniqueResponsibilities : 'entireObject') : []\" (closeList)=\"close()\" (closeEvent)=\"save()\" [displayElementKey]=\"'name'\" [singularText]=\"'Responsibility selected'\" [pluralText]=\"'Responsibilities selected'\" (deleteEvent)=\"deleteEvent($event)\"></app-floating-bar>\n </div>\n</div>", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";::ng-deep .program-responsibility-listing{position:fixed;inset:0 30px 0 0}::ng-deep .program-responsibility-listing:before{background:#1e5dd3;content:\"\";position:absolute;top:0;left:0;right:0;width:100%;height:3px}::ng-deep .program-responsibility-listing.animate{animation:animate-right .2s cubic-bezier(.25,.46,.45,.94) both;z-index:-1}::ng-deep .program-responsibility-listing-head{background:#fbfbfb;height:2.75rem;border-bottom:1px solid #f1f1f1}::ng-deep .program-responsibility-listing-body{background:#fff;height:calc(100vh - 2.75rem);padding:2rem}::ng-deep .program-responsibility-listing-body .search-block{position:relative}::ng-deep .program-responsibility-listing-body .search-block input{height:2.75rem;line-height:1.5rem;padding:.5rem 1rem .5rem 2.5rem;outline:none;border:1px solid #7475763f;border-radius:.25rem;width:100%;font-size:14px;color:#747576}::ng-deep .program-responsibility-listing-body .search-block input:focus{border-color:#1e5dd3}::ng-deep .program-responsibility-listing-body .search-block input::placeholder{color:#747576}::ng-deep .program-responsibility-listing-body .search-block i{position:absolute;left:1rem;font-size:12px;font-weight:400;top:1rem;pointer-events:none;color:#f1f1f1}::ng-deep .program-responsibility-listing-body-inner{height:calc(100vh - 17.5rem)}::ng-deep .program-responsibility-listing-body-inner .inner-item-left{width:0%}::ng-deep .program-responsibility-listing-body-inner .inner-item-mid{width:0%}::ng-deep .program-responsibility-listing-body-inner .inner-item-right{width:100%}@keyframes animate-right{0%{transform:translate(100%)}to{transform:translate(0)}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: PopoverModule }, { kind: "ngmodule", type: FormgroupModule }, { kind: "ngmodule", type: TooltipModule }, { kind: "ngmodule", type: FloatingBarModule }, { kind: "component", type: FloatingBarComponent, selector: "app-floating-bar", inputs: ["selectedData", "selectedGroups", "displayElementKey", "elementId", "singularText", "pluralText", "showNextButton", "showFrequencyText", "showWorkflow", "workflowText", "currentFrequency", "isDisabled", "workflowList", "selectedWorkflow", "workflowPlaceHolder", "mode", "defaultSelected", "groupsEnabled", "nonRemovableUsersList", "removePosition"], outputs: ["closeEvent", "deleteEvent", "closeList", "deleteGroupEvent", "workflowTypeChanged"] }, { kind: "ngmodule", type: PaginationModule$1 }, { kind: "component", type: GrcResponsibilityListingComponent, selector: "app-grc-responsibility-listing", inputs: ["tableCard", "activeProgram", "headerText", "currentPage", "perPageLimit", "totalListData", "totalPages", "selectedListData", "selectedListDataIds", "MODE", "allSelectedResponsibilityIds", "responsibilityData", "selectedProgramAndResp"], outputs: ["getUpdatedDataList", "changeSelectedProgramAndResp"] }, { kind: "ngmodule", type: ListLoaderModule }, { kind: "component", type: ListLoaderComponent, selector: "app-list-loader" }, { kind: "ngmodule", type: NoDataModule }, { kind: "component", type: NoDataComponentUI, selector: "app-no-data", inputs: ["action", "secondaryAction", "noDataImage", "noDataText", "noDataButton", "secondaryButton", "noDataSecButton", "altText", "smallButton"], outputs: ["buttonAction", "secondaryActionButton"] }, { kind: "ngmodule", type: WorkflowPipesModule }, { kind: "pipe", type: UniqueResponsibilitiesPipe, name: "uniqueResponsibilities" }] }); }
|
|
6096
6153
|
}
|
|
6097
6154
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ProgramResponsibilityListingComponent, decorators: [{
|
|
6098
6155
|
type: Component,
|
|
@@ -6111,8 +6168,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
6111
6168
|
NoDataModule,
|
|
6112
6169
|
TableCardLoaderComponent,
|
|
6113
6170
|
WorkflowPipesModule,
|
|
6114
|
-
], outputs: ['closeList'], template: "<div class=\"program-responsibility-listing\" [class.animate]=\"animation\">\n <div class=\"program-responsibility-listing-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\">\n <h3 class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Select Responsibilities</h3></div>\n <div class=\"program-responsibility-listing-body\">\n <app-table-card-loader *ngIf=\"programCountLoader\"></app-table-card-loader
|
|
6115
|
-
}], ctorParameters: function () { return [{ type: GrcService }]; }, propDecorators: { getSelectedProgramAndResp: [{
|
|
6171
|
+
], outputs: ['closeList'], providers: [GetUserDetailsPipe], template: "<div class=\"program-responsibility-listing\" [class.animate]=\"animation\">\n <div class=\"program-responsibility-listing-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\">\n <h3 class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Select Responsibilities</h3></div>\n <div class=\"program-responsibility-listing-body\">\n <!-- <app-table-card-loader *ngIf=\"programCountLoader\"></app-table-card-loader> -->\n <!-- <app-table-card\n *ngIf=\"!programCountLoader\"\n class=\"vx-w-100\"\n [tableCard]=\"programTypes\"\n [singleSelectedText]=\"'Responsibility Selected'\"\n [selectedTab]=\"selectedTab\"\n [multipleSelectedText]=\"'Responsibilities Selected'\"\n (setSelectedTab)=\"setSelectedTab($event)\">\n </app-table-card> -->\n <div class=\"search-block vx-mb-2\">\n <i class=\"icons\"></i>\n <input type=\"text\" #searchRiskCategory (keyup.enter)=\"handleSearch($event.target.value)\" placeholder=\"Search Responsibilities\" />\n </div>\n <div class=\"program-responsibility-listing-body-inner vx-mb-2 vx-d-flex\" [class.vx-justify-center]=\"(!responsibilityLoader && !responsibilityData?.data?.length)\">\n <ng-container *ngIf=\"(responsibilityLoader || responsibilityData?.data?.length)\">\n <!-- <div class=\"inner-item-left vx-pr-2\">\n\n <app-grc-category-listing *ngIf=\"!programLoader\" [headerText]=\"'Programs'\" [programData]=\"programData\" [selectedCatAndRisk]=\"selectedCatAndRisk\" [nameDisplayKey]=\"'item_name'\" [currentPage]=\"programCurrentPage\" [selectedTabIndex]=\"selectedTab\" [selectedCategoryIds]=\"selectedProgramIds\" (activeSelectedCategory)=\"activeSelectedProgram($event)\" (onCategoryPageChange)=\"onProgramPageChange($event)\"></app-grc-category-listing>\n \n <app-list-loader *ngIf=\"programLoader\"></app-list-loader>\n\n </div> -->\n\n <!-- <div class=\"inner-item-mid vx-pr-2\">\n <app-grc-sub-category-listing *ngIf=\"!categoryLoader && !programLoader\" [headerText]=\"'Programs'\" [categories]=\"categoryData\" [nameDisplayKey]=\"'item_name'\" [currentPage]=\"categoryCurrentPage\" [selectedCategoryIds]=\"selectedCategoryIds\" [activeProgram]=\"selectedProgram\" [selectedProgramAndResp]=\"selectedProgramAndResp\" (activeSelectedCategory)=\"activeSelectedSubCategory($event)\" (onCategoryPageChange)=\"onSubCategoryPageChange($event)\"></app-grc-sub-category-listing>\n <app-list-loader *ngIf=\"categoryLoader || programLoader\"></app-list-loader>\n </div> -->\n\n <div class=\"inner-item-right\">\n <!-- <app-grc-responsibility-listing></app-grc-responsibility-listing> -->\n\n <app-grc-responsibility-listing #dataListing *ngIf=\"!responsibilityLoader && !categoryLoader && !programLoader && responsibilityData?.data?.length !== 0\" [headerText]=\"'Responsibilities'\" [MODE]=\"MODE\" [responsibilityData]=\"responsibilityData\" [activeProgram]=\"selectedProgram\" [activeCategory]=\"selectedCategory\" [selectedProgramAndResp]=\"selectedProgramAndResp\" [allSelectedResponsibilityIds]=\"selectedResponsibilities | uniqueResponsibilities\" (changeSelectedProgramAndResp)=\"changeSelectedProgramAndResp($event)\" [currentPage]=\"responsibilityCurrentPage\" [perPageLimit]=\"30\" [totalListData]=\"responsibilityData?.total_items\" [totalPages]=\"responsibilityData?.total_pages\" (getUpdatedDataList)=\"getUpdatedDataList($event)\" ></app-grc-responsibility-listing>\n \n <app-list-loader *ngIf=\"responsibilityLoader || categoryLoader || programLoader\"></app-list-loader>\n \n <app-no-data *ngIf=\"responsibilityData?.data?.length === 0 && !(responsibilityLoader || categoryLoader || programLoader)\" [noDataImage]=\"CDN_LINK?.noData\" [noDataText]=\"'No data to display'\"></app-no-data>\n </div>\n </ng-container>\n <app-no-data *ngIf=\"(!responsibilityLoader && !responsibilityData?.data?.length)\" [noDataImage]=\"CDN_LINK?.noData\" [noDataText]=\"'No data to display'\"></app-no-data>\n </div>\n <app-floating-bar [selectedData]=\"selectedResponsibilities?.length ? (selectedResponsibilities | uniqueResponsibilities : 'entireObject') : []\" (closeList)=\"close()\" (closeEvent)=\"save()\" [displayElementKey]=\"'name'\" [singularText]=\"'Responsibility selected'\" [pluralText]=\"'Responsibilities selected'\" (deleteEvent)=\"deleteEvent($event)\"></app-floating-bar>\n </div>\n</div>", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";::ng-deep .program-responsibility-listing{position:fixed;inset:0 30px 0 0}::ng-deep .program-responsibility-listing:before{background:#1e5dd3;content:\"\";position:absolute;top:0;left:0;right:0;width:100%;height:3px}::ng-deep .program-responsibility-listing.animate{animation:animate-right .2s cubic-bezier(.25,.46,.45,.94) both;z-index:-1}::ng-deep .program-responsibility-listing-head{background:#fbfbfb;height:2.75rem;border-bottom:1px solid #f1f1f1}::ng-deep .program-responsibility-listing-body{background:#fff;height:calc(100vh - 2.75rem);padding:2rem}::ng-deep .program-responsibility-listing-body .search-block{position:relative}::ng-deep .program-responsibility-listing-body .search-block input{height:2.75rem;line-height:1.5rem;padding:.5rem 1rem .5rem 2.5rem;outline:none;border:1px solid #7475763f;border-radius:.25rem;width:100%;font-size:14px;color:#747576}::ng-deep .program-responsibility-listing-body .search-block input:focus{border-color:#1e5dd3}::ng-deep .program-responsibility-listing-body .search-block input::placeholder{color:#747576}::ng-deep .program-responsibility-listing-body .search-block i{position:absolute;left:1rem;font-size:12px;font-weight:400;top:1rem;pointer-events:none;color:#f1f1f1}::ng-deep .program-responsibility-listing-body-inner{height:calc(100vh - 17.5rem)}::ng-deep .program-responsibility-listing-body-inner .inner-item-left{width:0%}::ng-deep .program-responsibility-listing-body-inner .inner-item-mid{width:0%}::ng-deep .program-responsibility-listing-body-inner .inner-item-right{width:100%}@keyframes animate-right{0%{transform:translate(100%)}to{transform:translate(0)}}\n"] }]
|
|
6172
|
+
}], ctorParameters: function () { return [{ type: GrcService }, { type: i2$1.ResponsibilityService }, { type: GetUserDetailsPipe }]; }, propDecorators: { getSelectedProgramAndResp: [{
|
|
6116
6173
|
type: Input,
|
|
6117
6174
|
args: ['selectedProgramAndResp']
|
|
6118
6175
|
}], selectedRC: [{
|
|
@@ -7803,7 +7860,7 @@ class GrcObjectContainerComponent {
|
|
|
7803
7860
|
let PAYLOAD = JSON.parse(JSON.stringify(this.grcPayload));
|
|
7804
7861
|
PAYLOAD.owners = this.getOwnersExceptDefault(PAYLOAD.owners);
|
|
7805
7862
|
// Transform responsibilities data
|
|
7806
|
-
PAYLOAD.linked_responsibilities = this.CommonService.transformResponsibilitiesData(this.selectedResponsibility, this.linkedResponsibilities?.responsibilities?.linked || []);
|
|
7863
|
+
PAYLOAD.linked_responsibilities = this.CommonService.transformResponsibilitiesData(this.selectedResponsibility.map(resp => resp?.rid), this.linkedResponsibilities?.responsibilities?.linked || []);
|
|
7807
7864
|
this.apiService.addGRCObject(PAYLOAD).subscribe({
|
|
7808
7865
|
next: (data) => {
|
|
7809
7866
|
this.showSmiley = true;
|
|
@@ -7967,7 +8024,7 @@ class GrcObjectContainerComponent {
|
|
|
7967
8024
|
let PAYLOAD = JSON.parse(JSON.stringify(this.grcPayload));
|
|
7968
8025
|
PAYLOAD.owners = this.getOwnersExceptDefault(PAYLOAD.owners);
|
|
7969
8026
|
// Transform responsibilities data to get added/removed
|
|
7970
|
-
PAYLOAD.linked_responsibilities = this.CommonService.transformResponsibilitiesData(this.selectedResponsibility, this.linkedResponsibilities?.responsibilities?.linked || []);
|
|
8027
|
+
PAYLOAD.linked_responsibilities = this.CommonService.transformResponsibilitiesData(this.selectedResponsibility.map(resp => resp?.rid), this.linkedResponsibilities?.responsibilities?.linked || []);
|
|
7971
8028
|
this.apiService.updateGRCObject(PAYLOAD, this.ID).subscribe({
|
|
7972
8029
|
next: (data) => {
|
|
7973
8030
|
this.showSmiley = true;
|
|
@@ -43770,824 +43827,121 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
43770
43827
|
args: ['blur', ['$event']]
|
|
43771
43828
|
}] } });
|
|
43772
43829
|
|
|
43773
|
-
|
|
43774
|
-
|
|
43775
|
-
|
|
43776
|
-
|
|
43777
|
-
|
|
43778
|
-
|
|
43779
|
-
}
|
|
43780
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LoaderComponent, decorators: [{
|
|
43781
|
-
type: Component,
|
|
43782
|
-
args: [{ selector: 'role-loader', template: "<div class=\"assessment-list-item\" *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\n <div class=\"table-row\">\n <div class=\"table-column serial\">\n <div class=\"sr-no\"></div>\n </div>\n <div class=\"table-column name\">\n <div class=\"loader\"></div>\n </div>\n <div class=\"table-column action\">\n <div class=\"loader\"></div>\n </div>\n </div>\n</div>", styles: [".assessment-list-item{border:1px solid #f1f1f1;border-radius:2px;margin-bottom:4px}.assessment-list-item .table-row{display:flex;align-items:center;justify-content:space-between}.assessment-list-item .table-row .table-column{height:48px;position:relative;width:100%;display:flex;align-items:center;padding:0 4px}.assessment-list-item .table-row .table-column.serial{width:32px;max-width:32px;justify-content:center}.assessment-list-item .table-row .table-column.serial .sr-no{width:16px;background:#f8f8f8;writing-mode:vertical-lr;height:100%}.assessment-list-item .table-row .table-column.name{width:calc(100% - 64px);min-width:calc(100% - 64px)}.assessment-list-item .table-row .table-column.name .loader{width:calc(100% - 200px)}.assessment-list-item .table-row .table-column.action{width:32px;max-width:32px;justify-content:center}.assessment-list-item .table-row .table-column.action .loader{width:28px}.loader{background:#f1f1f1;border-radius:20px;height:10px}\n"] }]
|
|
43783
|
-
}], ctorParameters: function () { return []; } });
|
|
43784
|
-
|
|
43785
|
-
class RoleListComponent {
|
|
43830
|
+
const CUSTOM_TAG_VALUE_ACCESSOR = {
|
|
43831
|
+
provide: NG_VALUE_ACCESSOR,
|
|
43832
|
+
useExisting: forwardRef(() => CustomFieldComponent),
|
|
43833
|
+
multi: true,
|
|
43834
|
+
};
|
|
43835
|
+
class CustomFieldComponent {
|
|
43786
43836
|
constructor() {
|
|
43787
|
-
this.
|
|
43788
|
-
this.
|
|
43789
|
-
this.
|
|
43790
|
-
this.ASSETS = ASSETS;
|
|
43791
|
-
this.searchKey = '';
|
|
43792
|
-
//Used to disable items
|
|
43793
|
-
this.systemRolesIds = [];
|
|
43794
|
-
//used to check checkbox
|
|
43795
|
-
this.selectedIds = [];
|
|
43796
|
-
//complete object of selected items
|
|
43797
|
-
this.selectedRoles = [];
|
|
43798
|
-
//contains id's of all the expanded rows
|
|
43799
|
-
this.expandedRows = [];
|
|
43800
|
-
//list of all the available roles
|
|
43801
|
-
this.rolesList = [];
|
|
43802
|
-
this.initialSelected = null;
|
|
43803
|
-
this.showConfirmation = false;
|
|
43804
|
-
// only used in select all function
|
|
43805
|
-
this.allListIds = [];
|
|
43806
|
-
//isAllItems
|
|
43807
|
-
this.allSelected = false;
|
|
43808
|
-
this.loading = false;
|
|
43809
|
-
}
|
|
43810
|
-
ngOnInit() {
|
|
43811
|
-
this.animation = true;
|
|
43812
|
-
setTimeout(() => {
|
|
43813
|
-
this.animation = false;
|
|
43814
|
-
}, 300);
|
|
43815
|
-
}
|
|
43816
|
-
set setList(value) {
|
|
43817
|
-
if (value && value?.length) {
|
|
43818
|
-
this.rolesList = [...value];
|
|
43819
|
-
this.setSystemRole(this.rolesList);
|
|
43820
|
-
this.allListIds = this.rolesList.map((ele) => ele?._id);
|
|
43821
|
-
this.setAllSelectedStatus();
|
|
43822
|
-
}
|
|
43823
|
-
}
|
|
43824
|
-
set selectedRolesVal(value) {
|
|
43825
|
-
this.selectedRoles = this.uniqueByProp([...this.selectedRoles, ...value], '_id');
|
|
43826
|
-
this.selectedIds = this.selectedRoles.map((ele) => ele?._id);
|
|
43827
|
-
if (!this.initialSelected || !this.initialSelected?.length) {
|
|
43828
|
-
this.initialSelected = this.selectedIds;
|
|
43829
|
-
}
|
|
43830
|
-
this.setAllSelectedStatus();
|
|
43831
|
-
}
|
|
43832
|
-
/**
|
|
43833
|
-
* #### Description
|
|
43834
|
-
*
|
|
43835
|
-
* Expands or collapse the row
|
|
43836
|
-
* @param type
|
|
43837
|
-
* @param [id]
|
|
43838
|
-
*/
|
|
43839
|
-
expandOrCollapse(type, id) {
|
|
43840
|
-
switch (type) {
|
|
43841
|
-
case 'COLLAPSE': {
|
|
43842
|
-
this.expandedRows = this.expandedRows.filter((ele) => ele !== id);
|
|
43843
|
-
break;
|
|
43844
|
-
}
|
|
43845
|
-
case 'EXPAND': {
|
|
43846
|
-
this.expandedRows = Array.from(new Set([...this.expandedRows, ...[id]]));
|
|
43847
|
-
break;
|
|
43848
|
-
}
|
|
43849
|
-
case 'COLLAPSE_ALL': {
|
|
43850
|
-
this.expandedRows = [];
|
|
43851
|
-
break;
|
|
43852
|
-
}
|
|
43853
|
-
}
|
|
43837
|
+
this.onChanged = (value) => { };
|
|
43838
|
+
this.onTouched = () => { };
|
|
43839
|
+
this.customFields = [];
|
|
43854
43840
|
}
|
|
43855
|
-
|
|
43856
|
-
|
|
43857
|
-
this.selectedRoles = this.rolesList;
|
|
43858
|
-
this.selectedIds = this.rolesList.map((ele) => ele?._id);
|
|
43859
|
-
}
|
|
43860
|
-
else {
|
|
43861
|
-
this.selectedRoles = [];
|
|
43862
|
-
this.selectedIds = [];
|
|
43863
|
-
this.setSystemRole(this.rolesList);
|
|
43864
|
-
}
|
|
43865
|
-
this.setAllSelectedStatus();
|
|
43841
|
+
writeValue(value) {
|
|
43842
|
+
this.setField(value);
|
|
43866
43843
|
}
|
|
43867
|
-
|
|
43868
|
-
this.
|
|
43869
|
-
this.allListIds.sort().toString() === this.selectedIds.sort()?.toString();
|
|
43844
|
+
registerOnChange(fn) {
|
|
43845
|
+
this.onChanged = fn;
|
|
43870
43846
|
}
|
|
43871
|
-
|
|
43872
|
-
|
|
43873
|
-
*
|
|
43874
|
-
* Sets system role for admins and key admins
|
|
43875
|
-
* @param roles
|
|
43876
|
-
*/
|
|
43877
|
-
setSystemRole(roles) {
|
|
43878
|
-
const systemRoles = roles.filter((ele) => ele?.roleName?.toLowerCase() === 'key admin' ||
|
|
43879
|
-
ele?.roleName?.toLowerCase() === 'admin');
|
|
43880
|
-
this.systemRolesIds = Array.from(new Set([
|
|
43881
|
-
...this.systemRolesIds,
|
|
43882
|
-
...systemRoles.map((ele) => ele?._id),
|
|
43883
|
-
]));
|
|
43884
|
-
this.selectedIds = Array.from(new Set([...this.selectedIds, ...this.systemRolesIds]));
|
|
43885
|
-
this.selectedRoles = this.uniqueByProp([...systemRoles, ...this.selectedRoles], '_id');
|
|
43847
|
+
registerOnTouched(fn) {
|
|
43848
|
+
this.onTouched = fn;
|
|
43886
43849
|
}
|
|
43887
|
-
|
|
43888
|
-
|
|
43889
|
-
* Selects item or deselect a itme
|
|
43890
|
-
* @param evt
|
|
43891
|
-
* @param payload
|
|
43892
|
-
*/
|
|
43893
|
-
selectItem(evt, payload) {
|
|
43894
|
-
evt?.target?.checked === true
|
|
43895
|
-
? this.manipulateSelectedItems('ADD', payload)
|
|
43896
|
-
: this.manipulateSelectedItems('DELETE', payload);
|
|
43850
|
+
setDisabledState(isDisabled) {
|
|
43851
|
+
this.disabled = isDisabled;
|
|
43897
43852
|
}
|
|
43898
|
-
|
|
43899
|
-
|
|
43900
|
-
|
|
43901
|
-
|
|
43902
|
-
* @param action :'ADD' | 'DELETE'
|
|
43903
|
-
* @param payload
|
|
43904
|
-
*/
|
|
43905
|
-
manipulateSelectedItems(action, payload) {
|
|
43906
|
-
if (action === 'ADD') {
|
|
43907
|
-
this.selectedRoles = this.uniqueByProp([...this.selectedRoles, ...[payload]], '_id');
|
|
43908
|
-
this.selectedIds = this.selectedRoles.map((ele) => ele?._id);
|
|
43909
|
-
}
|
|
43910
|
-
else if (action === 'DELETE') {
|
|
43911
|
-
let index = this.selectedRoles.findIndex((ele) => ele?._id === payload?._id);
|
|
43912
|
-
if (index > -1) {
|
|
43913
|
-
this.selectedRoles = this.selectedRoles.filter((ele) => ele?._id !== payload?._id);
|
|
43914
|
-
this.selectedIds = this.selectedIds.filter((ele) => ele !== payload?._id);
|
|
43915
|
-
}
|
|
43916
|
-
}
|
|
43917
|
-
this.setAllSelectedStatus();
|
|
43853
|
+
valChange() {
|
|
43854
|
+
const field = this.customFields.map((ele) => ele?.name);
|
|
43855
|
+
this.onChanged(field);
|
|
43856
|
+
this.onTouched();
|
|
43918
43857
|
}
|
|
43919
|
-
|
|
43920
|
-
if (
|
|
43921
|
-
this.
|
|
43922
|
-
this.showConfirmation = true;
|
|
43858
|
+
setField(arrayOfFields) {
|
|
43859
|
+
if (arrayOfFields?.length) {
|
|
43860
|
+
this.customFields = arrayOfFields.map((ele) => { return { name: ele }; });
|
|
43923
43861
|
}
|
|
43924
43862
|
else {
|
|
43925
|
-
this.
|
|
43926
|
-
}
|
|
43927
|
-
}
|
|
43928
|
-
confirmAction(evt) {
|
|
43929
|
-
if (evt === 'YES') {
|
|
43930
|
-
this.save.emit(this.selectedRoles);
|
|
43931
|
-
}
|
|
43932
|
-
else if (evt === 'NO') {
|
|
43933
|
-
this.showConfirmation = false;
|
|
43863
|
+
this.customFields = [{ name: '' }];
|
|
43934
43864
|
}
|
|
43865
|
+
this.focus();
|
|
43935
43866
|
}
|
|
43936
|
-
|
|
43937
|
-
this.
|
|
43938
|
-
}
|
|
43939
|
-
/**
|
|
43940
|
-
* #### Description
|
|
43941
|
-
*
|
|
43942
|
-
* Returns the unique array of object based on unique key
|
|
43943
|
-
* @param array
|
|
43944
|
-
* @param key
|
|
43945
|
-
* @returns
|
|
43946
|
-
*/
|
|
43947
|
-
uniqueByProp(array, key) {
|
|
43948
|
-
return Array.from(array
|
|
43949
|
-
.reduce((acc, item) => (item && item[key] && acc.set(item[key], item), acc), new Map())
|
|
43950
|
-
.values());
|
|
43867
|
+
addCustomField() {
|
|
43868
|
+
this.customFields.push({ name: '', isEditing: true });
|
|
43951
43869
|
}
|
|
43952
|
-
|
|
43953
|
-
|
|
43954
|
-
|
|
43955
|
-
|
|
43956
|
-
|
|
43957
|
-
|
|
43958
|
-
|
|
43959
|
-
return 'view permission groups';
|
|
43960
|
-
}
|
|
43961
|
-
}
|
|
43962
|
-
if (permission == 'manage roles') {
|
|
43963
|
-
if (this.ff_rc_listing) {
|
|
43964
|
-
return 'Manage permissions';
|
|
43965
|
-
}
|
|
43966
|
-
else {
|
|
43967
|
-
return 'Manage permission groups';
|
|
43968
|
-
}
|
|
43969
|
-
}
|
|
43970
|
-
if (permission == 'view groups') {
|
|
43971
|
-
if (this.featureflagGroup) {
|
|
43972
|
-
return 'view user groups';
|
|
43973
|
-
}
|
|
43974
|
-
else {
|
|
43975
|
-
return permission;
|
|
43976
|
-
}
|
|
43977
|
-
}
|
|
43978
|
-
if (permission == 'manage groups') {
|
|
43979
|
-
if (this.featureflagGroup) {
|
|
43980
|
-
return 'Manage user groups';
|
|
43870
|
+
manipulateCustomField(type, index) {
|
|
43871
|
+
switch (type) {
|
|
43872
|
+
case 'ADD': {
|
|
43873
|
+
this.customFields.push({ name: '', isEditing: true });
|
|
43874
|
+
this.valChange();
|
|
43875
|
+
this.focus();
|
|
43876
|
+
break;
|
|
43981
43877
|
}
|
|
43982
|
-
|
|
43983
|
-
|
|
43878
|
+
case 'DELETE': {
|
|
43879
|
+
if (this.customFields?.length > 1) {
|
|
43880
|
+
this.customFields.splice(index, 1);
|
|
43881
|
+
this.valChange();
|
|
43882
|
+
this.focus();
|
|
43883
|
+
}
|
|
43884
|
+
break;
|
|
43984
43885
|
}
|
|
43985
43886
|
}
|
|
43986
|
-
return permission;
|
|
43987
43887
|
}
|
|
43988
|
-
|
|
43989
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: RoleListComponent, selector: "role-list", inputs: { featureflagrole: "featureflagrole", featureflagGroup: "featureflagGroup", ff_rc_listing: "ff_rc_listing", setList: ["list", "setList"], loading: "loading", selectedRolesVal: ["selected", "selectedRolesVal"] }, outputs: { save: "save", cancel: "cancel" }, ngImport: i0, template: "<div class=\"roles-list\" [class.animate]=\"animation\">\n <div\n class=\"roles-list-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\"\n >\n <div id=\"titlename\" class=\"vx-fs-14 vx-fw-500 vx-label-txt\">\n {{ ff_rc_listing ? \"Select Permissions\" : \"Select Permission Group(s)\" }}\n </div>\n </div>\n\n <div class=\"roles-list-body\">\n <div class=\"search-block vx-mb-1\" [class.disabled]=\"!rolesList?.length\">\n <i class=\"icons\"></i>\n <input\n type=\"text\"\n [placeholder]=\"\n ff_rc_listing ? 'Search Permissions' : 'Search Permission Groups'\n \"\n [(ngModel)]=\"searchKey\"\n />\n </div>\n <div class=\"vx-mt-4\" *ngIf=\"loading\"><role-loader></role-loader></div>\n\n <ng-container *ngIf=\"!loading\">\n <ng-container\n *ngIf=\"rolesList | search : searchKey : 'roleName' as roles\"\n >\n <div *ngIf=\"roles?.length > 0\" class=\"roles-list-mid vx-mb-4\">\n <div class=\"role-box-select vx-pb-2\">\n <vui-checkbox\n [indeterminateEnabled]=\"false\"\n #check\n (change)=\"selectAll($event)\"\n [(ngModel)]=\"allSelected\"\n [checked]=\"allSelected\"\n >\n <div class=\"user-name vx-fs-12 vx-fw-600 vx-label-txt\">\n {{ !check.checked ? \"Select All\" : \"Deselect All\" }}\n </div>\n </vui-checkbox>\n </div>\n\n <div\n class=\"role-box vx-mb-2\"\n *ngFor=\"let role of roles; let i = index\"\n >\n <div\n (click)=\"\n !expandedRows.includes(role?._id)\n ? expandOrCollapse('EXPAND', role?._id)\n : expandOrCollapse('COLLAPSE', role?._id)\n \"\n class=\"role-box-heading vx-d-flex vx-align-center vx-justify-between vx-p-3\"\n >\n <div class=\"left vx-d-flex vx-align-center vx-lh-4\">\n <vui-checkbox\n [disabled]=\"systemRolesIds.includes(role?._id)\"\n [checked]=\"selectedIds.includes(role?._id)\"\n (change)=\"selectItem($event, role)\"\n >\n </vui-checkbox>\n <div\n class=\"name vx-fs-12 vx-label-txt\"\n [appTooltip]=\"'Role name'\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >\n {{\n featureflagrole && role?.permissionGroupName\n ? role?.permissionGroupName\n : role?.roleName\n }}\n </div>\n <span\n *ngIf=\"role?.roleActions?.length > 0\"\n class=\"count vx-fs-9 vx-fw-600 vx-lh-3 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-ml-2\"\n >{{ role?.roleActions?.length }} PERMISSIONS</span\n >\n </div>\n <div class=\"right vx-d-flex vx-align-center vx-justify-between\">\n <div\n *ngIf=\"role?.licenseType === 'power users'\"\n class=\"status-label vx-fs-9 vx-fw-500 vx-txt-white vx-tt-uppercase vx-pl-1 vx-pr-1\"\n [class.power-user]=\"true\"\n [class.all-user]=\"false\"\n >\n Power User\n </div>\n <div\n *ngIf=\"role?.licenseType === 'light users'\"\n class=\"status-label vx-fs-9 vx-fw-500 vx-txt-white vx-tt-uppercase vx-pl-1 vx-pr-1\"\n [class.power-user]=\"false\"\n [class.all-user]=\"true\"\n >\n Light User\n </div>\n <button\n class=\"arrow-btn vx-fs-12 vx-paragraph-txt vx-m-0 vx-p-0 vx-d-flex vx-align-center\"\n >\n <i *ngIf=\"!expandedRows.includes(role?._id)\" class=\"icons\"\n ></i\n >\n <i *ngIf=\"expandedRows.includes(role?._id)\" class=\"icons\"\n ></i\n >\n </button>\n </div>\n </div>\n <div class=\"role-box-list\" *ngIf=\"expandedRows.includes(role?._id)\">\n <ul class=\"vx-p-0 vx-m-0\">\n <li\n class=\"vx-p-3 vx-lh-4\"\n *ngFor=\"let permission of role?.roleActions\"\n >\n <div class=\"value vx-fs-12 vx-label-txt\">\n {{ permissionText(permission) }}\n </div>\n </li>\n <!-- <li class=\"vx-p-3 vx-lh-4\">\n <div class=\"value vx-fs-12 vx-label-txt\">View User List</div>\n </li>\n <li class=\"vx-p-3 vx-lh-4\">\n <div class=\"value vx-fs-12 vx-label-txt\">Manage Users <span class=\"vx-fs-10 vx-paragraph-txt\">(Create/Edit/Delete/Deactivate)</span></div>\n </li>\n <li class=\"vx-p-3 vx-lh-4\">\n <div class=\"value vx-fs-12 vx-label-txt\">Over-ride Log In</div>\n </li>\n <li class=\"vx-p-3 vx-lh-4\">\n <div class=\"value vx-fs-12 vx-label-txt\">View Statutory Holidays</div>\n </li>\n <li class=\"vx-p-3 vx-lh-4\">\n <div class=\"value vx-fs-12 vx-label-txt\">Manage Statutory Holidays</div>\n </li> -->\n </ul>\n </div>\n </div>\n </div>\n\n <app-no-data\n *ngIf=\"roles?.length === 0\"\n [noDataImage]=\"ASSETS.search_data\"\n [noDataText]=\"\n searchKey?.length > 0 ? 'No match found.' : 'No Roles Found'\n \"\n ></app-no-data>\n </ng-container>\n </ng-container>\n\n <div class=\"roles-list-footer\" *ngIf=\"!showConfirmation\">\n <vui-floating-bar (closeEvent)=\"saveList()\" (closeList)=\"closeList()\">\n <!-- <div class=\"counter\" *ngIf=\"selectedRoles?.length\"\n placement=\"left\">{{selectedRoles?.length}}</div> -->\n <button\n *ngIf=\"selectedRoles?.length\"\n class=\"counter role-list-counter\"\n appPopover\n (click)=\"role.popover()\"\n placement=\"left\"\n >\n {{ selectedRoles?.length }}\n </button>\n <div\n class=\"name\"\n *ngIf=\"selectedRoles?.length > 1\"\n id=\"permissionselected\"\n >\n <span *ngIf=\"selectedRoles?.length === 1\">{{\n featureflagrole ? \"Permission selected\" : \"Role selected\"\n }}</span>\n <span *ngIf=\"selectedRoles?.length > 1\">{{\n featureflagrole ? \"Permissions selected\" : \"Roles selected\"\n }}</span>\n </div>\n </vui-floating-bar>\n\n <app-popover #role [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"let data of selectedRoles\">\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"!systemRolesIds.includes(data?._id)\"\n class=\"icons\"\n (click)=\"selectItem({ target: { checked: false } }, data)\"\n ></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 </div>\n </div>\n\n <div class=\"roles-list-confirmation\" *ngIf=\"showConfirmation\">\n <div class=\"confirmation-top\">\n <div class=\"icon-block\"><i class=\"icons\"></i></div>\n <div class=\"text\" id=\"confirmationmessage\">\n {{\n featureflagrole\n ? \"This action will update the Permission settings and impact the owners selected for the Program.\"\n : \"This action will update the Role settings and impact the owners selected for the Program.\"\n }}\n </div>\n </div>\n <div class=\"confirmation-bottom\">\n <div class=\"message\">Are you sure you would like to proceed?</div>\n <div class=\"button-group\">\n <button class=\"no-btn\" (click)=\"confirmAction('NO')\">NO</button>\n <button class=\"yes-btn\" (click)=\"confirmAction('YES')\">YES</button>\n </div>\n </div>\n </div>\n</div>\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/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";::ng-deep .roles-list{position:fixed;inset:0 500px 0 0}::ng-deep .roles-list:before{background:#1e5dd3;content:\"\";position:absolute;top:0;left:0;right:0;width:100%;height:3px}::ng-deep .roles-list.animate{animation:animate-right .2s cubic-bezier(.25,.46,.45,.94) both;z-index:-1}::ng-deep .roles-list-head{background:#fbfbfb;height:2.75rem;border-bottom:1px solid #f1f1f1}::ng-deep .roles-list-body{background:#fff;height:calc(100vh - 2.75rem);padding:2rem}::ng-deep .roles-list-body .search-block{position:relative}::ng-deep .roles-list-body .search-block input{height:2.75rem;line-height:1.5rem;padding:.5rem 1rem .5rem 2.5rem;outline:none;border:1px solid #7475763f;border-radius:.25rem;width:100%;font-size:14px;color:#747576}::ng-deep .roles-list-body .search-block input:focus{border-color:#1e5dd3}::ng-deep .roles-list-body .search-block i{position:absolute;left:1rem;top:1rem;pointer-events:none;color:#f1f1f1;font-size:12px}::ng-deep .roles-list-mid{width:calc(100% + .75rem);height:calc(100vh - 13.8rem);overflow:hidden;overflow-y:auto;padding-right:.75rem}::ng-deep .roles-list-mid .role-box{border:1px solid #f1f1f1;border-radius:.25rem}::ng-deep .roles-list-mid .role-box-select{background:#fff;position:sticky;top:0;z-index:1}::ng-deep .roles-list-mid .role-box-select vui-checkbox .checkbox-item{position:relative;padding-left:1.75rem;width:100%}::ng-deep .roles-list-mid .role-box-select vui-checkbox .checkbox-item .checkbox,::ng-deep .roles-list-mid .role-box-select vui-checkbox .checkbox-item .checkmark{position:absolute!important;top:0;left:0}::ng-deep .roles-list-mid .role-box-select vui-checkbox .checkbox-item .value{margin:0!important}::ng-deep .roles-list-mid .role-box-heading{cursor:pointer}::ng-deep .roles-list-mid .role-box-heading .left{width:calc(100% - 6.5rem)}::ng-deep .roles-list-mid .role-box-heading .left vui-checkbox{height:1rem}::ng-deep .roles-list-mid .role-box-heading .left vui-checkbox .checkbox-item{position:relative;padding-left:1.75rem;height:1rem}::ng-deep .roles-list-mid .role-box-heading .left vui-checkbox .checkbox-item .checkbox,::ng-deep .roles-list-mid .role-box-heading .left vui-checkbox .checkbox-item .checkmark{position:absolute!important;top:0;left:0}::ng-deep .roles-list-mid .role-box-heading .left .name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;max-width:calc(100% - 9.25rem)}::ng-deep .roles-list-mid .role-box-heading .left .count{background:#f1f1f1;border-radius:.125rem;color:#042e7d}::ng-deep .roles-list-mid .role-box-heading .right{width:6.5rem}::ng-deep .roles-list-mid .role-box-heading .right .status-label{border-radius:.125rem;height:.75rem}::ng-deep .roles-list-mid .role-box-heading .right .status-label.all-user{background:#7aa6f7}::ng-deep .roles-list-mid .role-box-heading .right .status-label.power-user{background:#fadd8a}::ng-deep .roles-list-mid .role-box-heading .right button.arrow-btn{background:transparent;border:none;border-radius:0}::ng-deep .roles-list-mid .role-box-list ul{list-style-type:none}::ng-deep .roles-list-mid .role-box-list ul li{border-top:1px solid #f1f1f1;padding-left:2.5rem!important;position:relative}::ng-deep .roles-list-mid .role-box-list ul li:before{background:#dbdbdb;border-radius:.125rem;width:.25rem;height:.25rem;content:\"\";position:absolute;top:18px;left:18px}::ng-deep .roles-list-mid .role-box-list ul li .value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;text-transform:capitalize}::ng-deep .roles-list-mid .role-box-list ul li vui-checkbox .checkbox-item{width:100%}::ng-deep .roles-list-mid .role-box-list ul li vui-checkbox .checkbox-item span.value{width:100%}::ng-deep .roles-list-mid .role-box-list ul li vui-checkbox .checkbox-item span.value .name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .roles-list-confirmation{background:#161b2f;border-radius:.25rem;position:absolute;left:2rem;right:2rem;bottom:2rem;z-index:1}::ng-deep .roles-list-confirmation .confirmation-top{display:flex;align-items:center;justify-content:flex-start;padding:1.25rem}::ng-deep .roles-list-confirmation .confirmation-top .icon-block{height:2.25rem;width:2.25rem;border-radius:50%;background:#fff;border:1px solid #dbdbdb;display:flex;justify-content:center;align-items:center;margin-right:1rem}::ng-deep .roles-list-confirmation .confirmation-top .icon-block i{color:#eb2424;font-size:12px}::ng-deep .roles-list-confirmation .confirmation-top .text{color:#fff;font-size:14px;font-weight:300}::ng-deep .roles-list-confirmation .confirmation-bottom{background:#282e48;border-radius:0 0 .25rem .25rem;padding:.75rem .75rem .75rem 1.25rem;display:flex;align-items:center;justify-content:space-between}::ng-deep .roles-list-confirmation .confirmation-bottom .message{font-size:14px;font-weight:500;line-height:20px;color:#fff}::ng-deep .roles-list-confirmation .confirmation-bottom .button-group{display:flex}::ng-deep .roles-list-confirmation .confirmation-bottom .button-group button{height:1.5rem;width:4rem;border:1px solid #fff;border-radius:.125rem;display:flex;align-items:center;justify-content:center;line-height:22px;cursor:pointer;font-size:11px;text-transform:uppercase;font-weight:500;padding:0}::ng-deep .roles-list-confirmation .confirmation-bottom .button-group button.no-btn{background:transparent;color:#fff}::ng-deep .roles-list-confirmation .confirmation-bottom .button-group button.yes-btn{background:#fff;color:#1e5dd3;margin-left:.25rem}.counter.role-list-counter{background:#1e5dd3!important;border:1px solid #1E5DD3!important;margin-left:0!important}.name{margin-left:4px}.name b{text-transform:lowercase}.wf-action-list{width:220px}.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}.wf-action-list ul.action-item{display:block}.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}.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}.wf-action-list ul.action-item li button i{font-size:16px;margin-right:10px;color:#1e5dd3}.wf-action-list ul.action-item li button:hover{background:#f3f3f3}.wf-action-list ul.action-item li .avatar-card{display:flex;align-items:center;width:100%;padding:7.5px}.wf-action-list ul.action-item li .avatar-card.within-con{display:block}.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}.wf-action-list ul.action-item li .avatar-card .avatar img{width:100%}.wf-action-list ul.action-item li .avatar-card .avatar+span.value{width:calc(100% - 29px)}.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}.wf-action-list ul.action-item li .avatar-card span.value i{font-size:8px;color:#747576;cursor:pointer;margin-right:5px}.wf-action-list ul.action-item li .avatar-card.no-image{display:block}.wf-action-list ul.action-item li .avatar-card.no-image span.value{width:100%;display:block}.wf-action-list ul.action-item li .chip-item{color:#1e5dd3;padding:10px;display:flex;align-items:center}.wf-action-list ul.action-item li .chip-item i{color:#747576;margin-right:7px;font-size:10px;cursor:pointer;display:inline-flex}.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}.wf-action-list ul.action-item li .chip-item span.chip-block{display:block;width:100%}.wf-action-list ul.action-item li .chip-item span.id{font-size:9px}.wf-action-list ul.action-item li .within{display:flex;align-items:center;justify-content:flex-start}.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}.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}.wf-action-list ul.action-item li:first-child{animation:action-list-open .25s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(2){animation:action-list-open .35s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(3){animation:action-list-open .45s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(4){animation:action-list-open .55s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(5){animation:action-list-open .65s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(6){animation:action-list-open .75s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(7){animation:action-list-open .85s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(8){animation:action-list-open .95s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(9){animation:action-list-open 1.05s cubic-bezier(.25,.46,.45,.94) both}.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)}}\n"], dependencies: [{ kind: "directive", type: i1$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: ToolTipDirective, selector: "[appTooltip]", inputs: ["appTooltip", "placement", "type", "tooltipMandatory", "showTooltip", "animate"] }, { kind: "component", type: PopoverComponent, selector: "app-popover", inputs: ["dontCloseonClick"] }, { kind: "directive", type: PopoverDirective, selector: "[appPopover]", inputs: ["refrence", "placement"] }, { kind: "directive", type: i1$3.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$3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: NoDataComponentUI, selector: "app-no-data", inputs: ["action", "secondaryAction", "noDataImage", "noDataText", "noDataButton", "secondaryButton", "noDataSecButton", "altText", "smallButton"], outputs: ["buttonAction", "secondaryActionButton"] }, { kind: "component", type: CheckboxComponent$1, selector: "vui-checkbox", inputs: ["disabled", "checked", "indeterminateEnabled"] }, { kind: "component", type: VuiFloatingBarComponent, selector: "vui-floating-bar", inputs: ["selectedData", "groupSelected", "displayElementKey", "elementId", "singularText", "pluralText", "showNextButton", "showFrequencyText", "showWorkflow", "workflowText", "currentFrequency", "isDisabled", "workflowList", "selectedWorkflow", "workflowPlaceHolder", "mode", "nextDisabled", "nonRemovableUsersList", "removePosition"], outputs: ["closeEvent", "deleteEvent", "closeList", "workflowTypeChanged"] }, { kind: "component", type: LoaderComponent, selector: "role-loader" }, { kind: "pipe", type: SearchPipe, name: "search" }] }); }
|
|
43888
|
+
focus() {
|
|
43889
|
+
setTimeout(() => {
|
|
43890
|
+
this.fields['_results'][this.fields.length - 1].nativeElement.focus();
|
|
43891
|
+
this.fields['_results'][this.fields.length - 1].nativeElement.scrollIntoView({ behavior: 'smooth', block: 'center' });
|
|
43892
|
+
}, 100);
|
|
43893
|
+
}
|
|
43894
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CustomFieldComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
43895
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CustomFieldComponent, selector: "custom-field", inputs: { disabled: "disabled" }, providers: [CUSTOM_TAG_VALUE_ACCESSOR], viewQueries: [{ propertyName: "fields", predicate: ["custom_fields"], descendants: true, read: ElementRef }], ngImport: i0, template: "\n <ng-container *ngFor=\"let field of customFields; let i = index\">\n <!-- <div class=\"selected\" *ngIf=\"field?.name && !field?.isEditing \">\n <div (click)=\"manipulateCustomField('ACTIVATE')\" class=\"custom-text vx-fs-13 vx-paragraph-txt\">CUSTOM TAG TEXT HERE</div>\n <button *ngIf=\"customFields?.length > 1\" (click)=\"manipulateCustomField('DELETE',i)\" class=\"cross-btn vx-fs-12 vx-txt-red vx-p-0 vx-m-0 vx-ml-2 vx-d-flex vx-align-center vx-justify-center\"><i class=\"icons\"></i></button>\n </div> -->\n\n <div class=\"custom-input vx-mt-2\" >\n <input #custom_fields (keyup.enter)=\"manipulateCustomField('ADD')\" (keyup.backspace)=\"field?.name?.length ? null : manipulateCustomField('DELETE',i)\" [(ngModel)]=\"field.name\" (ngModelChange)=\"valChange()\" type=\"text\" placeholder=\"Add a field name\" [ngModelOptions]=\"{standalone: true}\">\n <button *ngIf=\"customFields?.length > 1\" (click)=\"manipulateCustomField('DELETE',i)\" class=\"cross-btn vx-fs-12 vx-txt-red vx-p-0 vx-m-0 vx-ml-2 vx-d-flex vx-align-center vx-justify-center\"><i class=\"icons\"></i></button>\n </div>\n </ng-container>\n\n <div class=\"vx-d-flex vx-align-center vx-justify-end vx-mt-2\">\n <button (click)=\"manipulateCustomField('ADD')\" class=\"add-more-btn vx-fs-11 vx-fw-600 vx-txt-blue vx-tt-uppercase vx-p-0 vx-m-0\">+ ADD MORE\n FIELDS</button>\n </div>\n", styles: [""], dependencies: [{ kind: "directive", type: i1$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1$3.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$3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); }
|
|
43990
43896
|
}
|
|
43991
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type:
|
|
43897
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CustomFieldComponent, decorators: [{
|
|
43992
43898
|
type: Component,
|
|
43993
|
-
args: [{ selector: 'role-list', template: "<div class=\"roles-list\" [class.animate]=\"animation\">\n <div\n class=\"roles-list-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\"\n >\n <div id=\"titlename\" class=\"vx-fs-14 vx-fw-500 vx-label-txt\">\n {{ ff_rc_listing ? \"Select Permissions\" : \"Select Permission Group(s)\" }}\n </div>\n </div>\n\n <div class=\"roles-list-body\">\n <div class=\"search-block vx-mb-1\" [class.disabled]=\"!rolesList?.length\">\n <i class=\"icons\"></i>\n <input\n type=\"text\"\n [placeholder]=\"\n ff_rc_listing ? 'Search Permissions' : 'Search Permission Groups'\n \"\n [(ngModel)]=\"searchKey\"\n />\n </div>\n <div class=\"vx-mt-4\" *ngIf=\"loading\"><role-loader></role-loader></div>\n\n <ng-container *ngIf=\"!loading\">\n <ng-container\n *ngIf=\"rolesList | search : searchKey : 'roleName' as roles\"\n >\n <div *ngIf=\"roles?.length > 0\" class=\"roles-list-mid vx-mb-4\">\n <div class=\"role-box-select vx-pb-2\">\n <vui-checkbox\n [indeterminateEnabled]=\"false\"\n #check\n (change)=\"selectAll($event)\"\n [(ngModel)]=\"allSelected\"\n [checked]=\"allSelected\"\n >\n <div class=\"user-name vx-fs-12 vx-fw-600 vx-label-txt\">\n {{ !check.checked ? \"Select All\" : \"Deselect All\" }}\n </div>\n </vui-checkbox>\n </div>\n\n <div\n class=\"role-box vx-mb-2\"\n *ngFor=\"let role of roles; let i = index\"\n >\n <div\n (click)=\"\n !expandedRows.includes(role?._id)\n ? expandOrCollapse('EXPAND', role?._id)\n : expandOrCollapse('COLLAPSE', role?._id)\n \"\n class=\"role-box-heading vx-d-flex vx-align-center vx-justify-between vx-p-3\"\n >\n <div class=\"left vx-d-flex vx-align-center vx-lh-4\">\n <vui-checkbox\n [disabled]=\"systemRolesIds.includes(role?._id)\"\n [checked]=\"selectedIds.includes(role?._id)\"\n (change)=\"selectItem($event, role)\"\n >\n </vui-checkbox>\n <div\n class=\"name vx-fs-12 vx-label-txt\"\n [appTooltip]=\"'Role name'\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >\n {{\n featureflagrole && role?.permissionGroupName\n ? role?.permissionGroupName\n : role?.roleName\n }}\n </div>\n <span\n *ngIf=\"role?.roleActions?.length > 0\"\n class=\"count vx-fs-9 vx-fw-600 vx-lh-3 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-ml-2\"\n >{{ role?.roleActions?.length }} PERMISSIONS</span\n >\n </div>\n <div class=\"right vx-d-flex vx-align-center vx-justify-between\">\n <div\n *ngIf=\"role?.licenseType === 'power users'\"\n class=\"status-label vx-fs-9 vx-fw-500 vx-txt-white vx-tt-uppercase vx-pl-1 vx-pr-1\"\n [class.power-user]=\"true\"\n [class.all-user]=\"false\"\n >\n Power User\n </div>\n <div\n *ngIf=\"role?.licenseType === 'light users'\"\n class=\"status-label vx-fs-9 vx-fw-500 vx-txt-white vx-tt-uppercase vx-pl-1 vx-pr-1\"\n [class.power-user]=\"false\"\n [class.all-user]=\"true\"\n >\n Light User\n </div>\n <button\n class=\"arrow-btn vx-fs-12 vx-paragraph-txt vx-m-0 vx-p-0 vx-d-flex vx-align-center\"\n >\n <i *ngIf=\"!expandedRows.includes(role?._id)\" class=\"icons\"\n ></i\n >\n <i *ngIf=\"expandedRows.includes(role?._id)\" class=\"icons\"\n ></i\n >\n </button>\n </div>\n </div>\n <div class=\"role-box-list\" *ngIf=\"expandedRows.includes(role?._id)\">\n <ul class=\"vx-p-0 vx-m-0\">\n <li\n class=\"vx-p-3 vx-lh-4\"\n *ngFor=\"let permission of role?.roleActions\"\n >\n <div class=\"value vx-fs-12 vx-label-txt\">\n {{ permissionText(permission) }}\n </div>\n </li>\n <!-- <li class=\"vx-p-3 vx-lh-4\">\n <div class=\"value vx-fs-12 vx-label-txt\">View User List</div>\n </li>\n <li class=\"vx-p-3 vx-lh-4\">\n <div class=\"value vx-fs-12 vx-label-txt\">Manage Users <span class=\"vx-fs-10 vx-paragraph-txt\">(Create/Edit/Delete/Deactivate)</span></div>\n </li>\n <li class=\"vx-p-3 vx-lh-4\">\n <div class=\"value vx-fs-12 vx-label-txt\">Over-ride Log In</div>\n </li>\n <li class=\"vx-p-3 vx-lh-4\">\n <div class=\"value vx-fs-12 vx-label-txt\">View Statutory Holidays</div>\n </li>\n <li class=\"vx-p-3 vx-lh-4\">\n <div class=\"value vx-fs-12 vx-label-txt\">Manage Statutory Holidays</div>\n </li> -->\n </ul>\n </div>\n </div>\n </div>\n\n <app-no-data\n *ngIf=\"roles?.length === 0\"\n [noDataImage]=\"ASSETS.search_data\"\n [noDataText]=\"\n searchKey?.length > 0 ? 'No match found.' : 'No Roles Found'\n \"\n ></app-no-data>\n </ng-container>\n </ng-container>\n\n <div class=\"roles-list-footer\" *ngIf=\"!showConfirmation\">\n <vui-floating-bar (closeEvent)=\"saveList()\" (closeList)=\"closeList()\">\n <!-- <div class=\"counter\" *ngIf=\"selectedRoles?.length\"\n placement=\"left\">{{selectedRoles?.length}}</div> -->\n <button\n *ngIf=\"selectedRoles?.length\"\n class=\"counter role-list-counter\"\n appPopover\n (click)=\"role.popover()\"\n placement=\"left\"\n >\n {{ selectedRoles?.length }}\n </button>\n <div\n class=\"name\"\n *ngIf=\"selectedRoles?.length > 1\"\n id=\"permissionselected\"\n >\n <span *ngIf=\"selectedRoles?.length === 1\">{{\n featureflagrole ? \"Permission selected\" : \"Role selected\"\n }}</span>\n <span *ngIf=\"selectedRoles?.length > 1\">{{\n featureflagrole ? \"Permissions selected\" : \"Roles selected\"\n }}</span>\n </div>\n </vui-floating-bar>\n\n <app-popover #role [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"let data of selectedRoles\">\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"!systemRolesIds.includes(data?._id)\"\n class=\"icons\"\n (click)=\"selectItem({ target: { checked: false } }, data)\"\n ></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 </div>\n </div>\n\n <div class=\"roles-list-confirmation\" *ngIf=\"showConfirmation\">\n <div class=\"confirmation-top\">\n <div class=\"icon-block\"><i class=\"icons\"></i></div>\n <div class=\"text\" id=\"confirmationmessage\">\n {{\n featureflagrole\n ? \"This action will update the Permission settings and impact the owners selected for the Program.\"\n : \"This action will update the Role settings and impact the owners selected for the Program.\"\n }}\n </div>\n </div>\n <div class=\"confirmation-bottom\">\n <div class=\"message\">Are you sure you would like to proceed?</div>\n <div class=\"button-group\">\n <button class=\"no-btn\" (click)=\"confirmAction('NO')\">NO</button>\n <button class=\"yes-btn\" (click)=\"confirmAction('YES')\">YES</button>\n </div>\n </div>\n </div>\n</div>\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/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";::ng-deep .roles-list{position:fixed;inset:0 500px 0 0}::ng-deep .roles-list:before{background:#1e5dd3;content:\"\";position:absolute;top:0;left:0;right:0;width:100%;height:3px}::ng-deep .roles-list.animate{animation:animate-right .2s cubic-bezier(.25,.46,.45,.94) both;z-index:-1}::ng-deep .roles-list-head{background:#fbfbfb;height:2.75rem;border-bottom:1px solid #f1f1f1}::ng-deep .roles-list-body{background:#fff;height:calc(100vh - 2.75rem);padding:2rem}::ng-deep .roles-list-body .search-block{position:relative}::ng-deep .roles-list-body .search-block input{height:2.75rem;line-height:1.5rem;padding:.5rem 1rem .5rem 2.5rem;outline:none;border:1px solid #7475763f;border-radius:.25rem;width:100%;font-size:14px;color:#747576}::ng-deep .roles-list-body .search-block input:focus{border-color:#1e5dd3}::ng-deep .roles-list-body .search-block i{position:absolute;left:1rem;top:1rem;pointer-events:none;color:#f1f1f1;font-size:12px}::ng-deep .roles-list-mid{width:calc(100% + .75rem);height:calc(100vh - 13.8rem);overflow:hidden;overflow-y:auto;padding-right:.75rem}::ng-deep .roles-list-mid .role-box{border:1px solid #f1f1f1;border-radius:.25rem}::ng-deep .roles-list-mid .role-box-select{background:#fff;position:sticky;top:0;z-index:1}::ng-deep .roles-list-mid .role-box-select vui-checkbox .checkbox-item{position:relative;padding-left:1.75rem;width:100%}::ng-deep .roles-list-mid .role-box-select vui-checkbox .checkbox-item .checkbox,::ng-deep .roles-list-mid .role-box-select vui-checkbox .checkbox-item .checkmark{position:absolute!important;top:0;left:0}::ng-deep .roles-list-mid .role-box-select vui-checkbox .checkbox-item .value{margin:0!important}::ng-deep .roles-list-mid .role-box-heading{cursor:pointer}::ng-deep .roles-list-mid .role-box-heading .left{width:calc(100% - 6.5rem)}::ng-deep .roles-list-mid .role-box-heading .left vui-checkbox{height:1rem}::ng-deep .roles-list-mid .role-box-heading .left vui-checkbox .checkbox-item{position:relative;padding-left:1.75rem;height:1rem}::ng-deep .roles-list-mid .role-box-heading .left vui-checkbox .checkbox-item .checkbox,::ng-deep .roles-list-mid .role-box-heading .left vui-checkbox .checkbox-item .checkmark{position:absolute!important;top:0;left:0}::ng-deep .roles-list-mid .role-box-heading .left .name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;max-width:calc(100% - 9.25rem)}::ng-deep .roles-list-mid .role-box-heading .left .count{background:#f1f1f1;border-radius:.125rem;color:#042e7d}::ng-deep .roles-list-mid .role-box-heading .right{width:6.5rem}::ng-deep .roles-list-mid .role-box-heading .right .status-label{border-radius:.125rem;height:.75rem}::ng-deep .roles-list-mid .role-box-heading .right .status-label.all-user{background:#7aa6f7}::ng-deep .roles-list-mid .role-box-heading .right .status-label.power-user{background:#fadd8a}::ng-deep .roles-list-mid .role-box-heading .right button.arrow-btn{background:transparent;border:none;border-radius:0}::ng-deep .roles-list-mid .role-box-list ul{list-style-type:none}::ng-deep .roles-list-mid .role-box-list ul li{border-top:1px solid #f1f1f1;padding-left:2.5rem!important;position:relative}::ng-deep .roles-list-mid .role-box-list ul li:before{background:#dbdbdb;border-radius:.125rem;width:.25rem;height:.25rem;content:\"\";position:absolute;top:18px;left:18px}::ng-deep .roles-list-mid .role-box-list ul li .value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;text-transform:capitalize}::ng-deep .roles-list-mid .role-box-list ul li vui-checkbox .checkbox-item{width:100%}::ng-deep .roles-list-mid .role-box-list ul li vui-checkbox .checkbox-item span.value{width:100%}::ng-deep .roles-list-mid .role-box-list ul li vui-checkbox .checkbox-item span.value .name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .roles-list-confirmation{background:#161b2f;border-radius:.25rem;position:absolute;left:2rem;right:2rem;bottom:2rem;z-index:1}::ng-deep .roles-list-confirmation .confirmation-top{display:flex;align-items:center;justify-content:flex-start;padding:1.25rem}::ng-deep .roles-list-confirmation .confirmation-top .icon-block{height:2.25rem;width:2.25rem;border-radius:50%;background:#fff;border:1px solid #dbdbdb;display:flex;justify-content:center;align-items:center;margin-right:1rem}::ng-deep .roles-list-confirmation .confirmation-top .icon-block i{color:#eb2424;font-size:12px}::ng-deep .roles-list-confirmation .confirmation-top .text{color:#fff;font-size:14px;font-weight:300}::ng-deep .roles-list-confirmation .confirmation-bottom{background:#282e48;border-radius:0 0 .25rem .25rem;padding:.75rem .75rem .75rem 1.25rem;display:flex;align-items:center;justify-content:space-between}::ng-deep .roles-list-confirmation .confirmation-bottom .message{font-size:14px;font-weight:500;line-height:20px;color:#fff}::ng-deep .roles-list-confirmation .confirmation-bottom .button-group{display:flex}::ng-deep .roles-list-confirmation .confirmation-bottom .button-group button{height:1.5rem;width:4rem;border:1px solid #fff;border-radius:.125rem;display:flex;align-items:center;justify-content:center;line-height:22px;cursor:pointer;font-size:11px;text-transform:uppercase;font-weight:500;padding:0}::ng-deep .roles-list-confirmation .confirmation-bottom .button-group button.no-btn{background:transparent;color:#fff}::ng-deep .roles-list-confirmation .confirmation-bottom .button-group button.yes-btn{background:#fff;color:#1e5dd3;margin-left:.25rem}.counter.role-list-counter{background:#1e5dd3!important;border:1px solid #1E5DD3!important;margin-left:0!important}.name{margin-left:4px}.name b{text-transform:lowercase}.wf-action-list{width:220px}.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}.wf-action-list ul.action-item{display:block}.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}.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}.wf-action-list ul.action-item li button i{font-size:16px;margin-right:10px;color:#1e5dd3}.wf-action-list ul.action-item li button:hover{background:#f3f3f3}.wf-action-list ul.action-item li .avatar-card{display:flex;align-items:center;width:100%;padding:7.5px}.wf-action-list ul.action-item li .avatar-card.within-con{display:block}.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}.wf-action-list ul.action-item li .avatar-card .avatar img{width:100%}.wf-action-list ul.action-item li .avatar-card .avatar+span.value{width:calc(100% - 29px)}.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}.wf-action-list ul.action-item li .avatar-card span.value i{font-size:8px;color:#747576;cursor:pointer;margin-right:5px}.wf-action-list ul.action-item li .avatar-card.no-image{display:block}.wf-action-list ul.action-item li .avatar-card.no-image span.value{width:100%;display:block}.wf-action-list ul.action-item li .chip-item{color:#1e5dd3;padding:10px;display:flex;align-items:center}.wf-action-list ul.action-item li .chip-item i{color:#747576;margin-right:7px;font-size:10px;cursor:pointer;display:inline-flex}.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}.wf-action-list ul.action-item li .chip-item span.chip-block{display:block;width:100%}.wf-action-list ul.action-item li .chip-item span.id{font-size:9px}.wf-action-list ul.action-item li .within{display:flex;align-items:center;justify-content:flex-start}.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}.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}.wf-action-list ul.action-item li:first-child{animation:action-list-open .25s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(2){animation:action-list-open .35s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(3){animation:action-list-open .45s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(4){animation:action-list-open .55s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(5){animation:action-list-open .65s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(6){animation:action-list-open .75s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(7){animation:action-list-open .85s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(8){animation:action-list-open .95s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(9){animation:action-list-open 1.05s cubic-bezier(.25,.46,.45,.94) both}.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)}}\n"] }]
|
|
43994
|
-
}], ctorParameters: function () { return []; }, propDecorators: {
|
|
43995
|
-
type:
|
|
43996
|
-
|
|
43997
|
-
|
|
43998
|
-
}], featureflagrole: [{
|
|
43999
|
-
type: Input
|
|
44000
|
-
}], featureflagGroup: [{
|
|
44001
|
-
type: Input
|
|
44002
|
-
}], ff_rc_listing: [{
|
|
44003
|
-
type: Input
|
|
44004
|
-
}], setList: [{
|
|
44005
|
-
type: Input,
|
|
44006
|
-
args: ['list']
|
|
44007
|
-
}], loading: [{
|
|
43899
|
+
args: [{ selector: 'custom-field', providers: [CUSTOM_TAG_VALUE_ACCESSOR], template: "\n <ng-container *ngFor=\"let field of customFields; let i = index\">\n <!-- <div class=\"selected\" *ngIf=\"field?.name && !field?.isEditing \">\n <div (click)=\"manipulateCustomField('ACTIVATE')\" class=\"custom-text vx-fs-13 vx-paragraph-txt\">CUSTOM TAG TEXT HERE</div>\n <button *ngIf=\"customFields?.length > 1\" (click)=\"manipulateCustomField('DELETE',i)\" class=\"cross-btn vx-fs-12 vx-txt-red vx-p-0 vx-m-0 vx-ml-2 vx-d-flex vx-align-center vx-justify-center\"><i class=\"icons\"></i></button>\n </div> -->\n\n <div class=\"custom-input vx-mt-2\" >\n <input #custom_fields (keyup.enter)=\"manipulateCustomField('ADD')\" (keyup.backspace)=\"field?.name?.length ? null : manipulateCustomField('DELETE',i)\" [(ngModel)]=\"field.name\" (ngModelChange)=\"valChange()\" type=\"text\" placeholder=\"Add a field name\" [ngModelOptions]=\"{standalone: true}\">\n <button *ngIf=\"customFields?.length > 1\" (click)=\"manipulateCustomField('DELETE',i)\" class=\"cross-btn vx-fs-12 vx-txt-red vx-p-0 vx-m-0 vx-ml-2 vx-d-flex vx-align-center vx-justify-center\"><i class=\"icons\"></i></button>\n </div>\n </ng-container>\n\n <div class=\"vx-d-flex vx-align-center vx-justify-end vx-mt-2\">\n <button (click)=\"manipulateCustomField('ADD')\" class=\"add-more-btn vx-fs-11 vx-fw-600 vx-txt-blue vx-tt-uppercase vx-p-0 vx-m-0\">+ ADD MORE\n FIELDS</button>\n </div>\n" }]
|
|
43900
|
+
}], ctorParameters: function () { return []; }, propDecorators: { fields: [{
|
|
43901
|
+
type: ViewChildren,
|
|
43902
|
+
args: ['custom_fields', { read: ElementRef }]
|
|
43903
|
+
}], disabled: [{
|
|
44008
43904
|
type: Input
|
|
44009
|
-
}], selectedRolesVal: [{
|
|
44010
|
-
type: Input,
|
|
44011
|
-
args: ['selected']
|
|
44012
43905
|
}] } });
|
|
44013
43906
|
|
|
44014
|
-
class
|
|
44015
|
-
|
|
44016
|
-
|
|
44017
|
-
this.authService = authService;
|
|
44018
|
-
if (config) {
|
|
44019
|
-
this.env = config.envConfig;
|
|
44020
|
-
}
|
|
44021
|
-
}
|
|
44022
|
-
getAssessmentQuestions(id) {
|
|
44023
|
-
const headers = new HttpHeaders().set('token', this.authService.getAuthorizationToken());
|
|
44024
|
-
return this.http.get(this.env.assessmentEnpoint + 'assessment/fetchQuestionsByAssessmentId&id=' + id, { headers }).pipe(retry(2));
|
|
44025
|
-
}
|
|
44026
|
-
getAssessmentCategory(payload) {
|
|
44027
|
-
const headers = new HttpHeaders().set('token', this.authService.getAuthorizationToken());
|
|
44028
|
-
return this.http.post(this.env.assessmentEnpoint + 'category/list&isCreateResponsibility=true&bypass-businessCycle=true', payload, { headers }).pipe(retry(2));
|
|
44029
|
-
}
|
|
44030
|
-
getAssessmentList(payload, id) {
|
|
44031
|
-
const headers = new HttpHeaders().set('token', this.authService.getAuthorizationToken());
|
|
44032
|
-
return this.http.post(this.env.assessmentEnpoint + 'assessment/selectAssessment&isCreateResponsibility=true&catid=' + id, payload, { headers }).pipe(retry(2));
|
|
44033
|
-
}
|
|
44034
|
-
getAssessmentDetailsByID(id) {
|
|
44035
|
-
const headers = new HttpHeaders().set('token', this.authService.getAuthorizationToken());
|
|
44036
|
-
return this.http.post(this.env.assessmentEnpoint + 'assessment/getAssessmentById&id=' + id, {}, { headers }).pipe(retry(2));
|
|
43907
|
+
class ListToIdPipe {
|
|
43908
|
+
transform(value, arg) {
|
|
43909
|
+
return value.map((ele) => ele[arg]);
|
|
44037
43910
|
}
|
|
44038
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type:
|
|
44039
|
-
static { this.ɵ
|
|
43911
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ListToIdPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
43912
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: ListToIdPipe, name: "listToId" }); }
|
|
44040
43913
|
}
|
|
44041
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type:
|
|
44042
|
-
type:
|
|
43914
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ListToIdPipe, decorators: [{
|
|
43915
|
+
type: Pipe,
|
|
44043
43916
|
args: [{
|
|
44044
|
-
|
|
43917
|
+
name: 'listToId'
|
|
44045
43918
|
}]
|
|
44046
|
-
}]
|
|
44047
|
-
type: Optional
|
|
44048
|
-
}] }]; } });
|
|
44049
|
-
|
|
44050
|
-
class AssessmentLoaderComponent {
|
|
44051
|
-
constructor() { }
|
|
44052
|
-
ngOnInit() {
|
|
44053
|
-
}
|
|
44054
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AssessmentLoaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
44055
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AssessmentLoaderComponent, selector: "assessment-loader", ngImport: i0, template: "<div class=\"assessment-list-item\" *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\n <div class=\"table-row\">\n <div class=\"table-column serial\">\n <div class=\"sr-no\"></div>\n </div>\n <div class=\"table-column name\">\n <div class=\"loader\"></div>\n </div>\n <div class=\"table-column action\">\n <div class=\"loader\"></div>\n </div>\n </div>\n</div>", styles: [".assessment-list-item{border:1px solid #f1f1f1;border-radius:2px;margin-bottom:4px}.assessment-list-item .table-row{display:flex;align-items:center;justify-content:space-between}.assessment-list-item .table-row .table-column{height:48px;position:relative;width:100%;display:flex;align-items:center;padding:0 4px}.assessment-list-item .table-row .table-column.serial{width:32px;max-width:32px;justify-content:center}.assessment-list-item .table-row .table-column.serial .sr-no{width:16px;background:#f8f8f8;writing-mode:vertical-lr;height:100%}.assessment-list-item .table-row .table-column.name{width:calc(100% - 64px);min-width:calc(100% - 64px)}.assessment-list-item .table-row .table-column.name .loader{width:calc(100% - 200px)}.assessment-list-item .table-row .table-column.action{width:32px;max-width:32px;justify-content:center}.assessment-list-item .table-row .table-column.action .loader{width:28px}.loader{background:#f1f1f1;border-radius:20px;height:10px}\n"], dependencies: [{ kind: "directive", type: i1$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] }); }
|
|
44056
|
-
}
|
|
44057
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AssessmentLoaderComponent, decorators: [{
|
|
44058
|
-
type: Component,
|
|
44059
|
-
args: [{ selector: 'assessment-loader', template: "<div class=\"assessment-list-item\" *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\n <div class=\"table-row\">\n <div class=\"table-column serial\">\n <div class=\"sr-no\"></div>\n </div>\n <div class=\"table-column name\">\n <div class=\"loader\"></div>\n </div>\n <div class=\"table-column action\">\n <div class=\"loader\"></div>\n </div>\n </div>\n</div>", styles: [".assessment-list-item{border:1px solid #f1f1f1;border-radius:2px;margin-bottom:4px}.assessment-list-item .table-row{display:flex;align-items:center;justify-content:space-between}.assessment-list-item .table-row .table-column{height:48px;position:relative;width:100%;display:flex;align-items:center;padding:0 4px}.assessment-list-item .table-row .table-column.serial{width:32px;max-width:32px;justify-content:center}.assessment-list-item .table-row .table-column.serial .sr-no{width:16px;background:#f8f8f8;writing-mode:vertical-lr;height:100%}.assessment-list-item .table-row .table-column.name{width:calc(100% - 64px);min-width:calc(100% - 64px)}.assessment-list-item .table-row .table-column.name .loader{width:calc(100% - 200px)}.assessment-list-item .table-row .table-column.action{width:32px;max-width:32px;justify-content:center}.assessment-list-item .table-row .table-column.action .loader{width:28px}.loader{background:#f1f1f1;border-radius:20px;height:10px}\n"] }]
|
|
44060
|
-
}], ctorParameters: function () { return []; } });
|
|
44061
|
-
|
|
44062
|
-
class AssessmentSubLoaderComponent {
|
|
44063
|
-
constructor() { }
|
|
44064
|
-
ngOnInit() {
|
|
44065
|
-
}
|
|
44066
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AssessmentSubLoaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
44067
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AssessmentSubLoaderComponent, selector: "assessment-sub-loader", ngImport: i0, template: "<div class=\"assessment-list-item\" *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\n <div class=\"sub-list\">\n <div class=\"table-row\">\n <div class=\"table-column serial\">\n <div class=\"sr-no\"></div>\n </div>\n <div class=\"table-column sub-name\">\n <div class=\"loader\"></div>\n </div>\n <div class=\"table-column question\">\n <div class=\"loader\"></div>\n </div>\n </div>\n </div>\n</div>", styles: [".assessment-list-item{border:none!important;border-top:1px solid #f1f1f1;border-radius:2px;margin-bottom:0!important}.assessment-list-item .table-row{display:flex;align-items:center;justify-content:space-between}.assessment-list-item .table-row .table-column{height:32px;position:relative;width:100%;display:flex;align-items:center;padding:0 4px}.assessment-list-item .table-row .table-column.serial{width:32px;max-width:32px;justify-content:center}.assessment-list-item .table-row .table-column.serial .sr-no{width:16px;background:#f8f8f8;writing-mode:vertical-lr;height:100%}.assessment-list-item .table-row .table-column.sub-name{width:calc(100% - 232px);min-width:calc(100% - 232px)}.assessment-list-item .table-row .table-column.sub-name .loader{width:calc(100% - 200px)}.assessment-list-item .table-row .table-column.question{width:200px;max-width:200px;justify-content:flex-end}.assessment-list-item .table-row .table-column.question .loader{width:72px}.loader{background:#f1f1f1;border-radius:20px;height:10px}\n"], dependencies: [{ kind: "directive", type: i1$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] }); }
|
|
44068
|
-
}
|
|
44069
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AssessmentSubLoaderComponent, decorators: [{
|
|
44070
|
-
type: Component,
|
|
44071
|
-
args: [{ selector: 'assessment-sub-loader', template: "<div class=\"assessment-list-item\" *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\n <div class=\"sub-list\">\n <div class=\"table-row\">\n <div class=\"table-column serial\">\n <div class=\"sr-no\"></div>\n </div>\n <div class=\"table-column sub-name\">\n <div class=\"loader\"></div>\n </div>\n <div class=\"table-column question\">\n <div class=\"loader\"></div>\n </div>\n </div>\n </div>\n</div>", styles: [".assessment-list-item{border:none!important;border-top:1px solid #f1f1f1;border-radius:2px;margin-bottom:0!important}.assessment-list-item .table-row{display:flex;align-items:center;justify-content:space-between}.assessment-list-item .table-row .table-column{height:32px;position:relative;width:100%;display:flex;align-items:center;padding:0 4px}.assessment-list-item .table-row .table-column.serial{width:32px;max-width:32px;justify-content:center}.assessment-list-item .table-row .table-column.serial .sr-no{width:16px;background:#f8f8f8;writing-mode:vertical-lr;height:100%}.assessment-list-item .table-row .table-column.sub-name{width:calc(100% - 232px);min-width:calc(100% - 232px)}.assessment-list-item .table-row .table-column.sub-name .loader{width:calc(100% - 200px)}.assessment-list-item .table-row .table-column.question{width:200px;max-width:200px;justify-content:flex-end}.assessment-list-item .table-row .table-column.question .loader{width:72px}.loader{background:#f1f1f1;border-radius:20px;height:10px}\n"] }]
|
|
44072
|
-
}], ctorParameters: function () { return []; } });
|
|
43919
|
+
}] });
|
|
44073
43920
|
|
|
44074
|
-
class
|
|
44075
|
-
|
|
44076
|
-
|
|
44077
|
-
|
|
44078
|
-
|
|
44079
|
-
|
|
44080
|
-
|
|
44081
|
-
|
|
44082
|
-
|
|
44083
|
-
|
|
44084
|
-
ngOnInit() { }
|
|
44085
|
-
alphabetChange(alphabet) {
|
|
44086
|
-
this.activeAlphabet = alphabet;
|
|
44087
|
-
this.selectedAlphabet.emit(alphabet);
|
|
44088
|
-
this.goToPageArrayGenerate(1, false);
|
|
44089
|
-
}
|
|
44090
|
-
ngOnChanges(event) {
|
|
44091
|
-
this.pageArray = [];
|
|
44092
|
-
if (this.pageCount > 0) {
|
|
44093
|
-
if (this.pageCount < 5) {
|
|
44094
|
-
for (let i = 1; i <= this.pageCount; i++) {
|
|
44095
|
-
this.pageArray.push(i);
|
|
44096
|
-
}
|
|
44097
|
-
return;
|
|
44098
|
-
}
|
|
44099
|
-
this.goToPageArrayGenerate(this.currentPage, false);
|
|
44100
|
-
}
|
|
44101
|
-
}
|
|
44102
|
-
increaseOrDecrease(value) {
|
|
44103
|
-
this.currentPage += value;
|
|
44104
|
-
if (this.currentPage > 3 && this.currentPage <= this.pageCount && this.pageArray[this.pageArray.length - 1] < this.pageCount) {
|
|
44105
|
-
if (value > 0) {
|
|
44106
|
-
this.pageArray.shift();
|
|
44107
|
-
this.pageArray.push(this.pageArray[this.pageArray.length - 1] + 1);
|
|
44108
|
-
}
|
|
44109
|
-
}
|
|
44110
|
-
if (this.currentPage > 2 && value < 0 && this.pageArray[0] > 1 && this.currentPage < this.pageCount - 2) {
|
|
44111
|
-
this.pageArray.pop();
|
|
44112
|
-
this.pageArray.unshift(this.pageArray[0] - 1);
|
|
44113
|
-
}
|
|
44114
|
-
this.selectedPage.emit(this.currentPage);
|
|
44115
|
-
}
|
|
44116
|
-
onEnterPress(event) {
|
|
44117
|
-
if (event.key.toLowerCase() === 'enter') {
|
|
44118
|
-
if (!this.enterPageNumber || this.enterPageNumber > this.pageCount || this.enterPageNumber < 1) {
|
|
44119
|
-
this.isInvalidInput = true;
|
|
44120
|
-
return;
|
|
44121
|
-
}
|
|
44122
|
-
else {
|
|
44123
|
-
this.isInvalidInput = false;
|
|
44124
|
-
this.goToPageArrayGenerate(this.enterPageNumber, true);
|
|
44125
|
-
}
|
|
44126
|
-
}
|
|
44127
|
-
}
|
|
44128
|
-
goToPageArrayGenerate(page, shouldEmit) {
|
|
44129
|
-
this.isInvalidInput = false;
|
|
44130
|
-
this.currentPage = page;
|
|
44131
|
-
this.pageArray = [];
|
|
44132
|
-
if (this.currentPage > 3 && this.currentPage < this.pageCount - 2) {
|
|
44133
|
-
for (let i = this.currentPage - 2; i < this.currentPage + 3; i++) {
|
|
44134
|
-
this.pageArray.push(i);
|
|
44135
|
-
}
|
|
44136
|
-
}
|
|
44137
|
-
else if (this.currentPage <= 3) {
|
|
44138
|
-
if (this.pageCount > 4) {
|
|
44139
|
-
this.pageArray = [1, 2, 3, 4, 5];
|
|
44140
|
-
}
|
|
44141
|
-
else {
|
|
44142
|
-
for (let i = 1; i <= this.pageCount; i++) {
|
|
44143
|
-
this.pageArray.push(i);
|
|
44144
|
-
}
|
|
44145
|
-
}
|
|
44146
|
-
}
|
|
44147
|
-
else if (this.currentPage > this.pageCount - 3) {
|
|
44148
|
-
for (let i = this.pageCount - 4; i < this.pageCount + 1; i++) {
|
|
44149
|
-
this.pageArray.push(i);
|
|
44150
|
-
}
|
|
43921
|
+
class AssessmentResolverPipe {
|
|
43922
|
+
transform(value, ...args) {
|
|
43923
|
+
if (value && value?.length) {
|
|
43924
|
+
value = value.filter((ele) => ele?.assessmentIds?.length);
|
|
43925
|
+
const val = Object.assign(JSON.parse(JSON.stringify(value
|
|
43926
|
+
.map((category) => category.assessmentIds.map((assessment) => {
|
|
43927
|
+
return { ...assessment, category_id: category.category_id };
|
|
43928
|
+
}))
|
|
43929
|
+
?.flat())));
|
|
43930
|
+
return val;
|
|
44151
43931
|
}
|
|
44152
43932
|
else {
|
|
44153
|
-
|
|
44154
|
-
this.pageArray.push(i);
|
|
44155
|
-
}
|
|
44156
|
-
}
|
|
44157
|
-
if (shouldEmit) {
|
|
44158
|
-
this.selectedPage.emit(this.currentPage);
|
|
43933
|
+
return [];
|
|
44159
43934
|
}
|
|
44160
43935
|
}
|
|
44161
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type:
|
|
44162
|
-
static { this.ɵ
|
|
43936
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AssessmentResolverPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
43937
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: AssessmentResolverPipe, name: "assessmentResolver" }); }
|
|
44163
43938
|
}
|
|
44164
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type:
|
|
44165
|
-
type:
|
|
44166
|
-
args: [{
|
|
44167
|
-
|
|
44168
|
-
|
|
44169
|
-
|
|
44170
|
-
type: Input
|
|
44171
|
-
}], start: [{
|
|
44172
|
-
type: Input
|
|
44173
|
-
}], end: [{
|
|
44174
|
-
type: Input
|
|
44175
|
-
}], total: [{
|
|
44176
|
-
type: Input
|
|
44177
|
-
}], noFilter: [{
|
|
44178
|
-
type: Input
|
|
44179
|
-
}], currentPage: [{
|
|
44180
|
-
type: Input
|
|
44181
|
-
}], selectedPage: [{
|
|
44182
|
-
type: Output
|
|
44183
|
-
}], selectedAlphabet: [{
|
|
44184
|
-
type: Output
|
|
44185
|
-
}] } });
|
|
44186
|
-
|
|
44187
|
-
class AssessmentPickerComponent {
|
|
44188
|
-
set setSelected(value) {
|
|
44189
|
-
if (value && value?.length) {
|
|
44190
|
-
this.selectedAssessmentArr = [...value];
|
|
44191
|
-
//this.setCategoryAndAssessment();
|
|
44192
|
-
this.selectedAssessmentArr.forEach((ele, index) => {
|
|
44193
|
-
this.openedCategory.push(ele?.category_id);
|
|
44194
|
-
// this.showSubList(index,ele?.category_id);
|
|
44195
|
-
});
|
|
44196
|
-
}
|
|
44197
|
-
}
|
|
44198
|
-
constructor(assessmentService, auth) {
|
|
44199
|
-
this.assessmentService = assessmentService;
|
|
44200
|
-
this.auth = auth;
|
|
44201
|
-
this.ASSETS = ASSETS;
|
|
44202
|
-
this.animation = false;
|
|
44203
|
-
this.subList = false;
|
|
44204
|
-
this.isEdit = false;
|
|
44205
|
-
this.openedCategory = [];
|
|
44206
|
-
this.assessmentPayload = {
|
|
44207
|
-
search_title: '',
|
|
44208
|
-
page_no: '1',
|
|
44209
|
-
state: 'ACTIVE',
|
|
44210
|
-
search_text: '',
|
|
44211
|
-
alphabet_filter: '',
|
|
44212
|
-
};
|
|
44213
|
-
this.dataPerPage = 0;
|
|
44214
|
-
this.assessmentCategory = {
|
|
44215
|
-
data: [],
|
|
44216
|
-
totalPage: 0,
|
|
44217
|
-
totalRecords: 0,
|
|
44218
|
-
start_value: 0,
|
|
44219
|
-
end_value: 0,
|
|
44220
|
-
currentPage: 0,
|
|
44221
|
-
};
|
|
44222
|
-
this.isLoader = false;
|
|
44223
|
-
this.isDeleted = false;
|
|
44224
|
-
this.searchAssessments = '';
|
|
44225
|
-
this.isPreview = false;
|
|
44226
|
-
this.selectedAssessmentData = [];
|
|
44227
|
-
this.onAssessmentSelect = new EventEmitter();
|
|
44228
|
-
this.cancelAssessment = new EventEmitter();
|
|
44229
|
-
this.selectedAssessmentArr = [];
|
|
44230
|
-
this.selectedAssessmentCategoriesIds = [];
|
|
44231
|
-
this.selectedAssessmentIds = [];
|
|
44232
|
-
this.selectedAssessment = [];
|
|
44233
|
-
this.dataPerPage = 30;
|
|
44234
|
-
}
|
|
44235
|
-
ngOnInit() {
|
|
44236
|
-
this.animation = true;
|
|
44237
|
-
this.getAssessmentCategoryList();
|
|
44238
|
-
setTimeout(() => {
|
|
44239
|
-
this.animation = false;
|
|
44240
|
-
}, 300);
|
|
44241
|
-
}
|
|
44242
|
-
onAssessmentSelected(event) {
|
|
44243
|
-
this.selectedData = event;
|
|
44244
|
-
}
|
|
44245
|
-
preview(evt) {
|
|
44246
|
-
this.assessmentService.getAssessmentQuestions(evt?.id).subscribe({
|
|
44247
|
-
next: (res) => {
|
|
44248
|
-
this.auth.previewPanel.next(true);
|
|
44249
|
-
this.isPreview = true;
|
|
44250
|
-
this.previewQuestionData = res;
|
|
44251
|
-
},
|
|
44252
|
-
});
|
|
44253
|
-
}
|
|
44254
|
-
previewBack() {
|
|
44255
|
-
this.isPreview = false;
|
|
44256
|
-
this.previewQuestionData = {};
|
|
44257
|
-
this.auth.previewPanel.next(false);
|
|
44258
|
-
}
|
|
44259
|
-
/**
|
|
44260
|
-
*
|
|
44261
|
-
* @param index : Accept index of elementPosition
|
|
44262
|
-
*
|
|
44263
|
-
*/
|
|
44264
|
-
showSubList(index, id) {
|
|
44265
|
-
if (this.openedCategory.includes(id)) {
|
|
44266
|
-
this.openedCategory = this.openedCategory.filter((ele) => ele !== id);
|
|
44267
|
-
}
|
|
44268
|
-
else {
|
|
44269
|
-
this.openedCategory.push(id);
|
|
44270
|
-
this.getAssessmentList(id);
|
|
44271
|
-
}
|
|
44272
|
-
return this.openedCategory;
|
|
44273
|
-
}
|
|
44274
|
-
expandCategory(categoryId) {
|
|
44275
|
-
const index = this.assessmentCategory?.data?.findIndex((ele) => ele.id === categoryId);
|
|
44276
|
-
if (this.openedCategory.includes(categoryId) &&
|
|
44277
|
-
this.assessmentCategory.data[index].assessmentData) {
|
|
44278
|
-
this.openedCategory = this.openedCategory.filter((ele) => ele !== categoryId);
|
|
44279
|
-
}
|
|
44280
|
-
else {
|
|
44281
|
-
this.openedCategory.push(categoryId);
|
|
44282
|
-
this.getAssessmentList(categoryId);
|
|
44283
|
-
}
|
|
44284
|
-
}
|
|
44285
|
-
// TODO: Pagination
|
|
44286
|
-
/**
|
|
44287
|
-
*
|
|
44288
|
-
* @param event : page number that has been selected
|
|
44289
|
-
*/
|
|
44290
|
-
onPageSelection(event) {
|
|
44291
|
-
this.openedCategory = [];
|
|
44292
|
-
this.assessmentPayload.page_no = event.toString();
|
|
44293
|
-
this.getAssessmentCategoryList();
|
|
44294
|
-
}
|
|
44295
|
-
// TODO: Search
|
|
44296
|
-
/**
|
|
44297
|
-
*
|
|
44298
|
-
* @param search : search text
|
|
44299
|
-
*/
|
|
44300
|
-
onAssessmentSearch(search) {
|
|
44301
|
-
this.openedCategory = [];
|
|
44302
|
-
this.assessmentPayload.page_no = '1';
|
|
44303
|
-
this.assessmentPayload.search_title = search;
|
|
44304
|
-
this.assessmentPayload.search_text = search;
|
|
44305
|
-
this.getAssessmentCategoryList();
|
|
44306
|
-
}
|
|
44307
|
-
// TODO: Filter by alphabet
|
|
44308
|
-
/**
|
|
44309
|
-
*
|
|
44310
|
-
* @param event : Assessment category filter of Alphabet
|
|
44311
|
-
*/
|
|
44312
|
-
onAlphabetSelected(event) {
|
|
44313
|
-
this.openedCategory = [];
|
|
44314
|
-
this.assessmentPayload.page_no = '1';
|
|
44315
|
-
this.assessmentPayload.alphabet_filter = event;
|
|
44316
|
-
this.assessmentPayload.search_text = '';
|
|
44317
|
-
this.getAssessmentCategoryList();
|
|
44318
|
-
}
|
|
44319
|
-
// TODO: Call API method
|
|
44320
|
-
getAssessmentCategoryList() {
|
|
44321
|
-
this.isLoader = true;
|
|
44322
|
-
this.assessmentService
|
|
44323
|
-
.getAssessmentCategory(this.assessmentPayload)
|
|
44324
|
-
.subscribe((res) => {
|
|
44325
|
-
this.assessmentCategory = res;
|
|
44326
|
-
if (this.selectedAssessmentArr?.length) {
|
|
44327
|
-
// this.selectedAssessmentArr = [... new Set(this.selectedAssessmentArr)]
|
|
44328
|
-
this.selectedAssessmentArr.forEach((ele) => {
|
|
44329
|
-
const index = res.data.findIndex((assessment) => assessment.id === ele.category_id);
|
|
44330
|
-
this.expandCategory(ele.category_id);
|
|
44331
|
-
});
|
|
44332
|
-
// this.selectedAssessmentArr.forEach((ele:any,index:any) => {
|
|
44333
|
-
// this.openedCategory.push(ele?.category_id);
|
|
44334
|
-
// this.showSubList(index,ele?.category_id);
|
|
44335
|
-
// })
|
|
44336
|
-
}
|
|
44337
|
-
this.isLoader = false;
|
|
44338
|
-
});
|
|
44339
|
-
}
|
|
44340
|
-
// TODO: Call Sub data API method
|
|
44341
|
-
/**
|
|
44342
|
-
*
|
|
44343
|
-
* @param id : Assessment category id
|
|
44344
|
-
*/
|
|
44345
|
-
getAssessmentList(id) {
|
|
44346
|
-
const payload = {
|
|
44347
|
-
search_title: '',
|
|
44348
|
-
};
|
|
44349
|
-
this.assessmentService
|
|
44350
|
-
.getAssessmentList(payload, id)
|
|
44351
|
-
.subscribe((res) => {
|
|
44352
|
-
const index = this.assessmentCategory?.data?.findIndex((ele) => ele.id === id);
|
|
44353
|
-
if (index > -1) {
|
|
44354
|
-
this.assessmentCategory.data[index].assessmentData = [
|
|
44355
|
-
...new Set(res),
|
|
44356
|
-
];
|
|
44357
|
-
}
|
|
44358
|
-
if (this.selectedAssessmentArr?.length) {
|
|
44359
|
-
this.setCategoryAndAssessment();
|
|
44360
|
-
const index = this.selectedAssessmentArr.findIndex((ele) => ele.category_id === id);
|
|
44361
|
-
// if(index !== -1) {
|
|
44362
|
-
// this.selectedAssessmentArr[index].assessmentIds = this.selectedAssessmentArr[index].assessmentIds.map((ele: any) => {
|
|
44363
|
-
// ele = res.find((data: any) => data.id === ele);
|
|
44364
|
-
// return ele;
|
|
44365
|
-
// });
|
|
44366
|
-
// }
|
|
44367
|
-
}
|
|
44368
|
-
});
|
|
44369
|
-
}
|
|
44370
|
-
/**
|
|
44371
|
-
* #### Description
|
|
44372
|
-
* Selects item or deselect a itme
|
|
44373
|
-
* @param evt
|
|
44374
|
-
* @param payload
|
|
44375
|
-
*/
|
|
44376
|
-
selectAssessment(evt, payload, category) {
|
|
44377
|
-
if (evt?.target?.checked) {
|
|
44378
|
-
const index = this.selectedAssessmentArr.findIndex((ele) => ele.category_id === category.id);
|
|
44379
|
-
if (index > -1) {
|
|
44380
|
-
const currentCategoryAssessment = this.selectedAssessmentArr[index].assessmentIds;
|
|
44381
|
-
currentCategoryAssessment.push(payload);
|
|
44382
|
-
this.selectedAssessmentArr[index].assessmentIds = this.uniqueByProp(currentCategoryAssessment, 'id');
|
|
44383
|
-
this.selectedAssessmentArr = cloneDeep(this.selectedAssessmentArr);
|
|
44384
|
-
this.setCategoryAndAssessment();
|
|
44385
|
-
}
|
|
44386
|
-
else {
|
|
44387
|
-
this.selectedAssessmentArr.push({
|
|
44388
|
-
category_id: category.id,
|
|
44389
|
-
assessmentIds: [payload],
|
|
44390
|
-
});
|
|
44391
|
-
this.selectedAssessmentArr = cloneDeep(this.selectedAssessmentArr);
|
|
44392
|
-
this.setCategoryAndAssessment();
|
|
44393
|
-
}
|
|
44394
|
-
}
|
|
44395
|
-
else {
|
|
44396
|
-
const index = this.selectedAssessmentArr.findIndex((ele) => ele.category_id === category.id);
|
|
44397
|
-
if (index > -1) {
|
|
44398
|
-
this.selectedAssessmentArr[index].assessmentIds =
|
|
44399
|
-
this.selectedAssessmentArr[index].assessmentIds.filter((assessment) => assessment.id !== payload.id);
|
|
44400
|
-
this.selectedAssessmentArr = cloneDeep(this.selectedAssessmentArr);
|
|
44401
|
-
this.setCategoryAndAssessment();
|
|
44402
|
-
if (this.selectedAssessmentArr[index].assessmentIds?.length === 0) {
|
|
44403
|
-
this.selectedAssessmentArr.splice(index, 1);
|
|
44404
|
-
this.selectedAssessmentArr = cloneDeep(this.selectedAssessmentArr);
|
|
44405
|
-
this.setCategoryAndAssessment();
|
|
44406
|
-
}
|
|
44407
|
-
}
|
|
44408
|
-
}
|
|
44409
|
-
}
|
|
44410
|
-
setCategoryAndAssessment() {
|
|
44411
|
-
this.selectedAssessmentCategoriesIds = this.selectedAssessmentArr
|
|
44412
|
-
.filter((cat) => cat?.assessmentIds?.length > 0)
|
|
44413
|
-
?.map((ele) => ele?.category_id)
|
|
44414
|
-
.flat();
|
|
44415
|
-
this.selectedAssessmentIds = this.selectedAssessmentArr
|
|
44416
|
-
.map((cat) => cat?.assessmentIds.map((ele) => ele?.id))
|
|
44417
|
-
.flat();
|
|
44418
|
-
this.selectedAssessment = this.selectedAssessmentArr
|
|
44419
|
-
.map((cat) => cat?.assessmentIds.map((ele) => ele))
|
|
44420
|
-
.flat();
|
|
44421
|
-
}
|
|
44422
|
-
// TODO: Display selected data in bottom floating bar with next enabled button having
|
|
44423
|
-
// TODO: Send data in payload of create Responsibility form
|
|
44424
|
-
save() {
|
|
44425
|
-
this.onAssessmentSelect.emit(this.selectedAssessmentArr);
|
|
44426
|
-
}
|
|
44427
|
-
close() {
|
|
44428
|
-
this.cancelAssessment.emit();
|
|
44429
|
-
}
|
|
44430
|
-
/**
|
|
44431
|
-
* #### Description
|
|
44432
|
-
*
|
|
44433
|
-
* Returns the unique array of object based on unique key
|
|
44434
|
-
* @param array
|
|
44435
|
-
* @param key
|
|
44436
|
-
* @returns
|
|
44437
|
-
*/
|
|
44438
|
-
uniqueByProp(array, key) {
|
|
44439
|
-
return Array.from(array
|
|
44440
|
-
.reduce((acc, item) => (item && item[key] && acc.set(item[key], item), acc), new Map())
|
|
44441
|
-
.values());
|
|
44442
|
-
}
|
|
44443
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AssessmentPickerComponent, deps: [{ token: AssessmentService }, { token: AuthService$1 }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
44444
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AssessmentPickerComponent, selector: "assessment-picker", inputs: { isEdit: "isEdit", setSelected: ["selectedAssessment", "setSelected"], selectedAssessmentData: "selectedAssessmentData" }, outputs: { onAssessmentSelect: "onAssessmentSelect", cancelAssessment: "cancelAssessment" }, ngImport: i0, template: "<app-preview\n *ngIf=\"isPreview\"\n [questionData]=\"previewQuestionData\"\n (previewBack)=\"previewBack()\"\n></app-preview>\n<div class=\"assessment-list\" [class.animate]=\"animation\">\n <ng-container>\n <div class=\"assessment-list-head\">\n <button class=\"back-btn\">\n <!-- <i class=\"icons\"></i> -->\n </button>\n <h3 class=\"assessment-list-title\">Select Assessment(s)</h3>\n </div>\n <div class=\"assessment-list-body\">\n <div class=\"search-block\">\n <i class=\"icons\"></i>\n <input\n type=\"text\"\n [(ngModel)]=\"searchAssessments\"\n (change)=\"onAssessmentSearch($event.target.value)\"\n placeholder=\"Search Assessment Category\"\n />\n </div>\n <pagination\n [pageCount]=\"assessmentCategory?.totalPage\"\n [total]=\"assessmentCategory?.totalRecords\"\n [start]=\"assessmentCategory?.start_value\"\n [end]=\"assessmentCategory?.end_value\"\n [activeAlphabet]=\"''\"\n (selectedAlphabet)=\"onAlphabetSelected($event)\"\n (selectedPage)=\"onPageSelection($event)\"\n ></pagination>\n <div\n *ngIf=\"assessmentCategory.data.length === 0 && !isLoader\"\n class=\"assessment-list-part\"\n >\n <app-no-data\n [noDataImage]=\"ASSETS.search_data\"\n [noDataText]=\"'No Assessments Found.'\"\n ></app-no-data>\n </div>\n <div\n *ngIf=\"assessmentCategory.data.length || isLoader\"\n class=\"assessment-list-part\"\n >\n <div\n *ngIf=\"\n isEdit && selectedAssessment?.assessmentDetails?.assessment_name\n \"\n class=\"assessment-list-selected\"\n >\n <div class=\"assessment-list-heading\">\n Assessment already selected for this responsibility\n </div>\n <div class=\"assessment-list-item\">\n <div class=\"table-row\">\n <div class=\"table-column serial disabled\">\n <app-cs-radio\n [disabled]=\"true\"\n class=\"disabled\"\n [checked]=\"true\"\n [readonly]=\"true\"\n ></app-cs-radio>\n </div>\n <div class=\"table-column sub-name\">\n <div class=\"name-inner\">\n <div\n class=\"value\"\n [appTooltip]=\"\n selectedAssessment?.assessmentDetails?.assessment_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >\n {{ selectedAssessment?.assessmentDetails?.assessment_name }}\n </div>\n <div class=\"within-part\">\n <span class=\"within-box\">Within</span>\n <span\n class=\"value\"\n [appTooltip]=\"\n selectedAssessment?.category_details?.category_name +\n (selectedAssessment?.category_details?.parent_tree\n ? ' > ' +\n selectedAssessment?.category_details?.parent_tree\n : '')\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n selectedAssessment?.category_details?.category_name +\n (selectedAssessment?.category_details?.parent_tree\n ? \" > \" +\n selectedAssessment?.category_details?.parent_tree\n : \"\")\n }}</span\n >\n </div>\n </div>\n </div>\n <div class=\"table-column question\">\n <div class=\"label\">\n {{ selectedAssessment?.assessmentDetails?.questions }}\n {{\n selectedAssessment?.assessmentDetails?.questions > 1\n ? \"Questions\"\n : \"Question\"\n }}\n </div>\n <div class=\"buttons\">\n <button\n class=\"action-btn\"\n (click)=\"preview(selectedAssessment?.assessmentDetails)\"\n >\n <i class=\"icons\"></i> Preview\n </button>\n <!-- <button class=\"action-btn\"><i class=\"icons\"></i> Edit</button> -->\n </div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"assessment-list-heading\">\n Select an Assessment for this responsibility\n </div>\n\n <!--\n Assessment category list\n active class is used for highlighting opened element\n -->\n <ng-container *ngIf=\"!isLoader\">\n <div\n *ngFor=\"let data of assessmentCategory.data; let i = index\"\n class=\"assessment-list-item\"\n [class.active]=\"\n openedCategory.includes(data?.id) ||\n data.id === selectedAssessment?.category_id\n \"\n >\n <div\n class=\"table-row main-list\"\n (click)=\"expandCategory(data?.id)\"\n [class.disabled]=\"data?.assessmentcount < 1\"\n >\n <div class=\"table-column serial\">\n <div\n [id]=\"'sr-no' + i\"\n class=\"sr-no\"\n [appTooltip]=\"i + 1\"\n placement=\"bottom\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"true\"\n >\n {{ dataPerPage * (assessmentPayload.page_no - 1) + (i + 1) }}\n </div>\n </div>\n <div class=\"table-column name\">\n <div class=\"name-inner\">\n <div\n class=\"value\"\n [appTooltip]=\"data.category_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >\n {{ data?.category_name }}\n </div>\n <div class=\"within-part\" *ngIf=\"data?.parent_tree\">\n <span class=\"within-box\">Within</span>\n <span\n class=\"value\"\n [appTooltip]=\"data.parent_tree\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ data?.parent_tree }}</span\n >\n </div>\n </div>\n </div>\n <div class=\"table-column action\">\n <button\n [id]=\"'arrow' + i\"\n class=\"arrow\"\n [class.disabled]=\"data?.assessmentcount < 1\"\n [disabled]=\"data?.assessmentcount < 1\"\n >\n <i *ngIf=\"!openedCategory.includes(data?.id)\" class=\"icons\"\n ></i\n >\n <i *ngIf=\"openedCategory.includes(data?.id)\" class=\"icons\"\n ></i\n >\n </button>\n </div>\n </div>\n\n <!-- Assessment list start from here -->\n <div *ngIf=\"openedCategory.includes(data?.id)\" class=\"sub-list\">\n <ng-container *ngIf=\"data.assessmentData?.length > 0\">\n <div\n class=\"table-row\"\n *ngFor=\"let assessment of data.assessmentData; let j = index\"\n [class.active]=\"selectedAssessmentIds.includes(assessment.id)\"\n >\n <div class=\"table-column serial\">\n <div\n [id]=\"'sub-sr-no' + i + j\"\n class=\"sr-no active\"\n appTooltip=\"{{\n dataPerPage * (assessmentPayload.page_no - 1) + (i + 1)\n }}.{{ j + 1 }}\"\n placement=\"bottom\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"true\"\n >\n {{\n dataPerPage * (assessmentPayload.page_no - 1) + (i + 1)\n }}.{{ j + 1 }}\n <!-- <app-cs-radio name=\"assessment\" [value]=\"assessment.id\" [checked]=\"assessment?.id === selectedAssessment?.assessment_id && data?.id === selectedAssessment?.category_id\"\n (checkedEvent)=\"setAssessment(data, assessment)\"></app-cs-radio> -->\n <!-- (change)=\"selectGroup($event,group)\" [disabled]=\"nonRemovableGroupIds?.includes(group?.group_id)\" [checked]=\"selectedGroupIds.includes(group?.group_id)\" -->\n\n <vui-checkbox\n [checked]=\"\n selectedAssessmentIds.includes(assessment.id)\n \"\n (change)=\"selectAssessment($event, assessment, data)\"\n ></vui-checkbox>\n </div>\n </div>\n <div class=\"table-column sub-name\">\n <div\n class=\"value\"\n [appTooltip]=\"\n 'Mission and message, communications to external audiences'\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >\n {{ assessment?.assessment_name }}\n </div>\n </div>\n <div class=\"table-column question\">\n <div class=\"label\">\n {{ assessment?.questions }}\n {{ assessment?.questions > 1 ? \"Questions\" : \"Question\" }}\n </div>\n <div class=\"buttons\">\n <button class=\"action-btn\" (click)=\"preview(assessment)\">\n <i class=\"icons\"></i> Preview\n </button>\n <!-- <button class=\"action-btn\"><i class=\"icons\"></i> Edit</button> -->\n </div>\n </div>\n </div>\n </ng-container>\n <!-- Loader loading isLoader -->\n <assessment-sub-loader\n *ngIf=\"!data.assessmentData?.length\"\n ></assessment-sub-loader>\n <!-- <app-line-loader *ngIf=\"!data.assessmentData?.length\" [loaderHeight]=\"'5'\"></app-line-loader> -->\n </div>\n </div>\n </ng-container>\n <!-- Loader loading isLoader -->\n <assessment-loader *ngIf=\"isLoader\"></assessment-loader>\n </div>\n <!-- No data image -->\n <app-no-data\n *ngIf=\"!assessmentCategory.data.length && !isLoader\"\n [noDataImage]=\"ASSETS.search_data\"\n [noDataText]=\"'No Data to Display'\"\n ></app-no-data>\n </div>\n <!--\n bottom floating bar which includes cancel, next button\n closing tab\n -->\n\n <vui-floating-bar (closeEvent)=\"save()\" (closeList)=\"close()\">\n <div\n class=\"counter\"\n *ngIf=\"selectedAssessment?.length\"\n appPopover\n (click)=\"assessmentCount.popover()\"\n placement=\"left\"\n >\n {{ selectedAssessment?.length }}\n </div>\n <div class=\"name\">\n <span *ngIf=\"selectedAssessment?.length === 1\"\n >Assessment selected</span\n >\n <span *ngIf=\"selectedAssessment?.length > 1\">Assessments selected</span>\n </div>\n <app-popover #assessmentCount [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"let element of selectedAssessment; let i = index\">\n <div class=\"avatar-card\">\n <span class=\"value\">\n <!-- <i class=\"icons\"\n (click)=\"selectAssessment({target:{checked:false}},element)\"></i> -->\n {{ element?.assessment_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </vui-floating-bar>\n </ng-container>\n</div>\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";::ng-deep .assessment-list{background:#fff;border-top:3px solid #1E5DD3;position:fixed;inset:0 500px 0 0;z-index:1}::ng-deep .assessment-list.animate{animation:animate-right .2s cubic-bezier(.25,.46,.45,.94) both;z-index:-1}::ng-deep .assessment-list-head{background:#fbfbfb;height:42px;padding:0 18px;display:flex;align-items:center;border:1px solid #f1f1f1;border-right:none}::ng-deep .assessment-list-head button.back-btn{background:transparent;border-radius:0;border:0;color:#161b2f;font-size:16px;padding:0;margin:0 8px 0 0}::ng-deep .assessment-list-title{color:#161b2f;font-size:15px;font-weight:500;margin:0!important;padding:0;line-height:21px}::ng-deep .assessment-list-close{background:transparent;border:none;outline:none;cursor:pointer;color:#000;font-size:12px;display:inline-block;padding:0}::ng-deep .assessment-list-body{padding:24px 40px 24px 36px;height:calc(100vh - 112px)}::ng-deep .assessment-list-body .search-block{position:relative}::ng-deep .assessment-list-body .search-block input{height:44px;line-height:24px;padding:10px 15px 10px 40px;outline:none;border:1px solid #7475763f;border-radius:4px;width:100%;font-size:14px;color:#747576}::ng-deep .assessment-list-body .search-block input::placeholder{font-weight:400}::ng-deep .assessment-list-body .search-block input:focus{border-color:#1e5dd3}::ng-deep .assessment-list-body .search-block i{position:absolute;left:17px;font-size:12px;font-weight:400;top:17px;pointer-events:none;color:#f1f1f1}::ng-deep .assessment-list-body .assessment-list-part{height:calc(100vh - 228px);overflow:auto;padding:8px 12px 0 0;width:calc(100% + 12px)}::ng-deep .assessment-list-body .assessment-list-part::-webkit-scrollbar-track{background-color:#fff;position:absolute}::ng-deep .assessment-list-body .assessment-list-part::-webkit-scrollbar{width:3px;height:3px;background-color:transparent;position:absolute}::ng-deep .assessment-list-body .assessment-list-part::-webkit-scrollbar-thumb{border-radius:3px;background-color:#dbdbdb;position:absolute}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-selected{margin-bottom:8px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-heading{color:#161b2f;font-size:12px;font-weight:600;margin-bottom:4px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item{border:1px solid #f1f1f1;border-radius:2px;margin-bottom:4px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .main-list{cursor:pointer}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item.active{border-color:#1e5dd3;box-shadow:0 3px 6px #4681ef26}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row{display:flex;align-items:center;justify-content:space-between}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row.disabled{pointer-events:none}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column{color:#747576;height:48px;position:relative;width:100%;display:flex;align-items:center;padding:0 4px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.serial{width:32px;max-width:32px;justify-content:center}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.serial .sr-no{width:16px;background:#f8f8f8;writing-mode:vertical-lr;color:#747576;font-size:10px;font-weight:500;display:flex;height:100%;align-items:center;justify-content:center;position:relative;transition:all .2s ease-in-out}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.serial .sr-no vui-checkbox{position:absolute;top:8px;left:0;opacity:0;transition:all .2s ease-in-out}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.serial .sr-no vui-checkbox label.checkbox-item{position:unset}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.name{width:calc(100% - 64px);min-width:calc(100% - 64px)}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.name .name-inner{width:100%}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.name .name-inner .value{color:#161b2f;font-size:12px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;padding-right:20px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.action{width:32px;max-width:32px;justify-content:center}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.action button.arrow{background:transparent;border:none;border-radius:0;color:#747576;font-size:12px;padding:0;margin:0;display:flex;align-items:center;justify-content:center;height:100%;width:100%}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.action button.disabled{opacity:.5!important;pointer-events:none}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.sub-name{width:calc(100% - 232px);min-width:calc(100% - 232px)}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.sub-name .name-inner{width:100%}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.sub-name .value{color:#747576;font-size:12px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;padding-right:20px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.question{width:200px;max-width:200px;justify-content:flex-end}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.question .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-right:8px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.question .buttons{display:flex;width:0;overflow:hidden;transition:all .2s ease-in-out}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.question .buttons button.action-btn{background:#fff;border:1px solid #f1f1f1;border-radius:2px;color:#1e5dd3;font-size:11px;font-weight:500;line-height:24px;text-transform:uppercase;padding:0 8px;display:flex;align-items:center;margin:0}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.question .buttons button.action-btn i{margin-right:4px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.question .buttons button.action-btn+button{margin-left:4px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row:hover .table-column.question .buttons{width:86px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .sub-list .table-row{border-top:1px solid #f1f1f1}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .sub-list .table-row:hover .table-column.serial .sr-no,::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .sub-list .table-row.active .table-column.serial .sr-no{color:#f8f8f8}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .sub-list .table-row:hover .table-column.serial .sr-no vui-checkbox,::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .sub-list .table-row.active .table-column.serial .sr-no vui-checkbox{opacity:1}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .sub-list .table-row .table-column{height:32px}::ng-deep .assessment-list-body ul{padding:0;margin:0}::ng-deep .assessment-list-body ul.assessment{max-height:calc(100vh - 240px);overflow:auto;padding:16px 12px 0 0;width:calc(100% + 12px)}::ng-deep .assessment-list-body ul.assessment::-webkit-scrollbar-track{background-color:#fff;position:absolute}::ng-deep .assessment-list-body ul.assessment::-webkit-scrollbar{width:3px;height:3px;background-color:transparent;position:absolute}::ng-deep .assessment-list-body ul.assessment::-webkit-scrollbar-thumb{border-radius:3px;background-color:#dbdbdb;position:absolute}::ng-deep .assessment-list-body ul.assessment li{padding:0 0 12px;list-style:none;display:flex;align-items:center;justify-content:space-between}::ng-deep .assessment-list-body ul.assessment li vui-checkbox{width:calc(100% - 260px)}::ng-deep .assessment-list-body ul.assessment li vui-checkbox .radio-item .value .name{font-size:12px;color:#161b2f;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .assessment-list-body ul.assessment li .right{display:flex;align-items:center}::ng-deep .assessment-list-body ul.assessment li .right .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}::ng-deep .assessment-list-body ul.assessment li .right .buttons{display:flex;width:0;overflow:hidden;transition:all .2s ease-in-out}::ng-deep .assessment-list-body ul.assessment li .right .buttons button.action-btn{background:#fff;border:1px solid #f1f1f1;border-radius:2px;color:#1e5dd3;font-size:11px;font-weight:500;line-height:24px;text-transform:uppercase;padding:0 8px;margin-left:12px;display:flex;align-items:center}::ng-deep .assessment-list-body ul.assessment li .right .buttons button.action-btn i{margin-right:4px}::ng-deep .assessment-list-body ul.assessment li .right .buttons button.action-btn+button{margin-left:4px}::ng-deep .assessment-list-body ul.assessment li:hover .right .buttons{width:156px}.within-part{display:flex;align-items:center;padding-right:12px}.within-part .value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;font-size:12px;color:#747576}.within-box{background:#f1f1f1;border-radius:2px;color:#042e7d;font-size:9px;font-weight:600;text-transform:uppercase;padding:0 4px;margin-right:8px;line-height:12px}@keyframes animate-right{0%{transform:translate(100%)}to{transform:translate(0)}}.wf-action-list{width:220px}.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}.wf-action-list ul.action-item{display:block}.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}.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}.wf-action-list ul.action-item li button .file-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;width:calc(100% - 16px)}.wf-action-list ul.action-item li button i{font-size:16px;margin-right:10px;color:#1e5dd3}.wf-action-list ul.action-item li button:hover{background:#f3f3f3}.wf-action-list ul.action-item li .avatar-card{display:flex;align-items:center;width:100%;padding:7.5px}.wf-action-list ul.action-item li .avatar-card.within-con{display:block}.wf-action-list ul.action-item li .avatar-card .avatar{height:24px;width:24px!important;min-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}.wf-action-list ul.action-item li .avatar-card .avatar img{background:#fff;width:100%;height:100%}.wf-action-list ul.action-item li .avatar-card .avatar+span.value{width:calc(100% - 29px)}.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}.wf-action-list ul.action-item li .avatar-card span.value i{font-size:8px;color:#747576;cursor:pointer;margin-right:5px}.wf-action-list ul.action-item li .avatar-card.no-image{display:block}.wf-action-list ul.action-item li .avatar-card.no-image span.value{width:100%;display:block}.wf-action-list ul.action-item li .avatar-card i.delete-icon{color:#d93b41;cursor:pointer;font-size:14px}.wf-action-list ul.action-item li .chip-item{color:#1e5dd3;padding:10px;display:flex;align-items:center}.wf-action-list ul.action-item li .chip-item i{color:#747576;margin-left:7px;font-size:10px;cursor:pointer;display:inline-flex}.wf-action-list ul.action-item li .chip-item span{display:block;width:auto;width:calc(100% - 17px);font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wf-action-list ul.action-item li .chip-item span.chip-block{display:block;width:100%}.wf-action-list ul.action-item li .chip-item span.id{font-size:9px}.wf-action-list ul.action-item li .within{display:flex;align-items:center;justify-content:flex-start}.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}.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}.wf-action-list ul.action-item li:first-child{animation:action-list-open .25s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(2){animation:action-list-open .35s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(3){animation:action-list-open .45s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(4){animation:action-list-open .55s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(5){animation:action-list-open .65s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(6){animation:action-list-open .75s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(7){animation:action-list-open .85s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(8){animation:action-list-open .95s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(9){animation:action-list-open 1.05s cubic-bezier(.25,.46,.45,.94) both}.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)}}\n"], dependencies: [{ kind: "directive", type: i1$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: ToolTipDirective, selector: "[appTooltip]", inputs: ["appTooltip", "placement", "type", "tooltipMandatory", "showTooltip", "animate"] }, { kind: "component", type: PopoverComponent, selector: "app-popover", inputs: ["dontCloseonClick"] }, { kind: "directive", type: PopoverDirective, selector: "[appPopover]", inputs: ["refrence", "placement"] }, { kind: "directive", type: i1$3.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$3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: NoDataComponentUI, selector: "app-no-data", inputs: ["action", "secondaryAction", "noDataImage", "noDataText", "noDataButton", "secondaryButton", "noDataSecButton", "altText", "smallButton"], outputs: ["buttonAction", "secondaryActionButton"] }, { kind: "component", type: CsRadioComponentUI, selector: "app-cs-radio", inputs: ["disabled", "readonly", "name", "checked", "value"], outputs: ["checkedEvent"] }, { kind: "component", type: PreviewComponent, selector: "app-preview", inputs: ["questionData"], outputs: ["previewBack"] }, { kind: "component", type: CheckboxComponent$1, selector: "vui-checkbox", inputs: ["disabled", "checked", "indeterminateEnabled"] }, { kind: "component", type: VuiFloatingBarComponent, selector: "vui-floating-bar", inputs: ["selectedData", "groupSelected", "displayElementKey", "elementId", "singularText", "pluralText", "showNextButton", "showFrequencyText", "showWorkflow", "workflowText", "currentFrequency", "isDisabled", "workflowList", "selectedWorkflow", "workflowPlaceHolder", "mode", "nextDisabled", "nonRemovableUsersList", "removePosition"], outputs: ["closeEvent", "deleteEvent", "closeList", "workflowTypeChanged"] }, { kind: "component", type: AssessmentLoaderComponent, selector: "assessment-loader" }, { kind: "component", type: AssessmentSubLoaderComponent, selector: "assessment-sub-loader" }, { kind: "component", type: Pagination, selector: "pagination", inputs: ["activeAlphabet", "pageCount", "start", "end", "total", "noFilter", "currentPage"], outputs: ["selectedPage", "selectedAlphabet"] }] }); }
|
|
44445
|
-
}
|
|
44446
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AssessmentPickerComponent, decorators: [{
|
|
44447
|
-
type: Component,
|
|
44448
|
-
args: [{ selector: 'assessment-picker', template: "<app-preview\n *ngIf=\"isPreview\"\n [questionData]=\"previewQuestionData\"\n (previewBack)=\"previewBack()\"\n></app-preview>\n<div class=\"assessment-list\" [class.animate]=\"animation\">\n <ng-container>\n <div class=\"assessment-list-head\">\n <button class=\"back-btn\">\n <!-- <i class=\"icons\"></i> -->\n </button>\n <h3 class=\"assessment-list-title\">Select Assessment(s)</h3>\n </div>\n <div class=\"assessment-list-body\">\n <div class=\"search-block\">\n <i class=\"icons\"></i>\n <input\n type=\"text\"\n [(ngModel)]=\"searchAssessments\"\n (change)=\"onAssessmentSearch($event.target.value)\"\n placeholder=\"Search Assessment Category\"\n />\n </div>\n <pagination\n [pageCount]=\"assessmentCategory?.totalPage\"\n [total]=\"assessmentCategory?.totalRecords\"\n [start]=\"assessmentCategory?.start_value\"\n [end]=\"assessmentCategory?.end_value\"\n [activeAlphabet]=\"''\"\n (selectedAlphabet)=\"onAlphabetSelected($event)\"\n (selectedPage)=\"onPageSelection($event)\"\n ></pagination>\n <div\n *ngIf=\"assessmentCategory.data.length === 0 && !isLoader\"\n class=\"assessment-list-part\"\n >\n <app-no-data\n [noDataImage]=\"ASSETS.search_data\"\n [noDataText]=\"'No Assessments Found.'\"\n ></app-no-data>\n </div>\n <div\n *ngIf=\"assessmentCategory.data.length || isLoader\"\n class=\"assessment-list-part\"\n >\n <div\n *ngIf=\"\n isEdit && selectedAssessment?.assessmentDetails?.assessment_name\n \"\n class=\"assessment-list-selected\"\n >\n <div class=\"assessment-list-heading\">\n Assessment already selected for this responsibility\n </div>\n <div class=\"assessment-list-item\">\n <div class=\"table-row\">\n <div class=\"table-column serial disabled\">\n <app-cs-radio\n [disabled]=\"true\"\n class=\"disabled\"\n [checked]=\"true\"\n [readonly]=\"true\"\n ></app-cs-radio>\n </div>\n <div class=\"table-column sub-name\">\n <div class=\"name-inner\">\n <div\n class=\"value\"\n [appTooltip]=\"\n selectedAssessment?.assessmentDetails?.assessment_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >\n {{ selectedAssessment?.assessmentDetails?.assessment_name }}\n </div>\n <div class=\"within-part\">\n <span class=\"within-box\">Within</span>\n <span\n class=\"value\"\n [appTooltip]=\"\n selectedAssessment?.category_details?.category_name +\n (selectedAssessment?.category_details?.parent_tree\n ? ' > ' +\n selectedAssessment?.category_details?.parent_tree\n : '')\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n selectedAssessment?.category_details?.category_name +\n (selectedAssessment?.category_details?.parent_tree\n ? \" > \" +\n selectedAssessment?.category_details?.parent_tree\n : \"\")\n }}</span\n >\n </div>\n </div>\n </div>\n <div class=\"table-column question\">\n <div class=\"label\">\n {{ selectedAssessment?.assessmentDetails?.questions }}\n {{\n selectedAssessment?.assessmentDetails?.questions > 1\n ? \"Questions\"\n : \"Question\"\n }}\n </div>\n <div class=\"buttons\">\n <button\n class=\"action-btn\"\n (click)=\"preview(selectedAssessment?.assessmentDetails)\"\n >\n <i class=\"icons\"></i> Preview\n </button>\n <!-- <button class=\"action-btn\"><i class=\"icons\"></i> Edit</button> -->\n </div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"assessment-list-heading\">\n Select an Assessment for this responsibility\n </div>\n\n <!--\n Assessment category list\n active class is used for highlighting opened element\n -->\n <ng-container *ngIf=\"!isLoader\">\n <div\n *ngFor=\"let data of assessmentCategory.data; let i = index\"\n class=\"assessment-list-item\"\n [class.active]=\"\n openedCategory.includes(data?.id) ||\n data.id === selectedAssessment?.category_id\n \"\n >\n <div\n class=\"table-row main-list\"\n (click)=\"expandCategory(data?.id)\"\n [class.disabled]=\"data?.assessmentcount < 1\"\n >\n <div class=\"table-column serial\">\n <div\n [id]=\"'sr-no' + i\"\n class=\"sr-no\"\n [appTooltip]=\"i + 1\"\n placement=\"bottom\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"true\"\n >\n {{ dataPerPage * (assessmentPayload.page_no - 1) + (i + 1) }}\n </div>\n </div>\n <div class=\"table-column name\">\n <div class=\"name-inner\">\n <div\n class=\"value\"\n [appTooltip]=\"data.category_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >\n {{ data?.category_name }}\n </div>\n <div class=\"within-part\" *ngIf=\"data?.parent_tree\">\n <span class=\"within-box\">Within</span>\n <span\n class=\"value\"\n [appTooltip]=\"data.parent_tree\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ data?.parent_tree }}</span\n >\n </div>\n </div>\n </div>\n <div class=\"table-column action\">\n <button\n [id]=\"'arrow' + i\"\n class=\"arrow\"\n [class.disabled]=\"data?.assessmentcount < 1\"\n [disabled]=\"data?.assessmentcount < 1\"\n >\n <i *ngIf=\"!openedCategory.includes(data?.id)\" class=\"icons\"\n ></i\n >\n <i *ngIf=\"openedCategory.includes(data?.id)\" class=\"icons\"\n ></i\n >\n </button>\n </div>\n </div>\n\n <!-- Assessment list start from here -->\n <div *ngIf=\"openedCategory.includes(data?.id)\" class=\"sub-list\">\n <ng-container *ngIf=\"data.assessmentData?.length > 0\">\n <div\n class=\"table-row\"\n *ngFor=\"let assessment of data.assessmentData; let j = index\"\n [class.active]=\"selectedAssessmentIds.includes(assessment.id)\"\n >\n <div class=\"table-column serial\">\n <div\n [id]=\"'sub-sr-no' + i + j\"\n class=\"sr-no active\"\n appTooltip=\"{{\n dataPerPage * (assessmentPayload.page_no - 1) + (i + 1)\n }}.{{ j + 1 }}\"\n placement=\"bottom\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"true\"\n >\n {{\n dataPerPage * (assessmentPayload.page_no - 1) + (i + 1)\n }}.{{ j + 1 }}\n <!-- <app-cs-radio name=\"assessment\" [value]=\"assessment.id\" [checked]=\"assessment?.id === selectedAssessment?.assessment_id && data?.id === selectedAssessment?.category_id\"\n (checkedEvent)=\"setAssessment(data, assessment)\"></app-cs-radio> -->\n <!-- (change)=\"selectGroup($event,group)\" [disabled]=\"nonRemovableGroupIds?.includes(group?.group_id)\" [checked]=\"selectedGroupIds.includes(group?.group_id)\" -->\n\n <vui-checkbox\n [checked]=\"\n selectedAssessmentIds.includes(assessment.id)\n \"\n (change)=\"selectAssessment($event, assessment, data)\"\n ></vui-checkbox>\n </div>\n </div>\n <div class=\"table-column sub-name\">\n <div\n class=\"value\"\n [appTooltip]=\"\n 'Mission and message, communications to external audiences'\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >\n {{ assessment?.assessment_name }}\n </div>\n </div>\n <div class=\"table-column question\">\n <div class=\"label\">\n {{ assessment?.questions }}\n {{ assessment?.questions > 1 ? \"Questions\" : \"Question\" }}\n </div>\n <div class=\"buttons\">\n <button class=\"action-btn\" (click)=\"preview(assessment)\">\n <i class=\"icons\"></i> Preview\n </button>\n <!-- <button class=\"action-btn\"><i class=\"icons\"></i> Edit</button> -->\n </div>\n </div>\n </div>\n </ng-container>\n <!-- Loader loading isLoader -->\n <assessment-sub-loader\n *ngIf=\"!data.assessmentData?.length\"\n ></assessment-sub-loader>\n <!-- <app-line-loader *ngIf=\"!data.assessmentData?.length\" [loaderHeight]=\"'5'\"></app-line-loader> -->\n </div>\n </div>\n </ng-container>\n <!-- Loader loading isLoader -->\n <assessment-loader *ngIf=\"isLoader\"></assessment-loader>\n </div>\n <!-- No data image -->\n <app-no-data\n *ngIf=\"!assessmentCategory.data.length && !isLoader\"\n [noDataImage]=\"ASSETS.search_data\"\n [noDataText]=\"'No Data to Display'\"\n ></app-no-data>\n </div>\n <!--\n bottom floating bar which includes cancel, next button\n closing tab\n -->\n\n <vui-floating-bar (closeEvent)=\"save()\" (closeList)=\"close()\">\n <div\n class=\"counter\"\n *ngIf=\"selectedAssessment?.length\"\n appPopover\n (click)=\"assessmentCount.popover()\"\n placement=\"left\"\n >\n {{ selectedAssessment?.length }}\n </div>\n <div class=\"name\">\n <span *ngIf=\"selectedAssessment?.length === 1\"\n >Assessment selected</span\n >\n <span *ngIf=\"selectedAssessment?.length > 1\">Assessments selected</span>\n </div>\n <app-popover #assessmentCount [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"let element of selectedAssessment; let i = index\">\n <div class=\"avatar-card\">\n <span class=\"value\">\n <!-- <i class=\"icons\"\n (click)=\"selectAssessment({target:{checked:false}},element)\"></i> -->\n {{ element?.assessment_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </vui-floating-bar>\n </ng-container>\n</div>\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";::ng-deep .assessment-list{background:#fff;border-top:3px solid #1E5DD3;position:fixed;inset:0 500px 0 0;z-index:1}::ng-deep .assessment-list.animate{animation:animate-right .2s cubic-bezier(.25,.46,.45,.94) both;z-index:-1}::ng-deep .assessment-list-head{background:#fbfbfb;height:42px;padding:0 18px;display:flex;align-items:center;border:1px solid #f1f1f1;border-right:none}::ng-deep .assessment-list-head button.back-btn{background:transparent;border-radius:0;border:0;color:#161b2f;font-size:16px;padding:0;margin:0 8px 0 0}::ng-deep .assessment-list-title{color:#161b2f;font-size:15px;font-weight:500;margin:0!important;padding:0;line-height:21px}::ng-deep .assessment-list-close{background:transparent;border:none;outline:none;cursor:pointer;color:#000;font-size:12px;display:inline-block;padding:0}::ng-deep .assessment-list-body{padding:24px 40px 24px 36px;height:calc(100vh - 112px)}::ng-deep .assessment-list-body .search-block{position:relative}::ng-deep .assessment-list-body .search-block input{height:44px;line-height:24px;padding:10px 15px 10px 40px;outline:none;border:1px solid #7475763f;border-radius:4px;width:100%;font-size:14px;color:#747576}::ng-deep .assessment-list-body .search-block input::placeholder{font-weight:400}::ng-deep .assessment-list-body .search-block input:focus{border-color:#1e5dd3}::ng-deep .assessment-list-body .search-block i{position:absolute;left:17px;font-size:12px;font-weight:400;top:17px;pointer-events:none;color:#f1f1f1}::ng-deep .assessment-list-body .assessment-list-part{height:calc(100vh - 228px);overflow:auto;padding:8px 12px 0 0;width:calc(100% + 12px)}::ng-deep .assessment-list-body .assessment-list-part::-webkit-scrollbar-track{background-color:#fff;position:absolute}::ng-deep .assessment-list-body .assessment-list-part::-webkit-scrollbar{width:3px;height:3px;background-color:transparent;position:absolute}::ng-deep .assessment-list-body .assessment-list-part::-webkit-scrollbar-thumb{border-radius:3px;background-color:#dbdbdb;position:absolute}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-selected{margin-bottom:8px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-heading{color:#161b2f;font-size:12px;font-weight:600;margin-bottom:4px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item{border:1px solid #f1f1f1;border-radius:2px;margin-bottom:4px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .main-list{cursor:pointer}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item.active{border-color:#1e5dd3;box-shadow:0 3px 6px #4681ef26}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row{display:flex;align-items:center;justify-content:space-between}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row.disabled{pointer-events:none}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column{color:#747576;height:48px;position:relative;width:100%;display:flex;align-items:center;padding:0 4px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.serial{width:32px;max-width:32px;justify-content:center}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.serial .sr-no{width:16px;background:#f8f8f8;writing-mode:vertical-lr;color:#747576;font-size:10px;font-weight:500;display:flex;height:100%;align-items:center;justify-content:center;position:relative;transition:all .2s ease-in-out}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.serial .sr-no vui-checkbox{position:absolute;top:8px;left:0;opacity:0;transition:all .2s ease-in-out}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.serial .sr-no vui-checkbox label.checkbox-item{position:unset}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.name{width:calc(100% - 64px);min-width:calc(100% - 64px)}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.name .name-inner{width:100%}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.name .name-inner .value{color:#161b2f;font-size:12px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;padding-right:20px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.action{width:32px;max-width:32px;justify-content:center}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.action button.arrow{background:transparent;border:none;border-radius:0;color:#747576;font-size:12px;padding:0;margin:0;display:flex;align-items:center;justify-content:center;height:100%;width:100%}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.action button.disabled{opacity:.5!important;pointer-events:none}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.sub-name{width:calc(100% - 232px);min-width:calc(100% - 232px)}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.sub-name .name-inner{width:100%}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.sub-name .value{color:#747576;font-size:12px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;padding-right:20px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.question{width:200px;max-width:200px;justify-content:flex-end}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.question .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-right:8px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.question .buttons{display:flex;width:0;overflow:hidden;transition:all .2s ease-in-out}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.question .buttons button.action-btn{background:#fff;border:1px solid #f1f1f1;border-radius:2px;color:#1e5dd3;font-size:11px;font-weight:500;line-height:24px;text-transform:uppercase;padding:0 8px;display:flex;align-items:center;margin:0}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.question .buttons button.action-btn i{margin-right:4px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.question .buttons button.action-btn+button{margin-left:4px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row:hover .table-column.question .buttons{width:86px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .sub-list .table-row{border-top:1px solid #f1f1f1}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .sub-list .table-row:hover .table-column.serial .sr-no,::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .sub-list .table-row.active .table-column.serial .sr-no{color:#f8f8f8}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .sub-list .table-row:hover .table-column.serial .sr-no vui-checkbox,::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .sub-list .table-row.active .table-column.serial .sr-no vui-checkbox{opacity:1}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .sub-list .table-row .table-column{height:32px}::ng-deep .assessment-list-body ul{padding:0;margin:0}::ng-deep .assessment-list-body ul.assessment{max-height:calc(100vh - 240px);overflow:auto;padding:16px 12px 0 0;width:calc(100% + 12px)}::ng-deep .assessment-list-body ul.assessment::-webkit-scrollbar-track{background-color:#fff;position:absolute}::ng-deep .assessment-list-body ul.assessment::-webkit-scrollbar{width:3px;height:3px;background-color:transparent;position:absolute}::ng-deep .assessment-list-body ul.assessment::-webkit-scrollbar-thumb{border-radius:3px;background-color:#dbdbdb;position:absolute}::ng-deep .assessment-list-body ul.assessment li{padding:0 0 12px;list-style:none;display:flex;align-items:center;justify-content:space-between}::ng-deep .assessment-list-body ul.assessment li vui-checkbox{width:calc(100% - 260px)}::ng-deep .assessment-list-body ul.assessment li vui-checkbox .radio-item .value .name{font-size:12px;color:#161b2f;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .assessment-list-body ul.assessment li .right{display:flex;align-items:center}::ng-deep .assessment-list-body ul.assessment li .right .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}::ng-deep .assessment-list-body ul.assessment li .right .buttons{display:flex;width:0;overflow:hidden;transition:all .2s ease-in-out}::ng-deep .assessment-list-body ul.assessment li .right .buttons button.action-btn{background:#fff;border:1px solid #f1f1f1;border-radius:2px;color:#1e5dd3;font-size:11px;font-weight:500;line-height:24px;text-transform:uppercase;padding:0 8px;margin-left:12px;display:flex;align-items:center}::ng-deep .assessment-list-body ul.assessment li .right .buttons button.action-btn i{margin-right:4px}::ng-deep .assessment-list-body ul.assessment li .right .buttons button.action-btn+button{margin-left:4px}::ng-deep .assessment-list-body ul.assessment li:hover .right .buttons{width:156px}.within-part{display:flex;align-items:center;padding-right:12px}.within-part .value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;font-size:12px;color:#747576}.within-box{background:#f1f1f1;border-radius:2px;color:#042e7d;font-size:9px;font-weight:600;text-transform:uppercase;padding:0 4px;margin-right:8px;line-height:12px}@keyframes animate-right{0%{transform:translate(100%)}to{transform:translate(0)}}.wf-action-list{width:220px}.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}.wf-action-list ul.action-item{display:block}.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}.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}.wf-action-list ul.action-item li button .file-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;width:calc(100% - 16px)}.wf-action-list ul.action-item li button i{font-size:16px;margin-right:10px;color:#1e5dd3}.wf-action-list ul.action-item li button:hover{background:#f3f3f3}.wf-action-list ul.action-item li .avatar-card{display:flex;align-items:center;width:100%;padding:7.5px}.wf-action-list ul.action-item li .avatar-card.within-con{display:block}.wf-action-list ul.action-item li .avatar-card .avatar{height:24px;width:24px!important;min-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}.wf-action-list ul.action-item li .avatar-card .avatar img{background:#fff;width:100%;height:100%}.wf-action-list ul.action-item li .avatar-card .avatar+span.value{width:calc(100% - 29px)}.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}.wf-action-list ul.action-item li .avatar-card span.value i{font-size:8px;color:#747576;cursor:pointer;margin-right:5px}.wf-action-list ul.action-item li .avatar-card.no-image{display:block}.wf-action-list ul.action-item li .avatar-card.no-image span.value{width:100%;display:block}.wf-action-list ul.action-item li .avatar-card i.delete-icon{color:#d93b41;cursor:pointer;font-size:14px}.wf-action-list ul.action-item li .chip-item{color:#1e5dd3;padding:10px;display:flex;align-items:center}.wf-action-list ul.action-item li .chip-item i{color:#747576;margin-left:7px;font-size:10px;cursor:pointer;display:inline-flex}.wf-action-list ul.action-item li .chip-item span{display:block;width:auto;width:calc(100% - 17px);font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wf-action-list ul.action-item li .chip-item span.chip-block{display:block;width:100%}.wf-action-list ul.action-item li .chip-item span.id{font-size:9px}.wf-action-list ul.action-item li .within{display:flex;align-items:center;justify-content:flex-start}.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}.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}.wf-action-list ul.action-item li:first-child{animation:action-list-open .25s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(2){animation:action-list-open .35s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(3){animation:action-list-open .45s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(4){animation:action-list-open .55s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(5){animation:action-list-open .65s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(6){animation:action-list-open .75s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(7){animation:action-list-open .85s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(8){animation:action-list-open .95s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(9){animation:action-list-open 1.05s cubic-bezier(.25,.46,.45,.94) both}.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)}}\n"] }]
|
|
44449
|
-
}], ctorParameters: function () { return [{ type: AssessmentService }, { type: AuthService$1 }]; }, propDecorators: { isEdit: [{
|
|
44450
|
-
type: Input
|
|
44451
|
-
}], setSelected: [{
|
|
44452
|
-
type: Input,
|
|
44453
|
-
args: ['selectedAssessment']
|
|
44454
|
-
}], selectedAssessmentData: [{
|
|
44455
|
-
type: Input
|
|
44456
|
-
}], onAssessmentSelect: [{
|
|
44457
|
-
type: Output
|
|
44458
|
-
}], cancelAssessment: [{
|
|
44459
|
-
type: Output
|
|
44460
|
-
}] } });
|
|
44461
|
-
|
|
44462
|
-
const CUSTOM_TAG_VALUE_ACCESSOR = {
|
|
44463
|
-
provide: NG_VALUE_ACCESSOR,
|
|
44464
|
-
useExisting: forwardRef(() => CustomFieldComponent),
|
|
44465
|
-
multi: true,
|
|
44466
|
-
};
|
|
44467
|
-
class CustomFieldComponent {
|
|
44468
|
-
constructor() {
|
|
44469
|
-
this.onChanged = (value) => { };
|
|
44470
|
-
this.onTouched = () => { };
|
|
44471
|
-
this.customFields = [];
|
|
44472
|
-
}
|
|
44473
|
-
writeValue(value) {
|
|
44474
|
-
this.setField(value);
|
|
44475
|
-
}
|
|
44476
|
-
registerOnChange(fn) {
|
|
44477
|
-
this.onChanged = fn;
|
|
44478
|
-
}
|
|
44479
|
-
registerOnTouched(fn) {
|
|
44480
|
-
this.onTouched = fn;
|
|
44481
|
-
}
|
|
44482
|
-
setDisabledState(isDisabled) {
|
|
44483
|
-
this.disabled = isDisabled;
|
|
44484
|
-
}
|
|
44485
|
-
valChange() {
|
|
44486
|
-
const field = this.customFields.map((ele) => ele?.name);
|
|
44487
|
-
this.onChanged(field);
|
|
44488
|
-
this.onTouched();
|
|
44489
|
-
}
|
|
44490
|
-
setField(arrayOfFields) {
|
|
44491
|
-
if (arrayOfFields?.length) {
|
|
44492
|
-
this.customFields = arrayOfFields.map((ele) => { return { name: ele }; });
|
|
44493
|
-
}
|
|
44494
|
-
else {
|
|
44495
|
-
this.customFields = [{ name: '' }];
|
|
44496
|
-
}
|
|
44497
|
-
this.focus();
|
|
44498
|
-
}
|
|
44499
|
-
addCustomField() {
|
|
44500
|
-
this.customFields.push({ name: '', isEditing: true });
|
|
44501
|
-
}
|
|
44502
|
-
manipulateCustomField(type, index) {
|
|
44503
|
-
switch (type) {
|
|
44504
|
-
case 'ADD': {
|
|
44505
|
-
this.customFields.push({ name: '', isEditing: true });
|
|
44506
|
-
this.valChange();
|
|
44507
|
-
this.focus();
|
|
44508
|
-
break;
|
|
44509
|
-
}
|
|
44510
|
-
case 'DELETE': {
|
|
44511
|
-
if (this.customFields?.length > 1) {
|
|
44512
|
-
this.customFields.splice(index, 1);
|
|
44513
|
-
this.valChange();
|
|
44514
|
-
this.focus();
|
|
44515
|
-
}
|
|
44516
|
-
break;
|
|
44517
|
-
}
|
|
44518
|
-
}
|
|
44519
|
-
}
|
|
44520
|
-
focus() {
|
|
44521
|
-
setTimeout(() => {
|
|
44522
|
-
this.fields['_results'][this.fields.length - 1].nativeElement.focus();
|
|
44523
|
-
this.fields['_results'][this.fields.length - 1].nativeElement.scrollIntoView({ behavior: 'smooth', block: 'center' });
|
|
44524
|
-
}, 100);
|
|
44525
|
-
}
|
|
44526
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CustomFieldComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
44527
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CustomFieldComponent, selector: "custom-field", inputs: { disabled: "disabled" }, providers: [CUSTOM_TAG_VALUE_ACCESSOR], viewQueries: [{ propertyName: "fields", predicate: ["custom_fields"], descendants: true, read: ElementRef }], ngImport: i0, template: "\n <ng-container *ngFor=\"let field of customFields; let i = index\">\n <!-- <div class=\"selected\" *ngIf=\"field?.name && !field?.isEditing \">\n <div (click)=\"manipulateCustomField('ACTIVATE')\" class=\"custom-text vx-fs-13 vx-paragraph-txt\">CUSTOM TAG TEXT HERE</div>\n <button *ngIf=\"customFields?.length > 1\" (click)=\"manipulateCustomField('DELETE',i)\" class=\"cross-btn vx-fs-12 vx-txt-red vx-p-0 vx-m-0 vx-ml-2 vx-d-flex vx-align-center vx-justify-center\"><i class=\"icons\"></i></button>\n </div> -->\n\n <div class=\"custom-input vx-mt-2\" >\n <input #custom_fields (keyup.enter)=\"manipulateCustomField('ADD')\" (keyup.backspace)=\"field?.name?.length ? null : manipulateCustomField('DELETE',i)\" [(ngModel)]=\"field.name\" (ngModelChange)=\"valChange()\" type=\"text\" placeholder=\"Add a field name\" [ngModelOptions]=\"{standalone: true}\">\n <button *ngIf=\"customFields?.length > 1\" (click)=\"manipulateCustomField('DELETE',i)\" class=\"cross-btn vx-fs-12 vx-txt-red vx-p-0 vx-m-0 vx-ml-2 vx-d-flex vx-align-center vx-justify-center\"><i class=\"icons\"></i></button>\n </div>\n </ng-container>\n\n <div class=\"vx-d-flex vx-align-center vx-justify-end vx-mt-2\">\n <button (click)=\"manipulateCustomField('ADD')\" class=\"add-more-btn vx-fs-11 vx-fw-600 vx-txt-blue vx-tt-uppercase vx-p-0 vx-m-0\">+ ADD MORE\n FIELDS</button>\n </div>\n", styles: [""], dependencies: [{ kind: "directive", type: i1$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1$3.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$3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); }
|
|
44528
|
-
}
|
|
44529
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CustomFieldComponent, decorators: [{
|
|
44530
|
-
type: Component,
|
|
44531
|
-
args: [{ selector: 'custom-field', providers: [CUSTOM_TAG_VALUE_ACCESSOR], template: "\n <ng-container *ngFor=\"let field of customFields; let i = index\">\n <!-- <div class=\"selected\" *ngIf=\"field?.name && !field?.isEditing \">\n <div (click)=\"manipulateCustomField('ACTIVATE')\" class=\"custom-text vx-fs-13 vx-paragraph-txt\">CUSTOM TAG TEXT HERE</div>\n <button *ngIf=\"customFields?.length > 1\" (click)=\"manipulateCustomField('DELETE',i)\" class=\"cross-btn vx-fs-12 vx-txt-red vx-p-0 vx-m-0 vx-ml-2 vx-d-flex vx-align-center vx-justify-center\"><i class=\"icons\"></i></button>\n </div> -->\n\n <div class=\"custom-input vx-mt-2\" >\n <input #custom_fields (keyup.enter)=\"manipulateCustomField('ADD')\" (keyup.backspace)=\"field?.name?.length ? null : manipulateCustomField('DELETE',i)\" [(ngModel)]=\"field.name\" (ngModelChange)=\"valChange()\" type=\"text\" placeholder=\"Add a field name\" [ngModelOptions]=\"{standalone: true}\">\n <button *ngIf=\"customFields?.length > 1\" (click)=\"manipulateCustomField('DELETE',i)\" class=\"cross-btn vx-fs-12 vx-txt-red vx-p-0 vx-m-0 vx-ml-2 vx-d-flex vx-align-center vx-justify-center\"><i class=\"icons\"></i></button>\n </div>\n </ng-container>\n\n <div class=\"vx-d-flex vx-align-center vx-justify-end vx-mt-2\">\n <button (click)=\"manipulateCustomField('ADD')\" class=\"add-more-btn vx-fs-11 vx-fw-600 vx-txt-blue vx-tt-uppercase vx-p-0 vx-m-0\">+ ADD MORE\n FIELDS</button>\n </div>\n" }]
|
|
44532
|
-
}], ctorParameters: function () { return []; }, propDecorators: { fields: [{
|
|
44533
|
-
type: ViewChildren,
|
|
44534
|
-
args: ['custom_fields', { read: ElementRef }]
|
|
44535
|
-
}], disabled: [{
|
|
44536
|
-
type: Input
|
|
44537
|
-
}] } });
|
|
44538
|
-
|
|
44539
|
-
class ListToIdPipe {
|
|
44540
|
-
transform(value, arg) {
|
|
44541
|
-
return value.map((ele) => ele[arg]);
|
|
44542
|
-
}
|
|
44543
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ListToIdPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
44544
|
-
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: ListToIdPipe, name: "listToId" }); }
|
|
44545
|
-
}
|
|
44546
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ListToIdPipe, decorators: [{
|
|
44547
|
-
type: Pipe,
|
|
44548
|
-
args: [{
|
|
44549
|
-
name: 'listToId'
|
|
44550
|
-
}]
|
|
44551
|
-
}] });
|
|
44552
|
-
|
|
44553
|
-
class AssessmentResolverPipe {
|
|
44554
|
-
transform(value, ...args) {
|
|
44555
|
-
if (value && value?.length) {
|
|
44556
|
-
value = value.filter((ele) => ele?.assessmentIds?.length);
|
|
44557
|
-
const val = Object.assign(JSON.parse(JSON.stringify(value
|
|
44558
|
-
.map((category) => category.assessmentIds.map((assessment) => {
|
|
44559
|
-
return { ...assessment, category_id: category.category_id };
|
|
44560
|
-
}))
|
|
44561
|
-
?.flat())));
|
|
44562
|
-
return val;
|
|
44563
|
-
}
|
|
44564
|
-
else {
|
|
44565
|
-
return [];
|
|
44566
|
-
}
|
|
44567
|
-
}
|
|
44568
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AssessmentResolverPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
44569
|
-
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: AssessmentResolverPipe, name: "assessmentResolver" }); }
|
|
44570
|
-
}
|
|
44571
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AssessmentResolverPipe, decorators: [{
|
|
44572
|
-
type: Pipe,
|
|
44573
|
-
args: [{
|
|
44574
|
-
name: 'assessmentResolver',
|
|
44575
|
-
}]
|
|
44576
|
-
}] });
|
|
44577
|
-
|
|
44578
|
-
class ArrayConcatPipe {
|
|
44579
|
-
transform(value, ...args) {
|
|
44580
|
-
return [...value, ...args[0]];
|
|
44581
|
-
}
|
|
44582
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ArrayConcatPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
44583
|
-
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: ArrayConcatPipe, name: "arrayConcat" }); }
|
|
44584
|
-
}
|
|
44585
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ArrayConcatPipe, decorators: [{
|
|
44586
|
-
type: Pipe,
|
|
44587
|
-
args: [{
|
|
44588
|
-
name: 'arrayConcat'
|
|
44589
|
-
}]
|
|
44590
|
-
}] });
|
|
43939
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AssessmentResolverPipe, decorators: [{
|
|
43940
|
+
type: Pipe,
|
|
43941
|
+
args: [{
|
|
43942
|
+
name: 'assessmentResolver',
|
|
43943
|
+
}]
|
|
43944
|
+
}] });
|
|
44591
43945
|
|
|
44592
43946
|
class WorkflowProgramComponent {
|
|
44593
43947
|
constructor(fb, programService, authService, uiKitService, changeRef, iframeService) {
|
|
@@ -45330,9 +44684,6 @@ class WorkflowProgramComponent {
|
|
|
45330
44684
|
if (this.controls?.all_user_in_role?.value) {
|
|
45331
44685
|
this.setFormField('program_owners', res?.data);
|
|
45332
44686
|
}
|
|
45333
|
-
else {
|
|
45334
|
-
this.setDefaultOwners(res?.data, calledFrom);
|
|
45335
|
-
}
|
|
45336
44687
|
},
|
|
45337
44688
|
error: (err) => { },
|
|
45338
44689
|
});
|
|
@@ -45384,24 +44735,6 @@ class WorkflowProgramComponent {
|
|
|
45384
44735
|
next: (res) => {
|
|
45385
44736
|
this.lists.ALL_USER = res;
|
|
45386
44737
|
this.lists.ASSIGNEES = res;
|
|
45387
|
-
this.lists.REVIEWERS = res;
|
|
45388
|
-
this.lists.OVERSEERS = res;
|
|
45389
|
-
if (this.mode !== 'EDIT') {
|
|
45390
|
-
this.lists.DEFAULT_ASSIGNEES = res;
|
|
45391
|
-
this.lists.DEFAULT_REVIEWERS = res;
|
|
45392
|
-
this.lists.DEFAULT_OVERSEERS = res;
|
|
45393
|
-
}
|
|
45394
|
-
else if (this.mode === 'EDIT') {
|
|
45395
|
-
if (!this.controls.program_assignee?.value?.length) {
|
|
45396
|
-
this.lists.DEFAULT_ASSIGNEES = res;
|
|
45397
|
-
}
|
|
45398
|
-
if (!this.controls.program_reviewer?.value?.length) {
|
|
45399
|
-
this.lists.DEFAULT_REVIEWERS = res;
|
|
45400
|
-
}
|
|
45401
|
-
if (!this.controls.program_overseer?.value?.length) {
|
|
45402
|
-
this.lists.DEFAULT_OVERSEERS = res;
|
|
45403
|
-
}
|
|
45404
|
-
}
|
|
45405
44738
|
this.listLoadingState.USERS = false;
|
|
45406
44739
|
this.refreshList();
|
|
45407
44740
|
},
|
|
@@ -45415,13 +44748,6 @@ class WorkflowProgramComponent {
|
|
|
45415
44748
|
next: (res) => {
|
|
45416
44749
|
this.lists.ALL_GROUP = res;
|
|
45417
44750
|
this.lists.ASSIGNEES_GROUP = res;
|
|
45418
|
-
this.lists.REVIEWERS_GROUP = res;
|
|
45419
|
-
this.lists.OVERSEERS_GROUP = res;
|
|
45420
|
-
if (this.mode !== 'EDIT') {
|
|
45421
|
-
this.lists.DEFAULT_ASSIGNEES_GROUP = res;
|
|
45422
|
-
this.lists.DEFAULT_REVIEWERS_GROUP = res;
|
|
45423
|
-
this.lists.DEFAULT_OVERSEERS_GROUP = res;
|
|
45424
|
-
}
|
|
45425
44751
|
if (data) {
|
|
45426
44752
|
this.populateGroupsByGID(data, 'owners');
|
|
45427
44753
|
this.populateGroupsByGID(data, 'collaborators');
|
|
@@ -45874,11 +45200,11 @@ class WorkflowProgramComponent {
|
|
|
45874
45200
|
}
|
|
45875
45201
|
}
|
|
45876
45202
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: WorkflowProgramComponent, deps: [{ token: i1$3.UntypedFormBuilder }, { token: ProgramsService }, { token: AuthService$1 }, { token: UiKitService }, { token: i0.ChangeDetectorRef }, { token: IframeService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
45877
|
-
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 ></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\" ></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\"></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\"></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 ></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\"></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 ></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 ></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\"></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 ></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')\"></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\"></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 ></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 ></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\"></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\"></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 ></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 ></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\"></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\"></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\"></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 ></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 ></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')\"></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\"></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')\"></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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')\"></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\"></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 ></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 ></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 ></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<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 === '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 === 'COLLABORATORS'\"\n [groupEnabled]=\"true\"\n [singleSelect]=\"false\"\n [loading]=\"listLoadingState.USERS\"\n [userlist]=\"lists?.ASSIGNEES ?? []\"\n [selectedUsers]=\"controls?.collaborators?.value | refDisconnect\"\n [groupList]=\"lists?.ASSIGNEES_GROUP ?? []\"\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<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>", 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$3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1$3.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$3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1$3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1$3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i4.MarxEditorComponent, selector: "vcomply-editor", inputs: ["editorConfig"], outputs: ["comment", "sendSavedFiles", "popup"] }, { kind: "directive", type: i1$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: CsRadioComponent, selector: "app-cs-radio", inputs: ["disabled", "readonly", "name", "checked", "value", "oneLine"], outputs: ["checkedEvent"] }, { kind: "directive", type: ToolTipDirective, selector: "[appTooltip]", inputs: ["appTooltip", "placement", "type", "tooltipMandatory", "showTooltip", "animate"] }, { kind: "component", type: PopoverComponent, selector: "app-popover", inputs: ["dontCloseonClick"] }, { kind: "directive", type: PopoverDirective, selector: "[appPopover]", inputs: ["refrence", "placement"] }, { kind: "directive", type: i1$3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: LoaderInlineComponent, selector: "app-loader-inline" }, { kind: "component", type: SmileyDialogInlineComponent, selector: "app-smiley-dialog-inline", inputs: ["message", "actionButtons"], outputs: ["action", "closeSmiley"] }, { kind: "component", type: PopoverHoverComponent, selector: "popover-hover" }, { kind: "directive", type: PopoverHoverDirective, selector: "[libPopoverHover]", inputs: ["placement"] }, { kind: "component", type: TabSelector, selector: "tab-selector", inputs: ["disabled", "selectedItem", "displayArray"], outputs: ["onValueChanged"] }, { kind: "component", type: FormFieldComponent, selector: "form-field", inputs: ["active", "disabled", "checked", "img"] }, { kind: "component", type: InputWithPillComponent, selector: "input-with-pill", inputs: ["placeholder", "disabled", "selectDiv", "line"], outputs: ["select"] }, { kind: "directive", type: InputTrimDirective, selector: "[InputTrim]" }, { kind: "component", type: RoleListComponent, selector: "role-list", inputs: ["featureflagrole", "featureflagGroup", "ff_rc_listing", "list", "loading", "selected"], outputs: ["save", "cancel"] }, { kind: "component", type: 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: AssessmentPickerComponent, selector: "assessment-picker", inputs: ["isEdit", "selectedAssessment", "selectedAssessmentData"], outputs: ["onAssessmentSelect", "cancelAssessment"] }, { kind: "component", type: CustomFieldComponent, selector: "custom-field", inputs: ["disabled"] }, { kind: "component", type: ResponsibilityCentersListComponent, selector: "app-responsibility-centers-list", inputs: ["responsibilityCentersList", "selectedResponsibilityCenters", "rcIdKey", "radioSelection", "pluralText", "singularText", "loaded"], outputs: ["saveSelectedList", "closeRcList"] }, { kind: "component", type: FrameworkListComponent, selector: "app-framework-list", inputs: ["previousSelectedValues", "headerText", "workflowPage", "policy", "frameWorkList", "selectedFrameWork", "selectedCategories"], outputs: ["entrustFramework", "closeFramework", "assignControl"] }, { kind: "pipe", type: i1$1.SlicePipe, name: "slice" }, { kind: "pipe", type: ListToIdPipe, name: "listToId" }, { kind: "pipe", type: RefDisconnectPipe, name: "refDisconnect" }, { kind: "pipe", type: AssessmentResolverPipe, name: "assessmentResolver" }, { kind: "pipe", type: ArrayConcatPipe, name: "arrayConcat" }] }); }
|
|
45203
|
+
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 ></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\" ></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\"></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\"></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 ></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\"></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 ></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 ></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\"></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 ></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')\"></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\"></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 ></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 ></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\"></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\"></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 ></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 ></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\"></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\"></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\"></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 ></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 ></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')\"></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\"></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')\"></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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')\"></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\"></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 ></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 ></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 ></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$3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1$3.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$3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1$3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1$3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i4.MarxEditorComponent, selector: "vcomply-editor", inputs: ["editorConfig"], outputs: ["comment", "sendSavedFiles", "popup"] }, { kind: "directive", type: i1$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: CsRadioComponent, selector: "app-cs-radio", inputs: ["disabled", "readonly", "name", "checked", "value", "oneLine"], outputs: ["checkedEvent"] }, { kind: "directive", type: ToolTipDirective, selector: "[appTooltip]", inputs: ["appTooltip", "placement", "type", "tooltipMandatory", "showTooltip", "animate"] }, { kind: "component", type: PopoverComponent, selector: "app-popover", inputs: ["dontCloseonClick"] }, { kind: "directive", type: PopoverDirective, selector: "[appPopover]", inputs: ["refrence", "placement"] }, { kind: "directive", type: i1$3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: LoaderInlineComponent, selector: "app-loader-inline" }, { kind: "component", type: SmileyDialogInlineComponent, selector: "app-smiley-dialog-inline", inputs: ["message", "actionButtons"], outputs: ["action", "closeSmiley"] }, { kind: "component", type: PopoverHoverComponent, selector: "popover-hover" }, { kind: "directive", type: PopoverHoverDirective, selector: "[libPopoverHover]", inputs: ["placement"] }, { kind: "component", type: TabSelector, selector: "tab-selector", inputs: ["disabled", "selectedItem", "displayArray"], outputs: ["onValueChanged"] }, { kind: "component", type: FormFieldComponent, selector: "form-field", inputs: ["active", "disabled", "checked", "img"] }, { kind: "component", type: InputWithPillComponent, selector: "input-with-pill", inputs: ["placeholder", "disabled", "selectDiv", "line"], outputs: ["select"] }, { kind: "directive", type: InputTrimDirective, selector: "[InputTrim]" }, { kind: "component", type: 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: CustomFieldComponent, selector: "custom-field", inputs: ["disabled"] }, { kind: "component", type: FrameworkListComponent, selector: "app-framework-list", inputs: ["previousSelectedValues", "headerText", "workflowPage", "policy", "frameWorkList", "selectedFrameWork", "selectedCategories"], outputs: ["entrustFramework", "closeFramework", "assignControl"] }, { kind: "pipe", type: i1$1.SlicePipe, name: "slice" }, { kind: "pipe", type: ListToIdPipe, name: "listToId" }, { kind: "pipe", type: RefDisconnectPipe, name: "refDisconnect" }, { kind: "pipe", type: AssessmentResolverPipe, name: "assessmentResolver" }] }); }
|
|
45878
45204
|
}
|
|
45879
45205
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: WorkflowProgramComponent, decorators: [{
|
|
45880
45206
|
type: Component,
|
|
45881
|
-
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 ></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\" ></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\"></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\"></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 ></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\"></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 ></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 ></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\"></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 ></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')\"></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\"></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 ></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 ></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\"></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\"></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 ></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 ></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\"></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\"></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\"></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 ></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 ></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')\"></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\"></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')\"></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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')\"></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\"></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 ></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 ></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 ></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<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 === '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 === 'COLLABORATORS'\"\n [groupEnabled]=\"true\"\n [singleSelect]=\"false\"\n [loading]=\"listLoadingState.USERS\"\n [userlist]=\"lists?.ASSIGNEES ?? []\"\n [selectedUsers]=\"controls?.collaborators?.value | refDisconnect\"\n [groupList]=\"lists?.ASSIGNEES_GROUP ?? []\"\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<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>", 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"] }]
|
|
45207
|
+
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 ></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\" ></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\"></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\"></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 ></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\"></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 ></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 ></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\"></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 ></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')\"></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\"></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 ></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 ></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\"></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\"></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 ></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 ></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\"></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\"></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\"></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 ></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 ></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')\"></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\"></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')\"></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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')\" ></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')\" ></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\"></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 ></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 ></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 ></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 ></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')\"></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\"></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 ></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 ></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 ></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"] }]
|
|
45882
45208
|
}], ctorParameters: function () { return [{ type: i1$3.UntypedFormBuilder }, { type: ProgramsService }, { type: AuthService$1 }, { type: UiKitService }, { type: i0.ChangeDetectorRef }, { type: IframeService }]; }, propDecorators: { form: [{
|
|
45883
45209
|
type: ViewChild,
|
|
45884
45210
|
args: ['form', { read: ElementRef }]
|
|
@@ -51296,6 +50622,247 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
51296
50622
|
type: Output
|
|
51297
50623
|
}] } });
|
|
51298
50624
|
|
|
50625
|
+
class LoaderComponent {
|
|
50626
|
+
constructor() { }
|
|
50627
|
+
ngOnInit() {
|
|
50628
|
+
}
|
|
50629
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LoaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
50630
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: LoaderComponent, selector: "role-loader", ngImport: i0, template: "<div class=\"assessment-list-item\" *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\n <div class=\"table-row\">\n <div class=\"table-column serial\">\n <div class=\"sr-no\"></div>\n </div>\n <div class=\"table-column name\">\n <div class=\"loader\"></div>\n </div>\n <div class=\"table-column action\">\n <div class=\"loader\"></div>\n </div>\n </div>\n</div>", styles: [".assessment-list-item{border:1px solid #f1f1f1;border-radius:2px;margin-bottom:4px}.assessment-list-item .table-row{display:flex;align-items:center;justify-content:space-between}.assessment-list-item .table-row .table-column{height:48px;position:relative;width:100%;display:flex;align-items:center;padding:0 4px}.assessment-list-item .table-row .table-column.serial{width:32px;max-width:32px;justify-content:center}.assessment-list-item .table-row .table-column.serial .sr-no{width:16px;background:#f8f8f8;writing-mode:vertical-lr;height:100%}.assessment-list-item .table-row .table-column.name{width:calc(100% - 64px);min-width:calc(100% - 64px)}.assessment-list-item .table-row .table-column.name .loader{width:calc(100% - 200px)}.assessment-list-item .table-row .table-column.action{width:32px;max-width:32px;justify-content:center}.assessment-list-item .table-row .table-column.action .loader{width:28px}.loader{background:#f1f1f1;border-radius:20px;height:10px}\n"], dependencies: [{ kind: "directive", type: i1$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] }); }
|
|
50631
|
+
}
|
|
50632
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LoaderComponent, decorators: [{
|
|
50633
|
+
type: Component,
|
|
50634
|
+
args: [{ selector: 'role-loader', template: "<div class=\"assessment-list-item\" *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\n <div class=\"table-row\">\n <div class=\"table-column serial\">\n <div class=\"sr-no\"></div>\n </div>\n <div class=\"table-column name\">\n <div class=\"loader\"></div>\n </div>\n <div class=\"table-column action\">\n <div class=\"loader\"></div>\n </div>\n </div>\n</div>", styles: [".assessment-list-item{border:1px solid #f1f1f1;border-radius:2px;margin-bottom:4px}.assessment-list-item .table-row{display:flex;align-items:center;justify-content:space-between}.assessment-list-item .table-row .table-column{height:48px;position:relative;width:100%;display:flex;align-items:center;padding:0 4px}.assessment-list-item .table-row .table-column.serial{width:32px;max-width:32px;justify-content:center}.assessment-list-item .table-row .table-column.serial .sr-no{width:16px;background:#f8f8f8;writing-mode:vertical-lr;height:100%}.assessment-list-item .table-row .table-column.name{width:calc(100% - 64px);min-width:calc(100% - 64px)}.assessment-list-item .table-row .table-column.name .loader{width:calc(100% - 200px)}.assessment-list-item .table-row .table-column.action{width:32px;max-width:32px;justify-content:center}.assessment-list-item .table-row .table-column.action .loader{width:28px}.loader{background:#f1f1f1;border-radius:20px;height:10px}\n"] }]
|
|
50635
|
+
}], ctorParameters: function () { return []; } });
|
|
50636
|
+
|
|
50637
|
+
class RoleListComponent {
|
|
50638
|
+
constructor() {
|
|
50639
|
+
this.save = new EventEmitter();
|
|
50640
|
+
this.cancel = new EventEmitter();
|
|
50641
|
+
this.animation = true;
|
|
50642
|
+
this.ASSETS = ASSETS;
|
|
50643
|
+
this.searchKey = '';
|
|
50644
|
+
//Used to disable items
|
|
50645
|
+
this.systemRolesIds = [];
|
|
50646
|
+
//used to check checkbox
|
|
50647
|
+
this.selectedIds = [];
|
|
50648
|
+
//complete object of selected items
|
|
50649
|
+
this.selectedRoles = [];
|
|
50650
|
+
//contains id's of all the expanded rows
|
|
50651
|
+
this.expandedRows = [];
|
|
50652
|
+
//list of all the available roles
|
|
50653
|
+
this.rolesList = [];
|
|
50654
|
+
this.initialSelected = null;
|
|
50655
|
+
this.showConfirmation = false;
|
|
50656
|
+
// only used in select all function
|
|
50657
|
+
this.allListIds = [];
|
|
50658
|
+
//isAllItems
|
|
50659
|
+
this.allSelected = false;
|
|
50660
|
+
this.loading = false;
|
|
50661
|
+
}
|
|
50662
|
+
ngOnInit() {
|
|
50663
|
+
this.animation = true;
|
|
50664
|
+
setTimeout(() => {
|
|
50665
|
+
this.animation = false;
|
|
50666
|
+
}, 300);
|
|
50667
|
+
}
|
|
50668
|
+
set setList(value) {
|
|
50669
|
+
if (value && value?.length) {
|
|
50670
|
+
this.rolesList = [...value];
|
|
50671
|
+
this.setSystemRole(this.rolesList);
|
|
50672
|
+
this.allListIds = this.rolesList.map((ele) => ele?._id);
|
|
50673
|
+
this.setAllSelectedStatus();
|
|
50674
|
+
}
|
|
50675
|
+
}
|
|
50676
|
+
set selectedRolesVal(value) {
|
|
50677
|
+
this.selectedRoles = this.uniqueByProp([...this.selectedRoles, ...value], '_id');
|
|
50678
|
+
this.selectedIds = this.selectedRoles.map((ele) => ele?._id);
|
|
50679
|
+
if (!this.initialSelected || !this.initialSelected?.length) {
|
|
50680
|
+
this.initialSelected = this.selectedIds;
|
|
50681
|
+
}
|
|
50682
|
+
this.setAllSelectedStatus();
|
|
50683
|
+
}
|
|
50684
|
+
/**
|
|
50685
|
+
* #### Description
|
|
50686
|
+
*
|
|
50687
|
+
* Expands or collapse the row
|
|
50688
|
+
* @param type
|
|
50689
|
+
* @param [id]
|
|
50690
|
+
*/
|
|
50691
|
+
expandOrCollapse(type, id) {
|
|
50692
|
+
switch (type) {
|
|
50693
|
+
case 'COLLAPSE': {
|
|
50694
|
+
this.expandedRows = this.expandedRows.filter((ele) => ele !== id);
|
|
50695
|
+
break;
|
|
50696
|
+
}
|
|
50697
|
+
case 'EXPAND': {
|
|
50698
|
+
this.expandedRows = Array.from(new Set([...this.expandedRows, ...[id]]));
|
|
50699
|
+
break;
|
|
50700
|
+
}
|
|
50701
|
+
case 'COLLAPSE_ALL': {
|
|
50702
|
+
this.expandedRows = [];
|
|
50703
|
+
break;
|
|
50704
|
+
}
|
|
50705
|
+
}
|
|
50706
|
+
}
|
|
50707
|
+
selectAll(evt) {
|
|
50708
|
+
if (evt?.target?.checked === true) {
|
|
50709
|
+
this.selectedRoles = this.rolesList;
|
|
50710
|
+
this.selectedIds = this.rolesList.map((ele) => ele?._id);
|
|
50711
|
+
}
|
|
50712
|
+
else {
|
|
50713
|
+
this.selectedRoles = [];
|
|
50714
|
+
this.selectedIds = [];
|
|
50715
|
+
this.setSystemRole(this.rolesList);
|
|
50716
|
+
}
|
|
50717
|
+
this.setAllSelectedStatus();
|
|
50718
|
+
}
|
|
50719
|
+
setAllSelectedStatus() {
|
|
50720
|
+
this.allSelected =
|
|
50721
|
+
this.allListIds.sort().toString() === this.selectedIds.sort()?.toString();
|
|
50722
|
+
}
|
|
50723
|
+
/**
|
|
50724
|
+
* #### Description
|
|
50725
|
+
*
|
|
50726
|
+
* Sets system role for admins and key admins
|
|
50727
|
+
* @param roles
|
|
50728
|
+
*/
|
|
50729
|
+
setSystemRole(roles) {
|
|
50730
|
+
const systemRoles = roles.filter((ele) => ele?.roleName?.toLowerCase() === 'key admin' ||
|
|
50731
|
+
ele?.roleName?.toLowerCase() === 'admin');
|
|
50732
|
+
this.systemRolesIds = Array.from(new Set([
|
|
50733
|
+
...this.systemRolesIds,
|
|
50734
|
+
...systemRoles.map((ele) => ele?._id),
|
|
50735
|
+
]));
|
|
50736
|
+
this.selectedIds = Array.from(new Set([...this.selectedIds, ...this.systemRolesIds]));
|
|
50737
|
+
this.selectedRoles = this.uniqueByProp([...systemRoles, ...this.selectedRoles], '_id');
|
|
50738
|
+
}
|
|
50739
|
+
/**
|
|
50740
|
+
* #### Description
|
|
50741
|
+
* Selects item or deselect a itme
|
|
50742
|
+
* @param evt
|
|
50743
|
+
* @param payload
|
|
50744
|
+
*/
|
|
50745
|
+
selectItem(evt, payload) {
|
|
50746
|
+
evt?.target?.checked === true
|
|
50747
|
+
? this.manipulateSelectedItems('ADD', payload)
|
|
50748
|
+
: this.manipulateSelectedItems('DELETE', payload);
|
|
50749
|
+
}
|
|
50750
|
+
/**
|
|
50751
|
+
* #### Description
|
|
50752
|
+
*
|
|
50753
|
+
* Manipulates selected items in role list
|
|
50754
|
+
* @param action :'ADD' | 'DELETE'
|
|
50755
|
+
* @param payload
|
|
50756
|
+
*/
|
|
50757
|
+
manipulateSelectedItems(action, payload) {
|
|
50758
|
+
if (action === 'ADD') {
|
|
50759
|
+
this.selectedRoles = this.uniqueByProp([...this.selectedRoles, ...[payload]], '_id');
|
|
50760
|
+
this.selectedIds = this.selectedRoles.map((ele) => ele?._id);
|
|
50761
|
+
}
|
|
50762
|
+
else if (action === 'DELETE') {
|
|
50763
|
+
let index = this.selectedRoles.findIndex((ele) => ele?._id === payload?._id);
|
|
50764
|
+
if (index > -1) {
|
|
50765
|
+
this.selectedRoles = this.selectedRoles.filter((ele) => ele?._id !== payload?._id);
|
|
50766
|
+
this.selectedIds = this.selectedIds.filter((ele) => ele !== payload?._id);
|
|
50767
|
+
}
|
|
50768
|
+
}
|
|
50769
|
+
this.setAllSelectedStatus();
|
|
50770
|
+
}
|
|
50771
|
+
saveList() {
|
|
50772
|
+
if (this.initialSelected?.sort()?.toString() !==
|
|
50773
|
+
this.selectedIds.sort()?.toString()) {
|
|
50774
|
+
this.showConfirmation = true;
|
|
50775
|
+
}
|
|
50776
|
+
else {
|
|
50777
|
+
this.save.emit(this.selectedRoles);
|
|
50778
|
+
}
|
|
50779
|
+
}
|
|
50780
|
+
confirmAction(evt) {
|
|
50781
|
+
if (evt === 'YES') {
|
|
50782
|
+
this.save.emit(this.selectedRoles);
|
|
50783
|
+
}
|
|
50784
|
+
else if (evt === 'NO') {
|
|
50785
|
+
this.showConfirmation = false;
|
|
50786
|
+
}
|
|
50787
|
+
}
|
|
50788
|
+
closeList() {
|
|
50789
|
+
this.cancel.emit();
|
|
50790
|
+
}
|
|
50791
|
+
/**
|
|
50792
|
+
* #### Description
|
|
50793
|
+
*
|
|
50794
|
+
* Returns the unique array of object based on unique key
|
|
50795
|
+
* @param array
|
|
50796
|
+
* @param key
|
|
50797
|
+
* @returns
|
|
50798
|
+
*/
|
|
50799
|
+
uniqueByProp(array, key) {
|
|
50800
|
+
return Array.from(array
|
|
50801
|
+
.reduce((acc, item) => (item && item[key] && acc.set(item[key], item), acc), new Map())
|
|
50802
|
+
.values());
|
|
50803
|
+
}
|
|
50804
|
+
//view and manage roles and groups text changed with featureflag
|
|
50805
|
+
permissionText(permission) {
|
|
50806
|
+
if (permission == 'view roles') {
|
|
50807
|
+
if (this.ff_rc_listing) {
|
|
50808
|
+
return 'view permissions';
|
|
50809
|
+
}
|
|
50810
|
+
else {
|
|
50811
|
+
return 'view permission groups';
|
|
50812
|
+
}
|
|
50813
|
+
}
|
|
50814
|
+
if (permission == 'manage roles') {
|
|
50815
|
+
if (this.ff_rc_listing) {
|
|
50816
|
+
return 'Manage permissions';
|
|
50817
|
+
}
|
|
50818
|
+
else {
|
|
50819
|
+
return 'Manage permission groups';
|
|
50820
|
+
}
|
|
50821
|
+
}
|
|
50822
|
+
if (permission == 'view groups') {
|
|
50823
|
+
if (this.featureflagGroup) {
|
|
50824
|
+
return 'view user groups';
|
|
50825
|
+
}
|
|
50826
|
+
else {
|
|
50827
|
+
return permission;
|
|
50828
|
+
}
|
|
50829
|
+
}
|
|
50830
|
+
if (permission == 'manage groups') {
|
|
50831
|
+
if (this.featureflagGroup) {
|
|
50832
|
+
return 'Manage user groups';
|
|
50833
|
+
}
|
|
50834
|
+
else {
|
|
50835
|
+
return permission;
|
|
50836
|
+
}
|
|
50837
|
+
}
|
|
50838
|
+
return permission;
|
|
50839
|
+
}
|
|
50840
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: RoleListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
50841
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: RoleListComponent, selector: "role-list", inputs: { featureflagrole: "featureflagrole", featureflagGroup: "featureflagGroup", ff_rc_listing: "ff_rc_listing", setList: ["list", "setList"], loading: "loading", selectedRolesVal: ["selected", "selectedRolesVal"] }, outputs: { save: "save", cancel: "cancel" }, ngImport: i0, template: "<div class=\"roles-list\" [class.animate]=\"animation\">\n <div\n class=\"roles-list-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\"\n >\n <div id=\"titlename\" class=\"vx-fs-14 vx-fw-500 vx-label-txt\">\n {{ ff_rc_listing ? \"Select Permissions\" : \"Select Permission Group(s)\" }}\n </div>\n </div>\n\n <div class=\"roles-list-body\">\n <div class=\"search-block vx-mb-1\" [class.disabled]=\"!rolesList?.length\">\n <i class=\"icons\"></i>\n <input\n type=\"text\"\n [placeholder]=\"\n ff_rc_listing ? 'Search Permissions' : 'Search Permission Groups'\n \"\n [(ngModel)]=\"searchKey\"\n />\n </div>\n <div class=\"vx-mt-4\" *ngIf=\"loading\"><role-loader></role-loader></div>\n\n <ng-container *ngIf=\"!loading\">\n <ng-container\n *ngIf=\"rolesList | search : searchKey : 'roleName' as roles\"\n >\n <div *ngIf=\"roles?.length > 0\" class=\"roles-list-mid vx-mb-4\">\n <div class=\"role-box-select vx-pb-2\">\n <vui-checkbox\n [indeterminateEnabled]=\"false\"\n #check\n (change)=\"selectAll($event)\"\n [(ngModel)]=\"allSelected\"\n [checked]=\"allSelected\"\n >\n <div class=\"user-name vx-fs-12 vx-fw-600 vx-label-txt\">\n {{ !check.checked ? \"Select All\" : \"Deselect All\" }}\n </div>\n </vui-checkbox>\n </div>\n\n <div\n class=\"role-box vx-mb-2\"\n *ngFor=\"let role of roles; let i = index\"\n >\n <div\n (click)=\"\n !expandedRows.includes(role?._id)\n ? expandOrCollapse('EXPAND', role?._id)\n : expandOrCollapse('COLLAPSE', role?._id)\n \"\n class=\"role-box-heading vx-d-flex vx-align-center vx-justify-between vx-p-3\"\n >\n <div class=\"left vx-d-flex vx-align-center vx-lh-4\">\n <vui-checkbox\n [disabled]=\"systemRolesIds.includes(role?._id)\"\n [checked]=\"selectedIds.includes(role?._id)\"\n (change)=\"selectItem($event, role)\"\n >\n </vui-checkbox>\n <div\n class=\"name vx-fs-12 vx-label-txt\"\n [appTooltip]=\"'Role name'\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >\n {{\n featureflagrole && role?.permissionGroupName\n ? role?.permissionGroupName\n : role?.roleName\n }}\n </div>\n <span\n *ngIf=\"role?.roleActions?.length > 0\"\n class=\"count vx-fs-9 vx-fw-600 vx-lh-3 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-ml-2\"\n >{{ role?.roleActions?.length }} PERMISSIONS</span\n >\n </div>\n <div class=\"right vx-d-flex vx-align-center vx-justify-between\">\n <div\n *ngIf=\"role?.licenseType === 'power users'\"\n class=\"status-label vx-fs-9 vx-fw-500 vx-txt-white vx-tt-uppercase vx-pl-1 vx-pr-1\"\n [class.power-user]=\"true\"\n [class.all-user]=\"false\"\n >\n Power User\n </div>\n <div\n *ngIf=\"role?.licenseType === 'light users'\"\n class=\"status-label vx-fs-9 vx-fw-500 vx-txt-white vx-tt-uppercase vx-pl-1 vx-pr-1\"\n [class.power-user]=\"false\"\n [class.all-user]=\"true\"\n >\n Light User\n </div>\n <button\n class=\"arrow-btn vx-fs-12 vx-paragraph-txt vx-m-0 vx-p-0 vx-d-flex vx-align-center\"\n >\n <i *ngIf=\"!expandedRows.includes(role?._id)\" class=\"icons\"\n ></i\n >\n <i *ngIf=\"expandedRows.includes(role?._id)\" class=\"icons\"\n ></i\n >\n </button>\n </div>\n </div>\n <div class=\"role-box-list\" *ngIf=\"expandedRows.includes(role?._id)\">\n <ul class=\"vx-p-0 vx-m-0\">\n <li\n class=\"vx-p-3 vx-lh-4\"\n *ngFor=\"let permission of role?.roleActions\"\n >\n <div class=\"value vx-fs-12 vx-label-txt\">\n {{ permissionText(permission) }}\n </div>\n </li>\n <!-- <li class=\"vx-p-3 vx-lh-4\">\n <div class=\"value vx-fs-12 vx-label-txt\">View User List</div>\n </li>\n <li class=\"vx-p-3 vx-lh-4\">\n <div class=\"value vx-fs-12 vx-label-txt\">Manage Users <span class=\"vx-fs-10 vx-paragraph-txt\">(Create/Edit/Delete/Deactivate)</span></div>\n </li>\n <li class=\"vx-p-3 vx-lh-4\">\n <div class=\"value vx-fs-12 vx-label-txt\">Over-ride Log In</div>\n </li>\n <li class=\"vx-p-3 vx-lh-4\">\n <div class=\"value vx-fs-12 vx-label-txt\">View Statutory Holidays</div>\n </li>\n <li class=\"vx-p-3 vx-lh-4\">\n <div class=\"value vx-fs-12 vx-label-txt\">Manage Statutory Holidays</div>\n </li> -->\n </ul>\n </div>\n </div>\n </div>\n\n <app-no-data\n *ngIf=\"roles?.length === 0\"\n [noDataImage]=\"ASSETS.search_data\"\n [noDataText]=\"\n searchKey?.length > 0 ? 'No match found.' : 'No Roles Found'\n \"\n ></app-no-data>\n </ng-container>\n </ng-container>\n\n <div class=\"roles-list-footer\" *ngIf=\"!showConfirmation\">\n <vui-floating-bar (closeEvent)=\"saveList()\" (closeList)=\"closeList()\">\n <!-- <div class=\"counter\" *ngIf=\"selectedRoles?.length\"\n placement=\"left\">{{selectedRoles?.length}}</div> -->\n <button\n *ngIf=\"selectedRoles?.length\"\n class=\"counter role-list-counter\"\n appPopover\n (click)=\"role.popover()\"\n placement=\"left\"\n >\n {{ selectedRoles?.length }}\n </button>\n <div\n class=\"name\"\n *ngIf=\"selectedRoles?.length > 1\"\n id=\"permissionselected\"\n >\n <span *ngIf=\"selectedRoles?.length === 1\">{{\n featureflagrole ? \"Permission selected\" : \"Role selected\"\n }}</span>\n <span *ngIf=\"selectedRoles?.length > 1\">{{\n featureflagrole ? \"Permissions selected\" : \"Roles selected\"\n }}</span>\n </div>\n </vui-floating-bar>\n\n <app-popover #role [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"let data of selectedRoles\">\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"!systemRolesIds.includes(data?._id)\"\n class=\"icons\"\n (click)=\"selectItem({ target: { checked: false } }, data)\"\n ></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 </div>\n </div>\n\n <div class=\"roles-list-confirmation\" *ngIf=\"showConfirmation\">\n <div class=\"confirmation-top\">\n <div class=\"icon-block\"><i class=\"icons\"></i></div>\n <div class=\"text\" id=\"confirmationmessage\">\n {{\n featureflagrole\n ? \"This action will update the Permission settings and impact the owners selected for the Program.\"\n : \"This action will update the Role settings and impact the owners selected for the Program.\"\n }}\n </div>\n </div>\n <div class=\"confirmation-bottom\">\n <div class=\"message\">Are you sure you would like to proceed?</div>\n <div class=\"button-group\">\n <button class=\"no-btn\" (click)=\"confirmAction('NO')\">NO</button>\n <button class=\"yes-btn\" (click)=\"confirmAction('YES')\">YES</button>\n </div>\n </div>\n </div>\n</div>\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/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";::ng-deep .roles-list{position:fixed;inset:0 500px 0 0}::ng-deep .roles-list:before{background:#1e5dd3;content:\"\";position:absolute;top:0;left:0;right:0;width:100%;height:3px}::ng-deep .roles-list.animate{animation:animate-right .2s cubic-bezier(.25,.46,.45,.94) both;z-index:-1}::ng-deep .roles-list-head{background:#fbfbfb;height:2.75rem;border-bottom:1px solid #f1f1f1}::ng-deep .roles-list-body{background:#fff;height:calc(100vh - 2.75rem);padding:2rem}::ng-deep .roles-list-body .search-block{position:relative}::ng-deep .roles-list-body .search-block input{height:2.75rem;line-height:1.5rem;padding:.5rem 1rem .5rem 2.5rem;outline:none;border:1px solid #7475763f;border-radius:.25rem;width:100%;font-size:14px;color:#747576}::ng-deep .roles-list-body .search-block input:focus{border-color:#1e5dd3}::ng-deep .roles-list-body .search-block i{position:absolute;left:1rem;top:1rem;pointer-events:none;color:#f1f1f1;font-size:12px}::ng-deep .roles-list-mid{width:calc(100% + .75rem);height:calc(100vh - 13.8rem);overflow:hidden;overflow-y:auto;padding-right:.75rem}::ng-deep .roles-list-mid .role-box{border:1px solid #f1f1f1;border-radius:.25rem}::ng-deep .roles-list-mid .role-box-select{background:#fff;position:sticky;top:0;z-index:1}::ng-deep .roles-list-mid .role-box-select vui-checkbox .checkbox-item{position:relative;padding-left:1.75rem;width:100%}::ng-deep .roles-list-mid .role-box-select vui-checkbox .checkbox-item .checkbox,::ng-deep .roles-list-mid .role-box-select vui-checkbox .checkbox-item .checkmark{position:absolute!important;top:0;left:0}::ng-deep .roles-list-mid .role-box-select vui-checkbox .checkbox-item .value{margin:0!important}::ng-deep .roles-list-mid .role-box-heading{cursor:pointer}::ng-deep .roles-list-mid .role-box-heading .left{width:calc(100% - 6.5rem)}::ng-deep .roles-list-mid .role-box-heading .left vui-checkbox{height:1rem}::ng-deep .roles-list-mid .role-box-heading .left vui-checkbox .checkbox-item{position:relative;padding-left:1.75rem;height:1rem}::ng-deep .roles-list-mid .role-box-heading .left vui-checkbox .checkbox-item .checkbox,::ng-deep .roles-list-mid .role-box-heading .left vui-checkbox .checkbox-item .checkmark{position:absolute!important;top:0;left:0}::ng-deep .roles-list-mid .role-box-heading .left .name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;max-width:calc(100% - 9.25rem)}::ng-deep .roles-list-mid .role-box-heading .left .count{background:#f1f1f1;border-radius:.125rem;color:#042e7d}::ng-deep .roles-list-mid .role-box-heading .right{width:6.5rem}::ng-deep .roles-list-mid .role-box-heading .right .status-label{border-radius:.125rem;height:.75rem}::ng-deep .roles-list-mid .role-box-heading .right .status-label.all-user{background:#7aa6f7}::ng-deep .roles-list-mid .role-box-heading .right .status-label.power-user{background:#fadd8a}::ng-deep .roles-list-mid .role-box-heading .right button.arrow-btn{background:transparent;border:none;border-radius:0}::ng-deep .roles-list-mid .role-box-list ul{list-style-type:none}::ng-deep .roles-list-mid .role-box-list ul li{border-top:1px solid #f1f1f1;padding-left:2.5rem!important;position:relative}::ng-deep .roles-list-mid .role-box-list ul li:before{background:#dbdbdb;border-radius:.125rem;width:.25rem;height:.25rem;content:\"\";position:absolute;top:18px;left:18px}::ng-deep .roles-list-mid .role-box-list ul li .value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;text-transform:capitalize}::ng-deep .roles-list-mid .role-box-list ul li vui-checkbox .checkbox-item{width:100%}::ng-deep .roles-list-mid .role-box-list ul li vui-checkbox .checkbox-item span.value{width:100%}::ng-deep .roles-list-mid .role-box-list ul li vui-checkbox .checkbox-item span.value .name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .roles-list-confirmation{background:#161b2f;border-radius:.25rem;position:absolute;left:2rem;right:2rem;bottom:2rem;z-index:1}::ng-deep .roles-list-confirmation .confirmation-top{display:flex;align-items:center;justify-content:flex-start;padding:1.25rem}::ng-deep .roles-list-confirmation .confirmation-top .icon-block{height:2.25rem;width:2.25rem;border-radius:50%;background:#fff;border:1px solid #dbdbdb;display:flex;justify-content:center;align-items:center;margin-right:1rem}::ng-deep .roles-list-confirmation .confirmation-top .icon-block i{color:#eb2424;font-size:12px}::ng-deep .roles-list-confirmation .confirmation-top .text{color:#fff;font-size:14px;font-weight:300}::ng-deep .roles-list-confirmation .confirmation-bottom{background:#282e48;border-radius:0 0 .25rem .25rem;padding:.75rem .75rem .75rem 1.25rem;display:flex;align-items:center;justify-content:space-between}::ng-deep .roles-list-confirmation .confirmation-bottom .message{font-size:14px;font-weight:500;line-height:20px;color:#fff}::ng-deep .roles-list-confirmation .confirmation-bottom .button-group{display:flex}::ng-deep .roles-list-confirmation .confirmation-bottom .button-group button{height:1.5rem;width:4rem;border:1px solid #fff;border-radius:.125rem;display:flex;align-items:center;justify-content:center;line-height:22px;cursor:pointer;font-size:11px;text-transform:uppercase;font-weight:500;padding:0}::ng-deep .roles-list-confirmation .confirmation-bottom .button-group button.no-btn{background:transparent;color:#fff}::ng-deep .roles-list-confirmation .confirmation-bottom .button-group button.yes-btn{background:#fff;color:#1e5dd3;margin-left:.25rem}.counter.role-list-counter{background:#1e5dd3!important;border:1px solid #1E5DD3!important;margin-left:0!important}.name{margin-left:4px}.name b{text-transform:lowercase}.wf-action-list{width:220px}.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}.wf-action-list ul.action-item{display:block}.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}.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}.wf-action-list ul.action-item li button i{font-size:16px;margin-right:10px;color:#1e5dd3}.wf-action-list ul.action-item li button:hover{background:#f3f3f3}.wf-action-list ul.action-item li .avatar-card{display:flex;align-items:center;width:100%;padding:7.5px}.wf-action-list ul.action-item li .avatar-card.within-con{display:block}.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}.wf-action-list ul.action-item li .avatar-card .avatar img{width:100%}.wf-action-list ul.action-item li .avatar-card .avatar+span.value{width:calc(100% - 29px)}.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}.wf-action-list ul.action-item li .avatar-card span.value i{font-size:8px;color:#747576;cursor:pointer;margin-right:5px}.wf-action-list ul.action-item li .avatar-card.no-image{display:block}.wf-action-list ul.action-item li .avatar-card.no-image span.value{width:100%;display:block}.wf-action-list ul.action-item li .chip-item{color:#1e5dd3;padding:10px;display:flex;align-items:center}.wf-action-list ul.action-item li .chip-item i{color:#747576;margin-right:7px;font-size:10px;cursor:pointer;display:inline-flex}.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}.wf-action-list ul.action-item li .chip-item span.chip-block{display:block;width:100%}.wf-action-list ul.action-item li .chip-item span.id{font-size:9px}.wf-action-list ul.action-item li .within{display:flex;align-items:center;justify-content:flex-start}.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}.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}.wf-action-list ul.action-item li:first-child{animation:action-list-open .25s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(2){animation:action-list-open .35s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(3){animation:action-list-open .45s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(4){animation:action-list-open .55s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(5){animation:action-list-open .65s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(6){animation:action-list-open .75s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(7){animation:action-list-open .85s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(8){animation:action-list-open .95s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(9){animation:action-list-open 1.05s cubic-bezier(.25,.46,.45,.94) both}.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)}}\n"], dependencies: [{ kind: "directive", type: i1$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: ToolTipDirective, selector: "[appTooltip]", inputs: ["appTooltip", "placement", "type", "tooltipMandatory", "showTooltip", "animate"] }, { kind: "component", type: PopoverComponent, selector: "app-popover", inputs: ["dontCloseonClick"] }, { kind: "directive", type: PopoverDirective, selector: "[appPopover]", inputs: ["refrence", "placement"] }, { kind: "directive", type: i1$3.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$3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: NoDataComponentUI, selector: "app-no-data", inputs: ["action", "secondaryAction", "noDataImage", "noDataText", "noDataButton", "secondaryButton", "noDataSecButton", "altText", "smallButton"], outputs: ["buttonAction", "secondaryActionButton"] }, { kind: "component", type: CheckboxComponent$1, selector: "vui-checkbox", inputs: ["disabled", "checked", "indeterminateEnabled"] }, { kind: "component", type: VuiFloatingBarComponent, selector: "vui-floating-bar", inputs: ["selectedData", "groupSelected", "displayElementKey", "elementId", "singularText", "pluralText", "showNextButton", "showFrequencyText", "showWorkflow", "workflowText", "currentFrequency", "isDisabled", "workflowList", "selectedWorkflow", "workflowPlaceHolder", "mode", "nextDisabled", "nonRemovableUsersList", "removePosition"], outputs: ["closeEvent", "deleteEvent", "closeList", "workflowTypeChanged"] }, { kind: "component", type: LoaderComponent, selector: "role-loader" }, { kind: "pipe", type: SearchPipe, name: "search" }] }); }
|
|
50842
|
+
}
|
|
50843
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: RoleListComponent, decorators: [{
|
|
50844
|
+
type: Component,
|
|
50845
|
+
args: [{ selector: 'role-list', template: "<div class=\"roles-list\" [class.animate]=\"animation\">\n <div\n class=\"roles-list-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\"\n >\n <div id=\"titlename\" class=\"vx-fs-14 vx-fw-500 vx-label-txt\">\n {{ ff_rc_listing ? \"Select Permissions\" : \"Select Permission Group(s)\" }}\n </div>\n </div>\n\n <div class=\"roles-list-body\">\n <div class=\"search-block vx-mb-1\" [class.disabled]=\"!rolesList?.length\">\n <i class=\"icons\"></i>\n <input\n type=\"text\"\n [placeholder]=\"\n ff_rc_listing ? 'Search Permissions' : 'Search Permission Groups'\n \"\n [(ngModel)]=\"searchKey\"\n />\n </div>\n <div class=\"vx-mt-4\" *ngIf=\"loading\"><role-loader></role-loader></div>\n\n <ng-container *ngIf=\"!loading\">\n <ng-container\n *ngIf=\"rolesList | search : searchKey : 'roleName' as roles\"\n >\n <div *ngIf=\"roles?.length > 0\" class=\"roles-list-mid vx-mb-4\">\n <div class=\"role-box-select vx-pb-2\">\n <vui-checkbox\n [indeterminateEnabled]=\"false\"\n #check\n (change)=\"selectAll($event)\"\n [(ngModel)]=\"allSelected\"\n [checked]=\"allSelected\"\n >\n <div class=\"user-name vx-fs-12 vx-fw-600 vx-label-txt\">\n {{ !check.checked ? \"Select All\" : \"Deselect All\" }}\n </div>\n </vui-checkbox>\n </div>\n\n <div\n class=\"role-box vx-mb-2\"\n *ngFor=\"let role of roles; let i = index\"\n >\n <div\n (click)=\"\n !expandedRows.includes(role?._id)\n ? expandOrCollapse('EXPAND', role?._id)\n : expandOrCollapse('COLLAPSE', role?._id)\n \"\n class=\"role-box-heading vx-d-flex vx-align-center vx-justify-between vx-p-3\"\n >\n <div class=\"left vx-d-flex vx-align-center vx-lh-4\">\n <vui-checkbox\n [disabled]=\"systemRolesIds.includes(role?._id)\"\n [checked]=\"selectedIds.includes(role?._id)\"\n (change)=\"selectItem($event, role)\"\n >\n </vui-checkbox>\n <div\n class=\"name vx-fs-12 vx-label-txt\"\n [appTooltip]=\"'Role name'\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >\n {{\n featureflagrole && role?.permissionGroupName\n ? role?.permissionGroupName\n : role?.roleName\n }}\n </div>\n <span\n *ngIf=\"role?.roleActions?.length > 0\"\n class=\"count vx-fs-9 vx-fw-600 vx-lh-3 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-ml-2\"\n >{{ role?.roleActions?.length }} PERMISSIONS</span\n >\n </div>\n <div class=\"right vx-d-flex vx-align-center vx-justify-between\">\n <div\n *ngIf=\"role?.licenseType === 'power users'\"\n class=\"status-label vx-fs-9 vx-fw-500 vx-txt-white vx-tt-uppercase vx-pl-1 vx-pr-1\"\n [class.power-user]=\"true\"\n [class.all-user]=\"false\"\n >\n Power User\n </div>\n <div\n *ngIf=\"role?.licenseType === 'light users'\"\n class=\"status-label vx-fs-9 vx-fw-500 vx-txt-white vx-tt-uppercase vx-pl-1 vx-pr-1\"\n [class.power-user]=\"false\"\n [class.all-user]=\"true\"\n >\n Light User\n </div>\n <button\n class=\"arrow-btn vx-fs-12 vx-paragraph-txt vx-m-0 vx-p-0 vx-d-flex vx-align-center\"\n >\n <i *ngIf=\"!expandedRows.includes(role?._id)\" class=\"icons\"\n ></i\n >\n <i *ngIf=\"expandedRows.includes(role?._id)\" class=\"icons\"\n ></i\n >\n </button>\n </div>\n </div>\n <div class=\"role-box-list\" *ngIf=\"expandedRows.includes(role?._id)\">\n <ul class=\"vx-p-0 vx-m-0\">\n <li\n class=\"vx-p-3 vx-lh-4\"\n *ngFor=\"let permission of role?.roleActions\"\n >\n <div class=\"value vx-fs-12 vx-label-txt\">\n {{ permissionText(permission) }}\n </div>\n </li>\n <!-- <li class=\"vx-p-3 vx-lh-4\">\n <div class=\"value vx-fs-12 vx-label-txt\">View User List</div>\n </li>\n <li class=\"vx-p-3 vx-lh-4\">\n <div class=\"value vx-fs-12 vx-label-txt\">Manage Users <span class=\"vx-fs-10 vx-paragraph-txt\">(Create/Edit/Delete/Deactivate)</span></div>\n </li>\n <li class=\"vx-p-3 vx-lh-4\">\n <div class=\"value vx-fs-12 vx-label-txt\">Over-ride Log In</div>\n </li>\n <li class=\"vx-p-3 vx-lh-4\">\n <div class=\"value vx-fs-12 vx-label-txt\">View Statutory Holidays</div>\n </li>\n <li class=\"vx-p-3 vx-lh-4\">\n <div class=\"value vx-fs-12 vx-label-txt\">Manage Statutory Holidays</div>\n </li> -->\n </ul>\n </div>\n </div>\n </div>\n\n <app-no-data\n *ngIf=\"roles?.length === 0\"\n [noDataImage]=\"ASSETS.search_data\"\n [noDataText]=\"\n searchKey?.length > 0 ? 'No match found.' : 'No Roles Found'\n \"\n ></app-no-data>\n </ng-container>\n </ng-container>\n\n <div class=\"roles-list-footer\" *ngIf=\"!showConfirmation\">\n <vui-floating-bar (closeEvent)=\"saveList()\" (closeList)=\"closeList()\">\n <!-- <div class=\"counter\" *ngIf=\"selectedRoles?.length\"\n placement=\"left\">{{selectedRoles?.length}}</div> -->\n <button\n *ngIf=\"selectedRoles?.length\"\n class=\"counter role-list-counter\"\n appPopover\n (click)=\"role.popover()\"\n placement=\"left\"\n >\n {{ selectedRoles?.length }}\n </button>\n <div\n class=\"name\"\n *ngIf=\"selectedRoles?.length > 1\"\n id=\"permissionselected\"\n >\n <span *ngIf=\"selectedRoles?.length === 1\">{{\n featureflagrole ? \"Permission selected\" : \"Role selected\"\n }}</span>\n <span *ngIf=\"selectedRoles?.length > 1\">{{\n featureflagrole ? \"Permissions selected\" : \"Roles selected\"\n }}</span>\n </div>\n </vui-floating-bar>\n\n <app-popover #role [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"let data of selectedRoles\">\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"!systemRolesIds.includes(data?._id)\"\n class=\"icons\"\n (click)=\"selectItem({ target: { checked: false } }, data)\"\n ></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 </div>\n </div>\n\n <div class=\"roles-list-confirmation\" *ngIf=\"showConfirmation\">\n <div class=\"confirmation-top\">\n <div class=\"icon-block\"><i class=\"icons\"></i></div>\n <div class=\"text\" id=\"confirmationmessage\">\n {{\n featureflagrole\n ? \"This action will update the Permission settings and impact the owners selected for the Program.\"\n : \"This action will update the Role settings and impact the owners selected for the Program.\"\n }}\n </div>\n </div>\n <div class=\"confirmation-bottom\">\n <div class=\"message\">Are you sure you would like to proceed?</div>\n <div class=\"button-group\">\n <button class=\"no-btn\" (click)=\"confirmAction('NO')\">NO</button>\n <button class=\"yes-btn\" (click)=\"confirmAction('YES')\">YES</button>\n </div>\n </div>\n </div>\n</div>\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/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";::ng-deep .roles-list{position:fixed;inset:0 500px 0 0}::ng-deep .roles-list:before{background:#1e5dd3;content:\"\";position:absolute;top:0;left:0;right:0;width:100%;height:3px}::ng-deep .roles-list.animate{animation:animate-right .2s cubic-bezier(.25,.46,.45,.94) both;z-index:-1}::ng-deep .roles-list-head{background:#fbfbfb;height:2.75rem;border-bottom:1px solid #f1f1f1}::ng-deep .roles-list-body{background:#fff;height:calc(100vh - 2.75rem);padding:2rem}::ng-deep .roles-list-body .search-block{position:relative}::ng-deep .roles-list-body .search-block input{height:2.75rem;line-height:1.5rem;padding:.5rem 1rem .5rem 2.5rem;outline:none;border:1px solid #7475763f;border-radius:.25rem;width:100%;font-size:14px;color:#747576}::ng-deep .roles-list-body .search-block input:focus{border-color:#1e5dd3}::ng-deep .roles-list-body .search-block i{position:absolute;left:1rem;top:1rem;pointer-events:none;color:#f1f1f1;font-size:12px}::ng-deep .roles-list-mid{width:calc(100% + .75rem);height:calc(100vh - 13.8rem);overflow:hidden;overflow-y:auto;padding-right:.75rem}::ng-deep .roles-list-mid .role-box{border:1px solid #f1f1f1;border-radius:.25rem}::ng-deep .roles-list-mid .role-box-select{background:#fff;position:sticky;top:0;z-index:1}::ng-deep .roles-list-mid .role-box-select vui-checkbox .checkbox-item{position:relative;padding-left:1.75rem;width:100%}::ng-deep .roles-list-mid .role-box-select vui-checkbox .checkbox-item .checkbox,::ng-deep .roles-list-mid .role-box-select vui-checkbox .checkbox-item .checkmark{position:absolute!important;top:0;left:0}::ng-deep .roles-list-mid .role-box-select vui-checkbox .checkbox-item .value{margin:0!important}::ng-deep .roles-list-mid .role-box-heading{cursor:pointer}::ng-deep .roles-list-mid .role-box-heading .left{width:calc(100% - 6.5rem)}::ng-deep .roles-list-mid .role-box-heading .left vui-checkbox{height:1rem}::ng-deep .roles-list-mid .role-box-heading .left vui-checkbox .checkbox-item{position:relative;padding-left:1.75rem;height:1rem}::ng-deep .roles-list-mid .role-box-heading .left vui-checkbox .checkbox-item .checkbox,::ng-deep .roles-list-mid .role-box-heading .left vui-checkbox .checkbox-item .checkmark{position:absolute!important;top:0;left:0}::ng-deep .roles-list-mid .role-box-heading .left .name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;max-width:calc(100% - 9.25rem)}::ng-deep .roles-list-mid .role-box-heading .left .count{background:#f1f1f1;border-radius:.125rem;color:#042e7d}::ng-deep .roles-list-mid .role-box-heading .right{width:6.5rem}::ng-deep .roles-list-mid .role-box-heading .right .status-label{border-radius:.125rem;height:.75rem}::ng-deep .roles-list-mid .role-box-heading .right .status-label.all-user{background:#7aa6f7}::ng-deep .roles-list-mid .role-box-heading .right .status-label.power-user{background:#fadd8a}::ng-deep .roles-list-mid .role-box-heading .right button.arrow-btn{background:transparent;border:none;border-radius:0}::ng-deep .roles-list-mid .role-box-list ul{list-style-type:none}::ng-deep .roles-list-mid .role-box-list ul li{border-top:1px solid #f1f1f1;padding-left:2.5rem!important;position:relative}::ng-deep .roles-list-mid .role-box-list ul li:before{background:#dbdbdb;border-radius:.125rem;width:.25rem;height:.25rem;content:\"\";position:absolute;top:18px;left:18px}::ng-deep .roles-list-mid .role-box-list ul li .value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;text-transform:capitalize}::ng-deep .roles-list-mid .role-box-list ul li vui-checkbox .checkbox-item{width:100%}::ng-deep .roles-list-mid .role-box-list ul li vui-checkbox .checkbox-item span.value{width:100%}::ng-deep .roles-list-mid .role-box-list ul li vui-checkbox .checkbox-item span.value .name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .roles-list-confirmation{background:#161b2f;border-radius:.25rem;position:absolute;left:2rem;right:2rem;bottom:2rem;z-index:1}::ng-deep .roles-list-confirmation .confirmation-top{display:flex;align-items:center;justify-content:flex-start;padding:1.25rem}::ng-deep .roles-list-confirmation .confirmation-top .icon-block{height:2.25rem;width:2.25rem;border-radius:50%;background:#fff;border:1px solid #dbdbdb;display:flex;justify-content:center;align-items:center;margin-right:1rem}::ng-deep .roles-list-confirmation .confirmation-top .icon-block i{color:#eb2424;font-size:12px}::ng-deep .roles-list-confirmation .confirmation-top .text{color:#fff;font-size:14px;font-weight:300}::ng-deep .roles-list-confirmation .confirmation-bottom{background:#282e48;border-radius:0 0 .25rem .25rem;padding:.75rem .75rem .75rem 1.25rem;display:flex;align-items:center;justify-content:space-between}::ng-deep .roles-list-confirmation .confirmation-bottom .message{font-size:14px;font-weight:500;line-height:20px;color:#fff}::ng-deep .roles-list-confirmation .confirmation-bottom .button-group{display:flex}::ng-deep .roles-list-confirmation .confirmation-bottom .button-group button{height:1.5rem;width:4rem;border:1px solid #fff;border-radius:.125rem;display:flex;align-items:center;justify-content:center;line-height:22px;cursor:pointer;font-size:11px;text-transform:uppercase;font-weight:500;padding:0}::ng-deep .roles-list-confirmation .confirmation-bottom .button-group button.no-btn{background:transparent;color:#fff}::ng-deep .roles-list-confirmation .confirmation-bottom .button-group button.yes-btn{background:#fff;color:#1e5dd3;margin-left:.25rem}.counter.role-list-counter{background:#1e5dd3!important;border:1px solid #1E5DD3!important;margin-left:0!important}.name{margin-left:4px}.name b{text-transform:lowercase}.wf-action-list{width:220px}.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}.wf-action-list ul.action-item{display:block}.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}.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}.wf-action-list ul.action-item li button i{font-size:16px;margin-right:10px;color:#1e5dd3}.wf-action-list ul.action-item li button:hover{background:#f3f3f3}.wf-action-list ul.action-item li .avatar-card{display:flex;align-items:center;width:100%;padding:7.5px}.wf-action-list ul.action-item li .avatar-card.within-con{display:block}.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}.wf-action-list ul.action-item li .avatar-card .avatar img{width:100%}.wf-action-list ul.action-item li .avatar-card .avatar+span.value{width:calc(100% - 29px)}.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}.wf-action-list ul.action-item li .avatar-card span.value i{font-size:8px;color:#747576;cursor:pointer;margin-right:5px}.wf-action-list ul.action-item li .avatar-card.no-image{display:block}.wf-action-list ul.action-item li .avatar-card.no-image span.value{width:100%;display:block}.wf-action-list ul.action-item li .chip-item{color:#1e5dd3;padding:10px;display:flex;align-items:center}.wf-action-list ul.action-item li .chip-item i{color:#747576;margin-right:7px;font-size:10px;cursor:pointer;display:inline-flex}.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}.wf-action-list ul.action-item li .chip-item span.chip-block{display:block;width:100%}.wf-action-list ul.action-item li .chip-item span.id{font-size:9px}.wf-action-list ul.action-item li .within{display:flex;align-items:center;justify-content:flex-start}.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}.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}.wf-action-list ul.action-item li:first-child{animation:action-list-open .25s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(2){animation:action-list-open .35s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(3){animation:action-list-open .45s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(4){animation:action-list-open .55s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(5){animation:action-list-open .65s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(6){animation:action-list-open .75s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(7){animation:action-list-open .85s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(8){animation:action-list-open .95s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(9){animation:action-list-open 1.05s cubic-bezier(.25,.46,.45,.94) both}.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)}}\n"] }]
|
|
50846
|
+
}], ctorParameters: function () { return []; }, propDecorators: { save: [{
|
|
50847
|
+
type: Output
|
|
50848
|
+
}], cancel: [{
|
|
50849
|
+
type: Output
|
|
50850
|
+
}], featureflagrole: [{
|
|
50851
|
+
type: Input
|
|
50852
|
+
}], featureflagGroup: [{
|
|
50853
|
+
type: Input
|
|
50854
|
+
}], ff_rc_listing: [{
|
|
50855
|
+
type: Input
|
|
50856
|
+
}], setList: [{
|
|
50857
|
+
type: Input,
|
|
50858
|
+
args: ['list']
|
|
50859
|
+
}], loading: [{
|
|
50860
|
+
type: Input
|
|
50861
|
+
}], selectedRolesVal: [{
|
|
50862
|
+
type: Input,
|
|
50863
|
+
args: ['selected']
|
|
50864
|
+
}] } });
|
|
50865
|
+
|
|
51299
50866
|
class PaginationModule {
|
|
51300
50867
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: PaginationModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
51301
50868
|
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: PaginationModule, declarations: [PaginationComponent], imports: [CommonModule,
|
|
@@ -51319,6 +50886,454 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
51319
50886
|
}]
|
|
51320
50887
|
}] });
|
|
51321
50888
|
|
|
50889
|
+
class AssessmentService {
|
|
50890
|
+
constructor(http, authService, config) {
|
|
50891
|
+
this.http = http;
|
|
50892
|
+
this.authService = authService;
|
|
50893
|
+
if (config) {
|
|
50894
|
+
this.env = config.envConfig;
|
|
50895
|
+
}
|
|
50896
|
+
}
|
|
50897
|
+
getAssessmentQuestions(id) {
|
|
50898
|
+
const headers = new HttpHeaders().set('token', this.authService.getAuthorizationToken());
|
|
50899
|
+
return this.http.get(this.env.assessmentEnpoint + 'assessment/fetchQuestionsByAssessmentId&id=' + id, { headers }).pipe(retry(2));
|
|
50900
|
+
}
|
|
50901
|
+
getAssessmentCategory(payload) {
|
|
50902
|
+
const headers = new HttpHeaders().set('token', this.authService.getAuthorizationToken());
|
|
50903
|
+
return this.http.post(this.env.assessmentEnpoint + 'category/list&isCreateResponsibility=true&bypass-businessCycle=true', payload, { headers }).pipe(retry(2));
|
|
50904
|
+
}
|
|
50905
|
+
getAssessmentList(payload, id) {
|
|
50906
|
+
const headers = new HttpHeaders().set('token', this.authService.getAuthorizationToken());
|
|
50907
|
+
return this.http.post(this.env.assessmentEnpoint + 'assessment/selectAssessment&isCreateResponsibility=true&catid=' + id, payload, { headers }).pipe(retry(2));
|
|
50908
|
+
}
|
|
50909
|
+
getAssessmentDetailsByID(id) {
|
|
50910
|
+
const headers = new HttpHeaders().set('token', this.authService.getAuthorizationToken());
|
|
50911
|
+
return this.http.post(this.env.assessmentEnpoint + 'assessment/getAssessmentById&id=' + id, {}, { headers }).pipe(retry(2));
|
|
50912
|
+
}
|
|
50913
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AssessmentService, deps: [{ token: i1.HttpClient }, { token: AuthService$1 }, { token: Configurations, optional: true }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
50914
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AssessmentService, providedIn: 'root' }); }
|
|
50915
|
+
}
|
|
50916
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AssessmentService, decorators: [{
|
|
50917
|
+
type: Injectable,
|
|
50918
|
+
args: [{
|
|
50919
|
+
providedIn: 'root'
|
|
50920
|
+
}]
|
|
50921
|
+
}], ctorParameters: function () { return [{ type: i1.HttpClient }, { type: AuthService$1 }, { type: Configurations, decorators: [{
|
|
50922
|
+
type: Optional
|
|
50923
|
+
}] }]; } });
|
|
50924
|
+
|
|
50925
|
+
class AssessmentLoaderComponent {
|
|
50926
|
+
constructor() { }
|
|
50927
|
+
ngOnInit() {
|
|
50928
|
+
}
|
|
50929
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AssessmentLoaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
50930
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AssessmentLoaderComponent, selector: "assessment-loader", ngImport: i0, template: "<div class=\"assessment-list-item\" *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\n <div class=\"table-row\">\n <div class=\"table-column serial\">\n <div class=\"sr-no\"></div>\n </div>\n <div class=\"table-column name\">\n <div class=\"loader\"></div>\n </div>\n <div class=\"table-column action\">\n <div class=\"loader\"></div>\n </div>\n </div>\n</div>", styles: [".assessment-list-item{border:1px solid #f1f1f1;border-radius:2px;margin-bottom:4px}.assessment-list-item .table-row{display:flex;align-items:center;justify-content:space-between}.assessment-list-item .table-row .table-column{height:48px;position:relative;width:100%;display:flex;align-items:center;padding:0 4px}.assessment-list-item .table-row .table-column.serial{width:32px;max-width:32px;justify-content:center}.assessment-list-item .table-row .table-column.serial .sr-no{width:16px;background:#f8f8f8;writing-mode:vertical-lr;height:100%}.assessment-list-item .table-row .table-column.name{width:calc(100% - 64px);min-width:calc(100% - 64px)}.assessment-list-item .table-row .table-column.name .loader{width:calc(100% - 200px)}.assessment-list-item .table-row .table-column.action{width:32px;max-width:32px;justify-content:center}.assessment-list-item .table-row .table-column.action .loader{width:28px}.loader{background:#f1f1f1;border-radius:20px;height:10px}\n"], dependencies: [{ kind: "directive", type: i1$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] }); }
|
|
50931
|
+
}
|
|
50932
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AssessmentLoaderComponent, decorators: [{
|
|
50933
|
+
type: Component,
|
|
50934
|
+
args: [{ selector: 'assessment-loader', template: "<div class=\"assessment-list-item\" *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\n <div class=\"table-row\">\n <div class=\"table-column serial\">\n <div class=\"sr-no\"></div>\n </div>\n <div class=\"table-column name\">\n <div class=\"loader\"></div>\n </div>\n <div class=\"table-column action\">\n <div class=\"loader\"></div>\n </div>\n </div>\n</div>", styles: [".assessment-list-item{border:1px solid #f1f1f1;border-radius:2px;margin-bottom:4px}.assessment-list-item .table-row{display:flex;align-items:center;justify-content:space-between}.assessment-list-item .table-row .table-column{height:48px;position:relative;width:100%;display:flex;align-items:center;padding:0 4px}.assessment-list-item .table-row .table-column.serial{width:32px;max-width:32px;justify-content:center}.assessment-list-item .table-row .table-column.serial .sr-no{width:16px;background:#f8f8f8;writing-mode:vertical-lr;height:100%}.assessment-list-item .table-row .table-column.name{width:calc(100% - 64px);min-width:calc(100% - 64px)}.assessment-list-item .table-row .table-column.name .loader{width:calc(100% - 200px)}.assessment-list-item .table-row .table-column.action{width:32px;max-width:32px;justify-content:center}.assessment-list-item .table-row .table-column.action .loader{width:28px}.loader{background:#f1f1f1;border-radius:20px;height:10px}\n"] }]
|
|
50935
|
+
}], ctorParameters: function () { return []; } });
|
|
50936
|
+
|
|
50937
|
+
class AssessmentSubLoaderComponent {
|
|
50938
|
+
constructor() { }
|
|
50939
|
+
ngOnInit() {
|
|
50940
|
+
}
|
|
50941
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AssessmentSubLoaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
50942
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AssessmentSubLoaderComponent, selector: "assessment-sub-loader", ngImport: i0, template: "<div class=\"assessment-list-item\" *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\n <div class=\"sub-list\">\n <div class=\"table-row\">\n <div class=\"table-column serial\">\n <div class=\"sr-no\"></div>\n </div>\n <div class=\"table-column sub-name\">\n <div class=\"loader\"></div>\n </div>\n <div class=\"table-column question\">\n <div class=\"loader\"></div>\n </div>\n </div>\n </div>\n</div>", styles: [".assessment-list-item{border:none!important;border-top:1px solid #f1f1f1;border-radius:2px;margin-bottom:0!important}.assessment-list-item .table-row{display:flex;align-items:center;justify-content:space-between}.assessment-list-item .table-row .table-column{height:32px;position:relative;width:100%;display:flex;align-items:center;padding:0 4px}.assessment-list-item .table-row .table-column.serial{width:32px;max-width:32px;justify-content:center}.assessment-list-item .table-row .table-column.serial .sr-no{width:16px;background:#f8f8f8;writing-mode:vertical-lr;height:100%}.assessment-list-item .table-row .table-column.sub-name{width:calc(100% - 232px);min-width:calc(100% - 232px)}.assessment-list-item .table-row .table-column.sub-name .loader{width:calc(100% - 200px)}.assessment-list-item .table-row .table-column.question{width:200px;max-width:200px;justify-content:flex-end}.assessment-list-item .table-row .table-column.question .loader{width:72px}.loader{background:#f1f1f1;border-radius:20px;height:10px}\n"], dependencies: [{ kind: "directive", type: i1$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] }); }
|
|
50943
|
+
}
|
|
50944
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AssessmentSubLoaderComponent, decorators: [{
|
|
50945
|
+
type: Component,
|
|
50946
|
+
args: [{ selector: 'assessment-sub-loader', template: "<div class=\"assessment-list-item\" *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\n <div class=\"sub-list\">\n <div class=\"table-row\">\n <div class=\"table-column serial\">\n <div class=\"sr-no\"></div>\n </div>\n <div class=\"table-column sub-name\">\n <div class=\"loader\"></div>\n </div>\n <div class=\"table-column question\">\n <div class=\"loader\"></div>\n </div>\n </div>\n </div>\n</div>", styles: [".assessment-list-item{border:none!important;border-top:1px solid #f1f1f1;border-radius:2px;margin-bottom:0!important}.assessment-list-item .table-row{display:flex;align-items:center;justify-content:space-between}.assessment-list-item .table-row .table-column{height:32px;position:relative;width:100%;display:flex;align-items:center;padding:0 4px}.assessment-list-item .table-row .table-column.serial{width:32px;max-width:32px;justify-content:center}.assessment-list-item .table-row .table-column.serial .sr-no{width:16px;background:#f8f8f8;writing-mode:vertical-lr;height:100%}.assessment-list-item .table-row .table-column.sub-name{width:calc(100% - 232px);min-width:calc(100% - 232px)}.assessment-list-item .table-row .table-column.sub-name .loader{width:calc(100% - 200px)}.assessment-list-item .table-row .table-column.question{width:200px;max-width:200px;justify-content:flex-end}.assessment-list-item .table-row .table-column.question .loader{width:72px}.loader{background:#f1f1f1;border-radius:20px;height:10px}\n"] }]
|
|
50947
|
+
}], ctorParameters: function () { return []; } });
|
|
50948
|
+
|
|
50949
|
+
class Pagination {
|
|
50950
|
+
constructor() {
|
|
50951
|
+
this.activeAlphabet = '';
|
|
50952
|
+
this.pageArray = [];
|
|
50953
|
+
this.currentPage = 1;
|
|
50954
|
+
this.isInvalidInput = false;
|
|
50955
|
+
this.selectedPage = new EventEmitter();
|
|
50956
|
+
this.selectedAlphabet = new EventEmitter();
|
|
50957
|
+
this.alphabetsArray = 'abcdefghijklmnopqrstuvwxyz'.split('');
|
|
50958
|
+
}
|
|
50959
|
+
ngOnInit() { }
|
|
50960
|
+
alphabetChange(alphabet) {
|
|
50961
|
+
this.activeAlphabet = alphabet;
|
|
50962
|
+
this.selectedAlphabet.emit(alphabet);
|
|
50963
|
+
this.goToPageArrayGenerate(1, false);
|
|
50964
|
+
}
|
|
50965
|
+
ngOnChanges(event) {
|
|
50966
|
+
this.pageArray = [];
|
|
50967
|
+
if (this.pageCount > 0) {
|
|
50968
|
+
if (this.pageCount < 5) {
|
|
50969
|
+
for (let i = 1; i <= this.pageCount; i++) {
|
|
50970
|
+
this.pageArray.push(i);
|
|
50971
|
+
}
|
|
50972
|
+
return;
|
|
50973
|
+
}
|
|
50974
|
+
this.goToPageArrayGenerate(this.currentPage, false);
|
|
50975
|
+
}
|
|
50976
|
+
}
|
|
50977
|
+
increaseOrDecrease(value) {
|
|
50978
|
+
this.currentPage += value;
|
|
50979
|
+
if (this.currentPage > 3 && this.currentPage <= this.pageCount && this.pageArray[this.pageArray.length - 1] < this.pageCount) {
|
|
50980
|
+
if (value > 0) {
|
|
50981
|
+
this.pageArray.shift();
|
|
50982
|
+
this.pageArray.push(this.pageArray[this.pageArray.length - 1] + 1);
|
|
50983
|
+
}
|
|
50984
|
+
}
|
|
50985
|
+
if (this.currentPage > 2 && value < 0 && this.pageArray[0] > 1 && this.currentPage < this.pageCount - 2) {
|
|
50986
|
+
this.pageArray.pop();
|
|
50987
|
+
this.pageArray.unshift(this.pageArray[0] - 1);
|
|
50988
|
+
}
|
|
50989
|
+
this.selectedPage.emit(this.currentPage);
|
|
50990
|
+
}
|
|
50991
|
+
onEnterPress(event) {
|
|
50992
|
+
if (event.key.toLowerCase() === 'enter') {
|
|
50993
|
+
if (!this.enterPageNumber || this.enterPageNumber > this.pageCount || this.enterPageNumber < 1) {
|
|
50994
|
+
this.isInvalidInput = true;
|
|
50995
|
+
return;
|
|
50996
|
+
}
|
|
50997
|
+
else {
|
|
50998
|
+
this.isInvalidInput = false;
|
|
50999
|
+
this.goToPageArrayGenerate(this.enterPageNumber, true);
|
|
51000
|
+
}
|
|
51001
|
+
}
|
|
51002
|
+
}
|
|
51003
|
+
goToPageArrayGenerate(page, shouldEmit) {
|
|
51004
|
+
this.isInvalidInput = false;
|
|
51005
|
+
this.currentPage = page;
|
|
51006
|
+
this.pageArray = [];
|
|
51007
|
+
if (this.currentPage > 3 && this.currentPage < this.pageCount - 2) {
|
|
51008
|
+
for (let i = this.currentPage - 2; i < this.currentPage + 3; i++) {
|
|
51009
|
+
this.pageArray.push(i);
|
|
51010
|
+
}
|
|
51011
|
+
}
|
|
51012
|
+
else if (this.currentPage <= 3) {
|
|
51013
|
+
if (this.pageCount > 4) {
|
|
51014
|
+
this.pageArray = [1, 2, 3, 4, 5];
|
|
51015
|
+
}
|
|
51016
|
+
else {
|
|
51017
|
+
for (let i = 1; i <= this.pageCount; i++) {
|
|
51018
|
+
this.pageArray.push(i);
|
|
51019
|
+
}
|
|
51020
|
+
}
|
|
51021
|
+
}
|
|
51022
|
+
else if (this.currentPage > this.pageCount - 3) {
|
|
51023
|
+
for (let i = this.pageCount - 4; i < this.pageCount + 1; i++) {
|
|
51024
|
+
this.pageArray.push(i);
|
|
51025
|
+
}
|
|
51026
|
+
}
|
|
51027
|
+
else {
|
|
51028
|
+
for (let i = this.currentPage - 2; i < this.currentPage + 2; i++) {
|
|
51029
|
+
this.pageArray.push(i);
|
|
51030
|
+
}
|
|
51031
|
+
}
|
|
51032
|
+
if (shouldEmit) {
|
|
51033
|
+
this.selectedPage.emit(this.currentPage);
|
|
51034
|
+
}
|
|
51035
|
+
}
|
|
51036
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: Pagination, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
51037
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: Pagination, selector: "pagination", inputs: { activeAlphabet: "activeAlphabet", pageCount: "pageCount", start: "start", end: "end", total: "total", noFilter: "noFilter", currentPage: "currentPage" }, outputs: { selectedPage: "selectedPage", selectedAlphabet: "selectedAlphabet" }, usesOnChanges: true, ngImport: i0, template: "<!-- <p>workflow-pagination works!</p> -->\n<div class=\"pagination-sec\" [class.right-align]=\"noFilter\">\n <div class=\"left\" *ngIf=\"!noFilter\">\n <div class=\"pagination-box\">\n <ul>\n <li><button (click)=\"alphabetChange('')\" [class.active]=\"!activeAlphabet\">All</button></li>\n <li *ngFor=\"let data of alphabetsArray\" (click)=\"alphabetChange(data)\">\n <button [class.active]=\"activeAlphabet === data\" >{{data}}</button>\n </li>\n </ul>\n </div>\n </div>\n\n <div *ngIf=\"pageCount > 1\" class=\"right\">\n <div class=\"pagination-box\">\n <ul>\n <li>\n <button [disabled]=\"currentPage === 1\" [class.disabled]=\"currentPage === 1\" (click)=\"increaseOrDecrease(-1)\">\n <\n </button>\n </li>\n\n <li *ngFor=\"let page of pageArray; let i = index\">\n <button [disabled]=\"page === currentPage\" (click)=\"goToPageArrayGenerate(page,true)\" [class.active]=\"page === currentPage\">\n {{page}}\n </button>\n </li>\n\n <li>\n <button (click)=\"increaseOrDecrease(1)\" [disabled]=\"currentPage === pageCount\" [class.disabled]=\"currentPage === pageCount\">\n >\n </button>\n </li>\n </ul>\n </div>\n </div>\n</div>", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";.pagination-sec{display:flex;justify-content:space-between;padding:8px 0;align-items:center}.pagination-sec.right-align{justify-content:flex-end}.pagination-sec .left{width:auto;line-height:28px;font-size:12px;text-transform:uppercase;color:#161b2f;font-weight:400}.pagination-sec .left .pagination-box ul{display:flex;align-items:center;padding:0;margin:0}.pagination-sec .left .pagination-box ul li{list-style:none;display:flex}.pagination-sec .left .pagination-box ul li+li{margin-left:3px}.pagination-sec .left .pagination-box ul li button{border:1px solid #bcbcbc;background:#fff;border-radius:2px;color:#161b2f;font-weight:400;height:18px;min-width:18px;padding:0 2px;display:inline-flex;justify-content:center;align-items:center;outline:none;cursor:pointer;text-transform:uppercase;font-size:11px;line-height:18px;margin:0 0 0 1px}.pagination-sec .left .pagination-box ul li button.active,.pagination-sec .left .pagination-box ul li button:hover{border-color:#1e5dd3;background:#1e5dd3;color:#fff}.pagination-sec .left .pagination-box ul li button.disabled{filter:grayscale(100%);pointer-events:none;opacity:1;color:unset!important;border:1px solid #bcbcbc}.pagination-sec .left .pagination-box ul li button.disable{pointer-events:none}.pagination-sec .left .pagination-box ul li button i{font-size:8px;width:13px;height:13px;line-height:13px}.pagination-sec .right{width:auto;display:flex;align-items:center}.pagination-sec .right .pagination-box ul{display:flex;align-items:center;padding:0;margin:0}.pagination-sec .right .pagination-box ul li{list-style:none;display:flex}.pagination-sec .right .pagination-box ul li:first-child{margin-right:4px;height:24px}@media screen and (max-width: 1456px){.pagination-sec .right .pagination-box ul li:first-child{height:20px}}.pagination-sec .right .pagination-box ul li:first-child button{color:#4681ef;position:relative}.pagination-sec .right .pagination-box ul li:first-child button.disabled{color:#bcbcbc!important}.pagination-sec .right .pagination-box ul li:last-child{margin-left:6px!important;height:24px}@media screen and (max-width: 1456px){.pagination-sec .right .pagination-box ul li:last-child{height:20px}}.pagination-sec .right .pagination-box ul li:last-child button{color:#4681ef;position:relative}.pagination-sec .right .pagination-box ul li:last-child button.disabled{color:#bcbcbc!important}.pagination-sec .right .pagination-box ul li button{border:1px solid #bcbcbc;background:#fff;border-radius:2px;color:#161b2f;font-weight:400;height:24px;min-width:24px;padding:0 5px;display:inline-flex;justify-content:center;align-items:center;outline:none;cursor:pointer;line-height:21px;margin-left:3px}@media screen and (max-width: 1456px){.pagination-sec .right .pagination-box ul li button{min-width:20px;height:20px;padding:0 4px;font-size:10px;line-height:18px}}.pagination-sec .right .pagination-box ul li button.active,.pagination-sec .right .pagination-box ul li button:hover{border-color:#1e5dd3;color:#4681ef}.pagination-sec .right .pagination-box ul li button.disabled{filter:grayscale(100%);pointer-events:none;opacity:1;color:unset!important;border:1px solid #bcbcbc}.pagination-sec .right .pagination-box ul li button.disable{pointer-events:none}.pagination-sec .right .pagination-box ul li button i{font-size:8px;width:13px;height:13px;line-height:13px}.pagination-sec .right .goto-page{display:flex;align-items:center;background:#fff;border:1px solid #bcbcbc;border-radius:2px;height:25px;margin-left:10px}.pagination-sec .right .goto-page .goto-page-text{color:#161b2f;font-size:11px;text-transform:uppercase;display:block;padding:0 8px;border-right:1px solid #bcbcbc;height:23px;line-height:23px}.pagination-sec .right .goto-page .goto-page-text:last-of-type{border-right:none;border-left:1px solid #bcbcbc}.pagination-sec .right .goto-page .goto-page-input{position:relative}.pagination-sec .right .goto-page .goto-page-input input{-moz-appearance:textfield;background:transparent;border:none;color:#161b2f;font-size:11px;text-transform:uppercase;padding:0 25px 0 5px;width:95px;height:23px;position:relative;top:-1px}.pagination-sec .right .goto-page .goto-page-input input::-webkit-inner-spin-button,.pagination-sec .right .goto-page .goto-page-input input::-webkit-outer-spin-button{-webkit-appearance:none}.pagination-sec .right .goto-page .goto-page-input input:focus{outline:none}.pagination-sec .right .goto-page .goto-page-input input.invalid{border:1px solid #d93b41}.pagination-sec .right .goto-page .goto-page-input button{background:#f1f1f1;border:none;position:absolute;right:3px;top:4px;cursor:pointer;padding:0;height:18px;width:19px;line-height:22px}.pagination-sec .right .goto-page .goto-page-input button img{width:12px;height:12px}\n"], dependencies: [{ kind: "directive", type: i1$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
|
|
51038
|
+
}
|
|
51039
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: Pagination, decorators: [{
|
|
51040
|
+
type: Component,
|
|
51041
|
+
args: [{ selector: 'pagination', template: "<!-- <p>workflow-pagination works!</p> -->\n<div class=\"pagination-sec\" [class.right-align]=\"noFilter\">\n <div class=\"left\" *ngIf=\"!noFilter\">\n <div class=\"pagination-box\">\n <ul>\n <li><button (click)=\"alphabetChange('')\" [class.active]=\"!activeAlphabet\">All</button></li>\n <li *ngFor=\"let data of alphabetsArray\" (click)=\"alphabetChange(data)\">\n <button [class.active]=\"activeAlphabet === data\" >{{data}}</button>\n </li>\n </ul>\n </div>\n </div>\n\n <div *ngIf=\"pageCount > 1\" class=\"right\">\n <div class=\"pagination-box\">\n <ul>\n <li>\n <button [disabled]=\"currentPage === 1\" [class.disabled]=\"currentPage === 1\" (click)=\"increaseOrDecrease(-1)\">\n <\n </button>\n </li>\n\n <li *ngFor=\"let page of pageArray; let i = index\">\n <button [disabled]=\"page === currentPage\" (click)=\"goToPageArrayGenerate(page,true)\" [class.active]=\"page === currentPage\">\n {{page}}\n </button>\n </li>\n\n <li>\n <button (click)=\"increaseOrDecrease(1)\" [disabled]=\"currentPage === pageCount\" [class.disabled]=\"currentPage === pageCount\">\n >\n </button>\n </li>\n </ul>\n </div>\n </div>\n</div>", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";.pagination-sec{display:flex;justify-content:space-between;padding:8px 0;align-items:center}.pagination-sec.right-align{justify-content:flex-end}.pagination-sec .left{width:auto;line-height:28px;font-size:12px;text-transform:uppercase;color:#161b2f;font-weight:400}.pagination-sec .left .pagination-box ul{display:flex;align-items:center;padding:0;margin:0}.pagination-sec .left .pagination-box ul li{list-style:none;display:flex}.pagination-sec .left .pagination-box ul li+li{margin-left:3px}.pagination-sec .left .pagination-box ul li button{border:1px solid #bcbcbc;background:#fff;border-radius:2px;color:#161b2f;font-weight:400;height:18px;min-width:18px;padding:0 2px;display:inline-flex;justify-content:center;align-items:center;outline:none;cursor:pointer;text-transform:uppercase;font-size:11px;line-height:18px;margin:0 0 0 1px}.pagination-sec .left .pagination-box ul li button.active,.pagination-sec .left .pagination-box ul li button:hover{border-color:#1e5dd3;background:#1e5dd3;color:#fff}.pagination-sec .left .pagination-box ul li button.disabled{filter:grayscale(100%);pointer-events:none;opacity:1;color:unset!important;border:1px solid #bcbcbc}.pagination-sec .left .pagination-box ul li button.disable{pointer-events:none}.pagination-sec .left .pagination-box ul li button i{font-size:8px;width:13px;height:13px;line-height:13px}.pagination-sec .right{width:auto;display:flex;align-items:center}.pagination-sec .right .pagination-box ul{display:flex;align-items:center;padding:0;margin:0}.pagination-sec .right .pagination-box ul li{list-style:none;display:flex}.pagination-sec .right .pagination-box ul li:first-child{margin-right:4px;height:24px}@media screen and (max-width: 1456px){.pagination-sec .right .pagination-box ul li:first-child{height:20px}}.pagination-sec .right .pagination-box ul li:first-child button{color:#4681ef;position:relative}.pagination-sec .right .pagination-box ul li:first-child button.disabled{color:#bcbcbc!important}.pagination-sec .right .pagination-box ul li:last-child{margin-left:6px!important;height:24px}@media screen and (max-width: 1456px){.pagination-sec .right .pagination-box ul li:last-child{height:20px}}.pagination-sec .right .pagination-box ul li:last-child button{color:#4681ef;position:relative}.pagination-sec .right .pagination-box ul li:last-child button.disabled{color:#bcbcbc!important}.pagination-sec .right .pagination-box ul li button{border:1px solid #bcbcbc;background:#fff;border-radius:2px;color:#161b2f;font-weight:400;height:24px;min-width:24px;padding:0 5px;display:inline-flex;justify-content:center;align-items:center;outline:none;cursor:pointer;line-height:21px;margin-left:3px}@media screen and (max-width: 1456px){.pagination-sec .right .pagination-box ul li button{min-width:20px;height:20px;padding:0 4px;font-size:10px;line-height:18px}}.pagination-sec .right .pagination-box ul li button.active,.pagination-sec .right .pagination-box ul li button:hover{border-color:#1e5dd3;color:#4681ef}.pagination-sec .right .pagination-box ul li button.disabled{filter:grayscale(100%);pointer-events:none;opacity:1;color:unset!important;border:1px solid #bcbcbc}.pagination-sec .right .pagination-box ul li button.disable{pointer-events:none}.pagination-sec .right .pagination-box ul li button i{font-size:8px;width:13px;height:13px;line-height:13px}.pagination-sec .right .goto-page{display:flex;align-items:center;background:#fff;border:1px solid #bcbcbc;border-radius:2px;height:25px;margin-left:10px}.pagination-sec .right .goto-page .goto-page-text{color:#161b2f;font-size:11px;text-transform:uppercase;display:block;padding:0 8px;border-right:1px solid #bcbcbc;height:23px;line-height:23px}.pagination-sec .right .goto-page .goto-page-text:last-of-type{border-right:none;border-left:1px solid #bcbcbc}.pagination-sec .right .goto-page .goto-page-input{position:relative}.pagination-sec .right .goto-page .goto-page-input input{-moz-appearance:textfield;background:transparent;border:none;color:#161b2f;font-size:11px;text-transform:uppercase;padding:0 25px 0 5px;width:95px;height:23px;position:relative;top:-1px}.pagination-sec .right .goto-page .goto-page-input input::-webkit-inner-spin-button,.pagination-sec .right .goto-page .goto-page-input input::-webkit-outer-spin-button{-webkit-appearance:none}.pagination-sec .right .goto-page .goto-page-input input:focus{outline:none}.pagination-sec .right .goto-page .goto-page-input input.invalid{border:1px solid #d93b41}.pagination-sec .right .goto-page .goto-page-input button{background:#f1f1f1;border:none;position:absolute;right:3px;top:4px;cursor:pointer;padding:0;height:18px;width:19px;line-height:22px}.pagination-sec .right .goto-page .goto-page-input button img{width:12px;height:12px}\n"] }]
|
|
51042
|
+
}], ctorParameters: function () { return []; }, propDecorators: { activeAlphabet: [{
|
|
51043
|
+
type: Input
|
|
51044
|
+
}], pageCount: [{
|
|
51045
|
+
type: Input
|
|
51046
|
+
}], start: [{
|
|
51047
|
+
type: Input
|
|
51048
|
+
}], end: [{
|
|
51049
|
+
type: Input
|
|
51050
|
+
}], total: [{
|
|
51051
|
+
type: Input
|
|
51052
|
+
}], noFilter: [{
|
|
51053
|
+
type: Input
|
|
51054
|
+
}], currentPage: [{
|
|
51055
|
+
type: Input
|
|
51056
|
+
}], selectedPage: [{
|
|
51057
|
+
type: Output
|
|
51058
|
+
}], selectedAlphabet: [{
|
|
51059
|
+
type: Output
|
|
51060
|
+
}] } });
|
|
51061
|
+
|
|
51062
|
+
class AssessmentPickerComponent {
|
|
51063
|
+
set setSelected(value) {
|
|
51064
|
+
if (value && value?.length) {
|
|
51065
|
+
this.selectedAssessmentArr = [...value];
|
|
51066
|
+
//this.setCategoryAndAssessment();
|
|
51067
|
+
this.selectedAssessmentArr.forEach((ele, index) => {
|
|
51068
|
+
this.openedCategory.push(ele?.category_id);
|
|
51069
|
+
// this.showSubList(index,ele?.category_id);
|
|
51070
|
+
});
|
|
51071
|
+
}
|
|
51072
|
+
}
|
|
51073
|
+
constructor(assessmentService, auth) {
|
|
51074
|
+
this.assessmentService = assessmentService;
|
|
51075
|
+
this.auth = auth;
|
|
51076
|
+
this.ASSETS = ASSETS;
|
|
51077
|
+
this.animation = false;
|
|
51078
|
+
this.subList = false;
|
|
51079
|
+
this.isEdit = false;
|
|
51080
|
+
this.openedCategory = [];
|
|
51081
|
+
this.assessmentPayload = {
|
|
51082
|
+
search_title: '',
|
|
51083
|
+
page_no: '1',
|
|
51084
|
+
state: 'ACTIVE',
|
|
51085
|
+
search_text: '',
|
|
51086
|
+
alphabet_filter: '',
|
|
51087
|
+
};
|
|
51088
|
+
this.dataPerPage = 0;
|
|
51089
|
+
this.assessmentCategory = {
|
|
51090
|
+
data: [],
|
|
51091
|
+
totalPage: 0,
|
|
51092
|
+
totalRecords: 0,
|
|
51093
|
+
start_value: 0,
|
|
51094
|
+
end_value: 0,
|
|
51095
|
+
currentPage: 0,
|
|
51096
|
+
};
|
|
51097
|
+
this.isLoader = false;
|
|
51098
|
+
this.isDeleted = false;
|
|
51099
|
+
this.searchAssessments = '';
|
|
51100
|
+
this.isPreview = false;
|
|
51101
|
+
this.selectedAssessmentData = [];
|
|
51102
|
+
this.onAssessmentSelect = new EventEmitter();
|
|
51103
|
+
this.cancelAssessment = new EventEmitter();
|
|
51104
|
+
this.selectedAssessmentArr = [];
|
|
51105
|
+
this.selectedAssessmentCategoriesIds = [];
|
|
51106
|
+
this.selectedAssessmentIds = [];
|
|
51107
|
+
this.selectedAssessment = [];
|
|
51108
|
+
this.dataPerPage = 30;
|
|
51109
|
+
}
|
|
51110
|
+
ngOnInit() {
|
|
51111
|
+
this.animation = true;
|
|
51112
|
+
this.getAssessmentCategoryList();
|
|
51113
|
+
setTimeout(() => {
|
|
51114
|
+
this.animation = false;
|
|
51115
|
+
}, 300);
|
|
51116
|
+
}
|
|
51117
|
+
onAssessmentSelected(event) {
|
|
51118
|
+
this.selectedData = event;
|
|
51119
|
+
}
|
|
51120
|
+
preview(evt) {
|
|
51121
|
+
this.assessmentService.getAssessmentQuestions(evt?.id).subscribe({
|
|
51122
|
+
next: (res) => {
|
|
51123
|
+
this.auth.previewPanel.next(true);
|
|
51124
|
+
this.isPreview = true;
|
|
51125
|
+
this.previewQuestionData = res;
|
|
51126
|
+
},
|
|
51127
|
+
});
|
|
51128
|
+
}
|
|
51129
|
+
previewBack() {
|
|
51130
|
+
this.isPreview = false;
|
|
51131
|
+
this.previewQuestionData = {};
|
|
51132
|
+
this.auth.previewPanel.next(false);
|
|
51133
|
+
}
|
|
51134
|
+
/**
|
|
51135
|
+
*
|
|
51136
|
+
* @param index : Accept index of elementPosition
|
|
51137
|
+
*
|
|
51138
|
+
*/
|
|
51139
|
+
showSubList(index, id) {
|
|
51140
|
+
if (this.openedCategory.includes(id)) {
|
|
51141
|
+
this.openedCategory = this.openedCategory.filter((ele) => ele !== id);
|
|
51142
|
+
}
|
|
51143
|
+
else {
|
|
51144
|
+
this.openedCategory.push(id);
|
|
51145
|
+
this.getAssessmentList(id);
|
|
51146
|
+
}
|
|
51147
|
+
return this.openedCategory;
|
|
51148
|
+
}
|
|
51149
|
+
expandCategory(categoryId) {
|
|
51150
|
+
const index = this.assessmentCategory?.data?.findIndex((ele) => ele.id === categoryId);
|
|
51151
|
+
if (this.openedCategory.includes(categoryId) &&
|
|
51152
|
+
this.assessmentCategory.data[index].assessmentData) {
|
|
51153
|
+
this.openedCategory = this.openedCategory.filter((ele) => ele !== categoryId);
|
|
51154
|
+
}
|
|
51155
|
+
else {
|
|
51156
|
+
this.openedCategory.push(categoryId);
|
|
51157
|
+
this.getAssessmentList(categoryId);
|
|
51158
|
+
}
|
|
51159
|
+
}
|
|
51160
|
+
// TODO: Pagination
|
|
51161
|
+
/**
|
|
51162
|
+
*
|
|
51163
|
+
* @param event : page number that has been selected
|
|
51164
|
+
*/
|
|
51165
|
+
onPageSelection(event) {
|
|
51166
|
+
this.openedCategory = [];
|
|
51167
|
+
this.assessmentPayload.page_no = event.toString();
|
|
51168
|
+
this.getAssessmentCategoryList();
|
|
51169
|
+
}
|
|
51170
|
+
// TODO: Search
|
|
51171
|
+
/**
|
|
51172
|
+
*
|
|
51173
|
+
* @param search : search text
|
|
51174
|
+
*/
|
|
51175
|
+
onAssessmentSearch(search) {
|
|
51176
|
+
this.openedCategory = [];
|
|
51177
|
+
this.assessmentPayload.page_no = '1';
|
|
51178
|
+
this.assessmentPayload.search_title = search;
|
|
51179
|
+
this.assessmentPayload.search_text = search;
|
|
51180
|
+
this.getAssessmentCategoryList();
|
|
51181
|
+
}
|
|
51182
|
+
// TODO: Filter by alphabet
|
|
51183
|
+
/**
|
|
51184
|
+
*
|
|
51185
|
+
* @param event : Assessment category filter of Alphabet
|
|
51186
|
+
*/
|
|
51187
|
+
onAlphabetSelected(event) {
|
|
51188
|
+
this.openedCategory = [];
|
|
51189
|
+
this.assessmentPayload.page_no = '1';
|
|
51190
|
+
this.assessmentPayload.alphabet_filter = event;
|
|
51191
|
+
this.assessmentPayload.search_text = '';
|
|
51192
|
+
this.getAssessmentCategoryList();
|
|
51193
|
+
}
|
|
51194
|
+
// TODO: Call API method
|
|
51195
|
+
getAssessmentCategoryList() {
|
|
51196
|
+
this.isLoader = true;
|
|
51197
|
+
this.assessmentService
|
|
51198
|
+
.getAssessmentCategory(this.assessmentPayload)
|
|
51199
|
+
.subscribe((res) => {
|
|
51200
|
+
this.assessmentCategory = res;
|
|
51201
|
+
if (this.selectedAssessmentArr?.length) {
|
|
51202
|
+
// this.selectedAssessmentArr = [... new Set(this.selectedAssessmentArr)]
|
|
51203
|
+
this.selectedAssessmentArr.forEach((ele) => {
|
|
51204
|
+
const index = res.data.findIndex((assessment) => assessment.id === ele.category_id);
|
|
51205
|
+
this.expandCategory(ele.category_id);
|
|
51206
|
+
});
|
|
51207
|
+
// this.selectedAssessmentArr.forEach((ele:any,index:any) => {
|
|
51208
|
+
// this.openedCategory.push(ele?.category_id);
|
|
51209
|
+
// this.showSubList(index,ele?.category_id);
|
|
51210
|
+
// })
|
|
51211
|
+
}
|
|
51212
|
+
this.isLoader = false;
|
|
51213
|
+
});
|
|
51214
|
+
}
|
|
51215
|
+
// TODO: Call Sub data API method
|
|
51216
|
+
/**
|
|
51217
|
+
*
|
|
51218
|
+
* @param id : Assessment category id
|
|
51219
|
+
*/
|
|
51220
|
+
getAssessmentList(id) {
|
|
51221
|
+
const payload = {
|
|
51222
|
+
search_title: '',
|
|
51223
|
+
};
|
|
51224
|
+
this.assessmentService
|
|
51225
|
+
.getAssessmentList(payload, id)
|
|
51226
|
+
.subscribe((res) => {
|
|
51227
|
+
const index = this.assessmentCategory?.data?.findIndex((ele) => ele.id === id);
|
|
51228
|
+
if (index > -1) {
|
|
51229
|
+
this.assessmentCategory.data[index].assessmentData = [
|
|
51230
|
+
...new Set(res),
|
|
51231
|
+
];
|
|
51232
|
+
}
|
|
51233
|
+
if (this.selectedAssessmentArr?.length) {
|
|
51234
|
+
this.setCategoryAndAssessment();
|
|
51235
|
+
const index = this.selectedAssessmentArr.findIndex((ele) => ele.category_id === id);
|
|
51236
|
+
// if(index !== -1) {
|
|
51237
|
+
// this.selectedAssessmentArr[index].assessmentIds = this.selectedAssessmentArr[index].assessmentIds.map((ele: any) => {
|
|
51238
|
+
// ele = res.find((data: any) => data.id === ele);
|
|
51239
|
+
// return ele;
|
|
51240
|
+
// });
|
|
51241
|
+
// }
|
|
51242
|
+
}
|
|
51243
|
+
});
|
|
51244
|
+
}
|
|
51245
|
+
/**
|
|
51246
|
+
* #### Description
|
|
51247
|
+
* Selects item or deselect a itme
|
|
51248
|
+
* @param evt
|
|
51249
|
+
* @param payload
|
|
51250
|
+
*/
|
|
51251
|
+
selectAssessment(evt, payload, category) {
|
|
51252
|
+
if (evt?.target?.checked) {
|
|
51253
|
+
const index = this.selectedAssessmentArr.findIndex((ele) => ele.category_id === category.id);
|
|
51254
|
+
if (index > -1) {
|
|
51255
|
+
const currentCategoryAssessment = this.selectedAssessmentArr[index].assessmentIds;
|
|
51256
|
+
currentCategoryAssessment.push(payload);
|
|
51257
|
+
this.selectedAssessmentArr[index].assessmentIds = this.uniqueByProp(currentCategoryAssessment, 'id');
|
|
51258
|
+
this.selectedAssessmentArr = cloneDeep(this.selectedAssessmentArr);
|
|
51259
|
+
this.setCategoryAndAssessment();
|
|
51260
|
+
}
|
|
51261
|
+
else {
|
|
51262
|
+
this.selectedAssessmentArr.push({
|
|
51263
|
+
category_id: category.id,
|
|
51264
|
+
assessmentIds: [payload],
|
|
51265
|
+
});
|
|
51266
|
+
this.selectedAssessmentArr = cloneDeep(this.selectedAssessmentArr);
|
|
51267
|
+
this.setCategoryAndAssessment();
|
|
51268
|
+
}
|
|
51269
|
+
}
|
|
51270
|
+
else {
|
|
51271
|
+
const index = this.selectedAssessmentArr.findIndex((ele) => ele.category_id === category.id);
|
|
51272
|
+
if (index > -1) {
|
|
51273
|
+
this.selectedAssessmentArr[index].assessmentIds =
|
|
51274
|
+
this.selectedAssessmentArr[index].assessmentIds.filter((assessment) => assessment.id !== payload.id);
|
|
51275
|
+
this.selectedAssessmentArr = cloneDeep(this.selectedAssessmentArr);
|
|
51276
|
+
this.setCategoryAndAssessment();
|
|
51277
|
+
if (this.selectedAssessmentArr[index].assessmentIds?.length === 0) {
|
|
51278
|
+
this.selectedAssessmentArr.splice(index, 1);
|
|
51279
|
+
this.selectedAssessmentArr = cloneDeep(this.selectedAssessmentArr);
|
|
51280
|
+
this.setCategoryAndAssessment();
|
|
51281
|
+
}
|
|
51282
|
+
}
|
|
51283
|
+
}
|
|
51284
|
+
}
|
|
51285
|
+
setCategoryAndAssessment() {
|
|
51286
|
+
this.selectedAssessmentCategoriesIds = this.selectedAssessmentArr
|
|
51287
|
+
.filter((cat) => cat?.assessmentIds?.length > 0)
|
|
51288
|
+
?.map((ele) => ele?.category_id)
|
|
51289
|
+
.flat();
|
|
51290
|
+
this.selectedAssessmentIds = this.selectedAssessmentArr
|
|
51291
|
+
.map((cat) => cat?.assessmentIds.map((ele) => ele?.id))
|
|
51292
|
+
.flat();
|
|
51293
|
+
this.selectedAssessment = this.selectedAssessmentArr
|
|
51294
|
+
.map((cat) => cat?.assessmentIds.map((ele) => ele))
|
|
51295
|
+
.flat();
|
|
51296
|
+
}
|
|
51297
|
+
// TODO: Display selected data in bottom floating bar with next enabled button having
|
|
51298
|
+
// TODO: Send data in payload of create Responsibility form
|
|
51299
|
+
save() {
|
|
51300
|
+
this.onAssessmentSelect.emit(this.selectedAssessmentArr);
|
|
51301
|
+
}
|
|
51302
|
+
close() {
|
|
51303
|
+
this.cancelAssessment.emit();
|
|
51304
|
+
}
|
|
51305
|
+
/**
|
|
51306
|
+
* #### Description
|
|
51307
|
+
*
|
|
51308
|
+
* Returns the unique array of object based on unique key
|
|
51309
|
+
* @param array
|
|
51310
|
+
* @param key
|
|
51311
|
+
* @returns
|
|
51312
|
+
*/
|
|
51313
|
+
uniqueByProp(array, key) {
|
|
51314
|
+
return Array.from(array
|
|
51315
|
+
.reduce((acc, item) => (item && item[key] && acc.set(item[key], item), acc), new Map())
|
|
51316
|
+
.values());
|
|
51317
|
+
}
|
|
51318
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AssessmentPickerComponent, deps: [{ token: AssessmentService }, { token: AuthService$1 }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
51319
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AssessmentPickerComponent, selector: "assessment-picker", inputs: { isEdit: "isEdit", setSelected: ["selectedAssessment", "setSelected"], selectedAssessmentData: "selectedAssessmentData" }, outputs: { onAssessmentSelect: "onAssessmentSelect", cancelAssessment: "cancelAssessment" }, ngImport: i0, template: "<app-preview\n *ngIf=\"isPreview\"\n [questionData]=\"previewQuestionData\"\n (previewBack)=\"previewBack()\"\n></app-preview>\n<div class=\"assessment-list\" [class.animate]=\"animation\">\n <ng-container>\n <div class=\"assessment-list-head\">\n <button class=\"back-btn\">\n <!-- <i class=\"icons\"></i> -->\n </button>\n <h3 class=\"assessment-list-title\">Select Assessment(s)</h3>\n </div>\n <div class=\"assessment-list-body\">\n <div class=\"search-block\">\n <i class=\"icons\"></i>\n <input\n type=\"text\"\n [(ngModel)]=\"searchAssessments\"\n (change)=\"onAssessmentSearch($event.target.value)\"\n placeholder=\"Search Assessment Category\"\n />\n </div>\n <pagination\n [pageCount]=\"assessmentCategory?.totalPage\"\n [total]=\"assessmentCategory?.totalRecords\"\n [start]=\"assessmentCategory?.start_value\"\n [end]=\"assessmentCategory?.end_value\"\n [activeAlphabet]=\"''\"\n (selectedAlphabet)=\"onAlphabetSelected($event)\"\n (selectedPage)=\"onPageSelection($event)\"\n ></pagination>\n <div\n *ngIf=\"assessmentCategory.data.length === 0 && !isLoader\"\n class=\"assessment-list-part\"\n >\n <app-no-data\n [noDataImage]=\"ASSETS.search_data\"\n [noDataText]=\"'No Assessments Found.'\"\n ></app-no-data>\n </div>\n <div\n *ngIf=\"assessmentCategory.data.length || isLoader\"\n class=\"assessment-list-part\"\n >\n <div\n *ngIf=\"\n isEdit && selectedAssessment?.assessmentDetails?.assessment_name\n \"\n class=\"assessment-list-selected\"\n >\n <div class=\"assessment-list-heading\">\n Assessment already selected for this responsibility\n </div>\n <div class=\"assessment-list-item\">\n <div class=\"table-row\">\n <div class=\"table-column serial disabled\">\n <app-cs-radio\n [disabled]=\"true\"\n class=\"disabled\"\n [checked]=\"true\"\n [readonly]=\"true\"\n ></app-cs-radio>\n </div>\n <div class=\"table-column sub-name\">\n <div class=\"name-inner\">\n <div\n class=\"value\"\n [appTooltip]=\"\n selectedAssessment?.assessmentDetails?.assessment_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >\n {{ selectedAssessment?.assessmentDetails?.assessment_name }}\n </div>\n <div class=\"within-part\">\n <span class=\"within-box\">Within</span>\n <span\n class=\"value\"\n [appTooltip]=\"\n selectedAssessment?.category_details?.category_name +\n (selectedAssessment?.category_details?.parent_tree\n ? ' > ' +\n selectedAssessment?.category_details?.parent_tree\n : '')\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n selectedAssessment?.category_details?.category_name +\n (selectedAssessment?.category_details?.parent_tree\n ? \" > \" +\n selectedAssessment?.category_details?.parent_tree\n : \"\")\n }}</span\n >\n </div>\n </div>\n </div>\n <div class=\"table-column question\">\n <div class=\"label\">\n {{ selectedAssessment?.assessmentDetails?.questions }}\n {{\n selectedAssessment?.assessmentDetails?.questions > 1\n ? \"Questions\"\n : \"Question\"\n }}\n </div>\n <div class=\"buttons\">\n <button\n class=\"action-btn\"\n (click)=\"preview(selectedAssessment?.assessmentDetails)\"\n >\n <i class=\"icons\"></i> Preview\n </button>\n <!-- <button class=\"action-btn\"><i class=\"icons\"></i> Edit</button> -->\n </div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"assessment-list-heading\">\n Select an Assessment for this responsibility\n </div>\n\n <!--\n Assessment category list\n active class is used for highlighting opened element\n -->\n <ng-container *ngIf=\"!isLoader\">\n <div\n *ngFor=\"let data of assessmentCategory.data; let i = index\"\n class=\"assessment-list-item\"\n [class.active]=\"\n openedCategory.includes(data?.id) ||\n data.id === selectedAssessment?.category_id\n \"\n >\n <div\n class=\"table-row main-list\"\n (click)=\"expandCategory(data?.id)\"\n [class.disabled]=\"data?.assessmentcount < 1\"\n >\n <div class=\"table-column serial\">\n <div\n [id]=\"'sr-no' + i\"\n class=\"sr-no\"\n [appTooltip]=\"i + 1\"\n placement=\"bottom\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"true\"\n >\n {{ dataPerPage * (assessmentPayload.page_no - 1) + (i + 1) }}\n </div>\n </div>\n <div class=\"table-column name\">\n <div class=\"name-inner\">\n <div\n class=\"value\"\n [appTooltip]=\"data.category_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >\n {{ data?.category_name }}\n </div>\n <div class=\"within-part\" *ngIf=\"data?.parent_tree\">\n <span class=\"within-box\">Within</span>\n <span\n class=\"value\"\n [appTooltip]=\"data.parent_tree\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ data?.parent_tree }}</span\n >\n </div>\n </div>\n </div>\n <div class=\"table-column action\">\n <button\n [id]=\"'arrow' + i\"\n class=\"arrow\"\n [class.disabled]=\"data?.assessmentcount < 1\"\n [disabled]=\"data?.assessmentcount < 1\"\n >\n <i *ngIf=\"!openedCategory.includes(data?.id)\" class=\"icons\"\n ></i\n >\n <i *ngIf=\"openedCategory.includes(data?.id)\" class=\"icons\"\n ></i\n >\n </button>\n </div>\n </div>\n\n <!-- Assessment list start from here -->\n <div *ngIf=\"openedCategory.includes(data?.id)\" class=\"sub-list\">\n <ng-container *ngIf=\"data.assessmentData?.length > 0\">\n <div\n class=\"table-row\"\n *ngFor=\"let assessment of data.assessmentData; let j = index\"\n [class.active]=\"selectedAssessmentIds.includes(assessment.id)\"\n >\n <div class=\"table-column serial\">\n <div\n [id]=\"'sub-sr-no' + i + j\"\n class=\"sr-no active\"\n appTooltip=\"{{\n dataPerPage * (assessmentPayload.page_no - 1) + (i + 1)\n }}.{{ j + 1 }}\"\n placement=\"bottom\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"true\"\n >\n {{\n dataPerPage * (assessmentPayload.page_no - 1) + (i + 1)\n }}.{{ j + 1 }}\n <!-- <app-cs-radio name=\"assessment\" [value]=\"assessment.id\" [checked]=\"assessment?.id === selectedAssessment?.assessment_id && data?.id === selectedAssessment?.category_id\"\n (checkedEvent)=\"setAssessment(data, assessment)\"></app-cs-radio> -->\n <!-- (change)=\"selectGroup($event,group)\" [disabled]=\"nonRemovableGroupIds?.includes(group?.group_id)\" [checked]=\"selectedGroupIds.includes(group?.group_id)\" -->\n\n <vui-checkbox\n [checked]=\"\n selectedAssessmentIds.includes(assessment.id)\n \"\n (change)=\"selectAssessment($event, assessment, data)\"\n ></vui-checkbox>\n </div>\n </div>\n <div class=\"table-column sub-name\">\n <div\n class=\"value\"\n [appTooltip]=\"\n 'Mission and message, communications to external audiences'\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >\n {{ assessment?.assessment_name }}\n </div>\n </div>\n <div class=\"table-column question\">\n <div class=\"label\">\n {{ assessment?.questions }}\n {{ assessment?.questions > 1 ? \"Questions\" : \"Question\" }}\n </div>\n <div class=\"buttons\">\n <button class=\"action-btn\" (click)=\"preview(assessment)\">\n <i class=\"icons\"></i> Preview\n </button>\n <!-- <button class=\"action-btn\"><i class=\"icons\"></i> Edit</button> -->\n </div>\n </div>\n </div>\n </ng-container>\n <!-- Loader loading isLoader -->\n <assessment-sub-loader\n *ngIf=\"!data.assessmentData?.length\"\n ></assessment-sub-loader>\n <!-- <app-line-loader *ngIf=\"!data.assessmentData?.length\" [loaderHeight]=\"'5'\"></app-line-loader> -->\n </div>\n </div>\n </ng-container>\n <!-- Loader loading isLoader -->\n <assessment-loader *ngIf=\"isLoader\"></assessment-loader>\n </div>\n <!-- No data image -->\n <app-no-data\n *ngIf=\"!assessmentCategory.data.length && !isLoader\"\n [noDataImage]=\"ASSETS.search_data\"\n [noDataText]=\"'No Data to Display'\"\n ></app-no-data>\n </div>\n <!--\n bottom floating bar which includes cancel, next button\n closing tab\n -->\n\n <vui-floating-bar (closeEvent)=\"save()\" (closeList)=\"close()\">\n <div\n class=\"counter\"\n *ngIf=\"selectedAssessment?.length\"\n appPopover\n (click)=\"assessmentCount.popover()\"\n placement=\"left\"\n >\n {{ selectedAssessment?.length }}\n </div>\n <div class=\"name\">\n <span *ngIf=\"selectedAssessment?.length === 1\"\n >Assessment selected</span\n >\n <span *ngIf=\"selectedAssessment?.length > 1\">Assessments selected</span>\n </div>\n <app-popover #assessmentCount [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"let element of selectedAssessment; let i = index\">\n <div class=\"avatar-card\">\n <span class=\"value\">\n <!-- <i class=\"icons\"\n (click)=\"selectAssessment({target:{checked:false}},element)\"></i> -->\n {{ element?.assessment_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </vui-floating-bar>\n </ng-container>\n</div>\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";::ng-deep .assessment-list{background:#fff;border-top:3px solid #1E5DD3;position:fixed;inset:0 500px 0 0;z-index:1}::ng-deep .assessment-list.animate{animation:animate-right .2s cubic-bezier(.25,.46,.45,.94) both;z-index:-1}::ng-deep .assessment-list-head{background:#fbfbfb;height:42px;padding:0 18px;display:flex;align-items:center;border:1px solid #f1f1f1;border-right:none}::ng-deep .assessment-list-head button.back-btn{background:transparent;border-radius:0;border:0;color:#161b2f;font-size:16px;padding:0;margin:0 8px 0 0}::ng-deep .assessment-list-title{color:#161b2f;font-size:15px;font-weight:500;margin:0!important;padding:0;line-height:21px}::ng-deep .assessment-list-close{background:transparent;border:none;outline:none;cursor:pointer;color:#000;font-size:12px;display:inline-block;padding:0}::ng-deep .assessment-list-body{padding:24px 40px 24px 36px;height:calc(100vh - 112px)}::ng-deep .assessment-list-body .search-block{position:relative}::ng-deep .assessment-list-body .search-block input{height:44px;line-height:24px;padding:10px 15px 10px 40px;outline:none;border:1px solid #7475763f;border-radius:4px;width:100%;font-size:14px;color:#747576}::ng-deep .assessment-list-body .search-block input::placeholder{font-weight:400}::ng-deep .assessment-list-body .search-block input:focus{border-color:#1e5dd3}::ng-deep .assessment-list-body .search-block i{position:absolute;left:17px;font-size:12px;font-weight:400;top:17px;pointer-events:none;color:#f1f1f1}::ng-deep .assessment-list-body .assessment-list-part{height:calc(100vh - 228px);overflow:auto;padding:8px 12px 0 0;width:calc(100% + 12px)}::ng-deep .assessment-list-body .assessment-list-part::-webkit-scrollbar-track{background-color:#fff;position:absolute}::ng-deep .assessment-list-body .assessment-list-part::-webkit-scrollbar{width:3px;height:3px;background-color:transparent;position:absolute}::ng-deep .assessment-list-body .assessment-list-part::-webkit-scrollbar-thumb{border-radius:3px;background-color:#dbdbdb;position:absolute}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-selected{margin-bottom:8px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-heading{color:#161b2f;font-size:12px;font-weight:600;margin-bottom:4px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item{border:1px solid #f1f1f1;border-radius:2px;margin-bottom:4px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .main-list{cursor:pointer}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item.active{border-color:#1e5dd3;box-shadow:0 3px 6px #4681ef26}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row{display:flex;align-items:center;justify-content:space-between}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row.disabled{pointer-events:none}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column{color:#747576;height:48px;position:relative;width:100%;display:flex;align-items:center;padding:0 4px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.serial{width:32px;max-width:32px;justify-content:center}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.serial .sr-no{width:16px;background:#f8f8f8;writing-mode:vertical-lr;color:#747576;font-size:10px;font-weight:500;display:flex;height:100%;align-items:center;justify-content:center;position:relative;transition:all .2s ease-in-out}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.serial .sr-no vui-checkbox{position:absolute;top:8px;left:0;opacity:0;transition:all .2s ease-in-out}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.serial .sr-no vui-checkbox label.checkbox-item{position:unset}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.name{width:calc(100% - 64px);min-width:calc(100% - 64px)}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.name .name-inner{width:100%}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.name .name-inner .value{color:#161b2f;font-size:12px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;padding-right:20px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.action{width:32px;max-width:32px;justify-content:center}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.action button.arrow{background:transparent;border:none;border-radius:0;color:#747576;font-size:12px;padding:0;margin:0;display:flex;align-items:center;justify-content:center;height:100%;width:100%}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.action button.disabled{opacity:.5!important;pointer-events:none}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.sub-name{width:calc(100% - 232px);min-width:calc(100% - 232px)}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.sub-name .name-inner{width:100%}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.sub-name .value{color:#747576;font-size:12px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;padding-right:20px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.question{width:200px;max-width:200px;justify-content:flex-end}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.question .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-right:8px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.question .buttons{display:flex;width:0;overflow:hidden;transition:all .2s ease-in-out}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.question .buttons button.action-btn{background:#fff;border:1px solid #f1f1f1;border-radius:2px;color:#1e5dd3;font-size:11px;font-weight:500;line-height:24px;text-transform:uppercase;padding:0 8px;display:flex;align-items:center;margin:0}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.question .buttons button.action-btn i{margin-right:4px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.question .buttons button.action-btn+button{margin-left:4px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row:hover .table-column.question .buttons{width:86px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .sub-list .table-row{border-top:1px solid #f1f1f1}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .sub-list .table-row:hover .table-column.serial .sr-no,::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .sub-list .table-row.active .table-column.serial .sr-no{color:#f8f8f8}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .sub-list .table-row:hover .table-column.serial .sr-no vui-checkbox,::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .sub-list .table-row.active .table-column.serial .sr-no vui-checkbox{opacity:1}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .sub-list .table-row .table-column{height:32px}::ng-deep .assessment-list-body ul{padding:0;margin:0}::ng-deep .assessment-list-body ul.assessment{max-height:calc(100vh - 240px);overflow:auto;padding:16px 12px 0 0;width:calc(100% + 12px)}::ng-deep .assessment-list-body ul.assessment::-webkit-scrollbar-track{background-color:#fff;position:absolute}::ng-deep .assessment-list-body ul.assessment::-webkit-scrollbar{width:3px;height:3px;background-color:transparent;position:absolute}::ng-deep .assessment-list-body ul.assessment::-webkit-scrollbar-thumb{border-radius:3px;background-color:#dbdbdb;position:absolute}::ng-deep .assessment-list-body ul.assessment li{padding:0 0 12px;list-style:none;display:flex;align-items:center;justify-content:space-between}::ng-deep .assessment-list-body ul.assessment li vui-checkbox{width:calc(100% - 260px)}::ng-deep .assessment-list-body ul.assessment li vui-checkbox .radio-item .value .name{font-size:12px;color:#161b2f;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .assessment-list-body ul.assessment li .right{display:flex;align-items:center}::ng-deep .assessment-list-body ul.assessment li .right .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}::ng-deep .assessment-list-body ul.assessment li .right .buttons{display:flex;width:0;overflow:hidden;transition:all .2s ease-in-out}::ng-deep .assessment-list-body ul.assessment li .right .buttons button.action-btn{background:#fff;border:1px solid #f1f1f1;border-radius:2px;color:#1e5dd3;font-size:11px;font-weight:500;line-height:24px;text-transform:uppercase;padding:0 8px;margin-left:12px;display:flex;align-items:center}::ng-deep .assessment-list-body ul.assessment li .right .buttons button.action-btn i{margin-right:4px}::ng-deep .assessment-list-body ul.assessment li .right .buttons button.action-btn+button{margin-left:4px}::ng-deep .assessment-list-body ul.assessment li:hover .right .buttons{width:156px}.within-part{display:flex;align-items:center;padding-right:12px}.within-part .value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;font-size:12px;color:#747576}.within-box{background:#f1f1f1;border-radius:2px;color:#042e7d;font-size:9px;font-weight:600;text-transform:uppercase;padding:0 4px;margin-right:8px;line-height:12px}@keyframes animate-right{0%{transform:translate(100%)}to{transform:translate(0)}}.wf-action-list{width:220px}.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}.wf-action-list ul.action-item{display:block}.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}.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}.wf-action-list ul.action-item li button .file-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;width:calc(100% - 16px)}.wf-action-list ul.action-item li button i{font-size:16px;margin-right:10px;color:#1e5dd3}.wf-action-list ul.action-item li button:hover{background:#f3f3f3}.wf-action-list ul.action-item li .avatar-card{display:flex;align-items:center;width:100%;padding:7.5px}.wf-action-list ul.action-item li .avatar-card.within-con{display:block}.wf-action-list ul.action-item li .avatar-card .avatar{height:24px;width:24px!important;min-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}.wf-action-list ul.action-item li .avatar-card .avatar img{background:#fff;width:100%;height:100%}.wf-action-list ul.action-item li .avatar-card .avatar+span.value{width:calc(100% - 29px)}.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}.wf-action-list ul.action-item li .avatar-card span.value i{font-size:8px;color:#747576;cursor:pointer;margin-right:5px}.wf-action-list ul.action-item li .avatar-card.no-image{display:block}.wf-action-list ul.action-item li .avatar-card.no-image span.value{width:100%;display:block}.wf-action-list ul.action-item li .avatar-card i.delete-icon{color:#d93b41;cursor:pointer;font-size:14px}.wf-action-list ul.action-item li .chip-item{color:#1e5dd3;padding:10px;display:flex;align-items:center}.wf-action-list ul.action-item li .chip-item i{color:#747576;margin-left:7px;font-size:10px;cursor:pointer;display:inline-flex}.wf-action-list ul.action-item li .chip-item span{display:block;width:auto;width:calc(100% - 17px);font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wf-action-list ul.action-item li .chip-item span.chip-block{display:block;width:100%}.wf-action-list ul.action-item li .chip-item span.id{font-size:9px}.wf-action-list ul.action-item li .within{display:flex;align-items:center;justify-content:flex-start}.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}.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}.wf-action-list ul.action-item li:first-child{animation:action-list-open .25s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(2){animation:action-list-open .35s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(3){animation:action-list-open .45s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(4){animation:action-list-open .55s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(5){animation:action-list-open .65s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(6){animation:action-list-open .75s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(7){animation:action-list-open .85s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(8){animation:action-list-open .95s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(9){animation:action-list-open 1.05s cubic-bezier(.25,.46,.45,.94) both}.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)}}\n"], dependencies: [{ kind: "directive", type: i1$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: ToolTipDirective, selector: "[appTooltip]", inputs: ["appTooltip", "placement", "type", "tooltipMandatory", "showTooltip", "animate"] }, { kind: "component", type: PopoverComponent, selector: "app-popover", inputs: ["dontCloseonClick"] }, { kind: "directive", type: PopoverDirective, selector: "[appPopover]", inputs: ["refrence", "placement"] }, { kind: "directive", type: i1$3.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$3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: NoDataComponentUI, selector: "app-no-data", inputs: ["action", "secondaryAction", "noDataImage", "noDataText", "noDataButton", "secondaryButton", "noDataSecButton", "altText", "smallButton"], outputs: ["buttonAction", "secondaryActionButton"] }, { kind: "component", type: CsRadioComponentUI, selector: "app-cs-radio", inputs: ["disabled", "readonly", "name", "checked", "value"], outputs: ["checkedEvent"] }, { kind: "component", type: PreviewComponent, selector: "app-preview", inputs: ["questionData"], outputs: ["previewBack"] }, { kind: "component", type: CheckboxComponent$1, selector: "vui-checkbox", inputs: ["disabled", "checked", "indeterminateEnabled"] }, { kind: "component", type: VuiFloatingBarComponent, selector: "vui-floating-bar", inputs: ["selectedData", "groupSelected", "displayElementKey", "elementId", "singularText", "pluralText", "showNextButton", "showFrequencyText", "showWorkflow", "workflowText", "currentFrequency", "isDisabled", "workflowList", "selectedWorkflow", "workflowPlaceHolder", "mode", "nextDisabled", "nonRemovableUsersList", "removePosition"], outputs: ["closeEvent", "deleteEvent", "closeList", "workflowTypeChanged"] }, { kind: "component", type: AssessmentLoaderComponent, selector: "assessment-loader" }, { kind: "component", type: AssessmentSubLoaderComponent, selector: "assessment-sub-loader" }, { kind: "component", type: Pagination, selector: "pagination", inputs: ["activeAlphabet", "pageCount", "start", "end", "total", "noFilter", "currentPage"], outputs: ["selectedPage", "selectedAlphabet"] }] }); }
|
|
51320
|
+
}
|
|
51321
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AssessmentPickerComponent, decorators: [{
|
|
51322
|
+
type: Component,
|
|
51323
|
+
args: [{ selector: 'assessment-picker', template: "<app-preview\n *ngIf=\"isPreview\"\n [questionData]=\"previewQuestionData\"\n (previewBack)=\"previewBack()\"\n></app-preview>\n<div class=\"assessment-list\" [class.animate]=\"animation\">\n <ng-container>\n <div class=\"assessment-list-head\">\n <button class=\"back-btn\">\n <!-- <i class=\"icons\"></i> -->\n </button>\n <h3 class=\"assessment-list-title\">Select Assessment(s)</h3>\n </div>\n <div class=\"assessment-list-body\">\n <div class=\"search-block\">\n <i class=\"icons\"></i>\n <input\n type=\"text\"\n [(ngModel)]=\"searchAssessments\"\n (change)=\"onAssessmentSearch($event.target.value)\"\n placeholder=\"Search Assessment Category\"\n />\n </div>\n <pagination\n [pageCount]=\"assessmentCategory?.totalPage\"\n [total]=\"assessmentCategory?.totalRecords\"\n [start]=\"assessmentCategory?.start_value\"\n [end]=\"assessmentCategory?.end_value\"\n [activeAlphabet]=\"''\"\n (selectedAlphabet)=\"onAlphabetSelected($event)\"\n (selectedPage)=\"onPageSelection($event)\"\n ></pagination>\n <div\n *ngIf=\"assessmentCategory.data.length === 0 && !isLoader\"\n class=\"assessment-list-part\"\n >\n <app-no-data\n [noDataImage]=\"ASSETS.search_data\"\n [noDataText]=\"'No Assessments Found.'\"\n ></app-no-data>\n </div>\n <div\n *ngIf=\"assessmentCategory.data.length || isLoader\"\n class=\"assessment-list-part\"\n >\n <div\n *ngIf=\"\n isEdit && selectedAssessment?.assessmentDetails?.assessment_name\n \"\n class=\"assessment-list-selected\"\n >\n <div class=\"assessment-list-heading\">\n Assessment already selected for this responsibility\n </div>\n <div class=\"assessment-list-item\">\n <div class=\"table-row\">\n <div class=\"table-column serial disabled\">\n <app-cs-radio\n [disabled]=\"true\"\n class=\"disabled\"\n [checked]=\"true\"\n [readonly]=\"true\"\n ></app-cs-radio>\n </div>\n <div class=\"table-column sub-name\">\n <div class=\"name-inner\">\n <div\n class=\"value\"\n [appTooltip]=\"\n selectedAssessment?.assessmentDetails?.assessment_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >\n {{ selectedAssessment?.assessmentDetails?.assessment_name }}\n </div>\n <div class=\"within-part\">\n <span class=\"within-box\">Within</span>\n <span\n class=\"value\"\n [appTooltip]=\"\n selectedAssessment?.category_details?.category_name +\n (selectedAssessment?.category_details?.parent_tree\n ? ' > ' +\n selectedAssessment?.category_details?.parent_tree\n : '')\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n selectedAssessment?.category_details?.category_name +\n (selectedAssessment?.category_details?.parent_tree\n ? \" > \" +\n selectedAssessment?.category_details?.parent_tree\n : \"\")\n }}</span\n >\n </div>\n </div>\n </div>\n <div class=\"table-column question\">\n <div class=\"label\">\n {{ selectedAssessment?.assessmentDetails?.questions }}\n {{\n selectedAssessment?.assessmentDetails?.questions > 1\n ? \"Questions\"\n : \"Question\"\n }}\n </div>\n <div class=\"buttons\">\n <button\n class=\"action-btn\"\n (click)=\"preview(selectedAssessment?.assessmentDetails)\"\n >\n <i class=\"icons\"></i> Preview\n </button>\n <!-- <button class=\"action-btn\"><i class=\"icons\"></i> Edit</button> -->\n </div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"assessment-list-heading\">\n Select an Assessment for this responsibility\n </div>\n\n <!--\n Assessment category list\n active class is used for highlighting opened element\n -->\n <ng-container *ngIf=\"!isLoader\">\n <div\n *ngFor=\"let data of assessmentCategory.data; let i = index\"\n class=\"assessment-list-item\"\n [class.active]=\"\n openedCategory.includes(data?.id) ||\n data.id === selectedAssessment?.category_id\n \"\n >\n <div\n class=\"table-row main-list\"\n (click)=\"expandCategory(data?.id)\"\n [class.disabled]=\"data?.assessmentcount < 1\"\n >\n <div class=\"table-column serial\">\n <div\n [id]=\"'sr-no' + i\"\n class=\"sr-no\"\n [appTooltip]=\"i + 1\"\n placement=\"bottom\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"true\"\n >\n {{ dataPerPage * (assessmentPayload.page_no - 1) + (i + 1) }}\n </div>\n </div>\n <div class=\"table-column name\">\n <div class=\"name-inner\">\n <div\n class=\"value\"\n [appTooltip]=\"data.category_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >\n {{ data?.category_name }}\n </div>\n <div class=\"within-part\" *ngIf=\"data?.parent_tree\">\n <span class=\"within-box\">Within</span>\n <span\n class=\"value\"\n [appTooltip]=\"data.parent_tree\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ data?.parent_tree }}</span\n >\n </div>\n </div>\n </div>\n <div class=\"table-column action\">\n <button\n [id]=\"'arrow' + i\"\n class=\"arrow\"\n [class.disabled]=\"data?.assessmentcount < 1\"\n [disabled]=\"data?.assessmentcount < 1\"\n >\n <i *ngIf=\"!openedCategory.includes(data?.id)\" class=\"icons\"\n ></i\n >\n <i *ngIf=\"openedCategory.includes(data?.id)\" class=\"icons\"\n ></i\n >\n </button>\n </div>\n </div>\n\n <!-- Assessment list start from here -->\n <div *ngIf=\"openedCategory.includes(data?.id)\" class=\"sub-list\">\n <ng-container *ngIf=\"data.assessmentData?.length > 0\">\n <div\n class=\"table-row\"\n *ngFor=\"let assessment of data.assessmentData; let j = index\"\n [class.active]=\"selectedAssessmentIds.includes(assessment.id)\"\n >\n <div class=\"table-column serial\">\n <div\n [id]=\"'sub-sr-no' + i + j\"\n class=\"sr-no active\"\n appTooltip=\"{{\n dataPerPage * (assessmentPayload.page_no - 1) + (i + 1)\n }}.{{ j + 1 }}\"\n placement=\"bottom\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"true\"\n >\n {{\n dataPerPage * (assessmentPayload.page_no - 1) + (i + 1)\n }}.{{ j + 1 }}\n <!-- <app-cs-radio name=\"assessment\" [value]=\"assessment.id\" [checked]=\"assessment?.id === selectedAssessment?.assessment_id && data?.id === selectedAssessment?.category_id\"\n (checkedEvent)=\"setAssessment(data, assessment)\"></app-cs-radio> -->\n <!-- (change)=\"selectGroup($event,group)\" [disabled]=\"nonRemovableGroupIds?.includes(group?.group_id)\" [checked]=\"selectedGroupIds.includes(group?.group_id)\" -->\n\n <vui-checkbox\n [checked]=\"\n selectedAssessmentIds.includes(assessment.id)\n \"\n (change)=\"selectAssessment($event, assessment, data)\"\n ></vui-checkbox>\n </div>\n </div>\n <div class=\"table-column sub-name\">\n <div\n class=\"value\"\n [appTooltip]=\"\n 'Mission and message, communications to external audiences'\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >\n {{ assessment?.assessment_name }}\n </div>\n </div>\n <div class=\"table-column question\">\n <div class=\"label\">\n {{ assessment?.questions }}\n {{ assessment?.questions > 1 ? \"Questions\" : \"Question\" }}\n </div>\n <div class=\"buttons\">\n <button class=\"action-btn\" (click)=\"preview(assessment)\">\n <i class=\"icons\"></i> Preview\n </button>\n <!-- <button class=\"action-btn\"><i class=\"icons\"></i> Edit</button> -->\n </div>\n </div>\n </div>\n </ng-container>\n <!-- Loader loading isLoader -->\n <assessment-sub-loader\n *ngIf=\"!data.assessmentData?.length\"\n ></assessment-sub-loader>\n <!-- <app-line-loader *ngIf=\"!data.assessmentData?.length\" [loaderHeight]=\"'5'\"></app-line-loader> -->\n </div>\n </div>\n </ng-container>\n <!-- Loader loading isLoader -->\n <assessment-loader *ngIf=\"isLoader\"></assessment-loader>\n </div>\n <!-- No data image -->\n <app-no-data\n *ngIf=\"!assessmentCategory.data.length && !isLoader\"\n [noDataImage]=\"ASSETS.search_data\"\n [noDataText]=\"'No Data to Display'\"\n ></app-no-data>\n </div>\n <!--\n bottom floating bar which includes cancel, next button\n closing tab\n -->\n\n <vui-floating-bar (closeEvent)=\"save()\" (closeList)=\"close()\">\n <div\n class=\"counter\"\n *ngIf=\"selectedAssessment?.length\"\n appPopover\n (click)=\"assessmentCount.popover()\"\n placement=\"left\"\n >\n {{ selectedAssessment?.length }}\n </div>\n <div class=\"name\">\n <span *ngIf=\"selectedAssessment?.length === 1\"\n >Assessment selected</span\n >\n <span *ngIf=\"selectedAssessment?.length > 1\">Assessments selected</span>\n </div>\n <app-popover #assessmentCount [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"let element of selectedAssessment; let i = index\">\n <div class=\"avatar-card\">\n <span class=\"value\">\n <!-- <i class=\"icons\"\n (click)=\"selectAssessment({target:{checked:false}},element)\"></i> -->\n {{ element?.assessment_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </vui-floating-bar>\n </ng-container>\n</div>\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";::ng-deep .assessment-list{background:#fff;border-top:3px solid #1E5DD3;position:fixed;inset:0 500px 0 0;z-index:1}::ng-deep .assessment-list.animate{animation:animate-right .2s cubic-bezier(.25,.46,.45,.94) both;z-index:-1}::ng-deep .assessment-list-head{background:#fbfbfb;height:42px;padding:0 18px;display:flex;align-items:center;border:1px solid #f1f1f1;border-right:none}::ng-deep .assessment-list-head button.back-btn{background:transparent;border-radius:0;border:0;color:#161b2f;font-size:16px;padding:0;margin:0 8px 0 0}::ng-deep .assessment-list-title{color:#161b2f;font-size:15px;font-weight:500;margin:0!important;padding:0;line-height:21px}::ng-deep .assessment-list-close{background:transparent;border:none;outline:none;cursor:pointer;color:#000;font-size:12px;display:inline-block;padding:0}::ng-deep .assessment-list-body{padding:24px 40px 24px 36px;height:calc(100vh - 112px)}::ng-deep .assessment-list-body .search-block{position:relative}::ng-deep .assessment-list-body .search-block input{height:44px;line-height:24px;padding:10px 15px 10px 40px;outline:none;border:1px solid #7475763f;border-radius:4px;width:100%;font-size:14px;color:#747576}::ng-deep .assessment-list-body .search-block input::placeholder{font-weight:400}::ng-deep .assessment-list-body .search-block input:focus{border-color:#1e5dd3}::ng-deep .assessment-list-body .search-block i{position:absolute;left:17px;font-size:12px;font-weight:400;top:17px;pointer-events:none;color:#f1f1f1}::ng-deep .assessment-list-body .assessment-list-part{height:calc(100vh - 228px);overflow:auto;padding:8px 12px 0 0;width:calc(100% + 12px)}::ng-deep .assessment-list-body .assessment-list-part::-webkit-scrollbar-track{background-color:#fff;position:absolute}::ng-deep .assessment-list-body .assessment-list-part::-webkit-scrollbar{width:3px;height:3px;background-color:transparent;position:absolute}::ng-deep .assessment-list-body .assessment-list-part::-webkit-scrollbar-thumb{border-radius:3px;background-color:#dbdbdb;position:absolute}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-selected{margin-bottom:8px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-heading{color:#161b2f;font-size:12px;font-weight:600;margin-bottom:4px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item{border:1px solid #f1f1f1;border-radius:2px;margin-bottom:4px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .main-list{cursor:pointer}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item.active{border-color:#1e5dd3;box-shadow:0 3px 6px #4681ef26}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row{display:flex;align-items:center;justify-content:space-between}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row.disabled{pointer-events:none}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column{color:#747576;height:48px;position:relative;width:100%;display:flex;align-items:center;padding:0 4px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.serial{width:32px;max-width:32px;justify-content:center}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.serial .sr-no{width:16px;background:#f8f8f8;writing-mode:vertical-lr;color:#747576;font-size:10px;font-weight:500;display:flex;height:100%;align-items:center;justify-content:center;position:relative;transition:all .2s ease-in-out}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.serial .sr-no vui-checkbox{position:absolute;top:8px;left:0;opacity:0;transition:all .2s ease-in-out}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.serial .sr-no vui-checkbox label.checkbox-item{position:unset}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.name{width:calc(100% - 64px);min-width:calc(100% - 64px)}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.name .name-inner{width:100%}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.name .name-inner .value{color:#161b2f;font-size:12px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;padding-right:20px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.action{width:32px;max-width:32px;justify-content:center}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.action button.arrow{background:transparent;border:none;border-radius:0;color:#747576;font-size:12px;padding:0;margin:0;display:flex;align-items:center;justify-content:center;height:100%;width:100%}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.action button.disabled{opacity:.5!important;pointer-events:none}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.sub-name{width:calc(100% - 232px);min-width:calc(100% - 232px)}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.sub-name .name-inner{width:100%}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.sub-name .value{color:#747576;font-size:12px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;padding-right:20px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.question{width:200px;max-width:200px;justify-content:flex-end}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.question .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-right:8px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.question .buttons{display:flex;width:0;overflow:hidden;transition:all .2s ease-in-out}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.question .buttons button.action-btn{background:#fff;border:1px solid #f1f1f1;border-radius:2px;color:#1e5dd3;font-size:11px;font-weight:500;line-height:24px;text-transform:uppercase;padding:0 8px;display:flex;align-items:center;margin:0}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.question .buttons button.action-btn i{margin-right:4px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row .table-column.question .buttons button.action-btn+button{margin-left:4px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .table-row:hover .table-column.question .buttons{width:86px}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .sub-list .table-row{border-top:1px solid #f1f1f1}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .sub-list .table-row:hover .table-column.serial .sr-no,::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .sub-list .table-row.active .table-column.serial .sr-no{color:#f8f8f8}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .sub-list .table-row:hover .table-column.serial .sr-no vui-checkbox,::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .sub-list .table-row.active .table-column.serial .sr-no vui-checkbox{opacity:1}::ng-deep .assessment-list-body .assessment-list-part .assessment-list-item .sub-list .table-row .table-column{height:32px}::ng-deep .assessment-list-body ul{padding:0;margin:0}::ng-deep .assessment-list-body ul.assessment{max-height:calc(100vh - 240px);overflow:auto;padding:16px 12px 0 0;width:calc(100% + 12px)}::ng-deep .assessment-list-body ul.assessment::-webkit-scrollbar-track{background-color:#fff;position:absolute}::ng-deep .assessment-list-body ul.assessment::-webkit-scrollbar{width:3px;height:3px;background-color:transparent;position:absolute}::ng-deep .assessment-list-body ul.assessment::-webkit-scrollbar-thumb{border-radius:3px;background-color:#dbdbdb;position:absolute}::ng-deep .assessment-list-body ul.assessment li{padding:0 0 12px;list-style:none;display:flex;align-items:center;justify-content:space-between}::ng-deep .assessment-list-body ul.assessment li vui-checkbox{width:calc(100% - 260px)}::ng-deep .assessment-list-body ul.assessment li vui-checkbox .radio-item .value .name{font-size:12px;color:#161b2f;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .assessment-list-body ul.assessment li .right{display:flex;align-items:center}::ng-deep .assessment-list-body ul.assessment li .right .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}::ng-deep .assessment-list-body ul.assessment li .right .buttons{display:flex;width:0;overflow:hidden;transition:all .2s ease-in-out}::ng-deep .assessment-list-body ul.assessment li .right .buttons button.action-btn{background:#fff;border:1px solid #f1f1f1;border-radius:2px;color:#1e5dd3;font-size:11px;font-weight:500;line-height:24px;text-transform:uppercase;padding:0 8px;margin-left:12px;display:flex;align-items:center}::ng-deep .assessment-list-body ul.assessment li .right .buttons button.action-btn i{margin-right:4px}::ng-deep .assessment-list-body ul.assessment li .right .buttons button.action-btn+button{margin-left:4px}::ng-deep .assessment-list-body ul.assessment li:hover .right .buttons{width:156px}.within-part{display:flex;align-items:center;padding-right:12px}.within-part .value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;font-size:12px;color:#747576}.within-box{background:#f1f1f1;border-radius:2px;color:#042e7d;font-size:9px;font-weight:600;text-transform:uppercase;padding:0 4px;margin-right:8px;line-height:12px}@keyframes animate-right{0%{transform:translate(100%)}to{transform:translate(0)}}.wf-action-list{width:220px}.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}.wf-action-list ul.action-item{display:block}.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}.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}.wf-action-list ul.action-item li button .file-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;width:calc(100% - 16px)}.wf-action-list ul.action-item li button i{font-size:16px;margin-right:10px;color:#1e5dd3}.wf-action-list ul.action-item li button:hover{background:#f3f3f3}.wf-action-list ul.action-item li .avatar-card{display:flex;align-items:center;width:100%;padding:7.5px}.wf-action-list ul.action-item li .avatar-card.within-con{display:block}.wf-action-list ul.action-item li .avatar-card .avatar{height:24px;width:24px!important;min-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}.wf-action-list ul.action-item li .avatar-card .avatar img{background:#fff;width:100%;height:100%}.wf-action-list ul.action-item li .avatar-card .avatar+span.value{width:calc(100% - 29px)}.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}.wf-action-list ul.action-item li .avatar-card span.value i{font-size:8px;color:#747576;cursor:pointer;margin-right:5px}.wf-action-list ul.action-item li .avatar-card.no-image{display:block}.wf-action-list ul.action-item li .avatar-card.no-image span.value{width:100%;display:block}.wf-action-list ul.action-item li .avatar-card i.delete-icon{color:#d93b41;cursor:pointer;font-size:14px}.wf-action-list ul.action-item li .chip-item{color:#1e5dd3;padding:10px;display:flex;align-items:center}.wf-action-list ul.action-item li .chip-item i{color:#747576;margin-left:7px;font-size:10px;cursor:pointer;display:inline-flex}.wf-action-list ul.action-item li .chip-item span{display:block;width:auto;width:calc(100% - 17px);font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wf-action-list ul.action-item li .chip-item span.chip-block{display:block;width:100%}.wf-action-list ul.action-item li .chip-item span.id{font-size:9px}.wf-action-list ul.action-item li .within{display:flex;align-items:center;justify-content:flex-start}.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}.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}.wf-action-list ul.action-item li:first-child{animation:action-list-open .25s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(2){animation:action-list-open .35s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(3){animation:action-list-open .45s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(4){animation:action-list-open .55s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(5){animation:action-list-open .65s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(6){animation:action-list-open .75s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(7){animation:action-list-open .85s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(8){animation:action-list-open .95s cubic-bezier(.25,.46,.45,.94) both}.wf-action-list ul.action-item li:nth-child(9){animation:action-list-open 1.05s cubic-bezier(.25,.46,.45,.94) both}.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)}}\n"] }]
|
|
51324
|
+
}], ctorParameters: function () { return [{ type: AssessmentService }, { type: AuthService$1 }]; }, propDecorators: { isEdit: [{
|
|
51325
|
+
type: Input
|
|
51326
|
+
}], setSelected: [{
|
|
51327
|
+
type: Input,
|
|
51328
|
+
args: ['selectedAssessment']
|
|
51329
|
+
}], selectedAssessmentData: [{
|
|
51330
|
+
type: Input
|
|
51331
|
+
}], onAssessmentSelect: [{
|
|
51332
|
+
type: Output
|
|
51333
|
+
}], cancelAssessment: [{
|
|
51334
|
+
type: Output
|
|
51335
|
+
}] } });
|
|
51336
|
+
|
|
51322
51337
|
class FrameworkService {
|
|
51323
51338
|
constructor(http, authService, config) {
|
|
51324
51339
|
this.http = http;
|
|
@@ -51877,6 +51892,20 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
51877
51892
|
}]
|
|
51878
51893
|
}] });
|
|
51879
51894
|
|
|
51895
|
+
class ArrayConcatPipe {
|
|
51896
|
+
transform(value, ...args) {
|
|
51897
|
+
return [...value, ...args[0]];
|
|
51898
|
+
}
|
|
51899
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ArrayConcatPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
51900
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: ArrayConcatPipe, name: "arrayConcat" }); }
|
|
51901
|
+
}
|
|
51902
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ArrayConcatPipe, decorators: [{
|
|
51903
|
+
type: Pipe,
|
|
51904
|
+
args: [{
|
|
51905
|
+
name: 'arrayConcat'
|
|
51906
|
+
}]
|
|
51907
|
+
}] });
|
|
51908
|
+
|
|
51880
51909
|
class DirectiveModule {
|
|
51881
51910
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DirectiveModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
51882
51911
|
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: DirectiveModule, declarations: [StopPropagationDirective], imports: [CommonModule], exports: [StopPropagationDirective] }); }
|