vcomply-workflow-engine 6.0.72 → 6.0.74

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.
@@ -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], imports: [CommonModule], exports: [GetSelectedValuePipe,
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.getProgramsList();
5782
- this.getProgramsCount();
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
- .getResponsibilityByCategoryId(params, businessCycle)
6045
+ .getAllResponsibilities(this.responsibilityCurrentPage)
6010
6046
  .subscribe({
6011
6047
  next: (res) => {
6012
6048
  this.categoryLoader = false;
6013
- this.responsibilityData = res;
6014
- this.responsibilityData['data'] = this.setDataListStructure(res?.data);
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(res) {
6027
- const data = res?.map((responsibility) => {
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?.ReportName,
6031
- controlId: responsibility?.ControlId,
6032
- _id: responsibility?.EncryptedReportId,
6087
+ name: responsibility?.title || '',
6088
+ controlId: responsibility?.key || '',
6089
+ _id: responsibility?.rid,
6033
6090
  entrustedBy: {
6034
- name: responsibility?.AssignBy,
6035
- email: responsibility?.AssignByEmail,
6036
- profilePic: responsibility?.member_pic ?? '',
6037
- shortName: responsibility?.member_short_name,
6091
+ name: assignorDetails?.name || '',
6092
+ email: assignorDetails?.email || '',
6093
+ profilePic: assignorDetails?.avatar || '',
6094
+ shortName: assignorDetails?.short_name || '',
6038
6095
  },
6039
6096
  entrustedTo: {
6040
- name: responsibility?.AssignTo,
6041
- email: responsibility?.AssignTo,
6042
- profilePic: responsibility?.employee_pic ?? '',
6043
- shortName: responsibility?.employee_short_name,
6044
- EntrustedToMembers: responsibility?.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: responsibility?.RC_details_array?.map((within) => {
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>\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\">&#xe90b;</i>\n <input type=\"text\" #searchRiskCategory (keyup.enter)=\"handleSearch($event.target.value)\" placeholder=\"Search Programs\" />\n </div>\n <div class=\"program-responsibility-listing-body-inner vx-mb-2 vx-d-flex\" [class.vx-justify-center]=\"(!programLoader && !programData?.data?.length)\">\n <ng-container *ngIf=\"(programLoader || programData?.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=\"(!programLoader && !programData?.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]=\"'ReportName'\" [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:25%}::ng-deep .program-responsibility-listing-body-inner .inner-item-mid{width:25%}::ng-deep .program-responsibility-listing-body-inner .inner-item-right{width:50%}@keyframes animate-right{0%{transform:translate(100%)}to{transform:translate(0)}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: 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: TableCardComponent, selector: "app-table-card", inputs: ["singleSelectedText", "multipleSelectedText", "selectedTab", "tableCard"], outputs: ["setSelectedTab"] }, { kind: "component", type: GrcCategoryListingComponent, selector: "app-grc-category-listing", inputs: ["tableCard", "headerText", "currentPage", "selectedTabIndex", "selectedCatAndRisk", "selectedCategoryIds", "categories", "programData"], outputs: ["activeSelectedCategory", "onCategoryPageChange"] }, { kind: "component", type: GrcResponsibilityListingComponent, selector: "app-grc-responsibility-listing", inputs: ["tableCard", "activeProgram", "headerText", "currentPage", "perPageLimit", "totalListData", "totalPages", "selectedListData", "selectedListDataIds", "MODE", "allSelectedResponsibilityIds", "responsibilityData", "selectedProgramAndResp"], outputs: ["getUpdatedDataList", "changeSelectedProgramAndResp"] }, { kind: "component", type: GrcSubCategoryListingComponent, selector: "app-grc-sub-category-listing", inputs: ["currentPage", "nameDisplayKey", "activeProgram", "selectedCategoryIds", "categories", "selectedProgramAndResp"], outputs: ["activeSelectedCategory", "onCategoryPageChange"] }, { 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: "component", type: TableCardLoaderComponent, selector: "app-table-card-loader" }, { kind: "ngmodule", type: WorkflowPipesModule }, { kind: "pipe", type: UniqueResponsibilitiesPipe, name: "uniqueResponsibilities" }] }); }
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\">&#xe90b;</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>\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\">&#xe90b;</i>\n <input type=\"text\" #searchRiskCategory (keyup.enter)=\"handleSearch($event.target.value)\" placeholder=\"Search Programs\" />\n </div>\n <div class=\"program-responsibility-listing-body-inner vx-mb-2 vx-d-flex\" [class.vx-justify-center]=\"(!programLoader && !programData?.data?.length)\">\n <ng-container *ngIf=\"(programLoader || programData?.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=\"(!programLoader && !programData?.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]=\"'ReportName'\" [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:25%}::ng-deep .program-responsibility-listing-body-inner .inner-item-mid{width:25%}::ng-deep .program-responsibility-listing-body-inner .inner-item-right{width:50%}@keyframes animate-right{0%{transform:translate(100%)}to{transform:translate(0)}}\n"] }]
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\">&#xe90b;</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
- class LoaderComponent {
43774
- constructor() { }
43775
- ngOnInit() {
43776
- }
43777
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LoaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
43778
- 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"] }] }); }
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.save = new EventEmitter();
43788
- this.cancel = new EventEmitter();
43789
- this.animation = true;
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
- selectAll(evt) {
43856
- if (evt?.target?.checked === true) {
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
- setAllSelectedStatus() {
43868
- this.allSelected =
43869
- this.allListIds.sort().toString() === this.selectedIds.sort()?.toString();
43844
+ registerOnChange(fn) {
43845
+ this.onChanged = fn;
43870
43846
  }
43871
- /**
43872
- * #### Description
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
- * #### Description
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
- * #### Description
43900
- *
43901
- * Manipulates selected items in role list
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
- saveList() {
43920
- if (this.initialSelected?.sort()?.toString() !==
43921
- this.selectedIds.sort()?.toString()) {
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.save.emit(this.selectedRoles);
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
- closeList() {
43937
- this.cancel.emit();
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
- //view and manage roles and groups text changed with featureflag
43953
- permissionText(permission) {
43954
- if (permission == 'view roles') {
43955
- if (this.ff_rc_listing) {
43956
- return 'view permissions';
43957
- }
43958
- else {
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
- else {
43983
- return permission;
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
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: RoleListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
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\">&#xe90b;</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 >&#xe970;</i\n >\n <i *ngIf=\"expandedRows.includes(role?._id)\" class=\"icons\"\n >&#xe9e8;</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 >&#xe90d;</i\n >\n {{\n featureflagrole && data?.permissionGroupName\n ? data?.permissionGroupName\n : data?.roleName\n }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </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\">&#xe930;</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\">&#xe9ae;</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\">&#xe9ae;</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: RoleListComponent, decorators: [{
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\">&#xe90b;</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 >&#xe970;</i\n >\n <i *ngIf=\"expandedRows.includes(role?._id)\" class=\"icons\"\n >&#xe9e8;</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 >&#xe90d;</i\n >\n {{\n featureflagrole && data?.permissionGroupName\n ? data?.permissionGroupName\n : data?.roleName\n }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </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\">&#xe930;</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: { save: [{
43995
- type: Output
43996
- }], cancel: [{
43997
- type: Output
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\">&#xe9ae;</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\">&#xe9ae;</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 AssessmentService {
44015
- constructor(http, authService, config) {
44016
- this.http = http;
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: AssessmentService, deps: [{ token: i1.HttpClient }, { token: AuthService$1 }, { token: Configurations, optional: true }], target: i0.ɵɵFactoryTarget.Injectable }); }
44039
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AssessmentService, providedIn: 'root' }); }
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: AssessmentService, decorators: [{
44042
- type: Injectable,
43914
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ListToIdPipe, decorators: [{
43915
+ type: Pipe,
44043
43916
  args: [{
44044
- providedIn: 'root'
43917
+ name: 'listToId'
44045
43918
  }]
44046
- }], ctorParameters: function () { return [{ type: i1.HttpClient }, { type: AuthService$1 }, { type: Configurations, decorators: [{
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 Pagination {
44075
- constructor() {
44076
- this.activeAlphabet = '';
44077
- this.pageArray = [];
44078
- this.currentPage = 1;
44079
- this.isInvalidInput = false;
44080
- this.selectedPage = new EventEmitter();
44081
- this.selectedAlphabet = new EventEmitter();
44082
- this.alphabetsArray = 'abcdefghijklmnopqrstuvwxyz'.split('');
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
- for (let i = this.currentPage - 2; i < this.currentPage + 2; i++) {
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: Pagination, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
44162
- 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"] }] }); }
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: Pagination, decorators: [{
44165
- type: Component,
44166
- 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"] }]
44167
- }], ctorParameters: function () { return []; }, propDecorators: { activeAlphabet: [{
44168
- type: Input
44169
- }], pageCount: [{
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\">&#xe91d;</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\">&#xe90b;</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\">&#xeae5;</i> Preview\n </button>\n <!-- <button class=\"action-btn\"><i class=\"icons\">&#xe90c;</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 >&#xe970;</i\n >\n <i *ngIf=\"openedCategory.includes(data?.id)\" class=\"icons\"\n >&#xe9e8;</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\">&#xeae5;</i> Preview\n </button>\n <!-- <button class=\"action-btn\"><i class=\"icons\">&#xe9ba;</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)\">&#xe90d;</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\">&#xe91d;</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\">&#xe90b;</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\">&#xeae5;</i> Preview\n </button>\n <!-- <button class=\"action-btn\"><i class=\"icons\">&#xe90c;</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 >&#xe970;</i\n >\n <i *ngIf=\"openedCategory.includes(data?.id)\" class=\"icons\"\n >&#xe9e8;</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\">&#xeae5;</i> Preview\n </button>\n <!-- <button class=\"action-btn\"><i class=\"icons\">&#xe9ba;</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)\">&#xe90d;</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\">&#xe9ae;</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\">&#xe9ae;</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\">&#xe9ae;</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\">&#xe9ae;</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 >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.framework.value?.name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.framework.value?.name }}</span\n >\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i (click)=\"remove('', 'FRAMEWORK')\" *ngIf=\"canFrameworkChange\" class=\"icons\" >&#xe90d;</i> {{controls?.framework.value?.name}}</span>\n </div>\n </div> -->\n <button\n *ngIf=\"canFrameworkChange\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('FRAMEWORK')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n </form-field>\n\n <!-- Program Category Name -->\n <form-field\n [checked]=\"controls?.program_name?.value?.trim()?.length\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.what\"\n >\n <label class=\"vx-control-panel\"\n >PROGRAM NAME <span class=\"required\">*</span></label\n >\n <input\n InputTrim\n formControlName=\"program_name\"\n type=\"text\"\n placeholder=\"What is the Program name?\"\n />\n\n <p\n *ngIf=\"\n controls?.program_name?.errors && controls?.program_name?.touched\n \"\n class=\"error-message\"\n >\n Enter a name for this Program.\n </p>\n <p *ngIf=\"isNameExists\" class=\"error-message\">\n Program name already exists.\n </p>\n <vcomply-editor\n [(ngModel)]=\"editorData.programObjective\"\n [ngModelOptions]=\"{ standalone: true }\"\n (sendSavedFiles)=\"selectFile('OBJECTIVE', $event)\"\n (ngModelChange)=\"setFormField('program_objective', $event, true)\"\n [editorConfig]=\"constants?.description\"\n >\n </vcomply-editor>\n </form-field>\n\n\n\n <!-- Owners -->\n <form-field\n *ngIf=\"additionalOption?.OWNERS\"\n [checked]=\"\n controls?.program_owners?.value?.length > 0 ||\n controls?.program_owners_group?.value?.length > 0\n \"\n [active]=\"activeList === 'OWNER'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'OWNER'\"\n [img]=\"ASSETS.case_owners\"\n >\n <label class=\"vx-control-panel\"\n >OWNER(S) <span class=\"required\">*</span>\n <span\n class=\"icon\"\n *ngIf=\"toolTipData.owner !== ''\"\n libPopoverHover\n (mouseover)=\"dataTooltip.popover()\"\n (mouseleave)=\"dataTooltip.closePopover()\"\n placement=\"right\"\n ><i class=\"icons\">&#xe91f;</i></span\n >\n <popover-hover #dataTooltip>\n <div class=\"vx-info-card\">\n <div\n class=\"vx-info-card-body\"\n [innerHTML]=\"toolTipData.owner\"\n id=\"OwnerHelpText\"\n ></div>\n </div>\n </popover-hover>\n </label>\n <input-with-pill\n [placeholder]=\"'Who is responsible for managing this program?'\"\n (select)=\"activateList('OWNER')\"\n >\n <div class=\"selected\" *ngIf=\"controls?.program_owners?.value[0]\">\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_owners?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_owners?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4 greenBg\"\n appPopover\n (click)=\"owner.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_owners?.value?.length > 1\"\n >\n +{{ controls?.program_owners?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_owners_group?.value?.length &&\n controls?.program_owners?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_owners_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n (click)=\"\n remove(\n controls?.program_owners_group?.value[0],\n 'OWNER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_owners_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_owners_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"group.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_owners_group?.value?.length > 1\"\n >\n +{{ controls?.program_owners_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n <button\n *ngIf=\"activeList !== 'OWNER'\"\n [class.disabled]=\"controls?.all_user_in_role?.value\"\n (click)=\"activateList('OWNER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i>Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #owner [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"let owner of controls?.program_owners?.value | slice : 1\"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"\n !(\n lists.NON_REMOVABLE_OWNERS | listToId : 'member_id'\n ).includes(owner?.member_id)\n \"\n class=\"icons\"\n (click)=\"remove(owner, 'OWNER')\"\n >&#xe90d;</i\n >\n {{ owner?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #group [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let owner of controls?.program_owners_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n class=\"icons\"\n (click)=\"remove(owner, 'OWNER_GROUP')\"\n >&#xe90d;</i\n >\n {{ owner?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field>\n\n <!-- Collaborators -->\n <form-field\n *ngIf=\"additionalOption?.COLLABORATORS\"\n [checked]=\"\n controls?.collaborators?.value?.length > 0 ||\n controls?.collaborators_group?.value?.length > 0\n \"\n [active]=\"activeList === 'COLLABORATORS'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'COLLABORATORS'\"\n [img]=\"\n 'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/owner.svg'\n \"\n >\n <label class=\"vx-control-panel\"\n >COLLABORATORS \n <span\n class=\"icon\"\n *ngIf=\"toolTipData.collaborators !== ''\"\n libPopoverHover\n (mouseover)=\"dataTooltip.popover()\"\n (mouseleave)=\"dataTooltip.closePopover()\"\n placement=\"right\"\n ><i class=\"icons\">&#xe91f;</i></span\n >\n <popover-hover #dataTooltip>\n <div class=\"vx-info-card\">\n <div\n class=\"vx-info-card-body\"\n [innerHTML]=\"toolTipData.collaborators\"\n id=\"CollaboratorsHelpText\"\n ></div>\n </div>\n </popover-hover>\n </label>\n <input-with-pill\n [placeholder]=\"'Who is responsible for managing this program?'\"\n (select)=\"activateList('COLLABORATORS')\"\n >\n <div class=\"selected\" *ngIf=\"controls?.collaborators?.value[0] || controls?.collaborators_group?.value[0]\">\n <div class=\"vx-d-flex vx-align-center\">\n <!-- Users -->\n <div \n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.collaborators?.value[0]\"\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.collaborators?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.collaborators?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4 greenBg\"\n appPopover\n (click)=\"owner.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.collaborators?.value?.length > 1\"\n >\n +{{ controls?.collaborators?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\" \n controls?.collaborators_group?.value?.length &&\n controls?.collaborators?.value?.length\n \"\n >&</span\n >\n <!-- Groups -->\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.collaborators_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n (click)=\"\n remove(\n controls?.collaborators_group?.value[0],\n 'COLLABORATORS_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.collaborators_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.collaborators_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"group.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_owners_group?.value?.length > 1\"\n >\n +{{ controls?.collaborators_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\" [appTooltip]=\"controls?.program_owners?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\" >{{controls?.program_owners?.value[0]?.member_name}}</span></span>\n <button *ngIf=\"controls?.program_owners?.value?.length > 1\" class=\"count user\" appPopover (click)=\"owner.popover()\" placement=\"right\">+{{controls?.program_owners?.value?.length -1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_owners_group?.value?.length && controls?.program_owners?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_owners_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" *ngIf=\"!['ADMIN','KEY_ADMIN','LOGGED_IN'].includes(owner?.user_role)\" (click)=\"remove(owner,'OWNER_GROUP')\">&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_owners_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_owners_group?.value[0]?.group_name}}</span></span>\n <button *ngIf=\"controls?.program_owners_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"group.popover()\" placement=\"right\">+{{controls?.program_owners_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'COLLABORATORS'\"\n [class.disabled]=\"controls?.all_user_in_role?.value\"\n (click)=\"activateList('COLLABORATORS')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i>Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #owner [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"let owner of controls?.collaborators?.value | slice : 1\"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n\n class=\"icons\"\n (click)=\"remove(owner, 'COLLABORATORS')\"\n >&#xe90d;</i\n >\n {{ owner?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #group [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let owner of controls?.collaborators_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n class=\"icons\"\n (click)=\"remove(owner, 'COLLABORATORS_GROUP')\"\n >&#xe90d;</i\n >\n {{ owner?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field>\n\n <!-- Performance Calculated -->\n <!-- <form-field [checked]=\"controls?.performance_calculation?.value\" [active]=\"activeList === 'PERFORMANCE'\" [disabled]=\"sideElements.includes(activeList) && activeList !== 'PERFORMANCE'\"\n [img]=\"'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/performance-calc.svg'\">\n <label class=\"vx-control-panel\">HOW SHOULD THE PERFORMANCE OF THIS PROGRAM BE CALCULATED?</label>\n <tab-selector formControlName=\"performance_calculation\" [displayArray]=\"constants?.performanceCalculation\">\n </tab-selector>\n </form-field> -->\n <ng-container *ngIf=\"isProgramScope && false\">\n <div\n class=\"scope-label vx-fs-10 vx-txt-white vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mb-5 vx-lh-4 vx-d-inline-block\"\n >\n PROGRAM SCOPE\n </div>\n <!-- <i class=\"icons info-icon vx-fs-12 vx-txt-blue vx-ml-1\" [appTooltip]=\"tooltip.programScope\" placement=\"bottom\" delay=\"0\" type=\"white\" [tooltipMandatory]=\"true\">&#xe91f;</i> -->\n <span\n class=\"icon info-icon vx-fs-12 vx-txt-blue vx-ml-1\"\n *ngIf=\"toolTipData.programScop !== ''\"\n libPopoverHover\n (mouseover)=\"dataTooltip.popover()\"\n (mouseleave)=\"dataTooltip.closePopover()\"\n placement=\"right\"\n ><i class=\"icons\">&#xe91f;</i></span\n >\n <popover-hover #dataTooltip>\n <div class=\"vx-info-card\">\n <div\n class=\"vx-info-card-body\"\n [innerHTML]=\"toolTipData.programScope\"\n id=\"PSHelpText\"\n ></div>\n </div>\n </popover-hover>\n </ng-container>\n\n <!-- Program Frequency -->\n <form-field\n *ngIf=\"additionalOption?.PROGRAM_FREQUENCY\"\n [checked]=\"[true, false].includes(controls?.recurring_frequency?.value)\"\n [active]=\"activeList === 'FREQUENCY'\"\n [disabled]=\"\n sideElements.includes(activeList) && activeList !== 'FREQUENCY'\n \"\n [img]=\"ASSETS.recurring\"\n >\n <label class=\"vx-control-panel\" id=\"PDChange\"\n >PROGRAM DURATION\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Program Duration refers to the duration of the Program. A Program can occur in perpetuity, or it can occur until the end of the current business cycle that has been specified in ' +\n businessCycle.selectedCycle.business_cycle +\n '. All responsibilities linked with that Program will also have the same Program Duration.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"ProgramDurationHelpText\"\n >&#xeb16;</i\n ></label\n >\n <div class=\"upload-format\">\n <div class=\"vx-d-flex vx-align-center vx-justify-between\">\n <span class=\"text vx-mb-0\">Is this program recurring?</span>\n <div class=\"radio-group program\">\n <app-cs-radio\n [name]=\"'recurring_frequency'\"\n [checked]=\"controls?.recurring_frequency?.value\"\n (checkedEvent)=\"setFormField('recurring_frequency', true)\"\n >YES</app-cs-radio\n >\n <app-cs-radio\n [name]=\"'recurring_frequency'\"\n [checked]=\"!controls?.recurring_frequency?.value\"\n (checkedEvent)=\"setFormField('recurring_frequency', false)\"\n >NO</app-cs-radio\n >\n </div>\n </div>\n </div>\n </form-field>\n\n <!-- Scope Changes -->\n <form-field\n *ngIf=\"additionalOption?.SCOPE_CHANGES\"\n [checked]=\"[true, false].includes(controls?.lock_scope_change?.value)\"\n [active]=\"activeList === 'SCOPE'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'SCOPE'\"\n [img]=\"ASSETS.lock_scope\"\n >\n <label class=\"vx-control-panel\"\n >Lock the Program Scope\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If the Program Scope is locked, neither the Program nor the responsibilities linked with the Program can be edited once the Program begins. In order to edit the Program or the linked responsibilities, the Program details will need to be edited.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"ScopeChangesHelpText\"\n >&#xeb16;</i\n ></label\n >\n <div class=\"upload-format\">\n <span class=\"text\"\n >Would you like to\n <span class=\"vx-label-txt vx-fw-500\">lock changes</span> to the\n program scope?</span\n >\n <div class=\"radio-group program\">\n <app-cs-radio\n [name]=\"'lock_scope_change'\"\n [checked]=\"controls?.lock_scope_change?.value\"\n (checkedEvent)=\"setFormField('lock_scope_change', true)\"\n >YES</app-cs-radio\n >\n <app-cs-radio\n [name]=\"'lock_scope_change'\"\n [checked]=\"!controls?.lock_scope_change?.value\"\n (checkedEvent)=\"setFormField('lock_scope_change', false)\"\n >NO</app-cs-radio\n >\n </div>\n </div>\n </form-field>\n\n <!-- Framework -->\n <!-- <form-field [checked]=\"false\" [active]=\"activeList === 'FRAMEWORK'\" [disabled]=\"sideElements.includes(activeList) && activeList !== 'FRAMEWORK'\"\n [img]=\"'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/category.svg'\">\n <label class=\"vx-control-panel\">FRAMEWORK</label>\n <input-with-pill [placeholder]=\"'Select a framework that this Program relates to'\" (select)=\"activateList('FRAMEWORK')\">\n <div class=\"selected\" *ngIf=\"controls?.framework?.value?.framework_name\">\n <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i (click)=\"remove(controls?.framework.value,'FRAMEWORK')\" class=\"icons\">&#xe90d;</i>{{controls?.framework?.value?.framework_name}}</span>\n <button class=\"count\" appPopover (click)=\"framework.popover()\" placement=\"right\">+5</button>\n </div>\n </div>\n <button *ngIf=\"activeList!=='FRAMEWORK'\" (click)=\"activateList('FRAMEWORK')\" class=\"edit\" type=\"button\"><i class=\"icons\">&#xe9ba;</i> Edit</button>\n </div>\n </input-with-pill>\n <app-popover #framework [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i class=\"icons\">&#xe90d;</i>\n Manage framework name\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field> -->\n\n <!-- Responsibility Center -->\n <form-field\n *ngIf=\"additionalOption?.RC\"\n [checked]=\"controls?.rc?.value?.length\"\n [active]=\"activeList === 'RC'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'RC'\"\n [img]=\"ASSETS.responsibility_center\"\n >\n <label class=\"vx-control-panel\"\n >RESPONSIBILITY CENTER\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Responsibility Centers represent your organizational and operational infrastructure. Where Responsibility Centers are selected when creating a Program, only those Responsibilities Centers will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"RCHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n (select)=\"activateList('RC')\"\n [placeholder]=\"\n 'Which Responsibility Center(s) can be linked to the responsibilities associated with this Program?'\n \"\n >\n <div\n class=\"selected\"\n *ngIf=\"controls?.rc?.value && controls?.rc?.value?.length\"\n >\n <div class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\">\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"remove(controls?.rc?.value[0], 'RC')\"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.rc?.value[0]?.item_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.rc?.value[0]?.item_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"rc.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.rc?.value?.length > 1\"\n >\n +{{ controls?.rc?.value?.length - 1 }}\n </button>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i class=\"icons\" (click)=\"remove(controls?.rc?.value[0],'RC')\">&#xe90d;</i>{{controls?.rc?.value[0]?.item_name}}</span>\n <button *ngIf=\"controls?.rc?.value?.length > 1\" class=\"count\" appPopover (click)=\"rc.popover()\" placement=\"right\">+{{controls?.rc?.value?.length -1 }}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'RC'\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('RC')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #rc [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"let rc of controls?.rc?.value | slice : 1\">\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i class=\"icons\" (click)=\"remove(rc, 'RC')\">&#xe90d;</i>\n {{ rc?.item_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field>\n\n <!-- Assignee -->\n <form-field\n *ngIf=\"additionalOption?.ASSIGNEES\"\n [checked]=\"\n controls?.program_assignee?.value?.length ||\n controls?.program_default_assignee?.value?.length ||\n controls?.program_default_assignee?.value?.length ||\n controls?.program_default_assignee_group?.value?.length\n \"\n [active]=\"['ASSIGNEE', 'DEFAULT_ASSIGNEE']?.includes(activeList)\"\n [disabled]=\"\n sideElements?.includes(activeList) &&\n !['ASSIGNEE', 'DEFAULT_ASSIGNEE'].includes(activeList)\n \"\n [img]=\"ASSETS.case_assignees\"\n >\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"activeList === 'DEFAULT_ASSIGNEE'\"\n >ASSIGNEES\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Assignees are required to complete the responsibilities that have been assigned to them. Where Assignees are selected when creating a Program, only those Assignees will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"AssigneeHelpText\"\n >&#xeb16;</i\n >\n </label>\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'DEFAULT_ASSIGNEE'\"\n [placeholder]=\"\n 'Who is responsible for completing the responsibilities within this Program?'\n \"\n (select)=\"activateList('ASSIGNEE')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_assignee?.value?.length ||\n controls?.program_assignee_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_assignee?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(controls?.program_assignee?.value[0], 'ASSIGNEE')\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_assignee?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_assignee?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"assignee.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_assignee?.value?.length > 1\"\n >\n +{{ controls?.program_assignee?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_assignee_group?.value?.length &&\n controls?.program_assignee?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_assignee_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_assignee_group?.value[0],\n 'ASSIGNEE_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_assignee_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_assignee_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"assignee_group.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_assignee_group?.value?.length > 1\"\n >\n +{{ controls?.program_assignee_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_assignee?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_assignee?.value[0],'ASSIGNEE')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_assignee?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_assignee?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_assignee?.value?.length > 1\" class=\"count user\" appPopover (click)=\"assignee.popover()\" placement=\"right\">+{{controls?.program_assignee?.value?.length -1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_assignee_group?.value?.length && controls?.program_assignee?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_assignee_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_assignee_group?.value[0],'ASSIGNEE_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_assignee_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_assignee_group?.value[0]?.group_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_assignee_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"assignee_group.popover()\" placement=\"right\">+{{controls?.program_assignee_group?.value?.length -1 }}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'ASSIGNEE'\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('ASSIGNEE')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #assignee [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let assignee of controls?.program_assignee?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(assignee, 'ASSIGNEE')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ assignee?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #assignee_group [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_assignee_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(group, 'ASSIGNEE_GROUP')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"activeList === 'ASSIGNEE'\"\n >DEFAULT ASSIGNEE\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'This option lets you specify the Default Assignees for all new responsibilities linked with a Program. If a Default Assignees is selected, the user will automatically be selected the Assignee when creating a responsibility linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility. '\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"DAHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'ASSIGNEE'\"\n [placeholder]=\"\n 'Which persons will be selected as the default assignees for the responsibilities within this Program?'\n \"\n (select)=\"activateList('DEFAULT_ASSIGNEE')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_assignee?.value?.length ||\n controls?.program_default_assignee_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_assignee?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_assignee?.value[0],\n 'DEFAULT_ASSIGNEE'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_assignee?.value[0]?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_assignee?.value[0]?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultAssignee.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_default_assignee?.value?.length > 1\"\n >\n +{{ controls?.program_default_assignee?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_default_assignee_group?.value?.length &&\n controls?.program_default_assignee?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_assignee_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_assignee_group?.value[0],\n 'DEFAULT_ASSIGNEE_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_assignee_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_assignee_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultAssigneeGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_assignee_group?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_assignee_group?.value?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_assignee?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_assignee?.value[0],'DEFAULT_ASSIGNEE')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_assignee?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{ controls?.program_default_assignee?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_assignee?.value?.length > 1\" class=\"count user\" appPopover (click)=\"defaultAssignee.popover()\" placement=\"right\">+{{controls?.program_default_assignee?.value?.length - 1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_default_assignee_group?.value?.length && controls?.program_default_assignee?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_assignee_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_assignee_group?.value[0],'DEFAULT_ASSIGNEE_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_assignee_group?.value[0]?.group_name }}</span>\n </span>\n <button *ngIf=\"controls?.program_default_assignee_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"defaultAssigneeGroup.popover()\" placement=\"right\">+{{controls?.program_default_assignee_group?.value?.length -1 }}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_ASSIGNEE'\"\n (click)=\"activateList('DEFAULT_ASSIGNEE')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #defaultAssignee [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let assignee of controls?.program_default_assignee?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(assignee, 'DEFAULT_ASSIGNEE')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ assignee?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #defaultAssigneeGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_assignee_group?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(assignee, 'DEFAULT_ASSIGNEE_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <div\n class=\"radio-group-selector\"\n [class.disabled]=\"activeList === 'ASSIGNEE'\"\n >\n <app-cs-radio\n [name]=\"'assignee'\"\n [checked]=\"controls?.assignee_completion_criteria?.value === 'ALL'\"\n (checkedEvent)=\"setFormField('assignee_completion_criteria', 'ALL')\"\n >\n ALL SELECTED PERSONS NEED TO COMPLETE THIS\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If selected, separate responsibilities will be created for each person.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n <app-cs-radio\n [name]=\"'assignee'\"\n [checked]=\"controls?.assignee_completion_criteria?.value === 'ANYONE'\"\n (checkedEvent)=\"\n setFormField('assignee_completion_criteria', 'ANYONE')\n \"\n >\n ANY SELECTED PERSON CAN COMPLETE THIS\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If selected, only one responsibility will be created.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n </div>\n </form-field>\n\n <!-- Reviewer -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.REVIEWER\"\n [checked]=\"\n controls?.program_reviewer?.value?.length ||\n controls?.program_default_reviewer?.value?.length ||\n controls?.program_default_reviewer?.value?.length ||\n controls?.program_default_reviewer_group?.value?.length\n \"\n [active]=\"['REVIEWER', 'DEFAULT_REVIEWER']?.includes(activeList)\"\n [disabled]=\"\n sideElements?.includes(activeList) &&\n !['REVIEWER', 'DEFAULT_REVIEWER'].includes(activeList)\n \"\n [img]=\"ASSETS.reviewer\"\n >\n <label\n [class.disabled]=\"activeList === 'DEFAULT_REVIEWER'\"\n class=\"vx-control-panel\"\n >Reviewers\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Reviewers are required to review responsibilities after they have been completed. Where Reviewers are selected when creating a Program, only those Reviewers will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"ReviewerHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'DEFAULT_REVIEWER'\"\n [placeholder]=\"\n 'Who is responsible for reviewing the responsibilities within this Program?'\n \"\n (select)=\"activateList('REVIEWER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_reviewer?.value?.length ||\n controls?.program_reviewer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_reviewer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(controls?.program_reviewer?.value[0], 'REVIEWER')\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_reviewer?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_reviewer?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"reviewer.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_reviewer?.value?.length > 1\"\n >\n +{{ controls?.program_reviewer?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_reviewer_group?.value?.length &&\n controls?.program_reviewer?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_reviewer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_reviewer_group?.value[0],\n 'REVIEWER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_reviewer_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_reviewer_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"reviewerGroup.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_reviewer_group?.value?.length > 1\"\n >\n +{{ controls?.program_reviewer_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_reviewer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_reviewer?.value[0],'REVIEWER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_reviewer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_reviewer?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_reviewer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"reviewer.popover()\" placement=\"right\">+{{controls?.program_reviewer?.value?.length -1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_reviewer_group?.value?.length && controls?.program_reviewer?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_reviewer_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_reviewer_group?.value[0],'REVIEWER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_reviewer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_reviewer_group?.value[0]?.group_name}}\n </span>\n </span>\n <button *ngIf=\"controls?.program_reviewer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"reviewerGroup.popover()\" placement=\"right\">+{{controls?.program_reviewer_group?.value?.length - 1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'REVIEWER'\"\n (click)=\"activateList('REVIEWER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #reviewer [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let reviewer of controls?.program_reviewer?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(reviewer, 'REVIEWER')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ reviewer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #reviewerGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_reviewer_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(group, 'REVIEWER_GROUP')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <label\n [class.disabled]=\"activeList === 'REVIEWER'\"\n class=\"vx-control-panel\"\n >DEFAULT Reviewer\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'This option lets you specify the Default Reviewers for responsibilities linked with a Program. Where a user has been specified as a Default Reviewer, that user will automatically be selected as the Reviewer when creating a responsibility linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"DRHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'REVIEWER'\"\n [placeholder]=\"\n 'Which persons will be selected as the default reviewers for the responsibilities within this Program?'\n \"\n (select)=\"activateList('DEFAULT_REVIEWER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_reviewer?.value?.length ||\n controls?.program_default_reviewer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_reviewer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_reviewer?.value[0],\n 'DEFAULT_REVIEWER'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_reviewer?.value[0]?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_reviewer?.value[0]?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultReviewer.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_default_reviewer?.value?.length > 1\"\n >\n +{{ controls?.program_default_reviewer?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_default_reviewer_group?.value?.length &&\n controls?.program_default_reviewer?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_reviewer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_reviewer_group?.value[0],\n 'DEFAULT_REVIEWER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_reviewer_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_reviewer_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultReviewerGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_reviewer_group?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_reviewer_group?.value?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_reviewer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_reviewer?.value[0],'DEFAULT_REVIEWER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_reviewer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_reviewer?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_reviewer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"defaultReviewer.popover()\" placement=\"right\">+{{controls?.program_default_reviewer?.value?.length - 1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_default_reviewer_group?.value?.length && controls?.program_default_reviewer?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_reviewer_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_reviewer_group?.value[0],'DEFAULT_REVIEWER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_reviewer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_reviewer_group?.value[0]?.group_name}}\n </span>\n </span>\n <button *ngIf=\"controls?.program_default_reviewer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"defaultReviewerGroup.popover()\" placement=\"right\">+{{controls?.program_default_reviewer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_REVIEWER'\"\n (click)=\"activateList('DEFAULT_REVIEWER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #defaultReviewer [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let reviewer of controls?.program_default_reviewer?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(reviewer, 'DEFAULT_REVIEWER')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ reviewer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #defaultReviewerGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_reviewer_group?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(group, 'DEFAULT_REVIEWER_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <div\n class=\"radio-group-selector\"\n [class.disabled]=\"activeList === 'REVIEWER'\"\n >\n <app-cs-radio\n [name]=\"'reviewer'\"\n [checked]=\"\n controls?.reviewer_completion_criteria?.value === 'SEQUENTIAL'\n \"\n (checkedEvent)=\"\n setFormField('reviewer_completion_criteria', 'SEQUENTIAL')\n \"\n [class.disabled]=\"\n controls?.program_default_reviewer_group?.value?.length > 0\n \"\n >\n SEQUENTIAL\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'The responsibility will be sent for review one at a time in the sequence defined by you.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n <app-cs-radio\n [name]=\"'reviewer'\"\n [checked]=\"\n controls?.reviewer_completion_criteria?.value === 'ANYONE' ||\n controls?.program_default_reviewer_group?.value?.length > 0\n \"\n (checkedEvent)=\"\n setFormField('reviewer_completion_criteria', 'ANYONE')\n \"\n >\n ANY REVIEWER CAN MARK THIS AS REVIEWED\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'The responsibility will be sent for review to all reviewers at the same time. If anyone of the reviewer reviews the responsibility, it will be considered as reviewed.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n </div>\n </form-field>\n\n <!-- Overseer -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.OVERSEER\"\n [checked]=\"\n controls?.program_overseer?.value?.length ||\n controls?.program_default_overseer?.value?.length ||\n controls?.program_default_overseer?.value?.length ||\n controls?.program_default_overseer_group?.value?.length\n \"\n [active]=\"activeList === 'OVERSEER'\"\n [disabled]=\"\n sideElements?.includes(activeList) &&\n !['OVERSEER', 'DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(\n activeList\n )\n \"\n [img]=\"ASSETS.oversight\"\n >\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"\n ['DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n \"\n >Oversights\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Oversights receive updates when a responsibility is completed, completed with delay or not completed. Where Oversights are selected when creating a Program, only those Oversights will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"overseerHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"\n ['DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n \"\n [placeholder]=\"\n 'Who is responsible for overseeing the responsibilities within this Program?'\n \"\n (select)=\"activateList('OVERSEER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_overseer?.value?.length ||\n controls?.program_overseer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_overseer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(controls?.program_overseer?.value[0], 'OVERSEER')\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_overseer?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_overseer?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseers.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_overseer?.value?.length > 1\"\n >\n +{{ controls?.program_overseer?.value?.length - 1 }}\n </button>\n </div>\n <span\n *ngIf=\"\n controls?.program_overseer_group?.value?.length &&\n controls?.program_overseer?.value?.length\n \"\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_overseer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_overseer_group?.value[0],\n 'OVERSEER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_overseer_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_overseer_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseerGroup.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_overseer_group?.value?.length > 1\"\n >\n +{{ controls?.program_overseer_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_overseer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_overseer?.value[0],'OVERSEER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_overseer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">\n {{controls?.program_overseer?.value[0]?.member_name}}\n </span>\n </span>\n <button *ngIf=\"controls?.program_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseers.popover()\" placement=\"right\">+{{controls?.program_overseer?.value?.length -1}}</button>\n </div>\n <span *ngIf=\"controls?.program_overseer_group?.value?.length && controls?.program_overseer?.value?.length \" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_overseer_group?.value?.length \">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_overseer_group?.value[0],'OVERSEER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_overseer_group?.value[0]?.group_name}}</span></span>\n <button *ngIf=\"controls?.program_overseer_group?.value?.length> 1\" class=\"count\" appPopover (click)=\"overseerGroup.popover()\" placement=\"right\">+{{controls?.program_overseer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n\n <button\n *ngIf=\"activeList !== 'OVERSEER'\"\n (click)=\"activateList('OVERSEER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #overseers [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let overseer of controls?.program_overseer?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i class=\"icons\" (click)=\"remove(overseer, 'OVERSEER')\"\n >&#xe90d;</i\n >\n {{ overseer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #overseerGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_overseer_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(group, 'OVERSEER_GROUP')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <ng-container [class.disabled]=\"activeList === 'OVERSEER'\">\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"['OVERSEER'].includes(activeList)\"\n >DEFAULT Oversight\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'This option lets you specify the Default Oversight for responsibilities linked with a Program. Where a user has been specified as a Default Oversight, that user will automatically be selected as the Oversight when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"DOHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [disabled]=\"\n ['OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n \"\n [selectDiv]=\"true\"\n [placeholder]=\"\n 'Which persons will be selected as the default overseers for the responsibilities within this Program?'\n \"\n (select)=\"activateList('DEFAULT_OVERSEER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_overseer?.value?.length ||\n controls?.program_default_overseer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_overseer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_overseer?.value[0],\n 'DEFAULT_OVERSEER'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_overseer?.value[0]?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_overseer?.value[0]?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseersDefault.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_default_overseer?.value?.length > 1\"\n >\n +{{ controls?.program_default_overseer?.value?.length - 1 }}\n </button>\n </div>\n <span\n *ngIf=\"\n controls?.program_default_overseer_group?.value?.length &&\n controls?.program_default_overseer?.value?.length\n \"\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_overseer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_overseer_group?.value[0],\n 'DEFAULT_OVERSEER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_overseer_group?.value[0]\n ?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_overseer_group?.value[0]\n ?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseerDefaultGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_overseer_group?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_overseer_group?.value?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_overseer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_overseer?.value[0],'DEFAULT_OVERSEER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_overseer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_overseer?.value[0]?.member_name}}</span></span>\n <button *ngIf=\"controls?.program_default_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseersDefault.popover()\" placement=\"right\">+{{controls?.program_default_overseer?.value?.length -1}}</button>\n </div>\n <span *ngIf=\"controls?.program_default_overseer_group?.value?.length && controls?.program_default_overseer?.value?.length\" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_overseer_group?.value?.length \">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_overseer_group?.value[0],'DEFAULT_OVERSEER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_overseer_group?.value[0]?.group_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_overseer_group?.value?.length >1\" class=\"count\" appPopover (click)=\"overseerDefaultGroup.popover()\" placement=\"right\">+{{controls?.program_default_overseer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_OVERSEER'\"\n (click)=\"activateList('DEFAULT_OVERSEER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #overseersDefault [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let overseer of controls?.program_default_overseer?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n class=\"icons\"\n (click)=\"remove(overseer, 'DEFAULT_OVERSEER')\"\n >&#xe90d;</i\n >\n {{ overseer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #overseerDefaultGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_overseer_group?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(group, 'DEFAULT_OVERSEER_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <label class=\"vx-control-panel\"> </label>\n <input-with-pill\n class=\"vx-mt-2\"\n [selectDiv]=\"true\"\n [line]=\"3\"\n [disabled]=\"['OVERSEER', 'DEFAULT_OVERSEER'].includes(activeList)\"\n [placeholder]=\"\n 'Which persons will be selected as the default overseers for responsibilities that are not completed within this Program?'\n \"\n (select)=\"activateList('DEFAULT_FAILED_OVERSEER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_failed_overseer?.value?.length ||\n controls?.program_default_failed_overseer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_failed_overseer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_failed_overseer?.value[0],\n 'DEFAULT_FAILED_OVERSEER'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_failed_overseer?.value[0]\n ?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_failed_overseer?.value[0]\n ?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseersDefaultFail.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_failed_overseer?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_failed_overseer?.value?.length - 1\n }}\n </button>\n </div>\n <span\n *ngIf=\"\n controls?.program_default_failed_overseer_group?.value\n ?.length &&\n controls?.program_default_failed_overseer?.value?.length\n \"\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"\n controls?.program_default_failed_overseer_group?.value?.length\n \"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_failed_overseer_group?.value[0],\n 'DEFAULT_FAILED_OVERSEER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_failed_overseer_group?.value[0]\n ?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_failed_overseer_group?.value[0]\n ?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseerDefaultFailGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_failed_overseer_group?.value\n ?.length > 1\n \"\n >\n +{{\n controls?.program_default_failed_overseer_group?.value\n ?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_failed_overseer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_failed_overseer?.value[0],'DEFAULT_FAILED_OVERSEER')\" >&#xe90d;</i>\n <span class=\"chip\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_failed_overseer?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_failed_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseersDefaultFail.popover()\" placement=\"right\">+{{controls?.program_default_failed_overseer?.value?.length -1}}</button>\n </div>\n <span *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length && controls?.program_default_failed_overseer?.value?.length\" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length \">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_failed_overseer_group?.value[0],'DEFAULT_FAILED_OVERSEER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_failed_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_failed_overseer_group?.value[0]?.group_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"overseerDefaultFailGroup.popover()\" placement=\"right\">+{{controls?.program_default_failed_overseer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_FAILED_OVERSEER'\"\n (click)=\"activateList('DEFAULT_FAILED_OVERSEER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #overseersDefaultFail [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let overseer of controls?.program_default_failed_overseer\n ?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n class=\"icons\"\n (click)=\"remove(overseer, 'DEFAULT_FAILED_OVERSEER')\"\n >&#xe90d;</i\n >\n {{ overseer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #overseerDefaultFailGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_failed_overseer_group\n ?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(group, 'DEFAULT_FAILED_OVERSEER_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </ng-container>\n </form-field>\n\n <!-- Assessment -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.ASSESSMENT\"\n [checked]=\"controls?.program_assessments?.value?.length\"\n [active]=\"activeList === 'ASSESSMENT'\"\n [disabled]=\"\n sideElements.includes(activeList) && activeList !== 'ASSESSMENT'\n \"\n [img]=\"ASSETS.assessments\"\n >\n <label class=\"vx-control-panel\"\n >ASSESSMENTS\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Assessments are a digital form that are created in \u201CAssessment\u201D within the Compliance Module. Where Assessments are selected when creating a Program, only those Assessments will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"AssessmentHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [placeholder]=\"\n 'Which assessments can be linked to the responsibilities within this Program?'\n \"\n (select)=\"activateList('ASSESSMENT')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"controls?.program_assessments?.value?.length\"\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"\n controls?.program_assessments?.value\n | assessmentResolver as assessments\n \"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"remove(assessments[0], 'ASSESSMENT')\"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"assessments[0]?.assessment_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ assessments[0]?.assessment_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"program_assessments.popover()\"\n placement=\"right\"\n *ngIf=\"assessments?.length > 1\"\n >\n +{{ assessments?.length - 1 }}\n </button>\n </div>\n\n <!-- <div class=\"chip-container\">\n <ng-container *ngIf=\"(controls?.program_assessments?.value | assessmentResolver) as assessments\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i class=\"icons\" (click)=\"remove(assessments[0],'ASSESSMENT')\">&#xe90d;</i>{{assessments[0]?.assessment_name}} </span>\n <button *ngIf=\"assessments?.length > 1\" class=\"count\" appPopover (click)=\"program_assessments.popover()\" placement=\"right\">+{{assessments?.length -1 }}</button>\n </div>\n </ng-container>\n </div> -->\n <button\n *ngIf=\"activeList !== 'ASSESSMENT'\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('ASSESSMENT')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #program_assessments [dontCloseonClick]=\"true\">\n <ng-container>\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let assessment of controls?.program_assessments?.value\n | assessmentResolver\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(assessment, 'ASSESSMENT')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ assessment?.assessment_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </ng-container>\n </app-popover>\n </form-field>\n\n <!-- Format & Evidence -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.FORMATE_EVIDENCE\"\n [checked]=\"[true, false].includes(controls?.evidence_required?.value)\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.format_evidence\"\n >\n <label class=\"vx-control-panel\"\n >Evidence\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If selected, evidence of completion of a responsibility will be required for all responsibilities that are linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"EvidenceHelpText\"\n >&#xeb16;</i\n ></label\n >\n <div class=\"upload-format\">\n <span class=\"text\"\n >Do all responsibilities within this program require evidence?</span\n >\n <div class=\"radio-group program\">\n <app-cs-radio\n [name]=\"'evidence_required'\"\n [checked]=\"controls?.evidence_required?.value\"\n (checkedEvent)=\"setFormField('evidence_required', true)\"\n >YES</app-cs-radio\n >\n <app-cs-radio\n [name]=\"'evidence_required'\"\n [checked]=\"!controls?.evidence_required?.value\"\n (checkedEvent)=\"setFormField('evidence_required', false)\"\n >NO</app-cs-radio\n >\n </div>\n </div>\n <!-- <div class=\"vx-d-flex vx-align-center vx-justify-end vx-mt-2\">\n <div class=\"vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase vx-mr-2\">Allow any file to be marked as\n key\n evidence</div>\n <switch formControlName=\"allow_any_file_key_evidence\"\n (change)=\"setFormField('allow_any_file_key_evidence',$event?.target?.checked)\"></switch>\n </div> -->\n </form-field>\n\n <!-- Custom Field -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.CUSTOM_FIELDS\"\n [checked]=\"controls?.custom_fields?.value?.length\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.custom_fields\"\n >\n <label class=\"vx-control-panel\"\n >CUSTOM FIELD\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Where a custom field is specified, all responsibilities linked with a Program will contain that custom field. Custom fields enable the collection of additional meta data.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"CFHelpText\"\n >&#xeb16;</i\n ></label\n >\n <custom-field formControlName=\"custom_fields\"></custom-field>\n </form-field>\n </form>\n</div>\n\n<!-- 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 >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.framework.value?.name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.framework.value?.name }}</span\n >\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i (click)=\"remove('', 'FRAMEWORK')\" *ngIf=\"canFrameworkChange\" class=\"icons\" >&#xe90d;</i> {{controls?.framework.value?.name}}</span>\n </div>\n </div> -->\n <button\n *ngIf=\"canFrameworkChange\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('FRAMEWORK')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n </form-field>\n\n <!-- Program Category Name -->\n <form-field\n [checked]=\"controls?.program_name?.value?.trim()?.length\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.what\"\n >\n <label class=\"vx-control-panel\"\n >PROGRAM NAME <span class=\"required\">*</span></label\n >\n <input\n InputTrim\n formControlName=\"program_name\"\n type=\"text\"\n placeholder=\"What is the Program name?\"\n />\n\n <p\n *ngIf=\"\n controls?.program_name?.errors && controls?.program_name?.touched\n \"\n class=\"error-message\"\n >\n Enter a name for this Program.\n </p>\n <p *ngIf=\"isNameExists\" class=\"error-message\">\n Program name already exists.\n </p>\n <vcomply-editor\n [(ngModel)]=\"editorData.programObjective\"\n [ngModelOptions]=\"{ standalone: true }\"\n (sendSavedFiles)=\"selectFile('OBJECTIVE', $event)\"\n (ngModelChange)=\"setFormField('program_objective', $event, true)\"\n [editorConfig]=\"constants?.description\"\n >\n </vcomply-editor>\n </form-field>\n\n\n\n <!-- Owners -->\n <form-field\n *ngIf=\"additionalOption?.OWNERS\"\n [checked]=\"\n controls?.program_owners?.value?.length > 0 ||\n controls?.program_owners_group?.value?.length > 0\n \"\n [active]=\"activeList === 'OWNER'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'OWNER'\"\n [img]=\"ASSETS.case_owners\"\n >\n <label class=\"vx-control-panel\"\n >OWNER(S) <span class=\"required\">*</span>\n <span\n class=\"icon\"\n *ngIf=\"toolTipData.owner !== ''\"\n libPopoverHover\n (mouseover)=\"dataTooltip.popover()\"\n (mouseleave)=\"dataTooltip.closePopover()\"\n placement=\"right\"\n ><i class=\"icons\">&#xe91f;</i></span\n >\n <popover-hover #dataTooltip>\n <div class=\"vx-info-card\">\n <div\n class=\"vx-info-card-body\"\n [innerHTML]=\"toolTipData.owner\"\n id=\"OwnerHelpText\"\n ></div>\n </div>\n </popover-hover>\n </label>\n <input-with-pill\n [placeholder]=\"'Who is responsible for managing this program?'\"\n (select)=\"activateList('OWNER')\"\n >\n <div class=\"selected\" *ngIf=\"controls?.program_owners?.value[0]\">\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_owners?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_owners?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4 greenBg\"\n appPopover\n (click)=\"owner.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_owners?.value?.length > 1\"\n >\n +{{ controls?.program_owners?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_owners_group?.value?.length &&\n controls?.program_owners?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_owners_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n (click)=\"\n remove(\n controls?.program_owners_group?.value[0],\n 'OWNER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_owners_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_owners_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"group.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_owners_group?.value?.length > 1\"\n >\n +{{ controls?.program_owners_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n <button\n *ngIf=\"activeList !== 'OWNER'\"\n [class.disabled]=\"controls?.all_user_in_role?.value\"\n (click)=\"activateList('OWNER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i>Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #owner [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"let owner of controls?.program_owners?.value | slice : 1\"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"\n !(\n lists.NON_REMOVABLE_OWNERS | listToId : 'member_id'\n ).includes(owner?.member_id)\n \"\n class=\"icons\"\n (click)=\"remove(owner, 'OWNER')\"\n >&#xe90d;</i\n >\n {{ owner?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #group [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let owner of controls?.program_owners_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n class=\"icons\"\n (click)=\"remove(owner, 'OWNER_GROUP')\"\n >&#xe90d;</i\n >\n {{ owner?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field>\n\n <!-- Collaborators -->\n <form-field\n *ngIf=\"additionalOption?.COLLABORATORS\"\n [checked]=\"\n controls?.collaborators?.value?.length > 0 ||\n controls?.collaborators_group?.value?.length > 0\n \"\n [active]=\"activeList === 'COLLABORATORS'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'COLLABORATORS'\"\n [img]=\"\n 'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/owner.svg'\n \"\n >\n <label class=\"vx-control-panel\"\n >COLLABORATORS \n <span\n class=\"icon\"\n *ngIf=\"toolTipData.collaborators !== ''\"\n libPopoverHover\n (mouseover)=\"dataTooltip.popover()\"\n (mouseleave)=\"dataTooltip.closePopover()\"\n placement=\"right\"\n ><i class=\"icons\">&#xe91f;</i></span\n >\n <popover-hover #dataTooltip>\n <div class=\"vx-info-card\">\n <div\n class=\"vx-info-card-body\"\n [innerHTML]=\"toolTipData.collaborators\"\n id=\"CollaboratorsHelpText\"\n ></div>\n </div>\n </popover-hover>\n </label>\n <input-with-pill\n [placeholder]=\"'Who is responsible for managing this program?'\"\n (select)=\"activateList('COLLABORATORS')\"\n >\n <div class=\"selected\" *ngIf=\"controls?.collaborators?.value[0] || controls?.collaborators_group?.value[0]\">\n <div class=\"vx-d-flex vx-align-center\">\n <!-- Users -->\n <div \n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.collaborators?.value[0]\"\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.collaborators?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.collaborators?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4 greenBg\"\n appPopover\n (click)=\"owner.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.collaborators?.value?.length > 1\"\n >\n +{{ controls?.collaborators?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\" \n controls?.collaborators_group?.value?.length &&\n controls?.collaborators?.value?.length\n \"\n >&</span\n >\n <!-- Groups -->\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.collaborators_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n (click)=\"\n remove(\n controls?.collaborators_group?.value[0],\n 'COLLABORATORS_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.collaborators_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.collaborators_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"group.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_owners_group?.value?.length > 1\"\n >\n +{{ controls?.collaborators_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\" [appTooltip]=\"controls?.program_owners?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\" >{{controls?.program_owners?.value[0]?.member_name}}</span></span>\n <button *ngIf=\"controls?.program_owners?.value?.length > 1\" class=\"count user\" appPopover (click)=\"owner.popover()\" placement=\"right\">+{{controls?.program_owners?.value?.length -1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_owners_group?.value?.length && controls?.program_owners?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_owners_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" *ngIf=\"!['ADMIN','KEY_ADMIN','LOGGED_IN'].includes(owner?.user_role)\" (click)=\"remove(owner,'OWNER_GROUP')\">&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_owners_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_owners_group?.value[0]?.group_name}}</span></span>\n <button *ngIf=\"controls?.program_owners_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"group.popover()\" placement=\"right\">+{{controls?.program_owners_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'COLLABORATORS'\"\n [class.disabled]=\"controls?.all_user_in_role?.value\"\n (click)=\"activateList('COLLABORATORS')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i>Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #owner [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"let owner of controls?.collaborators?.value | slice : 1\"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n\n class=\"icons\"\n (click)=\"remove(owner, 'COLLABORATORS')\"\n >&#xe90d;</i\n >\n {{ owner?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #group [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let owner of controls?.collaborators_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n class=\"icons\"\n (click)=\"remove(owner, 'COLLABORATORS_GROUP')\"\n >&#xe90d;</i\n >\n {{ owner?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field>\n\n <!-- Performance Calculated -->\n <!-- <form-field [checked]=\"controls?.performance_calculation?.value\" [active]=\"activeList === 'PERFORMANCE'\" [disabled]=\"sideElements.includes(activeList) && activeList !== 'PERFORMANCE'\"\n [img]=\"'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/performance-calc.svg'\">\n <label class=\"vx-control-panel\">HOW SHOULD THE PERFORMANCE OF THIS PROGRAM BE CALCULATED?</label>\n <tab-selector formControlName=\"performance_calculation\" [displayArray]=\"constants?.performanceCalculation\">\n </tab-selector>\n </form-field> -->\n <ng-container *ngIf=\"isProgramScope && false\">\n <div\n class=\"scope-label vx-fs-10 vx-txt-white vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mb-5 vx-lh-4 vx-d-inline-block\"\n >\n PROGRAM SCOPE\n </div>\n <!-- <i class=\"icons info-icon vx-fs-12 vx-txt-blue vx-ml-1\" [appTooltip]=\"tooltip.programScope\" placement=\"bottom\" delay=\"0\" type=\"white\" [tooltipMandatory]=\"true\">&#xe91f;</i> -->\n <span\n class=\"icon info-icon vx-fs-12 vx-txt-blue vx-ml-1\"\n *ngIf=\"toolTipData.programScop !== ''\"\n libPopoverHover\n (mouseover)=\"dataTooltip.popover()\"\n (mouseleave)=\"dataTooltip.closePopover()\"\n placement=\"right\"\n ><i class=\"icons\">&#xe91f;</i></span\n >\n <popover-hover #dataTooltip>\n <div class=\"vx-info-card\">\n <div\n class=\"vx-info-card-body\"\n [innerHTML]=\"toolTipData.programScope\"\n id=\"PSHelpText\"\n ></div>\n </div>\n </popover-hover>\n </ng-container>\n\n <!-- Program Frequency -->\n <form-field\n *ngIf=\"additionalOption?.PROGRAM_FREQUENCY\"\n [checked]=\"[true, false].includes(controls?.recurring_frequency?.value)\"\n [active]=\"activeList === 'FREQUENCY'\"\n [disabled]=\"\n sideElements.includes(activeList) && activeList !== 'FREQUENCY'\n \"\n [img]=\"ASSETS.recurring\"\n >\n <label class=\"vx-control-panel\" id=\"PDChange\"\n >PROGRAM DURATION\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Program Duration refers to the duration of the Program. A Program can occur in perpetuity, or it can occur until the end of the current business cycle that has been specified in ' +\n businessCycle.selectedCycle.business_cycle +\n '. All responsibilities linked with that Program will also have the same Program Duration.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"ProgramDurationHelpText\"\n >&#xeb16;</i\n ></label\n >\n <div class=\"upload-format\">\n <div class=\"vx-d-flex vx-align-center vx-justify-between\">\n <span class=\"text vx-mb-0\">Is this program recurring?</span>\n <div class=\"radio-group program\">\n <app-cs-radio\n [name]=\"'recurring_frequency'\"\n [checked]=\"controls?.recurring_frequency?.value\"\n (checkedEvent)=\"setFormField('recurring_frequency', true)\"\n >YES</app-cs-radio\n >\n <app-cs-radio\n [name]=\"'recurring_frequency'\"\n [checked]=\"!controls?.recurring_frequency?.value\"\n (checkedEvent)=\"setFormField('recurring_frequency', false)\"\n >NO</app-cs-radio\n >\n </div>\n </div>\n </div>\n </form-field>\n\n <!-- Scope Changes -->\n <form-field\n *ngIf=\"additionalOption?.SCOPE_CHANGES\"\n [checked]=\"[true, false].includes(controls?.lock_scope_change?.value)\"\n [active]=\"activeList === 'SCOPE'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'SCOPE'\"\n [img]=\"ASSETS.lock_scope\"\n >\n <label class=\"vx-control-panel\"\n >Lock the Program Scope\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If the Program Scope is locked, neither the Program nor the responsibilities linked with the Program can be edited once the Program begins. In order to edit the Program or the linked responsibilities, the Program details will need to be edited.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"ScopeChangesHelpText\"\n >&#xeb16;</i\n ></label\n >\n <div class=\"upload-format\">\n <span class=\"text\"\n >Would you like to\n <span class=\"vx-label-txt vx-fw-500\">lock changes</span> to the\n program scope?</span\n >\n <div class=\"radio-group program\">\n <app-cs-radio\n [name]=\"'lock_scope_change'\"\n [checked]=\"controls?.lock_scope_change?.value\"\n (checkedEvent)=\"setFormField('lock_scope_change', true)\"\n >YES</app-cs-radio\n >\n <app-cs-radio\n [name]=\"'lock_scope_change'\"\n [checked]=\"!controls?.lock_scope_change?.value\"\n (checkedEvent)=\"setFormField('lock_scope_change', false)\"\n >NO</app-cs-radio\n >\n </div>\n </div>\n </form-field>\n\n <!-- Framework -->\n <!-- <form-field [checked]=\"false\" [active]=\"activeList === 'FRAMEWORK'\" [disabled]=\"sideElements.includes(activeList) && activeList !== 'FRAMEWORK'\"\n [img]=\"'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/category.svg'\">\n <label class=\"vx-control-panel\">FRAMEWORK</label>\n <input-with-pill [placeholder]=\"'Select a framework that this Program relates to'\" (select)=\"activateList('FRAMEWORK')\">\n <div class=\"selected\" *ngIf=\"controls?.framework?.value?.framework_name\">\n <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i (click)=\"remove(controls?.framework.value,'FRAMEWORK')\" class=\"icons\">&#xe90d;</i>{{controls?.framework?.value?.framework_name}}</span>\n <button class=\"count\" appPopover (click)=\"framework.popover()\" placement=\"right\">+5</button>\n </div>\n </div>\n <button *ngIf=\"activeList!=='FRAMEWORK'\" (click)=\"activateList('FRAMEWORK')\" class=\"edit\" type=\"button\"><i class=\"icons\">&#xe9ba;</i> Edit</button>\n </div>\n </input-with-pill>\n <app-popover #framework [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i class=\"icons\">&#xe90d;</i>\n Manage framework name\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field> -->\n\n <!-- Responsibility Center -->\n <form-field\n *ngIf=\"additionalOption?.RC\"\n [checked]=\"controls?.rc?.value?.length\"\n [active]=\"activeList === 'RC'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'RC'\"\n [img]=\"ASSETS.responsibility_center\"\n >\n <label class=\"vx-control-panel\"\n >RESPONSIBILITY CENTER\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Responsibility Centers represent your organizational and operational infrastructure. Where Responsibility Centers are selected when creating a Program, only those Responsibilities Centers will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"RCHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n (select)=\"activateList('RC')\"\n [placeholder]=\"\n 'Which Responsibility Center(s) can be linked to the responsibilities associated with this Program?'\n \"\n >\n <div\n class=\"selected\"\n *ngIf=\"controls?.rc?.value && controls?.rc?.value?.length\"\n >\n <div class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\">\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"remove(controls?.rc?.value[0], 'RC')\"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.rc?.value[0]?.item_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.rc?.value[0]?.item_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"rc.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.rc?.value?.length > 1\"\n >\n +{{ controls?.rc?.value?.length - 1 }}\n </button>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i class=\"icons\" (click)=\"remove(controls?.rc?.value[0],'RC')\">&#xe90d;</i>{{controls?.rc?.value[0]?.item_name}}</span>\n <button *ngIf=\"controls?.rc?.value?.length > 1\" class=\"count\" appPopover (click)=\"rc.popover()\" placement=\"right\">+{{controls?.rc?.value?.length -1 }}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'RC'\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('RC')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #rc [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"let rc of controls?.rc?.value | slice : 1\">\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i class=\"icons\" (click)=\"remove(rc, 'RC')\">&#xe90d;</i>\n {{ rc?.item_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field>\n\n <!-- Assignee -->\n <form-field\n *ngIf=\"additionalOption?.ASSIGNEES\"\n [checked]=\"\n controls?.program_assignee?.value?.length ||\n controls?.program_default_assignee?.value?.length ||\n controls?.program_default_assignee?.value?.length ||\n controls?.program_default_assignee_group?.value?.length\n \"\n [active]=\"['ASSIGNEE', 'DEFAULT_ASSIGNEE']?.includes(activeList)\"\n [disabled]=\"\n sideElements?.includes(activeList) &&\n !['ASSIGNEE', 'DEFAULT_ASSIGNEE'].includes(activeList)\n \"\n [img]=\"ASSETS.case_assignees\"\n >\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"activeList === 'DEFAULT_ASSIGNEE'\"\n >ASSIGNEES\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Assignees are required to complete the responsibilities that have been assigned to them. Where Assignees are selected when creating a Program, only those Assignees will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"AssigneeHelpText\"\n >&#xeb16;</i\n >\n </label>\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'DEFAULT_ASSIGNEE'\"\n [placeholder]=\"\n 'Who is responsible for completing the responsibilities within this Program?'\n \"\n (select)=\"activateList('ASSIGNEE')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_assignee?.value?.length ||\n controls?.program_assignee_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_assignee?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(controls?.program_assignee?.value[0], 'ASSIGNEE')\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_assignee?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_assignee?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"assignee.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_assignee?.value?.length > 1\"\n >\n +{{ controls?.program_assignee?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_assignee_group?.value?.length &&\n controls?.program_assignee?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_assignee_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_assignee_group?.value[0],\n 'ASSIGNEE_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_assignee_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_assignee_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"assignee_group.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_assignee_group?.value?.length > 1\"\n >\n +{{ controls?.program_assignee_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_assignee?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_assignee?.value[0],'ASSIGNEE')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_assignee?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_assignee?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_assignee?.value?.length > 1\" class=\"count user\" appPopover (click)=\"assignee.popover()\" placement=\"right\">+{{controls?.program_assignee?.value?.length -1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_assignee_group?.value?.length && controls?.program_assignee?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_assignee_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_assignee_group?.value[0],'ASSIGNEE_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_assignee_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_assignee_group?.value[0]?.group_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_assignee_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"assignee_group.popover()\" placement=\"right\">+{{controls?.program_assignee_group?.value?.length -1 }}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'ASSIGNEE'\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('ASSIGNEE')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #assignee [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let assignee of controls?.program_assignee?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(assignee, 'ASSIGNEE')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ assignee?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #assignee_group [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_assignee_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(group, 'ASSIGNEE_GROUP')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"activeList === 'ASSIGNEE'\"\n >DEFAULT ASSIGNEE\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'This option lets you specify the Default Assignees for all new responsibilities linked with a Program. If a Default Assignees is selected, the user will automatically be selected the Assignee when creating a responsibility linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility. '\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"DAHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'ASSIGNEE'\"\n [placeholder]=\"\n 'Which persons will be selected as the default assignees for the responsibilities within this Program?'\n \"\n (select)=\"activateList('DEFAULT_ASSIGNEE')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_assignee?.value?.length ||\n controls?.program_default_assignee_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_assignee?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_assignee?.value[0],\n 'DEFAULT_ASSIGNEE'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_assignee?.value[0]?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_assignee?.value[0]?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultAssignee.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_default_assignee?.value?.length > 1\"\n >\n +{{ controls?.program_default_assignee?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_default_assignee_group?.value?.length &&\n controls?.program_default_assignee?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_assignee_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_assignee_group?.value[0],\n 'DEFAULT_ASSIGNEE_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_assignee_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_assignee_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultAssigneeGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_assignee_group?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_assignee_group?.value?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_assignee?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_assignee?.value[0],'DEFAULT_ASSIGNEE')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_assignee?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{ controls?.program_default_assignee?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_assignee?.value?.length > 1\" class=\"count user\" appPopover (click)=\"defaultAssignee.popover()\" placement=\"right\">+{{controls?.program_default_assignee?.value?.length - 1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_default_assignee_group?.value?.length && controls?.program_default_assignee?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_assignee_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_assignee_group?.value[0],'DEFAULT_ASSIGNEE_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_assignee_group?.value[0]?.group_name }}</span>\n </span>\n <button *ngIf=\"controls?.program_default_assignee_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"defaultAssigneeGroup.popover()\" placement=\"right\">+{{controls?.program_default_assignee_group?.value?.length -1 }}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_ASSIGNEE'\"\n (click)=\"activateList('DEFAULT_ASSIGNEE')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #defaultAssignee [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let assignee of controls?.program_default_assignee?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(assignee, 'DEFAULT_ASSIGNEE')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ assignee?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #defaultAssigneeGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_assignee_group?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(assignee, 'DEFAULT_ASSIGNEE_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <div\n class=\"radio-group-selector\"\n [class.disabled]=\"activeList === 'ASSIGNEE'\"\n >\n <app-cs-radio\n [name]=\"'assignee'\"\n [checked]=\"controls?.assignee_completion_criteria?.value === 'ALL'\"\n (checkedEvent)=\"setFormField('assignee_completion_criteria', 'ALL')\"\n >\n ALL SELECTED PERSONS NEED TO COMPLETE THIS\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If selected, separate responsibilities will be created for each person.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n <app-cs-radio\n [name]=\"'assignee'\"\n [checked]=\"controls?.assignee_completion_criteria?.value === 'ANYONE'\"\n (checkedEvent)=\"\n setFormField('assignee_completion_criteria', 'ANYONE')\n \"\n >\n ANY SELECTED PERSON CAN COMPLETE THIS\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If selected, only one responsibility will be created.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n </div>\n </form-field>\n\n <!-- Reviewer -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.REVIEWER\"\n [checked]=\"\n controls?.program_reviewer?.value?.length ||\n controls?.program_default_reviewer?.value?.length ||\n controls?.program_default_reviewer?.value?.length ||\n controls?.program_default_reviewer_group?.value?.length\n \"\n [active]=\"['REVIEWER', 'DEFAULT_REVIEWER']?.includes(activeList)\"\n [disabled]=\"\n sideElements?.includes(activeList) &&\n !['REVIEWER', 'DEFAULT_REVIEWER'].includes(activeList)\n \"\n [img]=\"ASSETS.reviewer\"\n >\n <label\n [class.disabled]=\"activeList === 'DEFAULT_REVIEWER'\"\n class=\"vx-control-panel\"\n >Reviewers\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Reviewers are required to review responsibilities after they have been completed. Where Reviewers are selected when creating a Program, only those Reviewers will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"ReviewerHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'DEFAULT_REVIEWER'\"\n [placeholder]=\"\n 'Who is responsible for reviewing the responsibilities within this Program?'\n \"\n (select)=\"activateList('REVIEWER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_reviewer?.value?.length ||\n controls?.program_reviewer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_reviewer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(controls?.program_reviewer?.value[0], 'REVIEWER')\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_reviewer?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_reviewer?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"reviewer.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_reviewer?.value?.length > 1\"\n >\n +{{ controls?.program_reviewer?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_reviewer_group?.value?.length &&\n controls?.program_reviewer?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_reviewer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_reviewer_group?.value[0],\n 'REVIEWER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_reviewer_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_reviewer_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"reviewerGroup.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_reviewer_group?.value?.length > 1\"\n >\n +{{ controls?.program_reviewer_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_reviewer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_reviewer?.value[0],'REVIEWER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_reviewer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_reviewer?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_reviewer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"reviewer.popover()\" placement=\"right\">+{{controls?.program_reviewer?.value?.length -1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_reviewer_group?.value?.length && controls?.program_reviewer?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_reviewer_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_reviewer_group?.value[0],'REVIEWER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_reviewer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_reviewer_group?.value[0]?.group_name}}\n </span>\n </span>\n <button *ngIf=\"controls?.program_reviewer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"reviewerGroup.popover()\" placement=\"right\">+{{controls?.program_reviewer_group?.value?.length - 1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'REVIEWER'\"\n (click)=\"activateList('REVIEWER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #reviewer [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let reviewer of controls?.program_reviewer?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(reviewer, 'REVIEWER')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ reviewer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #reviewerGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_reviewer_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(group, 'REVIEWER_GROUP')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <label\n [class.disabled]=\"activeList === 'REVIEWER'\"\n class=\"vx-control-panel\"\n >DEFAULT Reviewer\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'This option lets you specify the Default Reviewers for responsibilities linked with a Program. Where a user has been specified as a Default Reviewer, that user will automatically be selected as the Reviewer when creating a responsibility linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"DRHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'REVIEWER'\"\n [placeholder]=\"\n 'Which persons will be selected as the default reviewers for the responsibilities within this Program?'\n \"\n (select)=\"activateList('DEFAULT_REVIEWER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_reviewer?.value?.length ||\n controls?.program_default_reviewer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_reviewer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_reviewer?.value[0],\n 'DEFAULT_REVIEWER'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_reviewer?.value[0]?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_reviewer?.value[0]?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultReviewer.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_default_reviewer?.value?.length > 1\"\n >\n +{{ controls?.program_default_reviewer?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_default_reviewer_group?.value?.length &&\n controls?.program_default_reviewer?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_reviewer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_reviewer_group?.value[0],\n 'DEFAULT_REVIEWER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_reviewer_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_reviewer_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultReviewerGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_reviewer_group?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_reviewer_group?.value?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_reviewer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_reviewer?.value[0],'DEFAULT_REVIEWER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_reviewer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_reviewer?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_reviewer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"defaultReviewer.popover()\" placement=\"right\">+{{controls?.program_default_reviewer?.value?.length - 1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_default_reviewer_group?.value?.length && controls?.program_default_reviewer?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_reviewer_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_reviewer_group?.value[0],'DEFAULT_REVIEWER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_reviewer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_reviewer_group?.value[0]?.group_name}}\n </span>\n </span>\n <button *ngIf=\"controls?.program_default_reviewer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"defaultReviewerGroup.popover()\" placement=\"right\">+{{controls?.program_default_reviewer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_REVIEWER'\"\n (click)=\"activateList('DEFAULT_REVIEWER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #defaultReviewer [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let reviewer of controls?.program_default_reviewer?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(reviewer, 'DEFAULT_REVIEWER')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ reviewer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #defaultReviewerGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_reviewer_group?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(group, 'DEFAULT_REVIEWER_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <div\n class=\"radio-group-selector\"\n [class.disabled]=\"activeList === 'REVIEWER'\"\n >\n <app-cs-radio\n [name]=\"'reviewer'\"\n [checked]=\"\n controls?.reviewer_completion_criteria?.value === 'SEQUENTIAL'\n \"\n (checkedEvent)=\"\n setFormField('reviewer_completion_criteria', 'SEQUENTIAL')\n \"\n [class.disabled]=\"\n controls?.program_default_reviewer_group?.value?.length > 0\n \"\n >\n SEQUENTIAL\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'The responsibility will be sent for review one at a time in the sequence defined by you.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n <app-cs-radio\n [name]=\"'reviewer'\"\n [checked]=\"\n controls?.reviewer_completion_criteria?.value === 'ANYONE' ||\n controls?.program_default_reviewer_group?.value?.length > 0\n \"\n (checkedEvent)=\"\n setFormField('reviewer_completion_criteria', 'ANYONE')\n \"\n >\n ANY REVIEWER CAN MARK THIS AS REVIEWED\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'The responsibility will be sent for review to all reviewers at the same time. If anyone of the reviewer reviews the responsibility, it will be considered as reviewed.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n </div>\n </form-field>\n\n <!-- Overseer -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.OVERSEER\"\n [checked]=\"\n controls?.program_overseer?.value?.length ||\n controls?.program_default_overseer?.value?.length ||\n controls?.program_default_overseer?.value?.length ||\n controls?.program_default_overseer_group?.value?.length\n \"\n [active]=\"activeList === 'OVERSEER'\"\n [disabled]=\"\n sideElements?.includes(activeList) &&\n !['OVERSEER', 'DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(\n activeList\n )\n \"\n [img]=\"ASSETS.oversight\"\n >\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"\n ['DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n \"\n >Oversights\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Oversights receive updates when a responsibility is completed, completed with delay or not completed. Where Oversights are selected when creating a Program, only those Oversights will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"overseerHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"\n ['DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n \"\n [placeholder]=\"\n 'Who is responsible for overseeing the responsibilities within this Program?'\n \"\n (select)=\"activateList('OVERSEER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_overseer?.value?.length ||\n controls?.program_overseer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_overseer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(controls?.program_overseer?.value[0], 'OVERSEER')\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_overseer?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_overseer?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseers.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_overseer?.value?.length > 1\"\n >\n +{{ controls?.program_overseer?.value?.length - 1 }}\n </button>\n </div>\n <span\n *ngIf=\"\n controls?.program_overseer_group?.value?.length &&\n controls?.program_overseer?.value?.length\n \"\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_overseer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_overseer_group?.value[0],\n 'OVERSEER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_overseer_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_overseer_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseerGroup.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_overseer_group?.value?.length > 1\"\n >\n +{{ controls?.program_overseer_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_overseer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_overseer?.value[0],'OVERSEER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_overseer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">\n {{controls?.program_overseer?.value[0]?.member_name}}\n </span>\n </span>\n <button *ngIf=\"controls?.program_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseers.popover()\" placement=\"right\">+{{controls?.program_overseer?.value?.length -1}}</button>\n </div>\n <span *ngIf=\"controls?.program_overseer_group?.value?.length && controls?.program_overseer?.value?.length \" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_overseer_group?.value?.length \">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_overseer_group?.value[0],'OVERSEER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_overseer_group?.value[0]?.group_name}}</span></span>\n <button *ngIf=\"controls?.program_overseer_group?.value?.length> 1\" class=\"count\" appPopover (click)=\"overseerGroup.popover()\" placement=\"right\">+{{controls?.program_overseer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n\n <button\n *ngIf=\"activeList !== 'OVERSEER'\"\n (click)=\"activateList('OVERSEER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #overseers [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let overseer of controls?.program_overseer?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i class=\"icons\" (click)=\"remove(overseer, 'OVERSEER')\"\n >&#xe90d;</i\n >\n {{ overseer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #overseerGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_overseer_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(group, 'OVERSEER_GROUP')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <ng-container [class.disabled]=\"activeList === 'OVERSEER'\">\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"['OVERSEER'].includes(activeList)\"\n >DEFAULT Oversight\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'This option lets you specify the Default Oversight for responsibilities linked with a Program. Where a user has been specified as a Default Oversight, that user will automatically be selected as the Oversight when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"DOHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [disabled]=\"\n ['OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n \"\n [selectDiv]=\"true\"\n [placeholder]=\"\n 'Which persons will be selected as the default overseers for the responsibilities within this Program?'\n \"\n (select)=\"activateList('DEFAULT_OVERSEER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_overseer?.value?.length ||\n controls?.program_default_overseer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_overseer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_overseer?.value[0],\n 'DEFAULT_OVERSEER'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_overseer?.value[0]?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_overseer?.value[0]?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseersDefault.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_default_overseer?.value?.length > 1\"\n >\n +{{ controls?.program_default_overseer?.value?.length - 1 }}\n </button>\n </div>\n <span\n *ngIf=\"\n controls?.program_default_overseer_group?.value?.length &&\n controls?.program_default_overseer?.value?.length\n \"\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_overseer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_overseer_group?.value[0],\n 'DEFAULT_OVERSEER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_overseer_group?.value[0]\n ?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_overseer_group?.value[0]\n ?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseerDefaultGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_overseer_group?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_overseer_group?.value?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_overseer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_overseer?.value[0],'DEFAULT_OVERSEER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_overseer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_overseer?.value[0]?.member_name}}</span></span>\n <button *ngIf=\"controls?.program_default_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseersDefault.popover()\" placement=\"right\">+{{controls?.program_default_overseer?.value?.length -1}}</button>\n </div>\n <span *ngIf=\"controls?.program_default_overseer_group?.value?.length && controls?.program_default_overseer?.value?.length\" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_overseer_group?.value?.length \">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_overseer_group?.value[0],'DEFAULT_OVERSEER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_overseer_group?.value[0]?.group_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_overseer_group?.value?.length >1\" class=\"count\" appPopover (click)=\"overseerDefaultGroup.popover()\" placement=\"right\">+{{controls?.program_default_overseer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_OVERSEER'\"\n (click)=\"activateList('DEFAULT_OVERSEER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #overseersDefault [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let overseer of controls?.program_default_overseer?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n class=\"icons\"\n (click)=\"remove(overseer, 'DEFAULT_OVERSEER')\"\n >&#xe90d;</i\n >\n {{ overseer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #overseerDefaultGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_overseer_group?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(group, 'DEFAULT_OVERSEER_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <label class=\"vx-control-panel\"> </label>\n <input-with-pill\n class=\"vx-mt-2\"\n [selectDiv]=\"true\"\n [line]=\"3\"\n [disabled]=\"['OVERSEER', 'DEFAULT_OVERSEER'].includes(activeList)\"\n [placeholder]=\"\n 'Which persons will be selected as the default overseers for responsibilities that are not completed within this Program?'\n \"\n (select)=\"activateList('DEFAULT_FAILED_OVERSEER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_failed_overseer?.value?.length ||\n controls?.program_default_failed_overseer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_failed_overseer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_failed_overseer?.value[0],\n 'DEFAULT_FAILED_OVERSEER'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_failed_overseer?.value[0]\n ?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_failed_overseer?.value[0]\n ?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseersDefaultFail.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_failed_overseer?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_failed_overseer?.value?.length - 1\n }}\n </button>\n </div>\n <span\n *ngIf=\"\n controls?.program_default_failed_overseer_group?.value\n ?.length &&\n controls?.program_default_failed_overseer?.value?.length\n \"\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"\n controls?.program_default_failed_overseer_group?.value?.length\n \"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_failed_overseer_group?.value[0],\n 'DEFAULT_FAILED_OVERSEER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_failed_overseer_group?.value[0]\n ?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_failed_overseer_group?.value[0]\n ?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseerDefaultFailGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_failed_overseer_group?.value\n ?.length > 1\n \"\n >\n +{{\n controls?.program_default_failed_overseer_group?.value\n ?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_failed_overseer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_failed_overseer?.value[0],'DEFAULT_FAILED_OVERSEER')\" >&#xe90d;</i>\n <span class=\"chip\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_failed_overseer?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_failed_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseersDefaultFail.popover()\" placement=\"right\">+{{controls?.program_default_failed_overseer?.value?.length -1}}</button>\n </div>\n <span *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length && controls?.program_default_failed_overseer?.value?.length\" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length \">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_failed_overseer_group?.value[0],'DEFAULT_FAILED_OVERSEER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_failed_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_failed_overseer_group?.value[0]?.group_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"overseerDefaultFailGroup.popover()\" placement=\"right\">+{{controls?.program_default_failed_overseer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_FAILED_OVERSEER'\"\n (click)=\"activateList('DEFAULT_FAILED_OVERSEER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #overseersDefaultFail [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let overseer of controls?.program_default_failed_overseer\n ?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n class=\"icons\"\n (click)=\"remove(overseer, 'DEFAULT_FAILED_OVERSEER')\"\n >&#xe90d;</i\n >\n {{ overseer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #overseerDefaultFailGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_failed_overseer_group\n ?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(group, 'DEFAULT_FAILED_OVERSEER_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </ng-container>\n </form-field>\n\n <!-- Assessment -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.ASSESSMENT\"\n [checked]=\"controls?.program_assessments?.value?.length\"\n [active]=\"activeList === 'ASSESSMENT'\"\n [disabled]=\"\n sideElements.includes(activeList) && activeList !== 'ASSESSMENT'\n \"\n [img]=\"ASSETS.assessments\"\n >\n <label class=\"vx-control-panel\"\n >ASSESSMENTS\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Assessments are a digital form that are created in \u201CAssessment\u201D within the Compliance Module. Where Assessments are selected when creating a Program, only those Assessments will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"AssessmentHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [placeholder]=\"\n 'Which assessments can be linked to the responsibilities within this Program?'\n \"\n (select)=\"activateList('ASSESSMENT')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"controls?.program_assessments?.value?.length\"\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"\n controls?.program_assessments?.value\n | assessmentResolver as assessments\n \"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"remove(assessments[0], 'ASSESSMENT')\"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"assessments[0]?.assessment_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ assessments[0]?.assessment_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"program_assessments.popover()\"\n placement=\"right\"\n *ngIf=\"assessments?.length > 1\"\n >\n +{{ assessments?.length - 1 }}\n </button>\n </div>\n\n <!-- <div class=\"chip-container\">\n <ng-container *ngIf=\"(controls?.program_assessments?.value | assessmentResolver) as assessments\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i class=\"icons\" (click)=\"remove(assessments[0],'ASSESSMENT')\">&#xe90d;</i>{{assessments[0]?.assessment_name}} </span>\n <button *ngIf=\"assessments?.length > 1\" class=\"count\" appPopover (click)=\"program_assessments.popover()\" placement=\"right\">+{{assessments?.length -1 }}</button>\n </div>\n </ng-container>\n </div> -->\n <button\n *ngIf=\"activeList !== 'ASSESSMENT'\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('ASSESSMENT')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #program_assessments [dontCloseonClick]=\"true\">\n <ng-container>\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let assessment of controls?.program_assessments?.value\n | assessmentResolver\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(assessment, 'ASSESSMENT')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ assessment?.assessment_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </ng-container>\n </app-popover>\n </form-field>\n\n <!-- Format & Evidence -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.FORMATE_EVIDENCE\"\n [checked]=\"[true, false].includes(controls?.evidence_required?.value)\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.format_evidence\"\n >\n <label class=\"vx-control-panel\"\n >Evidence\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If selected, evidence of completion of a responsibility will be required for all responsibilities that are linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"EvidenceHelpText\"\n >&#xeb16;</i\n ></label\n >\n <div class=\"upload-format\">\n <span class=\"text\"\n >Do all responsibilities within this program require evidence?</span\n >\n <div class=\"radio-group program\">\n <app-cs-radio\n [name]=\"'evidence_required'\"\n [checked]=\"controls?.evidence_required?.value\"\n (checkedEvent)=\"setFormField('evidence_required', true)\"\n >YES</app-cs-radio\n >\n <app-cs-radio\n [name]=\"'evidence_required'\"\n [checked]=\"!controls?.evidence_required?.value\"\n (checkedEvent)=\"setFormField('evidence_required', false)\"\n >NO</app-cs-radio\n >\n </div>\n </div>\n <!-- <div class=\"vx-d-flex vx-align-center vx-justify-end vx-mt-2\">\n <div class=\"vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase vx-mr-2\">Allow any file to be marked as\n key\n evidence</div>\n <switch formControlName=\"allow_any_file_key_evidence\"\n (change)=\"setFormField('allow_any_file_key_evidence',$event?.target?.checked)\"></switch>\n </div> -->\n </form-field>\n\n <!-- Custom Field -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.CUSTOM_FIELDS\"\n [checked]=\"controls?.custom_fields?.value?.length\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.custom_fields\"\n >\n <label class=\"vx-control-panel\"\n >CUSTOM FIELD\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Where a custom field is specified, all responsibilities linked with a Program will contain that custom field. Custom fields enable the collection of additional meta data.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"CFHelpText\"\n >&#xeb16;</i\n ></label\n >\n <custom-field formControlName=\"custom_fields\"></custom-field>\n </form-field>\n </form>\n</div>\n\n\n<!-- render userlist with group -->\n<user-group-list\n *ngIf=\"activeList === 'OWNER'\"\n [groupEnabled]=\"true\"\n [singleSelect]=\"false\"\n [loading]=\"listLoadingState.USERS\"\n [userlist]=\"lists?.OWNERS?.data ?? []\"\n [selectedUsers]=\"controls?.program_owners?.value | refDisconnect\"\n (fetchUserData)=\"fetchUsersAssociatedWithRoles(false, $event)\"\n [userListInfo]=\"lists?.OWNERS\"\n [groupListInfo]=\"lists?.OWNERS_GROUPS\"\n [groupList]=\"lists?.OWNERS_GROUPS?.data ?? []\"\n [selectedGroups]=\"controls?.program_owners_group?.value | refDisconnect\"\n (save)=\"listAction($event, 'OWNER')\"\n (cancel)=\"fieldDeselector('OWNER')\"\n [panelTitle]=\"panelTitleOwner\"\n [featureflag]=\"featureflagGroups\"\n></user-group-list>\n<user-group-list\n *ngIf=\"activeList === 'COLLABORATORS'\"\n [groupEnabled]=\"true\"\n [singleSelect]=\"false\"\n [loading]=\"listLoadingState.USERS\"\n [userlist]=\"lists?.OWNERS?.data ?? []\"\n [selectedUsers]=\"controls?.collaborators?.value | refDisconnect\"\n [groupList]=\"lists?.OWNERS_GROUPS ?? []\"\n [FromProgram]=\"true\"\n [selectedGroups]=\"controls?.collaborators_group?.value | refDisconnect\"\n [assignorId]=\"assignorId\"\n [userListInfo]=\"lists?.ASSIGNEES\"\n (save)=\"listAction($event, 'COLLABORATORS')\"\n (cancel)=\"fieldDeselector('COLLABORATORS')\"\n [panelTitle]=\"panelTitleAssignee\"\n [defaultSelectedUsers]=\"\n controls?.collaborators?.value | refDisconnect\n \"\n [userType]=\"'assignees'\"\n [featureflag]=\"featureflagGroups\"\n>\n</user-group-list>\n<app-loader-inline *ngIf=\"loader\"></app-loader-inline>\n<app-smiley-dialog-inline\n *ngIf=\"showSmiley\"\n [message]=\"smileyMessage\"\n [actionButtons]=\"actionButtons\"\n (action)=\"action($event)\"\n (closeSmiley)=\"closeSmiley($event)\"\n>\n</app-smiley-dialog-inline>\n\n<!-- Framework selector -->\n<app-framework-list\n *ngIf=\"activeList === 'FRAMEWORK'\"\n [workflowPage]=\"['FRAMEWORK']\"\n (assignControl)=\"listAction($event, 'FRAMEWORK')\"\n (closeFramework)=\"fieldDeselector('FRAMEWORK')\"\n [previousSelectedValues]=\"{ framework: controls?.framework.value }\"\n (entrustFramework)=\"entrustFramework($event)\"\n [headerText]=\"'Select a framework'\"\n></app-framework-list>", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";::ng-deep .workflow-program{display:block;position:relative}::ng-deep .workflow-program .scope-label{background:#747576;border-radius:.125rem;position:relative;z-index:1}::ng-deep .workflow-program .scope-label:before{background:#f1f1f1;content:\"\";position:absolute;top:.5rem;left:7rem;width:20rem;height:1px;z-index:-1}::ng-deep .workflow-program .scope-label:after{background:#f1f1f1;content:\"\";position:absolute;top:.5rem;left:-2.5rem;width:2.5rem;height:1px;z-index:-1}::ng-deep .workflow-program .scope-label .required{position:absolute;top:0;right:-.625rem}::ng-deep .workflow-program .info-icon{position:relative;top:.125rem;cursor:pointer}::ng-deep .workflow-program .date-picker .picker-group{width:calc(50% - .125rem);position:relative}::ng-deep .workflow-program .date-picker .picker-group:focus-within{border-color:#1e5dd3;box-shadow:0 0 5px #1e5dd345}::ng-deep .workflow-program .date-picker .picker-group input{height:2.5rem;border-radius:.25rem;border:1px solid #DBDBDB;background:#fff;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%;padding:0 2rem 0 .75rem;outline:none}::ng-deep .workflow-program .date-picker .picker-group input:focus,::ng-deep .workflow-program .date-picker .picker-group input:hover{border-color:#1e5dd3;box-shadow:0 0 5px #1e5dd345}::ng-deep .workflow-program .date-picker .picker-group input::placeholder{color:#747576;font-size:13px}::ng-deep .workflow-program .date-picker .picker-group input:-ms-input-placeholder{color:#747576;font-size:13px}::ng-deep .workflow-program .date-picker .picker-group input::-ms-input-placeholder{color:#747576;font-size:13px}::ng-deep .workflow-program .date-picker .picker-group i{height:1rem;width:1rem;position:absolute;right:.75rem;top:.625rem;pointer-events:none}::ng-deep .workflow-program .program-type-field{background:#f8f8f8;border:1px solid #dbdbdb;border-radius:4px;height:40px;display:flex;align-items:center;justify-content:space-between;padding:4px;position:relative;z-index:1}::ng-deep .workflow-program .program-type-field .type-item{position:relative}::ng-deep .workflow-program .program-type-field .type-item:first-of-type{width:6.25rem}::ng-deep .workflow-program .program-type-field .type-item:nth-child(2){width:5.75rem}::ng-deep .workflow-program .program-type-field .type-item:nth-child(2).active~.background-glider{transform:translate(6.4375rem);width:5.75rem}::ng-deep .workflow-program .program-type-field .type-item:nth-child(3){width:8.625rem}::ng-deep .workflow-program .program-type-field .type-item:nth-child(3).active~.background-glider{transform:translate(12.375rem);width:8.625rem}::ng-deep .workflow-program .program-type-field .type-item:last-of-type{width:5.25rem}::ng-deep .workflow-program .program-type-field .type-item:last-of-type.active~.background-glider{transform:translate(21.1875rem);width:5.25rem}::ng-deep .workflow-program .program-type-field .type-item button{background:transparent;border:none;border-radius:0;color:#747576;font-size:11px;font-weight:600;text-transform:uppercase;width:100%;height:32px;padding:0 12px;text-align:center}::ng-deep .workflow-program .program-type-field .type-item button.disabled{background:transparent!important;color:#dbdbdb!important;filter:unset!important;opacity:unset!important;pointer-events:none}::ng-deep .workflow-program .program-type-field .type-item .info{color:#1e5dd3;font-size:12px;position:absolute;top:10px;right:12px;cursor:pointer}::ng-deep .workflow-program .program-type-field .type-item.active button{color:#1e5dd3!important}::ng-deep .workflow-program .program-type-field .background-glider{background:#fff;border-radius:4px;box-shadow:0 1px 3px #161b2f26;position:absolute;display:flex;width:6.25rem;height:32px;z-index:-1;transition:.25s ease-out}::ng-deep .workflow-program .vx-form-group .upload-files .file-item{background:#f1f1f1;border:1px solid #dbdbdb;border-radius:.25rem;padding-left:.125rem}::ng-deep .workflow-program .vx-form-group .upload-files .file-item .file-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;max-width:8.5rem}::ng-deep .workflow-program .vx-form-group .upload-files .file-item button.delete-btn{background:transparent;border-radius:0;border:none;border-left:1px solid #dbdbdb;height:1.625rem}::ng-deep .workflow-program .vx-form-group .upload-files button.file-count{background:#1e5dd3;border-radius:.125rem;border:none;color:#fff;font-size:11px;display:flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0;margin:4px 0 0 4px}::ng-deep .workflow-program .vx-form-group .upload-format .radio-group app-cs-radio{height:1.375rem}::ng-deep .workflow-program .vx-form-group .default-selected{background:#fbfbfb;border:1px solid #F1F1F1;border-radius:.25rem;margin-top:.5rem}::ng-deep .workflow-program .vx-form-group .default-selected .selected{border-radius:0;border:none;background:none}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio{border-top:1px solid #F1F1F1}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio{margin-top:0!important}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item span.radio{position:absolute;top:.5rem;left:.75rem}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item span.value{font-size:11px;text-transform:uppercase;padding:.5rem .5rem .5rem 2.25rem;width:100%;display:flex;justify-content:space-between;margin:0;max-width:100%;font-weight:500;color:#707070}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item span.value i{font-size:12px;color:#1e5dd3}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item svg{position:absolute;top:.5rem;left:.75rem}::ng-deep .workflow-program .vx-form-group .selected .custom-text{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;max-height:2.4rem}::ng-deep .workflow-program .vx-form-group .selected button.cross-btn{background:transparent;border-radius:0;border:0;padding:0}::ng-deep .workflow-program .vx-form-group .custom-input{position:relative}::ng-deep .workflow-program .vx-form-group .custom-input input{padding-right:2rem}::ng-deep .workflow-program .vx-form-group .custom-input button.cross-btn{background:transparent;border-radius:0;border:0;position:absolute;top:.875rem;right:.625rem}::ng-deep .workflow-program .vx-form-group button.add-more-btn{background:transparent;border-radius:0;border:none;padding:0}::ng-deep app-popover .wf-action-list ul.action-item .avatar-card .value{text-transform:none!important}::ng-deep app-popover .wf-action-list ul.action-item li file-pill .file-item{background:transparent!important;border:none!important;border-radius:0!important;padding:0!important;margin:0!important}::ng-deep app-popover .wf-action-list ul.action-item li file-pill .file-name{width:100%!important;max-width:100%!important}::ng-deep app-popover .wf-action-list ul.action-item li file-pill button.delete-btn{border:none!important;padding-right:0!important}.disabled{opacity:.4;pointer-events:none;filter:grayscale(1)}.vx-info-card{width:280px;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both;background:#fff;box-shadow:0 3px 6px #1c5bd140;border-radius:4px;position:static;display:block;left:780}.vx-info-card-body{font-size:12px;padding:8px 12px;margin:0;font-weight:400;text-transform:none;color:#747576}\n", "@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";::-webkit-scrollbar-track{background-color:#f1f1f1;position:absolute}::-webkit-scrollbar{width:3px;height:3px;background-color:transparent;position:absolute}::-webkit-scrollbar-thumb{border-radius:3px;background-color:#dbdbdb;position:absolute}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}button{font-family:Poppins,sans-serif}::ng-deep input.textField{background:#fff;border-radius:.25rem;border:1px solid #dbdbdb;font-size:13px;color:#747576;padding:8px 12px;position:relative;height:2.5rem;width:100%;transition:all .2s ease-in-out}::ng-deep input.textField::placeholder{font-size:13px;color:#747576}::ng-deep input.textField:hover,::ng-deep input.textField:focus{outline:none;border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .selectBoxEnable{background:#fff;border-radius:.25rem;border:1px solid #dbdbdb;cursor:pointer;height:2.5rem;position:relative;transition:all .2s ease-in-out}::ng-deep .selectBoxEnable:after{border-bottom-style:solid;border-bottom-width:1px;border-right-style:solid;border-right-width:1px;border-color:#747576;content:\"\";display:inline-block;right:12px;position:absolute;top:calc(50% - 4px);width:5px;height:5px;transform:rotate(45deg)}::ng-deep .selectBoxEnable:hover,::ng-deep .selectBoxEnable:focus{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .selectBoxEnable.disabled{background:#f1f1f1;pointer-events:none;opacity:1}::ng-deep .selectBoxEnable.withBtn:after{display:none}::ng-deep .selectBoxEnable.withBtn button.setBtn{background:transparent;border-radius:0;border:none;min-width:98px}::ng-deep .selectBoxSuccess{background:#f8f8f8;border-radius:.25rem;border:1px solid #f1f1f1;min-height:2.5rem;position:relative}::ng-deep .selectBoxSuccess .selectBoxText{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;width:22rem}::ng-deep .selectBoxSuccess button{background:transparent;border-radius:0;border:none}::ng-deep .selectBoxSuccess button.deleteBtn{color:#d93b41}::ng-deep .selectBoxSuccess .level-left{border-right:1px solid #f1f1f1;height:2.375rem;width:5rem}::ng-deep .selectBoxSuccess .level-left .level-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;width:4.5rem}::ng-deep .chipContainer{background:#fff;border-radius:.125rem;box-shadow:0 0 2px #1e5dd340;height:1.5rem}::ng-deep .chipContainer .cross{cursor:pointer;min-width:16px;width:16px;height:16px;display:flex;align-items:center;justify-content:center;background:transparent;border-radius:2px;margin-left:-4px}::ng-deep .chipContainer .cross:hover{background:#f1f1f1}::ng-deep .chipContainer .chipName{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;max-width:6rem}::ng-deep .chipContainer .chipName.no-width{max-width:unset}::ng-deep .chipContainer .chipName.full-width{max-width:25rem}::ng-deep .chipContainer button.countBtn{background:#1e5dd3;border-radius:1.25rem;border:none;min-width:1.5rem;height:1rem;margin:0 0 0 .5rem;padding:0 .25rem}::ng-deep .chipContainer button.countBtn.greenBg{background:#34aa44}::ng-deep .workflowLavel{background:#f1f1f1;border-radius:.125rem;color:#042e7d;min-width:1rem;height:1rem}::ng-deep .reviewSelection{border-radius:.25rem;border:1px solid #dbdbdb;transition:all .2s ease-in-out}::ng-deep .reviewSelection:hover{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .selectButton{background:#fff;border-radius:.25rem;border:1px solid #dbdbdb;cursor:pointer;height:2.5rem;position:relative;transition:all .2s ease-in-out}::ng-deep .selectButton:hover,::ng-deep .selectButton:focus{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep button.createNewBtn{background:transparent;border-radius:0;border:none}::ng-deep .vx-form-group{display:block;position:relative;margin-bottom:20px}::ng-deep .vx-form-group:after{content:\"\";display:block;clear:both}::ng-deep .vx-form-group .select{position:relative}::ng-deep .vx-form-group .select:after{border-bottom-style:solid;border-bottom-width:1px;border-right-style:solid;border-right-width:1px;border-color:#707070;content:\"\";display:inline-block;right:12px;position:absolute;top:calc(50% - 4px);width:5px;height:5px;transform:rotate(45deg)}::ng-deep .vx-form-group .select input{cursor:pointer;padding-right:30px!important}::ng-deep .vx-form-group .select .custom-input{height:40px;border-radius:4px;border:1px solid #dbdbdb;background:#fff;outline:none;padding:3px 12px;line-height:16px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%;cursor:pointer}::ng-deep .vx-form-group .select .custom-input:empty:not(:focus):before{content:attr(aria-placeholder);line-height:16px;font-size:13px;width:94%;display:block;pointer-events:none;opacity:.8}::ng-deep .vx-form-group .select .custom-input:hover{border-color:#1e5dd3;box-shadow:0 0 5px #1e5dd345}::ng-deep .vx-form-group .select .custom-input.frequency-custom-input{padding-right:108px;display:flex;align-items:center}::ng-deep .vx-form-group .select+app-cs-switch{display:block;margin-top:8px}::ng-deep .vx-form-group .select+app-cs-switch label.cs-switch span.value{white-space:nowrap;margin-right:5px;text-transform:uppercase}::ng-deep .vx-form-group .select+app-cs-radio{margin-top:8px!important}::ng-deep .vx-form-group .select~app-cs-radio{margin-top:4px;display:block;width:100%}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item span.radio{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item span.value{font-size:11px;text-transform:uppercase;border:1px solid #dbdbdb;border-radius:4px;padding:8px 8px 8px 36px;width:100%;display:flex;justify-content:space-between;margin:0;max-width:100%;font-weight:500;color:#707070}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item span.value i{font-size:12px;color:#1e5dd3}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item svg{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item input:checked~span.value{background:#eefcf0;border-color:#34aa44}::ng-deep .vx-form-group .select.button-sec:after{display:none}::ng-deep .vx-form-group .select.button-sec button{background:transparent;border:none;display:inline-flex;float:right;color:#1e5dd3;text-transform:uppercase;font-weight:600;cursor:pointer;font-size:11px;position:absolute;top:12px;right:8px;padding:0;margin:0}::ng-deep .vx-form-group .select+.vx-control-panel{margin-top:8px}::ng-deep .vx-form-group .select+.selected{margin-top:8px}::ng-deep .vx-form-group .select.select{margin-top:8px}::ng-deep .vx-form-group .upload-format{border:1px solid #dbdbdb;border-radius:4px;padding:8px 12px;display:block}::ng-deep .vx-form-group .upload-format span.text{line-height:20px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%;display:block;margin-bottom:6px}::ng-deep .vx-form-group .upload-format .radio-group{display:flex}::ng-deep .vx-form-group .upload-format .radio-group app-cs-radio{display:inline-block}::ng-deep .vx-form-group .upload-format .radio-group app-cs-radio label.radio-item span.value{font-size:11px;text-transform:uppercase;margin-left:8px}::ng-deep .vx-form-group .upload-format .radio-group app-cs-radio+app-cs-radio{margin-left:12px}::ng-deep .vx-form-group .upload-format~.upload-format{margin-top:4px}::ng-deep .vx-form-group .form-tab{display:flex;justify-content:flex-start}::ng-deep .vx-form-group .form-tab button{background:transparent;color:#161b2f;font-size:11px;line-height:16px;text-transform:uppercase;cursor:pointer;padding:8px 8px 8px 0;border:none;outline:none;font-weight:500}::ng-deep .vx-form-group .form-tab button:disabled{opacity:.5;pointer-events:none;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group .form-tab button+button{padding:8px}::ng-deep .vx-form-group .form-tab button.active{color:#1e5dd3}::ng-deep .vx-form-group .tab-group{border:1px solid #dbdbdb;border-radius:4px;padding:0;display:block;position:relative;transition:all .2s ease-in-out}::ng-deep .vx-form-group .tab-group:hover{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .vx-form-group .tab-group .upload-file{padding:16px 62px 16px 24px;display:flex;align-items:center;justify-content:space-between}::ng-deep .vx-form-group .tab-group .upload-file .image{width:80px}::ng-deep .vx-form-group .tab-group .upload-file .browse span{display:inline-block;font-size:12px;color:#747576;line-height:16px;padding:0 4px}::ng-deep .vx-form-group .tab-group .upload-file .browse .label{font-size:11px;color:#1e5dd3;line-height:16px;font-weight:600;text-transform:uppercase;margin:0;padding:0}::ng-deep .vx-form-group .tab-group .upload-file .browse .label input{opacity:0;position:absolute;margin:0;padding:0;inset:0;cursor:pointer;width:100%}::ng-deep .vx-form-group .tab-group.active{border-color:#1e5dd3}::ng-deep .vx-form-group .tab-group.uploaded{margin-top:4px}::ng-deep .vx-form-group .tab-group.uploaded .upload-file{padding:8px 0!important;text-align:center}::ng-deep .vx-form-group .tab-group.uploaded .upload-file .image{display:none}::ng-deep .vx-form-group .tab-group.uploaded .upload-file .browse{width:100%;text-align:center}::ng-deep .vx-form-group .tab-group+label.vx-form-group{margin-top:8px;margin-bottom:4px}::ng-deep .vx-form-group .file-list{background:#fbfbfb;border:1px solid #f1f1f1;border-radius:4px;padding:12px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;position:relative}::ng-deep .vx-form-group .file-list span.file-name{color:#747576;line-height:16px;font-size:11px;font-weight:400;cursor:pointer;max-width:calc(100% - 20px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}::ng-deep .vx-form-group .file-list .button-group{display:flex}::ng-deep .vx-form-group .file-list button{font-size:12px;color:#eb2424;cursor:pointer;display:flex;padding:0;border:none;outline:none;background:transparent}::ng-deep .vx-form-group .file-list button.edit{color:#1e5dd3}::ng-deep .vx-form-group .file-list button+button{margin-left:16px}::ng-deep .vx-form-group .file-list+.file-list{margin-top:4px}::ng-deep .vx-form-group .file-list .file-container{display:flex;justify-content:space-between;width:100%}::ng-deep .vx-form-group .file-list.policy{background:#fff}::ng-deep .vx-form-group .file-list cs-select{position:relative;margin-top:8px;width:100%}::ng-deep .vx-form-group .file-list cs-select .selection-wrap .input-group input.value{height:32px!important;font-size:13px!important}::ng-deep .vx-form-group .file-list cs-select .selection-wrap .input-group i{right:12px!important;top:12px!important}::ng-deep .vx-form-group .file-list app-line-loader{display:block;position:absolute;left:10px;right:10px;bottom:0}::ng-deep .vx-form-group label.vx-control-panel{color:#161b2f;font-size:11px;font-weight:500;line-height:16px;margin-bottom:8px;display:block;text-transform:uppercase;text-align:left}::ng-deep .vx-form-group label.vx-control-panel.custom-tag{font-size:10px}::ng-deep .vx-form-group label.vx-control-panel.vx-mt-8{margin-top:8px}::ng-deep .vx-form-group label.vx-control-panel span.required{color:#eb2424;font-size:14px;font-weight:500;position:relative;top:-2px}::ng-deep .vx-form-group label.vx-control-panel .button{background:transparent;border:none;display:inline-flex;float:right;color:#1e5dd3;text-transform:uppercase;font-weight:600;cursor:pointer;font-size:11px;padding:0;margin:0}::ng-deep .vx-form-group label.vx-control-panel app-cs-switch{float:right;display:block}::ng-deep .vx-form-group label.vx-control-panel i{margin-left:8px;font-size:12px;color:#1e5dd3;cursor:pointer;position:relative;top:1px}::ng-deep .vx-form-group label.vx-control-panel i.depreciation-icon{color:#e4b700;font-size:16px;position:relative;top:3px}::ng-deep .vx-form-group label.vx-control-panel .checkpoint-version{background:#f1f1f1;border-radius:2px;color:#042e7d;font-size:10px;font-weight:600;line-height:14px;margin-left:4px;padding:0 2px}::ng-deep .vx-form-group input[type=text],::ng-deep .vx-form-group .input{height:40px;border-radius:4px;border:1px solid #dbdbdb;background:#fff;outline:none;padding:8px 12px;line-height:20px;font-size:13px;color:#747576;transition:all .2s ease-in-out;width:100%;font-weight:400}::ng-deep .vx-form-group input[type=text]::placeholder,::ng-deep .vx-form-group .input::placeholder{color:#747576;font-weight:400}::ng-deep .vx-form-group input[type=text]:focus,::ng-deep .vx-form-group .input:focus,::ng-deep .vx-form-group input[type=text]:hover,::ng-deep .vx-form-group .input:hover{border-color:#1e5dd3!important;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .vx-form-group input[type=text].error,::ng-deep .vx-form-group .input.error{border-color:#eb2424;color:#eb2424;margin-bottom:4px}::ng-deep .vx-form-group input[type=text].error:focus,::ng-deep .vx-form-group .input.error:focus{box-shadow:0 0 5px #d31e1e45}::ng-deep .vx-form-group input[type=text]:disabled,::ng-deep .vx-form-group .input:disabled{background:#f1f1f1;cursor:not-allowed;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group input[type=text]:disabled:hover,::ng-deep .vx-form-group .input:disabled:hover{border-color:#dbdbdb;box-shadow:none}::ng-deep .vx-form-group input[type=text] span.text,::ng-deep .vx-form-group .input span.text{font-size:13px;color:#747576;font-weight:400;display:block;width:100%}::ng-deep .vx-form-group input[type=text] .input-group,::ng-deep .vx-form-group .input .input-group{display:flex;align-items:center}::ng-deep .vx-form-group input[type=text] .input-group.counter,::ng-deep .vx-form-group .input .input-group.counter{min-width:96px;width:96px}::ng-deep .vx-form-group input[type=text] .input-group.counter button,::ng-deep .vx-form-group .input .input-group.counter button{height:24px;width:24px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#747576;font-size:8px;cursor:pointer;outline:none}::ng-deep .vx-form-group input[type=text] .input-group.counter input,::ng-deep .vx-form-group .input .input-group.counter input{-webkit-appearance:textfield;-moz-appearance:textfield;height:24px;width:calc(100% - 48px);border:1px solid #f1f1f1;outline:none;padding:0 6px;text-align:center}::ng-deep .vx-form-group input[type=text] .input-group.counter input::-webkit-inner-spin-button,::ng-deep .vx-form-group .input .input-group.counter input::-webkit-inner-spin-button,::ng-deep .vx-form-group input[type=text] .input-group.counter input::-webkit-outer-spin-button,::ng-deep .vx-form-group .input .input-group.counter input::-webkit-outer-spin-button{appearance:none;margin:0}::ng-deep .vx-form-group input[type=text]+.file-list,::ng-deep .vx-form-group .input+.file-list{margin-top:8px}::ng-deep .vx-form-group input[type=text]::placeholder,::ng-deep .vx-form-group .input::placeholder{font-size:13px}::ng-deep .vx-form-group input[type=text]:-ms-input-placeholder,::ng-deep .vx-form-group .input:-ms-input-placeholder{font-size:13px}::ng-deep .vx-form-group input[type=text]::-ms-input-placeholder,::ng-deep .vx-form-group .input::-ms-input-placeholder{font-size:13px}::ng-deep .vx-form-group .classification{height:40px;border-radius:4px;border:1px solid #dbdbdb;background:#fff;padding:8px 12px;display:flex;justify-content:space-between}::ng-deep .vx-form-group .classification label{margin:0 4px 0 0;width:100%;position:relative;z-index:1}::ng-deep .vx-form-group .classification label span{display:block;width:100%;height:24px;border:1px solid #f1f1f1;border-radius:2px;line-height:24px;font-size:10px;text-align:center;color:#747576;font-weight:500;position:relative;text-transform:uppercase}::ng-deep .vx-form-group .classification label span:before{height:2px;content:\"\";top:0;right:0;left:0;border-radius:2px;position:absolute;transition:all .2s ease-in-out}::ng-deep .vx-form-group .classification label input{opacity:0;position:absolute;inset:0;margin:0;padding:0;width:100%;height:100%;cursor:pointer;z-index:1}::ng-deep .vx-form-group .classification label input:checked+span{color:#fff}::ng-deep .vx-form-group .classification label input:checked+span:before{bottom:0;height:100%;z-index:-1}::ng-deep .vx-form-group .classification label.low span:before{background:#34aa44}::ng-deep .vx-form-group .classification label.low-med span:before{background:#f2bf19}::ng-deep .vx-form-group .classification label.med-high span:before{background:#f29619}::ng-deep .vx-form-group .classification label.high span:before{background:#eb2424}::ng-deep .vx-form-group .classification label:last-of-type{margin-right:0}::ng-deep .vx-form-group .input{display:flex;align-items:center}::ng-deep .vx-form-group .selected{height:40px;border-radius:4px;border:1px solid #f1f1f1;background:#fbfbfb;outline:none;padding:8px;line-height:20px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%;display:flex;align-items:center;position:relative;justify-content:space-between}::ng-deep .vx-form-group .selected.first-field{z-index:2}::ng-deep .vx-form-group .selected .chip-container{display:flex;width:calc(100% - 60px);align-items:center}::ng-deep .vx-form-group .selected .chip-container.checkpoints{width:calc(100% - 120px)}::ng-deep .vx-form-group .selected .chip-container span.chip{background:#fff;border-radius:2px;box-shadow:0 0 3px #1e5dd31a;height:24px;padding:0 8px;color:#1e5dd3;font-size:12px;display:block;width:auto;max-width:100%;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:24px}::ng-deep .vx-form-group .selected .chip-container span.chip.disabled{background:#f1f1f1;box-shadow:none;color:#747576;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group .selected .chip-container span.chip i{font-weight:400;margin-right:8px;cursor:pointer;font-size:10px;position:relative;top:1px}::ng-deep .vx-form-group .selected .chip-container span.chip span.step{background:#1e5dd3;border-radius:2px;color:#fff;font-size:9px;line-height:14px;padding:0 4px;font-weight:400;text-align:center;min-width:auto;margin-right:4px}::ng-deep .vx-form-group .selected .chip-container span.chip+span.chip{margin-left:4px}::ng-deep .vx-form-group .selected .chip-container span.chip.with-question{display:flex;align-items:center;justify-content:space-between;width:100%}::ng-deep .vx-form-group .selected .chip-container span.chip.with-question span.value{color:#1e5dd3;font-size:12px;font-weight:400;line-height:24px;padding:0;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;max-width:calc(100% - 80px)}::ng-deep .vx-form-group .selected .chip-container span.chip.with-question span.label{background:#f1f1f1;border-radius:2px;color:#042e7d;font-size:9px;font-weight:600;text-transform:uppercase;padding-left:4px;padding-right:4px;line-height:12px;margin-left:8px}::ng-deep .vx-form-group .selected .chip-container span.value{color:#747576;font-size:13px;line-height:20px;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:calc(100% - 52px);padding:0 4px}::ng-deep .vx-form-group .selected .chip-container span.checkpoint-point-text{color:#747576;font-size:10px;font-weight:500;padding:0 8px;width:122px;line-height:14px}::ng-deep .vx-form-group .selected .chip-container span.checkpoint-point-text.first{position:relative;min-width:162px}::ng-deep .vx-form-group .selected .chip-container span.checkpoint-point-text.first:before{background:#f1f1f1;content:\"\";position:absolute;top:0;right:0;height:calc(100% + 12px);width:1px}::ng-deep .vx-form-group .selected .chip-container span.checkpoint-point-text .no{color:#1e5dd3}::ng-deep .vx-form-group .selected .chip-container.plus span.chip{max-width:calc(50% - 35px)}::ng-deep .vx-form-group .selected .chip-container.more-one span.chip{max-width:50%}::ng-deep .vx-form-group .selected .chip-container .chip-inner{background:#fff;border-radius:2px;box-shadow:0 2px 4px #1e5dd31a;line-height:24px;padding:0 4px 0 8px;display:flex;align-items:center}::ng-deep .vx-form-group .selected .chip-container .chip-inner .chip{background:transparent;border-radius:0;box-shadow:none;height:auto;line-height:unset;padding:0;color:#747576;max-width:100px}::ng-deep .vx-form-group .selected .chip-container .chip-inner button.count{border-radius:20px;height:16px;padding:0 6px;border:none;font-size:9px;line-height:16px;margin-left:4px;min-width:20px}::ng-deep .vx-form-group .selected .chip-container .chip-inner button.count.user{background:#34aa44}::ng-deep .vx-form-group .selected .chip-container .chip-inner i.cross{cursor:pointer;position:relative;top:1px;font-size:8px}::ng-deep .vx-form-group .selected button.count{background:#1e5dd3;border-radius:2px;height:24px;padding:0 8px;border:1px solid #1e5dd3;cursor:pointer;outline:none;color:#fff;font:13px;font-weight:500;line-height:20px;white-space:nowrap;margin-left:8px}::ng-deep .vx-form-group .selected button.edit{border:none;border-radius:0;background:transparent;outline:none;cursor:pointer;display:block;font-size:11px;font-weight:600;color:#1e5dd3;text-transform:uppercase;white-space:nowrap;margin-left:8px}::ng-deep .vx-form-group .selected button.edit i{font-weight:400;font-size:8px;margin-right:4px}::ng-deep .vx-form-group .selected button.close-btn{background:transparent;border:none;padding:0;margin-left:8px;font-size:10px;color:#c7381b;display:flex;align-items:center}::ng-deep .vx-form-group .selected .workflow-label{min-width:92px;padding:4px;text-align:center;margin-left:-8px;margin-right:8px;border-right:1px solid #f1f1f1}::ng-deep .vx-form-group .selected .workflow-label p{margin:0;display:block;text-transform:uppercase}::ng-deep .vx-form-group .selected .workflow-label p.title{font-size:9px;line-height:12px;color:#161b2f;font-weight:500}::ng-deep .vx-form-group .selected .workflow-label p.description{font-size:11px;line-height:16px;color:#161b2f;font-weight:600}::ng-deep .vx-form-group .selected .workflow-label+.chip-container{width:calc(100% - 148px)}::ng-deep .vx-form-group .selected+.selected{margin-top:8px}::ng-deep .vx-form-group .selected+app-cs-switch{display:block;margin-top:8px}::ng-deep .vx-form-group .selected+app-cs-switch label.cs-switch span.value{white-space:nowrap;margin-right:5px;text-transform:uppercase}::ng-deep .vx-form-group .selected+app-cs-switch.who-toggle label.cs-switch span.value{color:#747576}::ng-deep .vx-form-group .selected+app-cs-radio{margin-top:8px!important}::ng-deep .vx-form-group .selected~app-cs-radio{margin-top:4px;display:block;width:100%}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item span.radio{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item span.value{font-size:11px;text-transform:uppercase;border:1px solid #dbdbdb;border-radius:4px;padding:8px 8px 8px 36px;width:100%;display:flex;justify-content:space-between;margin:0;max-width:100%;font-weight:500;color:#707070}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item span.value i{font-size:12px;color:#1e5dd3}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item svg{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item input:checked~span.value{background:#eefcf0;border-color:#34aa44}::ng-deep .vx-form-group .selected.readOnly{pointer-events:none}::ng-deep .vx-form-group .selected span.chip{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .vx-form-group .select-list{position:absolute;background:#fff;box-shadow:0 0 5px #1e5dd345;top:100%;right:0;left:0;z-index:2}::ng-deep .vx-form-group .select-list .vx-radio-group label.vx-radio-item{width:100%;padding:12px 16px}::ng-deep .vx-form-group .select-list .vx-radio-group label.vx-radio-item:hover{background:#f8f8f8}::ng-deep .vx-form-group ::ng-deep vcomply-editor{margin-top:8px;display:block;pointer-events:auto!important;z-index:1}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container{border-radius:4px;border:1px solid #dbdbdb}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block{min-height:60px;padding:11px 15px;max-height:100px;line-height:20px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block ul{padding:0 0 0 10px;margin-top:0}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block ul li{list-style:disc}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block ol{padding:0 0 0 10px;margin-top:0}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block ol li{list-style:decimal}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools{z-index:1;border-top:1px solid #dbdbdb;transition:none;border-radius:0 0 3px 3px;position:static}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button{height:22px!important;width:22px!important;padding:0 5px}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button svg{height:22px;width:12px}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button.submit{width:80px!important;line-height:22px;justify-content:center}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col .popover.small ul.option-list li button{width:100%!important;height:auto!important}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container:focus-within{border-color:#1e5dd3!important;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container:focus-within .editor-tools{border-color:#1e5dd3!important}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container:hover{border-color:#1e5dd3!important;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container:hover .editor-tools{border-color:#1e5dd3!important}::ng-deep .vx-form-group ::ng-deep vcomply-editor+app-cs-switch{margin-top:8px}::ng-deep .vx-form-group app-cs-switch label.cs-switch span.value{font-size:11px;color:#747576;text-transform:uppercase}::ng-deep .vx-form-group app-cs-switch+app-cs-switch{margin-top:8px}::ng-deep .vx-form-group .date-time-picker{display:flex;justify-content:space-between;height:40px;border-radius:4px;border:1px solid #dbdbdb;padding:11px 0;background:#fff}::ng-deep .vx-form-group .date-time-picker:focus-within{border-color:#1e5dd3;box-shadow:0 0 5px #1e5dd345}::ng-deep .vx-form-group .date-time-picker .picker-group{width:50%;position:relative;display:flex;align-items:center}::ng-deep .vx-form-group .date-time-picker .picker-group:first-of-type{border-right:1px solid #dbdbdb}::ng-deep .vx-form-group .date-time-picker .picker-group:only-of-type{border:none;width:100%}::ng-deep .vx-form-group .date-time-picker .picker-group input{height:38px;background:transparent;line-height:38px;font-size:13px;color:#747576;transition:all .2s ease-in-out;width:100%;font-weight:400;border:none;padding:0 12px 0 34px;outline:none}::ng-deep .vx-form-group .date-time-picker .picker-group input:focus,::ng-deep .vx-form-group .date-time-picker .picker-group input:hover{box-shadow:none;border:none}::ng-deep .vx-form-group .date-time-picker .picker-group input::placeholder{color:#999;font-size:13px}::ng-deep .vx-form-group .date-time-picker .picker-group input:-ms-input-placeholder{color:#999;font-size:13px}::ng-deep .vx-form-group .date-time-picker .picker-group input::-ms-input-placeholder{color:#999;font-size:13px}::ng-deep .vx-form-group .date-time-picker .picker-group i{display:flex;justify-content:center;align-items:center;height:16px;width:12px;position:absolute;left:12px;top:0;color:#747576;font-size:12px;pointer-events:none}::ng-deep .vx-form-group app-cs-radio.main-filed{margin-top:4px;display:block;width:100%}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item{width:100%;position:relative}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item span.radio{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item span.value{font-size:11px;text-transform:uppercase;border:1px solid #dbdbdb;border-radius:4px;padding:8px 8px 8px 36px;width:100%;display:flex;justify-content:space-between;margin:0;max-width:100%;color:#707070}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item span.value i{font-size:12px;color:#1e5dd3}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item svg{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item input:checked~span.value{background:#eefcf0;border-color:#34aa44}::ng-deep .vx-form-group app-cs-radio.disabled{pointer-events:none;opacity:.5;filter:grayscale(1);background:#f1f1f1}::ng-deep .vx-form-group .switch-row{display:flex}::ng-deep .vx-form-group .switch-row app-cs-switch{display:block;margin-top:8px}::ng-deep .vx-form-group .switch-row app-cs-switch label.cs-switch span.value{white-space:nowrap;margin-right:0;text-transform:uppercase;color:#747576!important}::ng-deep .vx-form-group .switch-row app-cs-switch label.cs-switch span.value i{display:inline-flex;font-size:11px;cursor:pointer;color:#1e5dd3;align-items:center;line-height:16px;margin:0 4px}::ng-deep .vx-form-group .switch-row app-cs-switch+app-cs-switch{margin-left:8px}::ng-deep .vx-form-group .switch-row.align-right{justify-content:flex-end}::ng-deep .vx-form-group .switch-row.align-right label.cs-switch span.value{margin-right:8px}::ng-deep .vx-form-group .risk-type-field{background:#f8f8f8;border:1px solid #dbdbdb;border-radius:4px;height:40px;display:flex;align-items:center;padding:4px;position:relative;z-index:1}::ng-deep .vx-form-group .risk-type-field .type-item{width:50%;position:relative}::ng-deep .vx-form-group .risk-type-field .type-item button{background:transparent;border:none;border-radius:0;color:#747576;font-size:11px;font-weight:600;text-transform:uppercase;width:100%;height:32px;padding:0 12px;text-align:left}::ng-deep .vx-form-group .risk-type-field .type-item button.disabled{background:transparent!important;color:#dbdbdb!important;filter:unset!important;opacity:unset!important;pointer-events:none;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group .risk-type-field .type-item .info{color:#1e5dd3;font-size:12px;position:absolute;top:10px;right:12px;cursor:pointer}::ng-deep .vx-form-group .risk-type-field .type-item .info.disabled{background:transparent!important;color:#dbdbdb!important;filter:unset!important;opacity:unset!important;pointer-events:none;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group .risk-type-field .type-item.active button{color:#1e5dd3!important}::ng-deep .vx-form-group .risk-type-field .type-item:nth-child(2).active~.background-glider{transform:translate(100%)}::ng-deep .vx-form-group .risk-type-field .background-glider{background:#fff;border-radius:4px;box-shadow:0 1px 3px #161b2f26;position:absolute;display:flex;width:212px;height:32px;z-index:-1;transition:.25s ease-out}.left{width:36px;height:36px;margin-top:26px;margin-left:-58px;margin-right:20px;display:flex;justify-content:center;align-items:center;position:relative;z-index:10;border-radius:50%}.left.deadline-completed{margin-top:18px}.left.checked{background:transparent}.left img{width:36px}.left .checkIcon{width:32px;height:32px;background:#fff;border-radius:50%;stroke-width:4;stroke:#34aa44;stroke-miterlimit:10;box-shadow:inset 0 0 #34aa44;animation:fillCheck .4s ease-in-out .4s forwards,scale .3s ease-in-out .9s both;margin-top:0}.left .checkIcon__circle{stroke-dasharray:166;stroke-dashoffset:166;stroke-width:2;stroke-miterlimit:10;stroke:#34aa44;fill:none;animation:strokeCheck .6s cubic-bezier(.65,0,.45,1) forwards}.left .checkIcon__check{transform-origin:50% 50%;stroke-dasharray:48;stroke-dashoffset:48;animation:strokeCheck .3s cubic-bezier(.65,0,.45,1) .8s forwards}.right{width:100%}.right span.indicator{position:absolute;top:36px;left:-16px;font-size:12px;color:#f0b819;cursor:pointer}.form-group-row{display:flex;position:relative;transition:all .2s ease-in-out}.form-group-row.disabled{-webkit-user-select:none;user-select:none;pointer-events:none;filter:grayscale(1);z-index:2}.form-group-row.disabled .left{position:relative}.form-group-row.disabled .left:before{content:\"\";position:absolute;inset:2px 0 0 2px;background:#fff;opacity:.7;border-radius:50%;width:32px;height:32px}.form-group-row.disabled .right{opacity:.3}.form-group-row.active{pointer-events:none;filter:grayscale(0);z-index:2;opacity:1}.form-group-row.active .right .vx-form-group input,.form-group-row.active .right .vx-form-group .custom-input,.form-group-row.active .right .vx-form-group .selectBoxEnable{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}.form-group-row.active .right .vx-form-group .selectBoxEnable.disabled{border-color:#dbdbdb;box-shadow:none}::ng-deep .radio-group-selector app-cs-radio{margin-top:4px;display:block;width:100%}::ng-deep .radio-group-selector app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .radio-group-selector app-cs-radio label.radio-item .radio,::ng-deep .radio-group-selector app-cs-radio label.radio-item .radiomark{position:absolute!important;top:9px;left:12px}::ng-deep .radio-group-selector app-cs-radio label.radio-item .value{font-size:11px!important;text-transform:uppercase;border:1px solid #dbdbdb;border-radius:4px;padding:8px 8px 8px 36px;width:100%;display:flex;justify-content:space-between;margin:0!important;max-width:100%!important;font-weight:500!important;color:#707070!important}::ng-deep .radio-group-selector app-cs-radio label.radio-item .value i{font-size:12px;color:#1e5dd3}::ng-deep .radio-group-selector app-cs-radio label.radio-item input:checked~span.value{background:#eefcf0;border-color:#34aa44}@keyframes strokeCheck{to{stroke-dashoffset:0}}@keyframes fillCheck{to{box-shadow:inset 0 0 0 2px #34aa44}}::ng-deep .wf-action-list{width:220px}::ng-deep .wf-action-list ul{padding:0;margin:0;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both;background:#fff;box-shadow:0 3px 6px #1c5bd140;border-radius:4px;max-height:220px;overflow:auto}::ng-deep .wf-action-list ul.action-item{display:block}::ng-deep .wf-action-list ul.action-item li{list-style:none;border:none;border-bottom:1px solid #f1f1f1;display:block;width:100%;padding:0;background:transparent;border-radius:0;margin:0;height:auto;justify-content:flex-start;box-shadow:none}::ng-deep .wf-action-list ul.action-item li button{color:#6e717e;text-align:left;text-decoration:none;cursor:pointer;background:transparent;font-size:12px;text-transform:capitalize;display:flex;width:100%;padding:7.5px 11px;border:none}::ng-deep .wf-action-list ul.action-item li button i{font-size:16px;margin-right:10px;color:#1e5dd3}::ng-deep .wf-action-list ul.action-item li button:hover{background:#f3f3f3}::ng-deep .wf-action-list ul.action-item li .avatar-card{display:flex;align-items:center;width:100%;padding:7.5px}::ng-deep .wf-action-list ul.action-item li .avatar-card.within-con{display:block}::ng-deep .wf-action-list ul.action-item li .avatar-card .avatar{height:24px;width:24px!important;overflow:hidden;background:#1e5dd3;color:#fff;font-size:10px;display:inline-flex;margin-right:5px;border-radius:50%;align-items:center;justify-content:center;text-transform:uppercase}::ng-deep .wf-action-list ul.action-item li .avatar-card .avatar img{width:100%}::ng-deep .wf-action-list ul.action-item li .avatar-card .avatar+span.value{width:calc(100% - 29px)}::ng-deep .wf-action-list ul.action-item li .avatar-card span.value{width:100%;color:#6e717e;text-decoration:none;background:transparent;font-size:12px;text-transform:capitalize;display:block;font-weight:400;text-align-last:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:20px}::ng-deep .wf-action-list ul.action-item li .avatar-card span.value i{font-size:8px;color:#747576;cursor:pointer;margin-right:5px}::ng-deep .wf-action-list ul.action-item li .avatar-card.no-image{display:block}::ng-deep .wf-action-list ul.action-item li .avatar-card.no-image span.value{width:100%;display:block}::ng-deep .wf-action-list ul.action-item li .chip-item{color:#1e5dd3;padding:10px;display:flex;align-items:center}::ng-deep .wf-action-list ul.action-item li .chip-item i{color:#747576;margin-right:7px;font-size:10px;cursor:pointer;display:inline-flex}::ng-deep .wf-action-list ul.action-item li .chip-item span{display:block;width:auto;max-width:calc(100% - 17px);font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}::ng-deep .wf-action-list ul.action-item li .chip-item span.chip-block{display:block;width:100%}::ng-deep .wf-action-list ul.action-item li .chip-item span.id{font-size:9px}::ng-deep .wf-action-list ul.action-item li .within{display:flex;align-items:center;justify-content:flex-start}::ng-deep .wf-action-list ul.action-item li .within .block{background:#f1f1f1;border-radius:2px;padding:0 2px;line-height:14px;font-size:9px;font-weight:500;color:#042e7d;margin-right:6px;display:block;text-transform:uppercase}::ng-deep .wf-action-list ul.action-item li .within .data{width:100%;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#747576;font-size:11px;font-weight:400;line-height:17px}::ng-deep .wf-action-list ul.action-item li:first-child{animation:action-list-open .25s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(2){animation:action-list-open .35s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(3){animation:action-list-open .45s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(4){animation:action-list-open .55s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(5){animation:action-list-open .65s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(6){animation:action-list-open .75s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(7){animation:action-list-open .85s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(8){animation:action-list-open .95s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(9){animation:action-list-open 1.05s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(10){animation:action-list-open 1.15s cubic-bezier(.25,.46,.45,.94) both}@keyframes action-list-open{0%{transform:translateY(50px)}to{transform:translateY(0)}}@keyframes scale-up-center{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}p.error-message{font-size:11px;font-weight:400;color:#eb2424;line-height:16px;margin-top:8px;margin-bottom:0}.edit-loader{position:absolute;top:-3px;left:-3px;width:46px;height:46px;transform:rotate(180deg)}.circular-loader{animation:rotate 2s linear infinite;height:100%;transform-origin:center center;width:100%;position:absolute;top:0;left:0;margin:auto}.loader-path{stroke-dasharray:150,200;stroke-dashoffset:-10;animation:dash 1.5s ease-in-out infinite;stroke-linecap:round}@keyframes rotate{to{transform:rotate(360deg)}}@keyframes dash{0%{stroke-dasharray:1,200;stroke-dashoffset:0}50%{stroke-dasharray:89,200;stroke-dashoffset:-35}to{stroke-dasharray:89,200;stroke-dashoffset:-124}}::ng-deep .dropdown{position:fixed;background:#fff;box-shadow:0 3px 6px #00000029;padding:24px 0;z-index:9;max-height:calc(100vh - 200px);overflow:auto}::ng-deep .dropdown ul.dropdown-list{padding:0 20px;margin:0;display:block}::ng-deep .dropdown ul.dropdown-list li{list-style:none}::ng-deep .dropdown ul.dropdown-list li app-cs-radio{display:flex}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item span.radio{position:absolute;top:12px;left:12px}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item span.value{padding:11px 12px 11px 32px;width:100%;border:1px solid #bcbcbc;border-radius:4px;margin-left:0;max-width:100%}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item svg{position:absolute;top:12px;left:12px}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item input[type=radio]:checked~span.value{background:#e8feeb;border-color:#34aa44}::ng-deep .dropdown ul.dropdown-list li+li{margin-top:8px}app-smiley-dialog{position:relative;z-index:10}app-smiley-dialog-inline{position:absolute;top:-3px;right:0;bottom:0;z-index:999;width:520px;height:calc(100vh + 3px)}::ng-deep .vx-overlay{position:fixed;z-index:3;inset:0}::ng-deep dp-date-picker{width:100%;position:fixed!important;z-index:14;top:-40px;left:0}::ng-deep dp-date-picker input{width:100%;border:none;opacity:0;pointer-events:none}::ng-deep dp-date-picker input:focus{outline:none}::ng-deep dp-date-picker .dp-popup{width:412px;box-shadow:0 0 20px #161b2f26;background-color:#fff;border-radius:4px;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both}::ng-deep dp-date-picker .dp-popup dp-day-calendar,::ng-deep dp-date-picker .dp-popup dp-month-calendar{width:100%;pointer-events:auto}::ng-deep dp-date-picker .dp-popup dp-day-calendar button,::ng-deep dp-date-picker .dp-popup dp-month-calendar button{background:transparent;border:none;outline:none}::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-current-location-btn,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-current-location-btn,::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-calendar-nav-left,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-calendar-nav-left,::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-calendar-nav-right,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-calendar-nav-right{width:40px;height:40px;display:flex;justify-content:center;align-items:center;border-radius:50%;font-size:14px}::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-current-location-btn:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-current-location-btn:hover,::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-calendar-nav-left:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-calendar-nav-left:hover,::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-calendar-nav-right:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-calendar-nav-right:hover{background-color:#f3f3f3}::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-current-location-btn,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-current-location-btn{display:none}::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-current-location-btn:before,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-current-location-btn:before{content:\"\";height:10px;width:10px;border-radius:50%;background:#000;display:inline-flex}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week{display:flex;justify-content:space-around}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays .dp-calendar-weekday,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays .dp-calendar-weekday,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week .dp-calendar-weekday,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week .dp-calendar-weekday{width:52px;border-left:none;border-bottom-color:#fff;color:#747576;font-size:11px;font-weight:600;text-transform:uppercase}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays button,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week button{width:40px;height:40px;border-radius:50%;display:inline-flex;justify-content:center;align-items:center}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays button:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays button:hover,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week button:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week button:hover{background-color:#f3f3f3}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays button.dp-selected,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays button.dp-selected,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week button.dp-selected,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week button.dp-selected{background:#1e5dd3}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays button.dp-current-day,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays button.dp-current-day,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week button.dp-current-day,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week button.dp-current-day{border:1px solid rgba(0,0,0,.38);color:#1e5dd3;background-color:#fff}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-day-calendar-container,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-day-calendar-container{padding:20px;border-radius:2px}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-nav-container,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-nav-container{display:flex;margin:0 0 20px;border:none}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-nav-container .dp-nav-header button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-nav-container .dp-nav-header button{color:#000;font-size:17px;font-weight:500;margin:0 0 0 12px;padding:0}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-nav-btns-container,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-nav-btns-container{width:80px;display:flex}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-nav-btns-container .dp-calendar-nav-container-left button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-nav-btns-container .dp-calendar-nav-container-left button,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-nav-btns-container .dp-calendar-nav-container-right button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-nav-btns-container .dp-calendar-nav-container-right button{margin:0!important}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-wrapper,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-wrapper{border:none}::ng-deep dp-date-picker .dp-open+div{position:fixed!important;inset:0!important;display:flex;justify-content:center;align-items:center;z-index:99;pointer-events:none;background:#0000004d}::ng-deep .cdk-overlay-container{z-index:2147483002!important}::ng-deep .dp-popup{z-index:999;display:flex!important;align-items:center;justify-content:center;width:100vw;height:100vh;background:#0000004d!important;box-shadow:unset!important}::ng-deep .dp-popup dp-day-calendar{width:412px!important;box-shadow:0 0 20px #161b2f26;background-color:#fff;border-radius:4px;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both}::ng-deep .dp-popup dp-day-calendar,::ng-deep .dp-popup dp-month-calendar{width:100%;pointer-events:auto}::ng-deep .dp-popup dp-day-calendar button,::ng-deep .dp-popup dp-month-calendar button{background:transparent;border:none;outline:none}::ng-deep .dp-popup dp-day-calendar button.dp-current-location-btn,::ng-deep .dp-popup dp-month-calendar button.dp-current-location-btn,::ng-deep .dp-popup dp-day-calendar button.dp-calendar-nav-left,::ng-deep .dp-popup dp-month-calendar button.dp-calendar-nav-left,::ng-deep .dp-popup dp-day-calendar button.dp-calendar-nav-right,::ng-deep .dp-popup dp-month-calendar button.dp-calendar-nav-right{width:40px;height:40px;display:flex;justify-content:center;align-items:center;border-radius:50%;font-size:14px}::ng-deep .dp-popup dp-day-calendar button.dp-current-location-btn:hover,::ng-deep .dp-popup dp-month-calendar button.dp-current-location-btn:hover,::ng-deep .dp-popup dp-day-calendar button.dp-calendar-nav-left:hover,::ng-deep .dp-popup dp-month-calendar button.dp-calendar-nav-left:hover,::ng-deep .dp-popup dp-day-calendar button.dp-calendar-nav-right:hover,::ng-deep .dp-popup dp-month-calendar button.dp-calendar-nav-right:hover{background-color:#f3f3f3}::ng-deep .dp-popup dp-day-calendar button.dp-current-location-btn,::ng-deep .dp-popup dp-month-calendar button.dp-current-location-btn{display:none}::ng-deep .dp-popup dp-day-calendar button.dp-current-location-btn:before,::ng-deep .dp-popup dp-month-calendar button.dp-current-location-btn:before{content:\"\";height:10px;width:10px;border-radius:50%;background:#000;display:inline-flex}::ng-deep .dp-popup dp-day-calendar .dp-weekdays,::ng-deep .dp-popup dp-month-calendar .dp-weekdays,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week{display:flex;justify-content:space-around}::ng-deep .dp-popup dp-day-calendar .dp-weekdays .dp-calendar-weekday,::ng-deep .dp-popup dp-month-calendar .dp-weekdays .dp-calendar-weekday,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week .dp-calendar-weekday,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week .dp-calendar-weekday{width:52px;border-left:none;border-bottom-color:#fff;color:#747576;font-size:11px;font-weight:600;text-transform:uppercase}::ng-deep .dp-popup dp-day-calendar .dp-weekdays button,::ng-deep .dp-popup dp-month-calendar .dp-weekdays button,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week button,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week button{width:40px;height:40px;border-radius:50%;display:inline-flex;justify-content:center;align-items:center}::ng-deep .dp-popup dp-day-calendar .dp-weekdays button:hover,::ng-deep .dp-popup dp-month-calendar .dp-weekdays button:hover,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week button:hover,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week button:hover{background-color:#f3f3f3}::ng-deep .dp-popup dp-day-calendar .dp-weekdays button.dp-selected,::ng-deep .dp-popup dp-month-calendar .dp-weekdays button.dp-selected,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week button.dp-selected,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week button.dp-selected{background:#1e5dd3}::ng-deep .dp-popup dp-day-calendar .dp-weekdays button.dp-current-day,::ng-deep .dp-popup dp-month-calendar .dp-weekdays button.dp-current-day,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week button.dp-current-day,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week button.dp-current-day{border:1px solid rgba(0,0,0,.38);color:#1e5dd3;background-color:#fff}::ng-deep .dp-popup dp-day-calendar .dp-day-calendar-container,::ng-deep .dp-popup dp-month-calendar .dp-day-calendar-container{padding:20px;border-radius:2px}::ng-deep .dp-popup dp-day-calendar .dp-calendar-nav-container,::ng-deep .dp-popup dp-month-calendar .dp-calendar-nav-container{display:flex;margin:0 0 20px;border:none}::ng-deep .dp-popup dp-day-calendar .dp-calendar-nav-container .dp-nav-header button,::ng-deep .dp-popup dp-month-calendar .dp-calendar-nav-container .dp-nav-header button{color:#000;font-size:17px;font-weight:500;margin:0 0 0 12px;padding:0}::ng-deep .dp-popup dp-day-calendar .dp-nav-btns-container,::ng-deep .dp-popup dp-month-calendar .dp-nav-btns-container{width:80px;display:flex}::ng-deep .dp-popup dp-day-calendar .dp-nav-btns-container .dp-calendar-nav-container-left button,::ng-deep .dp-popup dp-month-calendar .dp-nav-btns-container .dp-calendar-nav-container-left button,::ng-deep .dp-popup dp-day-calendar .dp-nav-btns-container .dp-calendar-nav-container-right button,::ng-deep .dp-popup dp-month-calendar .dp-nav-btns-container .dp-calendar-nav-container-right button{margin:0!important}::ng-deep .dp-popup dp-day-calendar .dp-calendar-wrapper,::ng-deep .dp-popup dp-month-calendar .dp-calendar-wrapper{border:none}@keyframes slide-bottom{0%{transform:translateY(-100px)}to{transform:translateY(0)}}::ng-deep span.file{display:block;width:20px;min-width:20px;border-radius:0 0 2px 2px;border:1px solid transparent;border-color:#747576;position:relative;margin-right:5px;border-top:none;margin-top:5px;background:#fff}::ng-deep span.file.table{margin-right:8px;width:18px;min-width:18px}::ng-deep span.file.table i{font-size:8px}::ng-deep span.file.table .format{height:8px;font-size:7px;line-height:8px;font-weight:400}::ng-deep span.file:before{position:absolute;border-radius:0;top:-4px;right:-1px;content:\"\";height:4px;width:4px;display:block;background:linear-gradient(45deg,#747576 0% 1%,#747576 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file:after{height:4px;left:-1px;right:3px;border-top:1px solid;border-right:none;border-left:1px solid;content:\"\";top:-4px;position:absolute;border-radius:2px 0 0;background:#fff}::ng-deep span.file .format{height:10px;font-size:6px;text-transform:uppercase;background:transparent;font-weight:600;text-align:center;display:block;line-height:10px}::ng-deep span.file i{font-size:10px;height:10px;display:flex;align-items:center;justify-content:center;color:#dbdbdb}::ng-deep span.file.docx{width:22px!important}::ng-deep span.file.pdf,::ng-deep span.file.template{border-color:#f31c39}::ng-deep span.file.pdf:before,::ng-deep span.file.template:before{background:linear-gradient(45deg,#f31c39 0% 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#f31c39\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.pdf:after,::ng-deep span.file.template:after{border-color:#f31c39}::ng-deep span.file.pdf .format,::ng-deep span.file.template .format{color:#f31c39}::ng-deep span.file.xlsx,::ng-deep span.file.xls,::ng-deep span.file.css,::ng-deep span.file.scss,::ng-deep span.file.less{border-color:#34aa44}::ng-deep span.file.xlsx:before,::ng-deep span.file.xls:before,::ng-deep span.file.css:before,::ng-deep span.file.scss:before,::ng-deep span.file.less:before{background:linear-gradient(45deg,#34aa44 0% 1%,#34aa44 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.xlsx:after,::ng-deep span.file.xls:after,::ng-deep span.file.css:after,::ng-deep span.file.scss:after,::ng-deep span.file.less:after{border-color:#34aa44;color:#34aa44}::ng-deep span.file.xlsx .format,::ng-deep span.file.xls .format,::ng-deep span.file.css .format,::ng-deep span.file.scss .format,::ng-deep span.file.less .format{color:#34aa44}::ng-deep span.file.doc,::ng-deep span.file.docx,::ng-deep span.file.psd{border-color:#1e5dd3}::ng-deep span.file.doc:before,::ng-deep span.file.docx:before,::ng-deep span.file.psd:before{background:linear-gradient(45deg,#1e5dd3 0% 1%,#1e5dd3 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.doc:after,::ng-deep span.file.docx:after,::ng-deep span.file.psd:after{border-color:#1e5dd3}::ng-deep span.file.doc .format,::ng-deep span.file.docx .format,::ng-deep span.file.psd .format{color:#1e5dd3}::ng-deep span.file.ppt,::ng-deep span.file.ai,::ng-deep span.file.html,::ng-deep span.file.jpg,::ng-deep span.file.jpeg,::ng-deep span.file.png{border-color:#f6882f}::ng-deep span.file.ppt:before,::ng-deep span.file.ai:before,::ng-deep span.file.html:before,::ng-deep span.file.jpg:before,::ng-deep span.file.jpeg:before,::ng-deep span.file.png:before{background:linear-gradient(45deg,#f6882f 0% 1%,#f6882f 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.ppt:after,::ng-deep span.file.ai:after,::ng-deep span.file.html:after,::ng-deep span.file.jpg:after,::ng-deep span.file.jpeg:after,::ng-deep span.file.png:after{border-color:#f6882f}::ng-deep span.file.ppt .format,::ng-deep span.file.ai .format,::ng-deep span.file.html .format,::ng-deep span.file.jpg .format,::ng-deep span.file.jpeg .format,::ng-deep span.file.png .format{color:#f6882f}::ng-deep span.file.php{border-color:#7aa6f7}::ng-deep span.file.php:before{background:linear-gradient(45deg,#7aa6f7 0% 1%,#7aa6f7 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.php:after{border-color:#7aa6f7}::ng-deep span.file.php .format{color:#7aa6f7}::ng-deep ngx-material-timepicker-container .timepicker-backdrop-overlay{background-color:#0000000d!important;z-index:9999999999!important}::ng-deep ngx-material-timepicker-container .timepicker-overlay{z-index:9999999999!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker{width:232px!important;border-radius:2px!important;box-shadow:0 4px 30px #161b2f26!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header{background-color:#fff!important;padding:0!important;border-radius:2px 2px 0 0}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container{display:block!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time{color:#000!important;width:150px!important;margin:0 auto;line-height:60px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time ngx-material-timepicker-dial-control .timepicker-dial__control{font-size:40px;background-color:transparent!important;color:#000!important;font-weight:600;text-align:right;caret-color:transparent;outline:none;font-family:Poppins;line-height:56px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time ngx-material-timepicker-dial-control .timepicker-dial__control:focus,::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time ngx-material-timepicker-dial-control .timepicker-dial__control:hover{background-color:transparent!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time ngx-material-timepicker-dial-control:last-of-type .timepicker-dial__control{text-align:left}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time span{padding:0 8px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period{display:flex!important;width:182px;margin:0 auto!important;background:#f1f1f1;padding:4px 10px;border-radius:20px;position:relative}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period:before{background:#f1f1f1;content:\"\";position:absolute;top:15px;left:-25px;width:calc(100% + 50px);height:2px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period{flex-direction:unset!important;position:relative;z-index:1}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period:after{content:\"\";position:absolute;right:-12px;top:0;border-left:solid 14px #f1f1f1;border-bottom:solid 12px transparent;border-top:solid 12px transparent;z-index:-1}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period:before{content:\"\";position:absolute;left:-18px;top:0;border-right:solid 14px #f1f1f1;border-bottom:solid 12px transparent;border-top:solid 12px transparent;z-index:-1}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period button{font-size:11px;background-color:transparent;padding:0;border-radius:20px;color:#747576;font-weight:600;font-family:Poppins;width:84px;height:24px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period button.timepicker-dial__item_active{background:#fff!important;color:#1e5dd3!important;box-shadow:0 1px 2px #dbdbdb}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period button+button{margin-left:0!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face{width:200px!important;height:200px!important;padding:10px!important;background:transparent!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__number--outer{height:92px!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__number--outer span{color:#000}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__number--outer span.active{color:#fff}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__clock-hand{height:80px!important;top:calc(50% - 80px)!important;background-color:#1e5dd3!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__number>span.active{background-color:#1e5dd3!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__clock-hand_minute:before{border:4px solid #1e5dd3!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .timepicker__actions{display:flex!important;padding:10px 0 0!important;background:#fff!important;justify-content:space-around!important;border-radius:0 0 2px 2px!important;overflow:hidden}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .timepicker__actions div:first-child ngx-material-timepicker-button button.timepicker-button{background:#f8f8f8;color:#1e5dd3}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .timepicker__actions div ngx-material-timepicker-button button.timepicker-button{line-height:28px!important;width:100%;background:#1e5dd3;color:#fff;border-radius:0!important;height:32px!important;width:116px!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .timepicker__actions div ngx-material-timepicker-button button.timepicker-button span{font-weight:500!important;font-size:11px;font-family:Poppins}::ng-deep vcomply-editor{display:block}::ng-deep vcomply-editor .editor-container{border-radius:4px;border:1px solid #dbdbdb;transition:all .2s ease-in-out}::ng-deep vcomply-editor .editor-container:hover,::ng-deep vcomply-editor .editor-container:focus-within{border:1px solid #1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep vcomply-editor .editor-container mention-list ul li a{font-size:16px!important}::ng-deep vcomply-editor .editor-container .editable-block{background:#fff;min-height:60px;padding:8px 12px;line-height:20px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%}::ng-deep vcomply-editor .editor-container .editable-block:before{color:#747576!important}::ng-deep vcomply-editor .editor-container .editor-tools{border-top:1px solid #dbdbdb;border-radius:0 0 3px 3px}::ng-deep vcomply-editor .editor-container .editor-tools:hover{border-color:#1e5dd3}::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button{height:22px!important;width:22px!important;padding:0 5px}::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button svg{height:22px;width:12px}::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button.submit{width:80px!important;line-height:22px;justify-content:center}::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col .popover.small ul.option-list li button{width:100%!important;height:auto!important}::ng-deep marx-modal .popup-modal-background{background-color:#161b2fcc!important}::ng-deep .within-box{background:#f1f1f1;border-radius:.125rem;color:#042e7d}::ng-deep .within-value{overflow:hidden;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;word-break:break-word}.wf-tooltip{pointer-events:none;position:absolute;max-width:300px;font-size:12px;text-align:left;color:#fff;padding:8px 12px;background:#000;border-radius:2px;z-index:-222;top:0;opacity:0;white-space:break-spaces;word-break:break-word}.wf-tooltip *{color:#fff!important}.wf-tooltip:empty{display:none!important}.wf-tooltip.white{box-shadow:0 2px 8px #1c5bd159;color:#747576;background:#fff;text-align:left}.wf-tooltip.white b{color:#747576!important}.wf-tooltip.animate-top{animation:animate-top .5s cubic-bezier(.25,.46,.45,.94) both}.wf-tooltip.animate-right{animation:animate-right .3s cubic-bezier(.25,.46,.45,.94) both}.wf-tooltip.animate-bottom{animation:animate-bottom .5s cubic-bezier(.25,.46,.45,.94) both}.wf-tooltip.animate-left{animation:animate-left .5s cubic-bezier(.25,.46,.45,.94) both}.wf-tooltip-top:after{top:100%;left:50%;margin-left:-5px;border-width:5px;border-color:#000000 transparent transparent transparent}.wf-tooltip-top.white:after{border-color:#f1f1f1 transparent transparent transparent}.wf-tooltip-bottom:after{bottom:100%;left:50%;margin-left:-5px;border-width:5px;border-color:transparent transparent #000000 transparent}.wf-tooltip-bottom.white:after{border-color:transparent transparent #f1f1f1 transparent}.wf-tooltip-left.white:after{border-color:transparent transparent transparent #f1f1f1}.wf-tooltip-left:after{top:50%;left:100%;margin-top:-5px;border-width:5px;border-color:transparent transparent transparent #000000}.wf-tooltip-right.white:after{border-color:transparent #f1f1f1 transparent transparent}.wf-tooltip-right:after{top:50%;right:100%;margin-top:-5px;border-width:5px;border-color:transparent #000000 transparent transparent}.wf-tooltip-bottom-right:after{bottom:100%;left:100%;margin-left:-20px;border-width:5px;border-color:transparent transparent #000000 transparent}.wf-tooltip-bottom-right.white:after{border-color:transparent transparent #f1f1f1 transparent}.wf-tooltip-bottom-left:after{bottom:100%;left:0;margin-left:10px;border-width:5px;border-color:transparent transparent #000000 transparent}.wf-tooltip-bottom-left.white:after{border-color:transparent transparent #f1f1f1 transparent}.wf-tooltip-top-left:after{top:100%;left:0;margin-left:10px;border-width:5px;border-color:#000000 transparent transparent transparent}.wf-tooltip-top-left.white:after{border-color:#f1f1f1 transparent transparent transparent}.wf-tooltip-top-right:after{top:100%;left:100%;margin-left:-5px;border-width:5px;border-color:#000000 transparent transparent transparent}.wf-tooltip-top-right.white:after{border-color:#f1f1f1 transparent transparent transparent}.wf-tooltip:after{content:\"\";position:absolute;border-style:solid}.wf-tooltip span.within{font-size:80%;display:block;width:100%}.wf-tooltip .small{display:block;font-size:10px}.wf-tooltip .within-box{background:#f1f1f1;border-radius:2px;color:#042e7d!important;font-size:9px;font-weight:500;text-transform:uppercase;padding:0 2px;margin-right:2px}.wf-tooltip-show{pointer-events:none;opacity:1;z-index:2147483001}\n"], dependencies: [{ kind: "directive", type: i1$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 >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.framework.value?.name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.framework.value?.name }}</span\n >\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i (click)=\"remove('', 'FRAMEWORK')\" *ngIf=\"canFrameworkChange\" class=\"icons\" >&#xe90d;</i> {{controls?.framework.value?.name}}</span>\n </div>\n </div> -->\n <button\n *ngIf=\"canFrameworkChange\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('FRAMEWORK')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n </form-field>\n\n <!-- Program Category Name -->\n <form-field\n [checked]=\"controls?.program_name?.value?.trim()?.length\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.what\"\n >\n <label class=\"vx-control-panel\"\n >PROGRAM NAME <span class=\"required\">*</span></label\n >\n <input\n InputTrim\n formControlName=\"program_name\"\n type=\"text\"\n placeholder=\"What is the Program name?\"\n />\n\n <p\n *ngIf=\"\n controls?.program_name?.errors && controls?.program_name?.touched\n \"\n class=\"error-message\"\n >\n Enter a name for this Program.\n </p>\n <p *ngIf=\"isNameExists\" class=\"error-message\">\n Program name already exists.\n </p>\n <vcomply-editor\n [(ngModel)]=\"editorData.programObjective\"\n [ngModelOptions]=\"{ standalone: true }\"\n (sendSavedFiles)=\"selectFile('OBJECTIVE', $event)\"\n (ngModelChange)=\"setFormField('program_objective', $event, true)\"\n [editorConfig]=\"constants?.description\"\n >\n </vcomply-editor>\n </form-field>\n\n\n\n <!-- Owners -->\n <form-field\n *ngIf=\"additionalOption?.OWNERS\"\n [checked]=\"\n controls?.program_owners?.value?.length > 0 ||\n controls?.program_owners_group?.value?.length > 0\n \"\n [active]=\"activeList === 'OWNER'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'OWNER'\"\n [img]=\"ASSETS.case_owners\"\n >\n <label class=\"vx-control-panel\"\n >OWNER(S) <span class=\"required\">*</span>\n <span\n class=\"icon\"\n *ngIf=\"toolTipData.owner !== ''\"\n libPopoverHover\n (mouseover)=\"dataTooltip.popover()\"\n (mouseleave)=\"dataTooltip.closePopover()\"\n placement=\"right\"\n ><i class=\"icons\">&#xe91f;</i></span\n >\n <popover-hover #dataTooltip>\n <div class=\"vx-info-card\">\n <div\n class=\"vx-info-card-body\"\n [innerHTML]=\"toolTipData.owner\"\n id=\"OwnerHelpText\"\n ></div>\n </div>\n </popover-hover>\n </label>\n <input-with-pill\n [placeholder]=\"'Who is responsible for managing this program?'\"\n (select)=\"activateList('OWNER')\"\n >\n <div class=\"selected\" *ngIf=\"controls?.program_owners?.value[0]\">\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_owners?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_owners?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4 greenBg\"\n appPopover\n (click)=\"owner.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_owners?.value?.length > 1\"\n >\n +{{ controls?.program_owners?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_owners_group?.value?.length &&\n controls?.program_owners?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_owners_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n (click)=\"\n remove(\n controls?.program_owners_group?.value[0],\n 'OWNER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_owners_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_owners_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"group.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_owners_group?.value?.length > 1\"\n >\n +{{ controls?.program_owners_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n <button\n *ngIf=\"activeList !== 'OWNER'\"\n [class.disabled]=\"controls?.all_user_in_role?.value\"\n (click)=\"activateList('OWNER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i>Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #owner [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"let owner of controls?.program_owners?.value | slice : 1\"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"\n !(\n lists.NON_REMOVABLE_OWNERS | listToId : 'member_id'\n ).includes(owner?.member_id)\n \"\n class=\"icons\"\n (click)=\"remove(owner, 'OWNER')\"\n >&#xe90d;</i\n >\n {{ owner?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #group [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let owner of controls?.program_owners_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n class=\"icons\"\n (click)=\"remove(owner, 'OWNER_GROUP')\"\n >&#xe90d;</i\n >\n {{ owner?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field>\n\n <!-- Collaborators -->\n <form-field\n *ngIf=\"additionalOption?.COLLABORATORS\"\n [checked]=\"\n controls?.collaborators?.value?.length > 0 ||\n controls?.collaborators_group?.value?.length > 0\n \"\n [active]=\"activeList === 'COLLABORATORS'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'COLLABORATORS'\"\n [img]=\"\n 'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/owner.svg'\n \"\n >\n <label class=\"vx-control-panel\"\n >COLLABORATORS \n <span\n class=\"icon\"\n *ngIf=\"toolTipData.collaborators !== ''\"\n libPopoverHover\n (mouseover)=\"dataTooltip.popover()\"\n (mouseleave)=\"dataTooltip.closePopover()\"\n placement=\"right\"\n ><i class=\"icons\">&#xe91f;</i></span\n >\n <popover-hover #dataTooltip>\n <div class=\"vx-info-card\">\n <div\n class=\"vx-info-card-body\"\n [innerHTML]=\"toolTipData.collaborators\"\n id=\"CollaboratorsHelpText\"\n ></div>\n </div>\n </popover-hover>\n </label>\n <input-with-pill\n [placeholder]=\"'Who is responsible for managing this program?'\"\n (select)=\"activateList('COLLABORATORS')\"\n >\n <div class=\"selected\" *ngIf=\"controls?.collaborators?.value[0] || controls?.collaborators_group?.value[0]\">\n <div class=\"vx-d-flex vx-align-center\">\n <!-- Users -->\n <div \n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.collaborators?.value[0]\"\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.collaborators?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.collaborators?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4 greenBg\"\n appPopover\n (click)=\"owner.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.collaborators?.value?.length > 1\"\n >\n +{{ controls?.collaborators?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\" \n controls?.collaborators_group?.value?.length &&\n controls?.collaborators?.value?.length\n \"\n >&</span\n >\n <!-- Groups -->\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.collaborators_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n (click)=\"\n remove(\n controls?.collaborators_group?.value[0],\n 'COLLABORATORS_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.collaborators_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.collaborators_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"group.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_owners_group?.value?.length > 1\"\n >\n +{{ controls?.collaborators_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\" [appTooltip]=\"controls?.program_owners?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\" >{{controls?.program_owners?.value[0]?.member_name}}</span></span>\n <button *ngIf=\"controls?.program_owners?.value?.length > 1\" class=\"count user\" appPopover (click)=\"owner.popover()\" placement=\"right\">+{{controls?.program_owners?.value?.length -1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_owners_group?.value?.length && controls?.program_owners?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_owners_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" *ngIf=\"!['ADMIN','KEY_ADMIN','LOGGED_IN'].includes(owner?.user_role)\" (click)=\"remove(owner,'OWNER_GROUP')\">&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_owners_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_owners_group?.value[0]?.group_name}}</span></span>\n <button *ngIf=\"controls?.program_owners_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"group.popover()\" placement=\"right\">+{{controls?.program_owners_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'COLLABORATORS'\"\n [class.disabled]=\"controls?.all_user_in_role?.value\"\n (click)=\"activateList('COLLABORATORS')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i>Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #owner [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"let owner of controls?.collaborators?.value | slice : 1\"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n\n class=\"icons\"\n (click)=\"remove(owner, 'COLLABORATORS')\"\n >&#xe90d;</i\n >\n {{ owner?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #group [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let owner of controls?.collaborators_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n class=\"icons\"\n (click)=\"remove(owner, 'COLLABORATORS_GROUP')\"\n >&#xe90d;</i\n >\n {{ owner?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field>\n\n <!-- Performance Calculated -->\n <!-- <form-field [checked]=\"controls?.performance_calculation?.value\" [active]=\"activeList === 'PERFORMANCE'\" [disabled]=\"sideElements.includes(activeList) && activeList !== 'PERFORMANCE'\"\n [img]=\"'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/performance-calc.svg'\">\n <label class=\"vx-control-panel\">HOW SHOULD THE PERFORMANCE OF THIS PROGRAM BE CALCULATED?</label>\n <tab-selector formControlName=\"performance_calculation\" [displayArray]=\"constants?.performanceCalculation\">\n </tab-selector>\n </form-field> -->\n <ng-container *ngIf=\"isProgramScope && false\">\n <div\n class=\"scope-label vx-fs-10 vx-txt-white vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mb-5 vx-lh-4 vx-d-inline-block\"\n >\n PROGRAM SCOPE\n </div>\n <!-- <i class=\"icons info-icon vx-fs-12 vx-txt-blue vx-ml-1\" [appTooltip]=\"tooltip.programScope\" placement=\"bottom\" delay=\"0\" type=\"white\" [tooltipMandatory]=\"true\">&#xe91f;</i> -->\n <span\n class=\"icon info-icon vx-fs-12 vx-txt-blue vx-ml-1\"\n *ngIf=\"toolTipData.programScop !== ''\"\n libPopoverHover\n (mouseover)=\"dataTooltip.popover()\"\n (mouseleave)=\"dataTooltip.closePopover()\"\n placement=\"right\"\n ><i class=\"icons\">&#xe91f;</i></span\n >\n <popover-hover #dataTooltip>\n <div class=\"vx-info-card\">\n <div\n class=\"vx-info-card-body\"\n [innerHTML]=\"toolTipData.programScope\"\n id=\"PSHelpText\"\n ></div>\n </div>\n </popover-hover>\n </ng-container>\n\n <!-- Program Frequency -->\n <form-field\n *ngIf=\"additionalOption?.PROGRAM_FREQUENCY\"\n [checked]=\"[true, false].includes(controls?.recurring_frequency?.value)\"\n [active]=\"activeList === 'FREQUENCY'\"\n [disabled]=\"\n sideElements.includes(activeList) && activeList !== 'FREQUENCY'\n \"\n [img]=\"ASSETS.recurring\"\n >\n <label class=\"vx-control-panel\" id=\"PDChange\"\n >PROGRAM DURATION\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Program Duration refers to the duration of the Program. A Program can occur in perpetuity, or it can occur until the end of the current business cycle that has been specified in ' +\n businessCycle.selectedCycle.business_cycle +\n '. All responsibilities linked with that Program will also have the same Program Duration.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"ProgramDurationHelpText\"\n >&#xeb16;</i\n ></label\n >\n <div class=\"upload-format\">\n <div class=\"vx-d-flex vx-align-center vx-justify-between\">\n <span class=\"text vx-mb-0\">Is this program recurring?</span>\n <div class=\"radio-group program\">\n <app-cs-radio\n [name]=\"'recurring_frequency'\"\n [checked]=\"controls?.recurring_frequency?.value\"\n (checkedEvent)=\"setFormField('recurring_frequency', true)\"\n >YES</app-cs-radio\n >\n <app-cs-radio\n [name]=\"'recurring_frequency'\"\n [checked]=\"!controls?.recurring_frequency?.value\"\n (checkedEvent)=\"setFormField('recurring_frequency', false)\"\n >NO</app-cs-radio\n >\n </div>\n </div>\n </div>\n </form-field>\n\n <!-- Scope Changes -->\n <form-field\n *ngIf=\"additionalOption?.SCOPE_CHANGES\"\n [checked]=\"[true, false].includes(controls?.lock_scope_change?.value)\"\n [active]=\"activeList === 'SCOPE'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'SCOPE'\"\n [img]=\"ASSETS.lock_scope\"\n >\n <label class=\"vx-control-panel\"\n >Lock the Program Scope\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If the Program Scope is locked, neither the Program nor the responsibilities linked with the Program can be edited once the Program begins. In order to edit the Program or the linked responsibilities, the Program details will need to be edited.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"ScopeChangesHelpText\"\n >&#xeb16;</i\n ></label\n >\n <div class=\"upload-format\">\n <span class=\"text\"\n >Would you like to\n <span class=\"vx-label-txt vx-fw-500\">lock changes</span> to the\n program scope?</span\n >\n <div class=\"radio-group program\">\n <app-cs-radio\n [name]=\"'lock_scope_change'\"\n [checked]=\"controls?.lock_scope_change?.value\"\n (checkedEvent)=\"setFormField('lock_scope_change', true)\"\n >YES</app-cs-radio\n >\n <app-cs-radio\n [name]=\"'lock_scope_change'\"\n [checked]=\"!controls?.lock_scope_change?.value\"\n (checkedEvent)=\"setFormField('lock_scope_change', false)\"\n >NO</app-cs-radio\n >\n </div>\n </div>\n </form-field>\n\n <!-- Framework -->\n <!-- <form-field [checked]=\"false\" [active]=\"activeList === 'FRAMEWORK'\" [disabled]=\"sideElements.includes(activeList) && activeList !== 'FRAMEWORK'\"\n [img]=\"'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/category.svg'\">\n <label class=\"vx-control-panel\">FRAMEWORK</label>\n <input-with-pill [placeholder]=\"'Select a framework that this Program relates to'\" (select)=\"activateList('FRAMEWORK')\">\n <div class=\"selected\" *ngIf=\"controls?.framework?.value?.framework_name\">\n <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i (click)=\"remove(controls?.framework.value,'FRAMEWORK')\" class=\"icons\">&#xe90d;</i>{{controls?.framework?.value?.framework_name}}</span>\n <button class=\"count\" appPopover (click)=\"framework.popover()\" placement=\"right\">+5</button>\n </div>\n </div>\n <button *ngIf=\"activeList!=='FRAMEWORK'\" (click)=\"activateList('FRAMEWORK')\" class=\"edit\" type=\"button\"><i class=\"icons\">&#xe9ba;</i> Edit</button>\n </div>\n </input-with-pill>\n <app-popover #framework [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i class=\"icons\">&#xe90d;</i>\n Manage framework name\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field> -->\n\n <!-- Responsibility Center -->\n <form-field\n *ngIf=\"additionalOption?.RC\"\n [checked]=\"controls?.rc?.value?.length\"\n [active]=\"activeList === 'RC'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'RC'\"\n [img]=\"ASSETS.responsibility_center\"\n >\n <label class=\"vx-control-panel\"\n >RESPONSIBILITY CENTER\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Responsibility Centers represent your organizational and operational infrastructure. Where Responsibility Centers are selected when creating a Program, only those Responsibilities Centers will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"RCHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n (select)=\"activateList('RC')\"\n [placeholder]=\"\n 'Which Responsibility Center(s) can be linked to the responsibilities associated with this Program?'\n \"\n >\n <div\n class=\"selected\"\n *ngIf=\"controls?.rc?.value && controls?.rc?.value?.length\"\n >\n <div class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\">\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"remove(controls?.rc?.value[0], 'RC')\"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.rc?.value[0]?.item_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.rc?.value[0]?.item_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"rc.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.rc?.value?.length > 1\"\n >\n +{{ controls?.rc?.value?.length - 1 }}\n </button>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i class=\"icons\" (click)=\"remove(controls?.rc?.value[0],'RC')\">&#xe90d;</i>{{controls?.rc?.value[0]?.item_name}}</span>\n <button *ngIf=\"controls?.rc?.value?.length > 1\" class=\"count\" appPopover (click)=\"rc.popover()\" placement=\"right\">+{{controls?.rc?.value?.length -1 }}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'RC'\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('RC')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #rc [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"let rc of controls?.rc?.value | slice : 1\">\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i class=\"icons\" (click)=\"remove(rc, 'RC')\">&#xe90d;</i>\n {{ rc?.item_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field>\n\n <!-- Assignee -->\n <form-field\n *ngIf=\"additionalOption?.ASSIGNEES\"\n [checked]=\"\n controls?.program_assignee?.value?.length ||\n controls?.program_default_assignee?.value?.length ||\n controls?.program_default_assignee?.value?.length ||\n controls?.program_default_assignee_group?.value?.length\n \"\n [active]=\"['ASSIGNEE', 'DEFAULT_ASSIGNEE']?.includes(activeList)\"\n [disabled]=\"\n sideElements?.includes(activeList) &&\n !['ASSIGNEE', 'DEFAULT_ASSIGNEE'].includes(activeList)\n \"\n [img]=\"ASSETS.case_assignees\"\n >\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"activeList === 'DEFAULT_ASSIGNEE'\"\n >ASSIGNEES\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Assignees are required to complete the responsibilities that have been assigned to them. Where Assignees are selected when creating a Program, only those Assignees will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"AssigneeHelpText\"\n >&#xeb16;</i\n >\n </label>\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'DEFAULT_ASSIGNEE'\"\n [placeholder]=\"\n 'Who is responsible for completing the responsibilities within this Program?'\n \"\n (select)=\"activateList('ASSIGNEE')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_assignee?.value?.length ||\n controls?.program_assignee_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_assignee?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(controls?.program_assignee?.value[0], 'ASSIGNEE')\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_assignee?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_assignee?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"assignee.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_assignee?.value?.length > 1\"\n >\n +{{ controls?.program_assignee?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_assignee_group?.value?.length &&\n controls?.program_assignee?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_assignee_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_assignee_group?.value[0],\n 'ASSIGNEE_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_assignee_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_assignee_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"assignee_group.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_assignee_group?.value?.length > 1\"\n >\n +{{ controls?.program_assignee_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_assignee?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_assignee?.value[0],'ASSIGNEE')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_assignee?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_assignee?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_assignee?.value?.length > 1\" class=\"count user\" appPopover (click)=\"assignee.popover()\" placement=\"right\">+{{controls?.program_assignee?.value?.length -1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_assignee_group?.value?.length && controls?.program_assignee?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_assignee_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_assignee_group?.value[0],'ASSIGNEE_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_assignee_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_assignee_group?.value[0]?.group_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_assignee_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"assignee_group.popover()\" placement=\"right\">+{{controls?.program_assignee_group?.value?.length -1 }}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'ASSIGNEE'\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('ASSIGNEE')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #assignee [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let assignee of controls?.program_assignee?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(assignee, 'ASSIGNEE')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ assignee?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #assignee_group [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_assignee_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(group, 'ASSIGNEE_GROUP')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"activeList === 'ASSIGNEE'\"\n >DEFAULT ASSIGNEE\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'This option lets you specify the Default Assignees for all new responsibilities linked with a Program. If a Default Assignees is selected, the user will automatically be selected the Assignee when creating a responsibility linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility. '\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"DAHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'ASSIGNEE'\"\n [placeholder]=\"\n 'Which persons will be selected as the default assignees for the responsibilities within this Program?'\n \"\n (select)=\"activateList('DEFAULT_ASSIGNEE')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_assignee?.value?.length ||\n controls?.program_default_assignee_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_assignee?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_assignee?.value[0],\n 'DEFAULT_ASSIGNEE'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_assignee?.value[0]?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_assignee?.value[0]?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultAssignee.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_default_assignee?.value?.length > 1\"\n >\n +{{ controls?.program_default_assignee?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_default_assignee_group?.value?.length &&\n controls?.program_default_assignee?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_assignee_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_assignee_group?.value[0],\n 'DEFAULT_ASSIGNEE_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_assignee_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_assignee_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultAssigneeGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_assignee_group?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_assignee_group?.value?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_assignee?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_assignee?.value[0],'DEFAULT_ASSIGNEE')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_assignee?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{ controls?.program_default_assignee?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_assignee?.value?.length > 1\" class=\"count user\" appPopover (click)=\"defaultAssignee.popover()\" placement=\"right\">+{{controls?.program_default_assignee?.value?.length - 1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_default_assignee_group?.value?.length && controls?.program_default_assignee?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_assignee_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_assignee_group?.value[0],'DEFAULT_ASSIGNEE_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_assignee_group?.value[0]?.group_name }}</span>\n </span>\n <button *ngIf=\"controls?.program_default_assignee_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"defaultAssigneeGroup.popover()\" placement=\"right\">+{{controls?.program_default_assignee_group?.value?.length -1 }}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_ASSIGNEE'\"\n (click)=\"activateList('DEFAULT_ASSIGNEE')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #defaultAssignee [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let assignee of controls?.program_default_assignee?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(assignee, 'DEFAULT_ASSIGNEE')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ assignee?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #defaultAssigneeGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_assignee_group?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(assignee, 'DEFAULT_ASSIGNEE_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <div\n class=\"radio-group-selector\"\n [class.disabled]=\"activeList === 'ASSIGNEE'\"\n >\n <app-cs-radio\n [name]=\"'assignee'\"\n [checked]=\"controls?.assignee_completion_criteria?.value === 'ALL'\"\n (checkedEvent)=\"setFormField('assignee_completion_criteria', 'ALL')\"\n >\n ALL SELECTED PERSONS NEED TO COMPLETE THIS\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If selected, separate responsibilities will be created for each person.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n <app-cs-radio\n [name]=\"'assignee'\"\n [checked]=\"controls?.assignee_completion_criteria?.value === 'ANYONE'\"\n (checkedEvent)=\"\n setFormField('assignee_completion_criteria', 'ANYONE')\n \"\n >\n ANY SELECTED PERSON CAN COMPLETE THIS\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If selected, only one responsibility will be created.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n </div>\n </form-field>\n\n <!-- Reviewer -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.REVIEWER\"\n [checked]=\"\n controls?.program_reviewer?.value?.length ||\n controls?.program_default_reviewer?.value?.length ||\n controls?.program_default_reviewer?.value?.length ||\n controls?.program_default_reviewer_group?.value?.length\n \"\n [active]=\"['REVIEWER', 'DEFAULT_REVIEWER']?.includes(activeList)\"\n [disabled]=\"\n sideElements?.includes(activeList) &&\n !['REVIEWER', 'DEFAULT_REVIEWER'].includes(activeList)\n \"\n [img]=\"ASSETS.reviewer\"\n >\n <label\n [class.disabled]=\"activeList === 'DEFAULT_REVIEWER'\"\n class=\"vx-control-panel\"\n >Reviewers\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Reviewers are required to review responsibilities after they have been completed. Where Reviewers are selected when creating a Program, only those Reviewers will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"ReviewerHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'DEFAULT_REVIEWER'\"\n [placeholder]=\"\n 'Who is responsible for reviewing the responsibilities within this Program?'\n \"\n (select)=\"activateList('REVIEWER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_reviewer?.value?.length ||\n controls?.program_reviewer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_reviewer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(controls?.program_reviewer?.value[0], 'REVIEWER')\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_reviewer?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_reviewer?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"reviewer.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_reviewer?.value?.length > 1\"\n >\n +{{ controls?.program_reviewer?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_reviewer_group?.value?.length &&\n controls?.program_reviewer?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_reviewer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_reviewer_group?.value[0],\n 'REVIEWER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_reviewer_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_reviewer_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"reviewerGroup.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_reviewer_group?.value?.length > 1\"\n >\n +{{ controls?.program_reviewer_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_reviewer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_reviewer?.value[0],'REVIEWER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_reviewer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_reviewer?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_reviewer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"reviewer.popover()\" placement=\"right\">+{{controls?.program_reviewer?.value?.length -1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_reviewer_group?.value?.length && controls?.program_reviewer?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_reviewer_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_reviewer_group?.value[0],'REVIEWER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_reviewer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_reviewer_group?.value[0]?.group_name}}\n </span>\n </span>\n <button *ngIf=\"controls?.program_reviewer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"reviewerGroup.popover()\" placement=\"right\">+{{controls?.program_reviewer_group?.value?.length - 1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'REVIEWER'\"\n (click)=\"activateList('REVIEWER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #reviewer [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let reviewer of controls?.program_reviewer?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(reviewer, 'REVIEWER')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ reviewer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #reviewerGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_reviewer_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(group, 'REVIEWER_GROUP')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <label\n [class.disabled]=\"activeList === 'REVIEWER'\"\n class=\"vx-control-panel\"\n >DEFAULT Reviewer\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'This option lets you specify the Default Reviewers for responsibilities linked with a Program. Where a user has been specified as a Default Reviewer, that user will automatically be selected as the Reviewer when creating a responsibility linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"DRHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'REVIEWER'\"\n [placeholder]=\"\n 'Which persons will be selected as the default reviewers for the responsibilities within this Program?'\n \"\n (select)=\"activateList('DEFAULT_REVIEWER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_reviewer?.value?.length ||\n controls?.program_default_reviewer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_reviewer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_reviewer?.value[0],\n 'DEFAULT_REVIEWER'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_reviewer?.value[0]?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_reviewer?.value[0]?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultReviewer.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_default_reviewer?.value?.length > 1\"\n >\n +{{ controls?.program_default_reviewer?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_default_reviewer_group?.value?.length &&\n controls?.program_default_reviewer?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_reviewer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_reviewer_group?.value[0],\n 'DEFAULT_REVIEWER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_reviewer_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_reviewer_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultReviewerGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_reviewer_group?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_reviewer_group?.value?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_reviewer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_reviewer?.value[0],'DEFAULT_REVIEWER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_reviewer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_reviewer?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_reviewer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"defaultReviewer.popover()\" placement=\"right\">+{{controls?.program_default_reviewer?.value?.length - 1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_default_reviewer_group?.value?.length && controls?.program_default_reviewer?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_reviewer_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_reviewer_group?.value[0],'DEFAULT_REVIEWER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_reviewer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_reviewer_group?.value[0]?.group_name}}\n </span>\n </span>\n <button *ngIf=\"controls?.program_default_reviewer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"defaultReviewerGroup.popover()\" placement=\"right\">+{{controls?.program_default_reviewer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_REVIEWER'\"\n (click)=\"activateList('DEFAULT_REVIEWER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #defaultReviewer [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let reviewer of controls?.program_default_reviewer?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(reviewer, 'DEFAULT_REVIEWER')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ reviewer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #defaultReviewerGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_reviewer_group?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(group, 'DEFAULT_REVIEWER_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <div\n class=\"radio-group-selector\"\n [class.disabled]=\"activeList === 'REVIEWER'\"\n >\n <app-cs-radio\n [name]=\"'reviewer'\"\n [checked]=\"\n controls?.reviewer_completion_criteria?.value === 'SEQUENTIAL'\n \"\n (checkedEvent)=\"\n setFormField('reviewer_completion_criteria', 'SEQUENTIAL')\n \"\n [class.disabled]=\"\n controls?.program_default_reviewer_group?.value?.length > 0\n \"\n >\n SEQUENTIAL\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'The responsibility will be sent for review one at a time in the sequence defined by you.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n <app-cs-radio\n [name]=\"'reviewer'\"\n [checked]=\"\n controls?.reviewer_completion_criteria?.value === 'ANYONE' ||\n controls?.program_default_reviewer_group?.value?.length > 0\n \"\n (checkedEvent)=\"\n setFormField('reviewer_completion_criteria', 'ANYONE')\n \"\n >\n ANY REVIEWER CAN MARK THIS AS REVIEWED\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'The responsibility will be sent for review to all reviewers at the same time. If anyone of the reviewer reviews the responsibility, it will be considered as reviewed.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n </div>\n </form-field>\n\n <!-- Overseer -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.OVERSEER\"\n [checked]=\"\n controls?.program_overseer?.value?.length ||\n controls?.program_default_overseer?.value?.length ||\n controls?.program_default_overseer?.value?.length ||\n controls?.program_default_overseer_group?.value?.length\n \"\n [active]=\"activeList === 'OVERSEER'\"\n [disabled]=\"\n sideElements?.includes(activeList) &&\n !['OVERSEER', 'DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(\n activeList\n )\n \"\n [img]=\"ASSETS.oversight\"\n >\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"\n ['DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n \"\n >Oversights\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Oversights receive updates when a responsibility is completed, completed with delay or not completed. Where Oversights are selected when creating a Program, only those Oversights will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"overseerHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"\n ['DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n \"\n [placeholder]=\"\n 'Who is responsible for overseeing the responsibilities within this Program?'\n \"\n (select)=\"activateList('OVERSEER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_overseer?.value?.length ||\n controls?.program_overseer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_overseer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(controls?.program_overseer?.value[0], 'OVERSEER')\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_overseer?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_overseer?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseers.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_overseer?.value?.length > 1\"\n >\n +{{ controls?.program_overseer?.value?.length - 1 }}\n </button>\n </div>\n <span\n *ngIf=\"\n controls?.program_overseer_group?.value?.length &&\n controls?.program_overseer?.value?.length\n \"\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_overseer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_overseer_group?.value[0],\n 'OVERSEER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_overseer_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_overseer_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseerGroup.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_overseer_group?.value?.length > 1\"\n >\n +{{ controls?.program_overseer_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_overseer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_overseer?.value[0],'OVERSEER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_overseer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">\n {{controls?.program_overseer?.value[0]?.member_name}}\n </span>\n </span>\n <button *ngIf=\"controls?.program_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseers.popover()\" placement=\"right\">+{{controls?.program_overseer?.value?.length -1}}</button>\n </div>\n <span *ngIf=\"controls?.program_overseer_group?.value?.length && controls?.program_overseer?.value?.length \" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_overseer_group?.value?.length \">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_overseer_group?.value[0],'OVERSEER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_overseer_group?.value[0]?.group_name}}</span></span>\n <button *ngIf=\"controls?.program_overseer_group?.value?.length> 1\" class=\"count\" appPopover (click)=\"overseerGroup.popover()\" placement=\"right\">+{{controls?.program_overseer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n\n <button\n *ngIf=\"activeList !== 'OVERSEER'\"\n (click)=\"activateList('OVERSEER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #overseers [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let overseer of controls?.program_overseer?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i class=\"icons\" (click)=\"remove(overseer, 'OVERSEER')\"\n >&#xe90d;</i\n >\n {{ overseer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #overseerGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_overseer_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(group, 'OVERSEER_GROUP')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <ng-container [class.disabled]=\"activeList === 'OVERSEER'\">\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"['OVERSEER'].includes(activeList)\"\n >DEFAULT Oversight\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'This option lets you specify the Default Oversight for responsibilities linked with a Program. Where a user has been specified as a Default Oversight, that user will automatically be selected as the Oversight when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"DOHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [disabled]=\"\n ['OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n \"\n [selectDiv]=\"true\"\n [placeholder]=\"\n 'Which persons will be selected as the default overseers for the responsibilities within this Program?'\n \"\n (select)=\"activateList('DEFAULT_OVERSEER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_overseer?.value?.length ||\n controls?.program_default_overseer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_overseer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_overseer?.value[0],\n 'DEFAULT_OVERSEER'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_overseer?.value[0]?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_overseer?.value[0]?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseersDefault.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_default_overseer?.value?.length > 1\"\n >\n +{{ controls?.program_default_overseer?.value?.length - 1 }}\n </button>\n </div>\n <span\n *ngIf=\"\n controls?.program_default_overseer_group?.value?.length &&\n controls?.program_default_overseer?.value?.length\n \"\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_overseer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_overseer_group?.value[0],\n 'DEFAULT_OVERSEER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_overseer_group?.value[0]\n ?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_overseer_group?.value[0]\n ?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseerDefaultGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_overseer_group?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_overseer_group?.value?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_overseer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_overseer?.value[0],'DEFAULT_OVERSEER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_overseer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_overseer?.value[0]?.member_name}}</span></span>\n <button *ngIf=\"controls?.program_default_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseersDefault.popover()\" placement=\"right\">+{{controls?.program_default_overseer?.value?.length -1}}</button>\n </div>\n <span *ngIf=\"controls?.program_default_overseer_group?.value?.length && controls?.program_default_overseer?.value?.length\" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_overseer_group?.value?.length \">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_overseer_group?.value[0],'DEFAULT_OVERSEER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_overseer_group?.value[0]?.group_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_overseer_group?.value?.length >1\" class=\"count\" appPopover (click)=\"overseerDefaultGroup.popover()\" placement=\"right\">+{{controls?.program_default_overseer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_OVERSEER'\"\n (click)=\"activateList('DEFAULT_OVERSEER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #overseersDefault [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let overseer of controls?.program_default_overseer?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n class=\"icons\"\n (click)=\"remove(overseer, 'DEFAULT_OVERSEER')\"\n >&#xe90d;</i\n >\n {{ overseer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #overseerDefaultGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_overseer_group?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(group, 'DEFAULT_OVERSEER_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <label class=\"vx-control-panel\"> </label>\n <input-with-pill\n class=\"vx-mt-2\"\n [selectDiv]=\"true\"\n [line]=\"3\"\n [disabled]=\"['OVERSEER', 'DEFAULT_OVERSEER'].includes(activeList)\"\n [placeholder]=\"\n 'Which persons will be selected as the default overseers for responsibilities that are not completed within this Program?'\n \"\n (select)=\"activateList('DEFAULT_FAILED_OVERSEER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_failed_overseer?.value?.length ||\n controls?.program_default_failed_overseer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_failed_overseer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_failed_overseer?.value[0],\n 'DEFAULT_FAILED_OVERSEER'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_failed_overseer?.value[0]\n ?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_failed_overseer?.value[0]\n ?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseersDefaultFail.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_failed_overseer?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_failed_overseer?.value?.length - 1\n }}\n </button>\n </div>\n <span\n *ngIf=\"\n controls?.program_default_failed_overseer_group?.value\n ?.length &&\n controls?.program_default_failed_overseer?.value?.length\n \"\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"\n controls?.program_default_failed_overseer_group?.value?.length\n \"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_failed_overseer_group?.value[0],\n 'DEFAULT_FAILED_OVERSEER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_failed_overseer_group?.value[0]\n ?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_failed_overseer_group?.value[0]\n ?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseerDefaultFailGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_failed_overseer_group?.value\n ?.length > 1\n \"\n >\n +{{\n controls?.program_default_failed_overseer_group?.value\n ?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_failed_overseer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_failed_overseer?.value[0],'DEFAULT_FAILED_OVERSEER')\" >&#xe90d;</i>\n <span class=\"chip\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_failed_overseer?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_failed_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseersDefaultFail.popover()\" placement=\"right\">+{{controls?.program_default_failed_overseer?.value?.length -1}}</button>\n </div>\n <span *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length && controls?.program_default_failed_overseer?.value?.length\" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length \">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_failed_overseer_group?.value[0],'DEFAULT_FAILED_OVERSEER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_failed_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_failed_overseer_group?.value[0]?.group_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"overseerDefaultFailGroup.popover()\" placement=\"right\">+{{controls?.program_default_failed_overseer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_FAILED_OVERSEER'\"\n (click)=\"activateList('DEFAULT_FAILED_OVERSEER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #overseersDefaultFail [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let overseer of controls?.program_default_failed_overseer\n ?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n class=\"icons\"\n (click)=\"remove(overseer, 'DEFAULT_FAILED_OVERSEER')\"\n >&#xe90d;</i\n >\n {{ overseer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #overseerDefaultFailGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_failed_overseer_group\n ?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(group, 'DEFAULT_FAILED_OVERSEER_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </ng-container>\n </form-field>\n\n <!-- Assessment -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.ASSESSMENT\"\n [checked]=\"controls?.program_assessments?.value?.length\"\n [active]=\"activeList === 'ASSESSMENT'\"\n [disabled]=\"\n sideElements.includes(activeList) && activeList !== 'ASSESSMENT'\n \"\n [img]=\"ASSETS.assessments\"\n >\n <label class=\"vx-control-panel\"\n >ASSESSMENTS\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Assessments are a digital form that are created in \u201CAssessment\u201D within the Compliance Module. Where Assessments are selected when creating a Program, only those Assessments will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"AssessmentHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [placeholder]=\"\n 'Which assessments can be linked to the responsibilities within this Program?'\n \"\n (select)=\"activateList('ASSESSMENT')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"controls?.program_assessments?.value?.length\"\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"\n controls?.program_assessments?.value\n | assessmentResolver as assessments\n \"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"remove(assessments[0], 'ASSESSMENT')\"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"assessments[0]?.assessment_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ assessments[0]?.assessment_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"program_assessments.popover()\"\n placement=\"right\"\n *ngIf=\"assessments?.length > 1\"\n >\n +{{ assessments?.length - 1 }}\n </button>\n </div>\n\n <!-- <div class=\"chip-container\">\n <ng-container *ngIf=\"(controls?.program_assessments?.value | assessmentResolver) as assessments\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i class=\"icons\" (click)=\"remove(assessments[0],'ASSESSMENT')\">&#xe90d;</i>{{assessments[0]?.assessment_name}} </span>\n <button *ngIf=\"assessments?.length > 1\" class=\"count\" appPopover (click)=\"program_assessments.popover()\" placement=\"right\">+{{assessments?.length -1 }}</button>\n </div>\n </ng-container>\n </div> -->\n <button\n *ngIf=\"activeList !== 'ASSESSMENT'\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('ASSESSMENT')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #program_assessments [dontCloseonClick]=\"true\">\n <ng-container>\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let assessment of controls?.program_assessments?.value\n | assessmentResolver\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(assessment, 'ASSESSMENT')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ assessment?.assessment_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </ng-container>\n </app-popover>\n </form-field>\n\n <!-- Format & Evidence -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.FORMATE_EVIDENCE\"\n [checked]=\"[true, false].includes(controls?.evidence_required?.value)\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.format_evidence\"\n >\n <label class=\"vx-control-panel\"\n >Evidence\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If selected, evidence of completion of a responsibility will be required for all responsibilities that are linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"EvidenceHelpText\"\n >&#xeb16;</i\n ></label\n >\n <div class=\"upload-format\">\n <span class=\"text\"\n >Do all responsibilities within this program require evidence?</span\n >\n <div class=\"radio-group program\">\n <app-cs-radio\n [name]=\"'evidence_required'\"\n [checked]=\"controls?.evidence_required?.value\"\n (checkedEvent)=\"setFormField('evidence_required', true)\"\n >YES</app-cs-radio\n >\n <app-cs-radio\n [name]=\"'evidence_required'\"\n [checked]=\"!controls?.evidence_required?.value\"\n (checkedEvent)=\"setFormField('evidence_required', false)\"\n >NO</app-cs-radio\n >\n </div>\n </div>\n <!-- <div class=\"vx-d-flex vx-align-center vx-justify-end vx-mt-2\">\n <div class=\"vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase vx-mr-2\">Allow any file to be marked as\n key\n evidence</div>\n <switch formControlName=\"allow_any_file_key_evidence\"\n (change)=\"setFormField('allow_any_file_key_evidence',$event?.target?.checked)\"></switch>\n </div> -->\n </form-field>\n\n <!-- Custom Field -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.CUSTOM_FIELDS\"\n [checked]=\"controls?.custom_fields?.value?.length\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.custom_fields\"\n >\n <label class=\"vx-control-panel\"\n >CUSTOM FIELD\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Where a custom field is specified, all responsibilities linked with a Program will contain that custom field. Custom fields enable the collection of additional meta data.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"CFHelpText\"\n >&#xeb16;</i\n ></label\n >\n <custom-field formControlName=\"custom_fields\"></custom-field>\n </form-field>\n </form>\n</div>\n\n<!-- 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 >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.framework.value?.name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.framework.value?.name }}</span\n >\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i (click)=\"remove('', 'FRAMEWORK')\" *ngIf=\"canFrameworkChange\" class=\"icons\" >&#xe90d;</i> {{controls?.framework.value?.name}}</span>\n </div>\n </div> -->\n <button\n *ngIf=\"canFrameworkChange\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('FRAMEWORK')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n </form-field>\n\n <!-- Program Category Name -->\n <form-field\n [checked]=\"controls?.program_name?.value?.trim()?.length\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.what\"\n >\n <label class=\"vx-control-panel\"\n >PROGRAM NAME <span class=\"required\">*</span></label\n >\n <input\n InputTrim\n formControlName=\"program_name\"\n type=\"text\"\n placeholder=\"What is the Program name?\"\n />\n\n <p\n *ngIf=\"\n controls?.program_name?.errors && controls?.program_name?.touched\n \"\n class=\"error-message\"\n >\n Enter a name for this Program.\n </p>\n <p *ngIf=\"isNameExists\" class=\"error-message\">\n Program name already exists.\n </p>\n <vcomply-editor\n [(ngModel)]=\"editorData.programObjective\"\n [ngModelOptions]=\"{ standalone: true }\"\n (sendSavedFiles)=\"selectFile('OBJECTIVE', $event)\"\n (ngModelChange)=\"setFormField('program_objective', $event, true)\"\n [editorConfig]=\"constants?.description\"\n >\n </vcomply-editor>\n </form-field>\n\n\n\n <!-- Owners -->\n <form-field\n *ngIf=\"additionalOption?.OWNERS\"\n [checked]=\"\n controls?.program_owners?.value?.length > 0 ||\n controls?.program_owners_group?.value?.length > 0\n \"\n [active]=\"activeList === 'OWNER'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'OWNER'\"\n [img]=\"ASSETS.case_owners\"\n >\n <label class=\"vx-control-panel\"\n >OWNER(S) <span class=\"required\">*</span>\n <span\n class=\"icon\"\n *ngIf=\"toolTipData.owner !== ''\"\n libPopoverHover\n (mouseover)=\"dataTooltip.popover()\"\n (mouseleave)=\"dataTooltip.closePopover()\"\n placement=\"right\"\n ><i class=\"icons\">&#xe91f;</i></span\n >\n <popover-hover #dataTooltip>\n <div class=\"vx-info-card\">\n <div\n class=\"vx-info-card-body\"\n [innerHTML]=\"toolTipData.owner\"\n id=\"OwnerHelpText\"\n ></div>\n </div>\n </popover-hover>\n </label>\n <input-with-pill\n [placeholder]=\"'Who is responsible for managing this program?'\"\n (select)=\"activateList('OWNER')\"\n >\n <div class=\"selected\" *ngIf=\"controls?.program_owners?.value[0]\">\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_owners?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_owners?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4 greenBg\"\n appPopover\n (click)=\"owner.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_owners?.value?.length > 1\"\n >\n +{{ controls?.program_owners?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_owners_group?.value?.length &&\n controls?.program_owners?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_owners_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n (click)=\"\n remove(\n controls?.program_owners_group?.value[0],\n 'OWNER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_owners_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_owners_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"group.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_owners_group?.value?.length > 1\"\n >\n +{{ controls?.program_owners_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n <button\n *ngIf=\"activeList !== 'OWNER'\"\n [class.disabled]=\"controls?.all_user_in_role?.value\"\n (click)=\"activateList('OWNER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i>Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #owner [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"let owner of controls?.program_owners?.value | slice : 1\"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"\n !(\n lists.NON_REMOVABLE_OWNERS | listToId : 'member_id'\n ).includes(owner?.member_id)\n \"\n class=\"icons\"\n (click)=\"remove(owner, 'OWNER')\"\n >&#xe90d;</i\n >\n {{ owner?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #group [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let owner of controls?.program_owners_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n class=\"icons\"\n (click)=\"remove(owner, 'OWNER_GROUP')\"\n >&#xe90d;</i\n >\n {{ owner?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field>\n\n <!-- Collaborators -->\n <form-field\n *ngIf=\"additionalOption?.COLLABORATORS\"\n [checked]=\"\n controls?.collaborators?.value?.length > 0 ||\n controls?.collaborators_group?.value?.length > 0\n \"\n [active]=\"activeList === 'COLLABORATORS'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'COLLABORATORS'\"\n [img]=\"\n 'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/owner.svg'\n \"\n >\n <label class=\"vx-control-panel\"\n >COLLABORATORS \n <span\n class=\"icon\"\n *ngIf=\"toolTipData.collaborators !== ''\"\n libPopoverHover\n (mouseover)=\"dataTooltip.popover()\"\n (mouseleave)=\"dataTooltip.closePopover()\"\n placement=\"right\"\n ><i class=\"icons\">&#xe91f;</i></span\n >\n <popover-hover #dataTooltip>\n <div class=\"vx-info-card\">\n <div\n class=\"vx-info-card-body\"\n [innerHTML]=\"toolTipData.collaborators\"\n id=\"CollaboratorsHelpText\"\n ></div>\n </div>\n </popover-hover>\n </label>\n <input-with-pill\n [placeholder]=\"'Who is responsible for managing this program?'\"\n (select)=\"activateList('COLLABORATORS')\"\n >\n <div class=\"selected\" *ngIf=\"controls?.collaborators?.value[0] || controls?.collaborators_group?.value[0]\">\n <div class=\"vx-d-flex vx-align-center\">\n <!-- Users -->\n <div \n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.collaborators?.value[0]\"\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.collaborators?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.collaborators?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4 greenBg\"\n appPopover\n (click)=\"owner.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.collaborators?.value?.length > 1\"\n >\n +{{ controls?.collaborators?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\" \n controls?.collaborators_group?.value?.length &&\n controls?.collaborators?.value?.length\n \"\n >&</span\n >\n <!-- Groups -->\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.collaborators_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n (click)=\"\n remove(\n controls?.collaborators_group?.value[0],\n 'COLLABORATORS_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.collaborators_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.collaborators_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"group.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_owners_group?.value?.length > 1\"\n >\n +{{ controls?.collaborators_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\" [appTooltip]=\"controls?.program_owners?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\" >{{controls?.program_owners?.value[0]?.member_name}}</span></span>\n <button *ngIf=\"controls?.program_owners?.value?.length > 1\" class=\"count user\" appPopover (click)=\"owner.popover()\" placement=\"right\">+{{controls?.program_owners?.value?.length -1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_owners_group?.value?.length && controls?.program_owners?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_owners_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" *ngIf=\"!['ADMIN','KEY_ADMIN','LOGGED_IN'].includes(owner?.user_role)\" (click)=\"remove(owner,'OWNER_GROUP')\">&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_owners_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_owners_group?.value[0]?.group_name}}</span></span>\n <button *ngIf=\"controls?.program_owners_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"group.popover()\" placement=\"right\">+{{controls?.program_owners_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'COLLABORATORS'\"\n [class.disabled]=\"controls?.all_user_in_role?.value\"\n (click)=\"activateList('COLLABORATORS')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i>Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #owner [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"let owner of controls?.collaborators?.value | slice : 1\"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n\n class=\"icons\"\n (click)=\"remove(owner, 'COLLABORATORS')\"\n >&#xe90d;</i\n >\n {{ owner?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #group [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let owner of controls?.collaborators_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n *ngIf=\"\n !['ADMIN', 'KEY_ADMIN', 'LOGGED_IN'].includes(\n owner?.user_role\n )\n \"\n class=\"icons\"\n (click)=\"remove(owner, 'COLLABORATORS_GROUP')\"\n >&#xe90d;</i\n >\n {{ owner?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field>\n\n <!-- Performance Calculated -->\n <!-- <form-field [checked]=\"controls?.performance_calculation?.value\" [active]=\"activeList === 'PERFORMANCE'\" [disabled]=\"sideElements.includes(activeList) && activeList !== 'PERFORMANCE'\"\n [img]=\"'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/performance-calc.svg'\">\n <label class=\"vx-control-panel\">HOW SHOULD THE PERFORMANCE OF THIS PROGRAM BE CALCULATED?</label>\n <tab-selector formControlName=\"performance_calculation\" [displayArray]=\"constants?.performanceCalculation\">\n </tab-selector>\n </form-field> -->\n <ng-container *ngIf=\"isProgramScope && false\">\n <div\n class=\"scope-label vx-fs-10 vx-txt-white vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mb-5 vx-lh-4 vx-d-inline-block\"\n >\n PROGRAM SCOPE\n </div>\n <!-- <i class=\"icons info-icon vx-fs-12 vx-txt-blue vx-ml-1\" [appTooltip]=\"tooltip.programScope\" placement=\"bottom\" delay=\"0\" type=\"white\" [tooltipMandatory]=\"true\">&#xe91f;</i> -->\n <span\n class=\"icon info-icon vx-fs-12 vx-txt-blue vx-ml-1\"\n *ngIf=\"toolTipData.programScop !== ''\"\n libPopoverHover\n (mouseover)=\"dataTooltip.popover()\"\n (mouseleave)=\"dataTooltip.closePopover()\"\n placement=\"right\"\n ><i class=\"icons\">&#xe91f;</i></span\n >\n <popover-hover #dataTooltip>\n <div class=\"vx-info-card\">\n <div\n class=\"vx-info-card-body\"\n [innerHTML]=\"toolTipData.programScope\"\n id=\"PSHelpText\"\n ></div>\n </div>\n </popover-hover>\n </ng-container>\n\n <!-- Program Frequency -->\n <form-field\n *ngIf=\"additionalOption?.PROGRAM_FREQUENCY\"\n [checked]=\"[true, false].includes(controls?.recurring_frequency?.value)\"\n [active]=\"activeList === 'FREQUENCY'\"\n [disabled]=\"\n sideElements.includes(activeList) && activeList !== 'FREQUENCY'\n \"\n [img]=\"ASSETS.recurring\"\n >\n <label class=\"vx-control-panel\" id=\"PDChange\"\n >PROGRAM DURATION\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Program Duration refers to the duration of the Program. A Program can occur in perpetuity, or it can occur until the end of the current business cycle that has been specified in ' +\n businessCycle.selectedCycle.business_cycle +\n '. All responsibilities linked with that Program will also have the same Program Duration.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"ProgramDurationHelpText\"\n >&#xeb16;</i\n ></label\n >\n <div class=\"upload-format\">\n <div class=\"vx-d-flex vx-align-center vx-justify-between\">\n <span class=\"text vx-mb-0\">Is this program recurring?</span>\n <div class=\"radio-group program\">\n <app-cs-radio\n [name]=\"'recurring_frequency'\"\n [checked]=\"controls?.recurring_frequency?.value\"\n (checkedEvent)=\"setFormField('recurring_frequency', true)\"\n >YES</app-cs-radio\n >\n <app-cs-radio\n [name]=\"'recurring_frequency'\"\n [checked]=\"!controls?.recurring_frequency?.value\"\n (checkedEvent)=\"setFormField('recurring_frequency', false)\"\n >NO</app-cs-radio\n >\n </div>\n </div>\n </div>\n </form-field>\n\n <!-- Scope Changes -->\n <form-field\n *ngIf=\"additionalOption?.SCOPE_CHANGES\"\n [checked]=\"[true, false].includes(controls?.lock_scope_change?.value)\"\n [active]=\"activeList === 'SCOPE'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'SCOPE'\"\n [img]=\"ASSETS.lock_scope\"\n >\n <label class=\"vx-control-panel\"\n >Lock the Program Scope\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If the Program Scope is locked, neither the Program nor the responsibilities linked with the Program can be edited once the Program begins. In order to edit the Program or the linked responsibilities, the Program details will need to be edited.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"ScopeChangesHelpText\"\n >&#xeb16;</i\n ></label\n >\n <div class=\"upload-format\">\n <span class=\"text\"\n >Would you like to\n <span class=\"vx-label-txt vx-fw-500\">lock changes</span> to the\n program scope?</span\n >\n <div class=\"radio-group program\">\n <app-cs-radio\n [name]=\"'lock_scope_change'\"\n [checked]=\"controls?.lock_scope_change?.value\"\n (checkedEvent)=\"setFormField('lock_scope_change', true)\"\n >YES</app-cs-radio\n >\n <app-cs-radio\n [name]=\"'lock_scope_change'\"\n [checked]=\"!controls?.lock_scope_change?.value\"\n (checkedEvent)=\"setFormField('lock_scope_change', false)\"\n >NO</app-cs-radio\n >\n </div>\n </div>\n </form-field>\n\n <!-- Framework -->\n <!-- <form-field [checked]=\"false\" [active]=\"activeList === 'FRAMEWORK'\" [disabled]=\"sideElements.includes(activeList) && activeList !== 'FRAMEWORK'\"\n [img]=\"'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/category.svg'\">\n <label class=\"vx-control-panel\">FRAMEWORK</label>\n <input-with-pill [placeholder]=\"'Select a framework that this Program relates to'\" (select)=\"activateList('FRAMEWORK')\">\n <div class=\"selected\" *ngIf=\"controls?.framework?.value?.framework_name\">\n <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i (click)=\"remove(controls?.framework.value,'FRAMEWORK')\" class=\"icons\">&#xe90d;</i>{{controls?.framework?.value?.framework_name}}</span>\n <button class=\"count\" appPopover (click)=\"framework.popover()\" placement=\"right\">+5</button>\n </div>\n </div>\n <button *ngIf=\"activeList!=='FRAMEWORK'\" (click)=\"activateList('FRAMEWORK')\" class=\"edit\" type=\"button\"><i class=\"icons\">&#xe9ba;</i> Edit</button>\n </div>\n </input-with-pill>\n <app-popover #framework [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i class=\"icons\">&#xe90d;</i>\n Manage framework name\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field> -->\n\n <!-- Responsibility Center -->\n <form-field\n *ngIf=\"additionalOption?.RC\"\n [checked]=\"controls?.rc?.value?.length\"\n [active]=\"activeList === 'RC'\"\n [disabled]=\"sideElements.includes(activeList) && activeList !== 'RC'\"\n [img]=\"ASSETS.responsibility_center\"\n >\n <label class=\"vx-control-panel\"\n >RESPONSIBILITY CENTER\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Responsibility Centers represent your organizational and operational infrastructure. Where Responsibility Centers are selected when creating a Program, only those Responsibilities Centers will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"RCHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n (select)=\"activateList('RC')\"\n [placeholder]=\"\n 'Which Responsibility Center(s) can be linked to the responsibilities associated with this Program?'\n \"\n >\n <div\n class=\"selected\"\n *ngIf=\"controls?.rc?.value && controls?.rc?.value?.length\"\n >\n <div class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\">\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"remove(controls?.rc?.value[0], 'RC')\"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.rc?.value[0]?.item_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.rc?.value[0]?.item_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"rc.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.rc?.value?.length > 1\"\n >\n +{{ controls?.rc?.value?.length - 1 }}\n </button>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i class=\"icons\" (click)=\"remove(controls?.rc?.value[0],'RC')\">&#xe90d;</i>{{controls?.rc?.value[0]?.item_name}}</span>\n <button *ngIf=\"controls?.rc?.value?.length > 1\" class=\"count\" appPopover (click)=\"rc.popover()\" placement=\"right\">+{{controls?.rc?.value?.length -1 }}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'RC'\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('RC')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #rc [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li *ngFor=\"let rc of controls?.rc?.value | slice : 1\">\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i class=\"icons\" (click)=\"remove(rc, 'RC')\">&#xe90d;</i>\n {{ rc?.item_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </form-field>\n\n <!-- Assignee -->\n <form-field\n *ngIf=\"additionalOption?.ASSIGNEES\"\n [checked]=\"\n controls?.program_assignee?.value?.length ||\n controls?.program_default_assignee?.value?.length ||\n controls?.program_default_assignee?.value?.length ||\n controls?.program_default_assignee_group?.value?.length\n \"\n [active]=\"['ASSIGNEE', 'DEFAULT_ASSIGNEE']?.includes(activeList)\"\n [disabled]=\"\n sideElements?.includes(activeList) &&\n !['ASSIGNEE', 'DEFAULT_ASSIGNEE'].includes(activeList)\n \"\n [img]=\"ASSETS.case_assignees\"\n >\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"activeList === 'DEFAULT_ASSIGNEE'\"\n >ASSIGNEES\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Assignees are required to complete the responsibilities that have been assigned to them. Where Assignees are selected when creating a Program, only those Assignees will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"AssigneeHelpText\"\n >&#xeb16;</i\n >\n </label>\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'DEFAULT_ASSIGNEE'\"\n [placeholder]=\"\n 'Who is responsible for completing the responsibilities within this Program?'\n \"\n (select)=\"activateList('ASSIGNEE')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_assignee?.value?.length ||\n controls?.program_assignee_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_assignee?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(controls?.program_assignee?.value[0], 'ASSIGNEE')\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_assignee?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_assignee?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"assignee.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_assignee?.value?.length > 1\"\n >\n +{{ controls?.program_assignee?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_assignee_group?.value?.length &&\n controls?.program_assignee?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_assignee_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_assignee_group?.value[0],\n 'ASSIGNEE_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_assignee_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_assignee_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"assignee_group.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_assignee_group?.value?.length > 1\"\n >\n +{{ controls?.program_assignee_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_assignee?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_assignee?.value[0],'ASSIGNEE')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_assignee?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_assignee?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_assignee?.value?.length > 1\" class=\"count user\" appPopover (click)=\"assignee.popover()\" placement=\"right\">+{{controls?.program_assignee?.value?.length -1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_assignee_group?.value?.length && controls?.program_assignee?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_assignee_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_assignee_group?.value[0],'ASSIGNEE_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_assignee_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_assignee_group?.value[0]?.group_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_assignee_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"assignee_group.popover()\" placement=\"right\">+{{controls?.program_assignee_group?.value?.length -1 }}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'ASSIGNEE'\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('ASSIGNEE')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #assignee [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let assignee of controls?.program_assignee?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(assignee, 'ASSIGNEE')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ assignee?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #assignee_group [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_assignee_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(group, 'ASSIGNEE_GROUP')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"activeList === 'ASSIGNEE'\"\n >DEFAULT ASSIGNEE\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'This option lets you specify the Default Assignees for all new responsibilities linked with a Program. If a Default Assignees is selected, the user will automatically be selected the Assignee when creating a responsibility linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility. '\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"DAHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'ASSIGNEE'\"\n [placeholder]=\"\n 'Which persons will be selected as the default assignees for the responsibilities within this Program?'\n \"\n (select)=\"activateList('DEFAULT_ASSIGNEE')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_assignee?.value?.length ||\n controls?.program_default_assignee_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_assignee?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_assignee?.value[0],\n 'DEFAULT_ASSIGNEE'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_assignee?.value[0]?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_assignee?.value[0]?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultAssignee.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_default_assignee?.value?.length > 1\"\n >\n +{{ controls?.program_default_assignee?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_default_assignee_group?.value?.length &&\n controls?.program_default_assignee?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_assignee_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_assignee_group?.value[0],\n 'DEFAULT_ASSIGNEE_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_assignee_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_assignee_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultAssigneeGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_assignee_group?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_assignee_group?.value?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_assignee?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_assignee?.value[0],'DEFAULT_ASSIGNEE')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_assignee?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{ controls?.program_default_assignee?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_assignee?.value?.length > 1\" class=\"count user\" appPopover (click)=\"defaultAssignee.popover()\" placement=\"right\">+{{controls?.program_default_assignee?.value?.length - 1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_default_assignee_group?.value?.length && controls?.program_default_assignee?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_assignee_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_assignee_group?.value[0],'DEFAULT_ASSIGNEE_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_assignee_group?.value[0]?.group_name }}</span>\n </span>\n <button *ngIf=\"controls?.program_default_assignee_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"defaultAssigneeGroup.popover()\" placement=\"right\">+{{controls?.program_default_assignee_group?.value?.length -1 }}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_ASSIGNEE'\"\n (click)=\"activateList('DEFAULT_ASSIGNEE')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #defaultAssignee [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let assignee of controls?.program_default_assignee?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(assignee, 'DEFAULT_ASSIGNEE')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ assignee?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #defaultAssigneeGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_assignee_group?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(assignee, 'DEFAULT_ASSIGNEE_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <div\n class=\"radio-group-selector\"\n [class.disabled]=\"activeList === 'ASSIGNEE'\"\n >\n <app-cs-radio\n [name]=\"'assignee'\"\n [checked]=\"controls?.assignee_completion_criteria?.value === 'ALL'\"\n (checkedEvent)=\"setFormField('assignee_completion_criteria', 'ALL')\"\n >\n ALL SELECTED PERSONS NEED TO COMPLETE THIS\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If selected, separate responsibilities will be created for each person.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n <app-cs-radio\n [name]=\"'assignee'\"\n [checked]=\"controls?.assignee_completion_criteria?.value === 'ANYONE'\"\n (checkedEvent)=\"\n setFormField('assignee_completion_criteria', 'ANYONE')\n \"\n >\n ANY SELECTED PERSON CAN COMPLETE THIS\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If selected, only one responsibility will be created.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n </div>\n </form-field>\n\n <!-- Reviewer -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.REVIEWER\"\n [checked]=\"\n controls?.program_reviewer?.value?.length ||\n controls?.program_default_reviewer?.value?.length ||\n controls?.program_default_reviewer?.value?.length ||\n controls?.program_default_reviewer_group?.value?.length\n \"\n [active]=\"['REVIEWER', 'DEFAULT_REVIEWER']?.includes(activeList)\"\n [disabled]=\"\n sideElements?.includes(activeList) &&\n !['REVIEWER', 'DEFAULT_REVIEWER'].includes(activeList)\n \"\n [img]=\"ASSETS.reviewer\"\n >\n <label\n [class.disabled]=\"activeList === 'DEFAULT_REVIEWER'\"\n class=\"vx-control-panel\"\n >Reviewers\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Reviewers are required to review responsibilities after they have been completed. Where Reviewers are selected when creating a Program, only those Reviewers will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"ReviewerHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'DEFAULT_REVIEWER'\"\n [placeholder]=\"\n 'Who is responsible for reviewing the responsibilities within this Program?'\n \"\n (select)=\"activateList('REVIEWER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_reviewer?.value?.length ||\n controls?.program_reviewer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_reviewer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(controls?.program_reviewer?.value[0], 'REVIEWER')\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_reviewer?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_reviewer?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"reviewer.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_reviewer?.value?.length > 1\"\n >\n +{{ controls?.program_reviewer?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_reviewer_group?.value?.length &&\n controls?.program_reviewer?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_reviewer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_reviewer_group?.value[0],\n 'REVIEWER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_reviewer_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_reviewer_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"reviewerGroup.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_reviewer_group?.value?.length > 1\"\n >\n +{{ controls?.program_reviewer_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_reviewer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_reviewer?.value[0],'REVIEWER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_reviewer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_reviewer?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_reviewer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"reviewer.popover()\" placement=\"right\">+{{controls?.program_reviewer?.value?.length -1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_reviewer_group?.value?.length && controls?.program_reviewer?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_reviewer_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_reviewer_group?.value[0],'REVIEWER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_reviewer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_reviewer_group?.value[0]?.group_name}}\n </span>\n </span>\n <button *ngIf=\"controls?.program_reviewer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"reviewerGroup.popover()\" placement=\"right\">+{{controls?.program_reviewer_group?.value?.length - 1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'REVIEWER'\"\n (click)=\"activateList('REVIEWER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #reviewer [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let reviewer of controls?.program_reviewer?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(reviewer, 'REVIEWER')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ reviewer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #reviewerGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_reviewer_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(group, 'REVIEWER_GROUP')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <label\n [class.disabled]=\"activeList === 'REVIEWER'\"\n class=\"vx-control-panel\"\n >DEFAULT Reviewer\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'This option lets you specify the Default Reviewers for responsibilities linked with a Program. Where a user has been specified as a Default Reviewer, that user will automatically be selected as the Reviewer when creating a responsibility linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"DRHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"activeList === 'REVIEWER'\"\n [placeholder]=\"\n 'Which persons will be selected as the default reviewers for the responsibilities within this Program?'\n \"\n (select)=\"activateList('DEFAULT_REVIEWER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_reviewer?.value?.length ||\n controls?.program_default_reviewer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_reviewer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_reviewer?.value[0],\n 'DEFAULT_REVIEWER'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_reviewer?.value[0]?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_reviewer?.value[0]?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultReviewer.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_default_reviewer?.value?.length > 1\"\n >\n +{{ controls?.program_default_reviewer?.value?.length - 1 }}\n </button>\n </div>\n <span\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n *ngIf=\"\n controls?.program_default_reviewer_group?.value?.length &&\n controls?.program_default_reviewer?.value?.length\n \"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_reviewer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_reviewer_group?.value[0],\n 'DEFAULT_REVIEWER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_reviewer_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_reviewer_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"defaultReviewerGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_reviewer_group?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_reviewer_group?.value?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_reviewer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_reviewer?.value[0],'DEFAULT_REVIEWER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_reviewer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_reviewer?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_reviewer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"defaultReviewer.popover()\" placement=\"right\">+{{controls?.program_default_reviewer?.value?.length - 1}}</button>\n </div>\n <span class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\" *ngIf=\"controls?.program_default_reviewer_group?.value?.length && controls?.program_default_reviewer?.value?.length\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_reviewer_group?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_reviewer_group?.value[0],'DEFAULT_REVIEWER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_reviewer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_reviewer_group?.value[0]?.group_name}}\n </span>\n </span>\n <button *ngIf=\"controls?.program_default_reviewer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"defaultReviewerGroup.popover()\" placement=\"right\">+{{controls?.program_default_reviewer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_REVIEWER'\"\n (click)=\"activateList('DEFAULT_REVIEWER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #defaultReviewer [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let reviewer of controls?.program_default_reviewer?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(reviewer, 'DEFAULT_REVIEWER')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ reviewer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #defaultReviewerGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_reviewer_group?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(group, 'DEFAULT_REVIEWER_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <div\n class=\"radio-group-selector\"\n [class.disabled]=\"activeList === 'REVIEWER'\"\n >\n <app-cs-radio\n [name]=\"'reviewer'\"\n [checked]=\"\n controls?.reviewer_completion_criteria?.value === 'SEQUENTIAL'\n \"\n (checkedEvent)=\"\n setFormField('reviewer_completion_criteria', 'SEQUENTIAL')\n \"\n [class.disabled]=\"\n controls?.program_default_reviewer_group?.value?.length > 0\n \"\n >\n SEQUENTIAL\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'The responsibility will be sent for review one at a time in the sequence defined by you.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n <app-cs-radio\n [name]=\"'reviewer'\"\n [checked]=\"\n controls?.reviewer_completion_criteria?.value === 'ANYONE' ||\n controls?.program_default_reviewer_group?.value?.length > 0\n \"\n (checkedEvent)=\"\n setFormField('reviewer_completion_criteria', 'ANYONE')\n \"\n >\n ANY REVIEWER CAN MARK THIS AS REVIEWED\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'The responsibility will be sent for review to all reviewers at the same time. If anyone of the reviewer reviews the responsibility, it will be considered as reviewed.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </app-cs-radio>\n </div>\n </form-field>\n\n <!-- Overseer -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.OVERSEER\"\n [checked]=\"\n controls?.program_overseer?.value?.length ||\n controls?.program_default_overseer?.value?.length ||\n controls?.program_default_overseer?.value?.length ||\n controls?.program_default_overseer_group?.value?.length\n \"\n [active]=\"activeList === 'OVERSEER'\"\n [disabled]=\"\n sideElements?.includes(activeList) &&\n !['OVERSEER', 'DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(\n activeList\n )\n \"\n [img]=\"ASSETS.oversight\"\n >\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"\n ['DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n \"\n >Oversights\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Oversights receive updates when a responsibility is completed, completed with delay or not completed. Where Oversights are selected when creating a Program, only those Oversights will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"overseerHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [disabled]=\"\n ['DEFAULT_OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n \"\n [placeholder]=\"\n 'Who is responsible for overseeing the responsibilities within this Program?'\n \"\n (select)=\"activateList('OVERSEER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_overseer?.value?.length ||\n controls?.program_overseer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_overseer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(controls?.program_overseer?.value[0], 'OVERSEER')\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"controls?.program_overseer?.value[0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ controls?.program_overseer?.value[0]?.member_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseers.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_overseer?.value?.length > 1\"\n >\n +{{ controls?.program_overseer?.value?.length - 1 }}\n </button>\n </div>\n <span\n *ngIf=\"\n controls?.program_overseer_group?.value?.length &&\n controls?.program_overseer?.value?.length\n \"\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_overseer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_overseer_group?.value[0],\n 'OVERSEER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_overseer_group?.value[0]?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_overseer_group?.value[0]?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseerGroup.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_overseer_group?.value?.length > 1\"\n >\n +{{ controls?.program_overseer_group?.value?.length - 1 }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_overseer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_overseer?.value[0],'OVERSEER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_overseer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">\n {{controls?.program_overseer?.value[0]?.member_name}}\n </span>\n </span>\n <button *ngIf=\"controls?.program_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseers.popover()\" placement=\"right\">+{{controls?.program_overseer?.value?.length -1}}</button>\n </div>\n <span *ngIf=\"controls?.program_overseer_group?.value?.length && controls?.program_overseer?.value?.length \" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_overseer_group?.value?.length \">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_overseer_group?.value[0],'OVERSEER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_overseer_group?.value[0]?.group_name}}</span></span>\n <button *ngIf=\"controls?.program_overseer_group?.value?.length> 1\" class=\"count\" appPopover (click)=\"overseerGroup.popover()\" placement=\"right\">+{{controls?.program_overseer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n\n <button\n *ngIf=\"activeList !== 'OVERSEER'\"\n (click)=\"activateList('OVERSEER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #overseers [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let overseer of controls?.program_overseer?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i class=\"icons\" (click)=\"remove(overseer, 'OVERSEER')\"\n >&#xe90d;</i\n >\n {{ overseer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #overseerGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_overseer_group?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(group, 'OVERSEER_GROUP')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <ng-container [class.disabled]=\"activeList === 'OVERSEER'\">\n <label\n class=\"vx-control-panel\"\n [class.disabled]=\"['OVERSEER'].includes(activeList)\"\n >DEFAULT Oversight\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'This option lets you specify the Default Oversight for responsibilities linked with a Program. Where a user has been specified as a Default Oversight, that user will automatically be selected as the Oversight when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"DOHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [disabled]=\"\n ['OVERSEER', 'DEFAULT_FAILED_OVERSEER'].includes(activeList)\n \"\n [selectDiv]=\"true\"\n [placeholder]=\"\n 'Which persons will be selected as the default overseers for the responsibilities within this Program?'\n \"\n (select)=\"activateList('DEFAULT_OVERSEER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_overseer?.value?.length ||\n controls?.program_default_overseer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_overseer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_overseer?.value[0],\n 'DEFAULT_OVERSEER'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_overseer?.value[0]?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_overseer?.value[0]?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseersDefault.popover()\"\n placement=\"right\"\n *ngIf=\"controls?.program_default_overseer?.value?.length > 1\"\n >\n +{{ controls?.program_default_overseer?.value?.length - 1 }}\n </button>\n </div>\n <span\n *ngIf=\"\n controls?.program_default_overseer_group?.value?.length &&\n controls?.program_default_overseer?.value?.length\n \"\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_overseer_group?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_overseer_group?.value[0],\n 'DEFAULT_OVERSEER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_overseer_group?.value[0]\n ?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_overseer_group?.value[0]\n ?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseerDefaultGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_overseer_group?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_overseer_group?.value?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_overseer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_overseer?.value[0],'DEFAULT_OVERSEER')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_overseer?.value[0]?.member_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_overseer?.value[0]?.member_name}}</span></span>\n <button *ngIf=\"controls?.program_default_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseersDefault.popover()\" placement=\"right\">+{{controls?.program_default_overseer?.value?.length -1}}</button>\n </div>\n <span *ngIf=\"controls?.program_default_overseer_group?.value?.length && controls?.program_default_overseer?.value?.length\" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_overseer_group?.value?.length \">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_overseer_group?.value[0],'DEFAULT_OVERSEER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_overseer_group?.value[0]?.group_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_overseer_group?.value?.length >1\" class=\"count\" appPopover (click)=\"overseerDefaultGroup.popover()\" placement=\"right\">+{{controls?.program_default_overseer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_OVERSEER'\"\n (click)=\"activateList('DEFAULT_OVERSEER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #overseersDefault [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let overseer of controls?.program_default_overseer?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n class=\"icons\"\n (click)=\"remove(overseer, 'DEFAULT_OVERSEER')\"\n >&#xe90d;</i\n >\n {{ overseer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #overseerDefaultGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_overseer_group?.value\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(group, 'DEFAULT_OVERSEER_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <label class=\"vx-control-panel\"> </label>\n <input-with-pill\n class=\"vx-mt-2\"\n [selectDiv]=\"true\"\n [line]=\"3\"\n [disabled]=\"['OVERSEER', 'DEFAULT_OVERSEER'].includes(activeList)\"\n [placeholder]=\"\n 'Which persons will be selected as the default overseers for responsibilities that are not completed within this Program?'\n \"\n (select)=\"activateList('DEFAULT_FAILED_OVERSEER')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"\n controls?.program_default_failed_overseer?.value?.length ||\n controls?.program_default_failed_overseer_group?.value?.length\n \"\n >\n <div class=\"vx-d-flex vx-align-center\">\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"controls?.program_default_failed_overseer?.value?.length\"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_failed_overseer?.value[0],\n 'DEFAULT_FAILED_OVERSEER'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_failed_overseer?.value[0]\n ?.member_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_failed_overseer?.value[0]\n ?.member_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseersDefaultFail.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_failed_overseer?.value?.length > 1\n \"\n >\n +{{\n controls?.program_default_failed_overseer?.value?.length - 1\n }}\n </button>\n </div>\n <span\n *ngIf=\"\n controls?.program_default_failed_overseer_group?.value\n ?.length &&\n controls?.program_default_failed_overseer?.value?.length\n \"\n class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\"\n >&</span\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"\n controls?.program_default_failed_overseer_group?.value?.length\n \"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"\n remove(\n controls?.program_default_failed_overseer_group?.value[0],\n 'DEFAULT_FAILED_OVERSEER_GROUP'\n )\n \"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"\n controls?.program_default_failed_overseer_group?.value[0]\n ?.group_name\n \"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{\n controls?.program_default_failed_overseer_group?.value[0]\n ?.group_name\n }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"overseerDefaultFailGroup.popover()\"\n placement=\"right\"\n *ngIf=\"\n controls?.program_default_failed_overseer_group?.value\n ?.length > 1\n \"\n >\n +{{\n controls?.program_default_failed_overseer_group?.value\n ?.length - 1\n }}\n </button>\n </div>\n </div>\n\n <!-- <div class=\"chip-container\">\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_failed_overseer?.value?.length\">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_failed_overseer?.value[0],'DEFAULT_FAILED_OVERSEER')\" >&#xe90d;</i>\n <span class=\"chip\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_failed_overseer?.value[0]?.member_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_failed_overseer?.value?.length > 1\" class=\"count user\" appPopover (click)=\"overseersDefaultFail.popover()\" placement=\"right\">+{{controls?.program_default_failed_overseer?.value?.length -1}}</button>\n </div>\n <span *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length && controls?.program_default_failed_overseer?.value?.length\" class=\"vx-fs-12 vx-paragraph-txt vx-ml-2 vx-mr-2\">&</span>\n <div class=\"chip-inner\" *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length \">\n <i class=\"icons cross vx-mr-1\" (click)=\"remove(controls?.program_default_failed_overseer_group?.value[0],'DEFAULT_FAILED_OVERSEER_GROUP')\" >&#xe90d;</i>\n <span class=\"chip\" [appTooltip]=\"controls?.program_default_failed_overseer_group?.value[0]?.group_name\" placement=\"bottom-left\" type=\"black\" delay=\"0\" [tooltipMandatory]=\"false\">\n <span class=\"vx-fs-11 vx-paragraph-txt vx-fw-500 vx-tt-uppercase\">{{controls?.program_default_failed_overseer_group?.value[0]?.group_name}}</span>\n </span>\n <button *ngIf=\"controls?.program_default_failed_overseer_group?.value?.length > 1\" class=\"count\" appPopover (click)=\"overseerDefaultFailGroup.popover()\" placement=\"right\">+{{controls?.program_default_failed_overseer_group?.value?.length -1}}</button>\n </div>\n </div> -->\n <button\n *ngIf=\"activeList !== 'DEFAULT_FAILED_OVERSEER'\"\n (click)=\"activateList('DEFAULT_FAILED_OVERSEER')\"\n class=\"edit\"\n type=\"button\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #overseersDefaultFail [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let overseer of controls?.program_default_failed_overseer\n ?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n class=\"icons\"\n (click)=\"remove(overseer, 'DEFAULT_FAILED_OVERSEER')\"\n >&#xe90d;</i\n >\n {{ overseer?.member_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n <app-popover #overseerDefaultFailGroup [dontCloseonClick]=\"true\">\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let group of controls?.program_default_failed_overseer_group\n ?.value | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i\n (click)=\"remove(group, 'DEFAULT_FAILED_OVERSEER_GROUP')\"\n class=\"icons\"\n >&#xe90d;</i\n >\n {{ group?.group_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </ng-container>\n </form-field>\n\n <!-- Assessment -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.ASSESSMENT\"\n [checked]=\"controls?.program_assessments?.value?.length\"\n [active]=\"activeList === 'ASSESSMENT'\"\n [disabled]=\"\n sideElements.includes(activeList) && activeList !== 'ASSESSMENT'\n \"\n [img]=\"ASSETS.assessments\"\n >\n <label class=\"vx-control-panel\"\n >ASSESSMENTS\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Assessments are a digital form that are created in \u201CAssessment\u201D within the Compliance Module. Where Assessments are selected when creating a Program, only those Assessments will be available for selection when creating a responsibility linked with the Program.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"AssessmentHelpText\"\n >&#xeb16;</i\n ></label\n >\n <input-with-pill\n [selectDiv]=\"true\"\n [placeholder]=\"\n 'Which assessments can be linked to the responsibilities within this Program?'\n \"\n (select)=\"activateList('ASSESSMENT')\"\n >\n <div\n class=\"selected\"\n *ngIf=\"controls?.program_assessments?.value?.length\"\n >\n <div\n class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\"\n *ngIf=\"\n controls?.program_assessments?.value\n | assessmentResolver as assessments\n \"\n >\n <i\n class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n (click)=\"remove(assessments[0], 'ASSESSMENT')\"\n >&#xe9ae;</i\n >\n <span\n class=\"chipName vx-fs-11 vx-label-txt\"\n [appTooltip]=\"assessments[0]?.assessment_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >{{ assessments[0]?.assessment_name }}</span\n >\n <button\n class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n appPopover\n (click)=\"program_assessments.popover()\"\n placement=\"right\"\n *ngIf=\"assessments?.length > 1\"\n >\n +{{ assessments?.length - 1 }}\n </button>\n </div>\n\n <!-- <div class=\"chip-container\">\n <ng-container *ngIf=\"(controls?.program_assessments?.value | assessmentResolver) as assessments\">\n <div class=\"chip-inner\">\n <span class=\"chip\"><i class=\"icons\" (click)=\"remove(assessments[0],'ASSESSMENT')\">&#xe90d;</i>{{assessments[0]?.assessment_name}} </span>\n <button *ngIf=\"assessments?.length > 1\" class=\"count\" appPopover (click)=\"program_assessments.popover()\" placement=\"right\">+{{assessments?.length -1 }}</button>\n </div>\n </ng-container>\n </div> -->\n <button\n *ngIf=\"activeList !== 'ASSESSMENT'\"\n class=\"edit\"\n type=\"button\"\n (click)=\"activateList('ASSESSMENT')\"\n >\n <i class=\"icons\">&#xe9ba;</i> Edit\n </button>\n </div>\n </input-with-pill>\n <app-popover #program_assessments [dontCloseonClick]=\"true\">\n <ng-container>\n <div class=\"wf-action-list\">\n <ul class=\"action-item\">\n <li\n *ngFor=\"\n let assessment of controls?.program_assessments?.value\n | assessmentResolver\n | slice : 1\n \"\n >\n <div class=\"avatar-card\">\n <span class=\"value\">\n <i (click)=\"remove(assessment, 'ASSESSMENT')\" class=\"icons\"\n >&#xe90d;</i\n >\n {{ assessment?.assessment_name }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </ng-container>\n </app-popover>\n </form-field>\n\n <!-- Format & Evidence -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.FORMATE_EVIDENCE\"\n [checked]=\"[true, false].includes(controls?.evidence_required?.value)\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.format_evidence\"\n >\n <label class=\"vx-control-panel\"\n >Evidence\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'If selected, evidence of completion of a responsibility will be required for all responsibilities that are linked with the Program. An Assignor, being the person who creates the responsibility, can override this option when creating a responsibility.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"EvidenceHelpText\"\n >&#xeb16;</i\n ></label\n >\n <div class=\"upload-format\">\n <span class=\"text\"\n >Do all responsibilities within this program require evidence?</span\n >\n <div class=\"radio-group program\">\n <app-cs-radio\n [name]=\"'evidence_required'\"\n [checked]=\"controls?.evidence_required?.value\"\n (checkedEvent)=\"setFormField('evidence_required', true)\"\n >YES</app-cs-radio\n >\n <app-cs-radio\n [name]=\"'evidence_required'\"\n [checked]=\"!controls?.evidence_required?.value\"\n (checkedEvent)=\"setFormField('evidence_required', false)\"\n >NO</app-cs-radio\n >\n </div>\n </div>\n <!-- <div class=\"vx-d-flex vx-align-center vx-justify-end vx-mt-2\">\n <div class=\"vx-fs-11 vx-fw-500 vx-paragraph-txt vx-tt-uppercase vx-mr-2\">Allow any file to be marked as\n key\n evidence</div>\n <switch formControlName=\"allow_any_file_key_evidence\"\n (change)=\"setFormField('allow_any_file_key_evidence',$event?.target?.checked)\"></switch>\n </div> -->\n </form-field>\n\n <!-- Custom Field -->\n <form-field\n [appScrollInView]=\"scrollToBottom\"\n *ngIf=\"additionalOption?.CUSTOM_FIELDS\"\n [checked]=\"controls?.custom_fields?.value?.length\"\n [active]=\"false\"\n [disabled]=\"sideElements.includes(activeList)\"\n [img]=\"ASSETS.custom_fields\"\n >\n <label class=\"vx-control-panel\"\n >CUSTOM FIELD\n <i\n class=\"icons\"\n [appTooltip]=\"\n 'Where a custom field is specified, all responsibilities linked with a Program will contain that custom field. Custom fields enable the collection of additional meta data.'\n \"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n id=\"CFHelpText\"\n >&#xeb16;</i\n ></label\n >\n <custom-field formControlName=\"custom_fields\"></custom-field>\n </form-field>\n </form>\n</div>\n\n\n<!-- render userlist with group -->\n<user-group-list\n *ngIf=\"activeList === 'OWNER'\"\n [groupEnabled]=\"true\"\n [singleSelect]=\"false\"\n [loading]=\"listLoadingState.USERS\"\n [userlist]=\"lists?.OWNERS?.data ?? []\"\n [selectedUsers]=\"controls?.program_owners?.value | refDisconnect\"\n (fetchUserData)=\"fetchUsersAssociatedWithRoles(false, $event)\"\n [userListInfo]=\"lists?.OWNERS\"\n [groupListInfo]=\"lists?.OWNERS_GROUPS\"\n [groupList]=\"lists?.OWNERS_GROUPS?.data ?? []\"\n [selectedGroups]=\"controls?.program_owners_group?.value | refDisconnect\"\n (save)=\"listAction($event, 'OWNER')\"\n (cancel)=\"fieldDeselector('OWNER')\"\n [panelTitle]=\"panelTitleOwner\"\n [featureflag]=\"featureflagGroups\"\n></user-group-list>\n<user-group-list\n *ngIf=\"activeList === 'COLLABORATORS'\"\n [groupEnabled]=\"true\"\n [singleSelect]=\"false\"\n [loading]=\"listLoadingState.USERS\"\n [userlist]=\"lists?.OWNERS?.data ?? []\"\n [selectedUsers]=\"controls?.collaborators?.value | refDisconnect\"\n [groupList]=\"lists?.OWNERS_GROUPS ?? []\"\n [FromProgram]=\"true\"\n [selectedGroups]=\"controls?.collaborators_group?.value | refDisconnect\"\n [assignorId]=\"assignorId\"\n [userListInfo]=\"lists?.ASSIGNEES\"\n (save)=\"listAction($event, 'COLLABORATORS')\"\n (cancel)=\"fieldDeselector('COLLABORATORS')\"\n [panelTitle]=\"panelTitleAssignee\"\n [defaultSelectedUsers]=\"\n controls?.collaborators?.value | refDisconnect\n \"\n [userType]=\"'assignees'\"\n [featureflag]=\"featureflagGroups\"\n>\n</user-group-list>\n<app-loader-inline *ngIf=\"loader\"></app-loader-inline>\n<app-smiley-dialog-inline\n *ngIf=\"showSmiley\"\n [message]=\"smileyMessage\"\n [actionButtons]=\"actionButtons\"\n (action)=\"action($event)\"\n (closeSmiley)=\"closeSmiley($event)\"\n>\n</app-smiley-dialog-inline>\n\n<!-- Framework selector -->\n<app-framework-list\n *ngIf=\"activeList === 'FRAMEWORK'\"\n [workflowPage]=\"['FRAMEWORK']\"\n (assignControl)=\"listAction($event, 'FRAMEWORK')\"\n (closeFramework)=\"fieldDeselector('FRAMEWORK')\"\n [previousSelectedValues]=\"{ framework: controls?.framework.value }\"\n (entrustFramework)=\"entrustFramework($event)\"\n [headerText]=\"'Select a framework'\"\n></app-framework-list>", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";::ng-deep .workflow-program{display:block;position:relative}::ng-deep .workflow-program .scope-label{background:#747576;border-radius:.125rem;position:relative;z-index:1}::ng-deep .workflow-program .scope-label:before{background:#f1f1f1;content:\"\";position:absolute;top:.5rem;left:7rem;width:20rem;height:1px;z-index:-1}::ng-deep .workflow-program .scope-label:after{background:#f1f1f1;content:\"\";position:absolute;top:.5rem;left:-2.5rem;width:2.5rem;height:1px;z-index:-1}::ng-deep .workflow-program .scope-label .required{position:absolute;top:0;right:-.625rem}::ng-deep .workflow-program .info-icon{position:relative;top:.125rem;cursor:pointer}::ng-deep .workflow-program .date-picker .picker-group{width:calc(50% - .125rem);position:relative}::ng-deep .workflow-program .date-picker .picker-group:focus-within{border-color:#1e5dd3;box-shadow:0 0 5px #1e5dd345}::ng-deep .workflow-program .date-picker .picker-group input{height:2.5rem;border-radius:.25rem;border:1px solid #DBDBDB;background:#fff;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%;padding:0 2rem 0 .75rem;outline:none}::ng-deep .workflow-program .date-picker .picker-group input:focus,::ng-deep .workflow-program .date-picker .picker-group input:hover{border-color:#1e5dd3;box-shadow:0 0 5px #1e5dd345}::ng-deep .workflow-program .date-picker .picker-group input::placeholder{color:#747576;font-size:13px}::ng-deep .workflow-program .date-picker .picker-group input:-ms-input-placeholder{color:#747576;font-size:13px}::ng-deep .workflow-program .date-picker .picker-group input::-ms-input-placeholder{color:#747576;font-size:13px}::ng-deep .workflow-program .date-picker .picker-group i{height:1rem;width:1rem;position:absolute;right:.75rem;top:.625rem;pointer-events:none}::ng-deep .workflow-program .program-type-field{background:#f8f8f8;border:1px solid #dbdbdb;border-radius:4px;height:40px;display:flex;align-items:center;justify-content:space-between;padding:4px;position:relative;z-index:1}::ng-deep .workflow-program .program-type-field .type-item{position:relative}::ng-deep .workflow-program .program-type-field .type-item:first-of-type{width:6.25rem}::ng-deep .workflow-program .program-type-field .type-item:nth-child(2){width:5.75rem}::ng-deep .workflow-program .program-type-field .type-item:nth-child(2).active~.background-glider{transform:translate(6.4375rem);width:5.75rem}::ng-deep .workflow-program .program-type-field .type-item:nth-child(3){width:8.625rem}::ng-deep .workflow-program .program-type-field .type-item:nth-child(3).active~.background-glider{transform:translate(12.375rem);width:8.625rem}::ng-deep .workflow-program .program-type-field .type-item:last-of-type{width:5.25rem}::ng-deep .workflow-program .program-type-field .type-item:last-of-type.active~.background-glider{transform:translate(21.1875rem);width:5.25rem}::ng-deep .workflow-program .program-type-field .type-item button{background:transparent;border:none;border-radius:0;color:#747576;font-size:11px;font-weight:600;text-transform:uppercase;width:100%;height:32px;padding:0 12px;text-align:center}::ng-deep .workflow-program .program-type-field .type-item button.disabled{background:transparent!important;color:#dbdbdb!important;filter:unset!important;opacity:unset!important;pointer-events:none}::ng-deep .workflow-program .program-type-field .type-item .info{color:#1e5dd3;font-size:12px;position:absolute;top:10px;right:12px;cursor:pointer}::ng-deep .workflow-program .program-type-field .type-item.active button{color:#1e5dd3!important}::ng-deep .workflow-program .program-type-field .background-glider{background:#fff;border-radius:4px;box-shadow:0 1px 3px #161b2f26;position:absolute;display:flex;width:6.25rem;height:32px;z-index:-1;transition:.25s ease-out}::ng-deep .workflow-program .vx-form-group .upload-files .file-item{background:#f1f1f1;border:1px solid #dbdbdb;border-radius:.25rem;padding-left:.125rem}::ng-deep .workflow-program .vx-form-group .upload-files .file-item .file-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;max-width:8.5rem}::ng-deep .workflow-program .vx-form-group .upload-files .file-item button.delete-btn{background:transparent;border-radius:0;border:none;border-left:1px solid #dbdbdb;height:1.625rem}::ng-deep .workflow-program .vx-form-group .upload-files button.file-count{background:#1e5dd3;border-radius:.125rem;border:none;color:#fff;font-size:11px;display:flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0;margin:4px 0 0 4px}::ng-deep .workflow-program .vx-form-group .upload-format .radio-group app-cs-radio{height:1.375rem}::ng-deep .workflow-program .vx-form-group .default-selected{background:#fbfbfb;border:1px solid #F1F1F1;border-radius:.25rem;margin-top:.5rem}::ng-deep .workflow-program .vx-form-group .default-selected .selected{border-radius:0;border:none;background:none}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio{border-top:1px solid #F1F1F1}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio{margin-top:0!important}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item span.radio{position:absolute;top:.5rem;left:.75rem}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item span.value{font-size:11px;text-transform:uppercase;padding:.5rem .5rem .5rem 2.25rem;width:100%;display:flex;justify-content:space-between;margin:0;max-width:100%;font-weight:500;color:#707070}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item span.value i{font-size:12px;color:#1e5dd3}::ng-deep .workflow-program .vx-form-group .default-selected .default-radio app-cs-radio label.radio-item svg{position:absolute;top:.5rem;left:.75rem}::ng-deep .workflow-program .vx-form-group .selected .custom-text{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;max-height:2.4rem}::ng-deep .workflow-program .vx-form-group .selected button.cross-btn{background:transparent;border-radius:0;border:0;padding:0}::ng-deep .workflow-program .vx-form-group .custom-input{position:relative}::ng-deep .workflow-program .vx-form-group .custom-input input{padding-right:2rem}::ng-deep .workflow-program .vx-form-group .custom-input button.cross-btn{background:transparent;border-radius:0;border:0;position:absolute;top:.875rem;right:.625rem}::ng-deep .workflow-program .vx-form-group button.add-more-btn{background:transparent;border-radius:0;border:none;padding:0}::ng-deep app-popover .wf-action-list ul.action-item .avatar-card .value{text-transform:none!important}::ng-deep app-popover .wf-action-list ul.action-item li file-pill .file-item{background:transparent!important;border:none!important;border-radius:0!important;padding:0!important;margin:0!important}::ng-deep app-popover .wf-action-list ul.action-item li file-pill .file-name{width:100%!important;max-width:100%!important}::ng-deep app-popover .wf-action-list ul.action-item li file-pill button.delete-btn{border:none!important;padding-right:0!important}.disabled{opacity:.4;pointer-events:none;filter:grayscale(1)}.vx-info-card{width:280px;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both;background:#fff;box-shadow:0 3px 6px #1c5bd140;border-radius:4px;position:static;display:block;left:780}.vx-info-card-body{font-size:12px;padding:8px 12px;margin:0;font-weight:400;text-transform:none;color:#747576}\n", "@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";::-webkit-scrollbar-track{background-color:#f1f1f1;position:absolute}::-webkit-scrollbar{width:3px;height:3px;background-color:transparent;position:absolute}::-webkit-scrollbar-thumb{border-radius:3px;background-color:#dbdbdb;position:absolute}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}button{font-family:Poppins,sans-serif}::ng-deep input.textField{background:#fff;border-radius:.25rem;border:1px solid #dbdbdb;font-size:13px;color:#747576;padding:8px 12px;position:relative;height:2.5rem;width:100%;transition:all .2s ease-in-out}::ng-deep input.textField::placeholder{font-size:13px;color:#747576}::ng-deep input.textField:hover,::ng-deep input.textField:focus{outline:none;border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .selectBoxEnable{background:#fff;border-radius:.25rem;border:1px solid #dbdbdb;cursor:pointer;height:2.5rem;position:relative;transition:all .2s ease-in-out}::ng-deep .selectBoxEnable:after{border-bottom-style:solid;border-bottom-width:1px;border-right-style:solid;border-right-width:1px;border-color:#747576;content:\"\";display:inline-block;right:12px;position:absolute;top:calc(50% - 4px);width:5px;height:5px;transform:rotate(45deg)}::ng-deep .selectBoxEnable:hover,::ng-deep .selectBoxEnable:focus{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .selectBoxEnable.disabled{background:#f1f1f1;pointer-events:none;opacity:1}::ng-deep .selectBoxEnable.withBtn:after{display:none}::ng-deep .selectBoxEnable.withBtn button.setBtn{background:transparent;border-radius:0;border:none;min-width:98px}::ng-deep .selectBoxSuccess{background:#f8f8f8;border-radius:.25rem;border:1px solid #f1f1f1;min-height:2.5rem;position:relative}::ng-deep .selectBoxSuccess .selectBoxText{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;width:22rem}::ng-deep .selectBoxSuccess button{background:transparent;border-radius:0;border:none}::ng-deep .selectBoxSuccess button.deleteBtn{color:#d93b41}::ng-deep .selectBoxSuccess .level-left{border-right:1px solid #f1f1f1;height:2.375rem;width:5rem}::ng-deep .selectBoxSuccess .level-left .level-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;width:4.5rem}::ng-deep .chipContainer{background:#fff;border-radius:.125rem;box-shadow:0 0 2px #1e5dd340;height:1.5rem}::ng-deep .chipContainer .cross{cursor:pointer;min-width:16px;width:16px;height:16px;display:flex;align-items:center;justify-content:center;background:transparent;border-radius:2px;margin-left:-4px}::ng-deep .chipContainer .cross:hover{background:#f1f1f1}::ng-deep .chipContainer .chipName{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;max-width:6rem}::ng-deep .chipContainer .chipName.no-width{max-width:unset}::ng-deep .chipContainer .chipName.full-width{max-width:25rem}::ng-deep .chipContainer button.countBtn{background:#1e5dd3;border-radius:1.25rem;border:none;min-width:1.5rem;height:1rem;margin:0 0 0 .5rem;padding:0 .25rem}::ng-deep .chipContainer button.countBtn.greenBg{background:#34aa44}::ng-deep .workflowLavel{background:#f1f1f1;border-radius:.125rem;color:#042e7d;min-width:1rem;height:1rem}::ng-deep .reviewSelection{border-radius:.25rem;border:1px solid #dbdbdb;transition:all .2s ease-in-out}::ng-deep .reviewSelection:hover{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .selectButton{background:#fff;border-radius:.25rem;border:1px solid #dbdbdb;cursor:pointer;height:2.5rem;position:relative;transition:all .2s ease-in-out}::ng-deep .selectButton:hover,::ng-deep .selectButton:focus{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep button.createNewBtn{background:transparent;border-radius:0;border:none}::ng-deep .vx-form-group{display:block;position:relative;margin-bottom:20px}::ng-deep .vx-form-group:after{content:\"\";display:block;clear:both}::ng-deep .vx-form-group .select{position:relative}::ng-deep .vx-form-group .select:after{border-bottom-style:solid;border-bottom-width:1px;border-right-style:solid;border-right-width:1px;border-color:#707070;content:\"\";display:inline-block;right:12px;position:absolute;top:calc(50% - 4px);width:5px;height:5px;transform:rotate(45deg)}::ng-deep .vx-form-group .select input{cursor:pointer;padding-right:30px!important}::ng-deep .vx-form-group .select .custom-input{height:40px;border-radius:4px;border:1px solid #dbdbdb;background:#fff;outline:none;padding:3px 12px;line-height:16px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%;cursor:pointer}::ng-deep .vx-form-group .select .custom-input:empty:not(:focus):before{content:attr(aria-placeholder);line-height:16px;font-size:13px;width:94%;display:block;pointer-events:none;opacity:.8}::ng-deep .vx-form-group .select .custom-input:hover{border-color:#1e5dd3;box-shadow:0 0 5px #1e5dd345}::ng-deep .vx-form-group .select .custom-input.frequency-custom-input{padding-right:108px;display:flex;align-items:center}::ng-deep .vx-form-group .select+app-cs-switch{display:block;margin-top:8px}::ng-deep .vx-form-group .select+app-cs-switch label.cs-switch span.value{white-space:nowrap;margin-right:5px;text-transform:uppercase}::ng-deep .vx-form-group .select+app-cs-radio{margin-top:8px!important}::ng-deep .vx-form-group .select~app-cs-radio{margin-top:4px;display:block;width:100%}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item span.radio{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item span.value{font-size:11px;text-transform:uppercase;border:1px solid #dbdbdb;border-radius:4px;padding:8px 8px 8px 36px;width:100%;display:flex;justify-content:space-between;margin:0;max-width:100%;font-weight:500;color:#707070}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item span.value i{font-size:12px;color:#1e5dd3}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item svg{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group .select~app-cs-radio label.radio-item input:checked~span.value{background:#eefcf0;border-color:#34aa44}::ng-deep .vx-form-group .select.button-sec:after{display:none}::ng-deep .vx-form-group .select.button-sec button{background:transparent;border:none;display:inline-flex;float:right;color:#1e5dd3;text-transform:uppercase;font-weight:600;cursor:pointer;font-size:11px;position:absolute;top:12px;right:8px;padding:0;margin:0}::ng-deep .vx-form-group .select+.vx-control-panel{margin-top:8px}::ng-deep .vx-form-group .select+.selected{margin-top:8px}::ng-deep .vx-form-group .select.select{margin-top:8px}::ng-deep .vx-form-group .upload-format{border:1px solid #dbdbdb;border-radius:4px;padding:8px 12px;display:block}::ng-deep .vx-form-group .upload-format span.text{line-height:20px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%;display:block;margin-bottom:6px}::ng-deep .vx-form-group .upload-format .radio-group{display:flex}::ng-deep .vx-form-group .upload-format .radio-group app-cs-radio{display:inline-block}::ng-deep .vx-form-group .upload-format .radio-group app-cs-radio label.radio-item span.value{font-size:11px;text-transform:uppercase;margin-left:8px}::ng-deep .vx-form-group .upload-format .radio-group app-cs-radio+app-cs-radio{margin-left:12px}::ng-deep .vx-form-group .upload-format~.upload-format{margin-top:4px}::ng-deep .vx-form-group .form-tab{display:flex;justify-content:flex-start}::ng-deep .vx-form-group .form-tab button{background:transparent;color:#161b2f;font-size:11px;line-height:16px;text-transform:uppercase;cursor:pointer;padding:8px 8px 8px 0;border:none;outline:none;font-weight:500}::ng-deep .vx-form-group .form-tab button:disabled{opacity:.5;pointer-events:none;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group .form-tab button+button{padding:8px}::ng-deep .vx-form-group .form-tab button.active{color:#1e5dd3}::ng-deep .vx-form-group .tab-group{border:1px solid #dbdbdb;border-radius:4px;padding:0;display:block;position:relative;transition:all .2s ease-in-out}::ng-deep .vx-form-group .tab-group:hover{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .vx-form-group .tab-group .upload-file{padding:16px 62px 16px 24px;display:flex;align-items:center;justify-content:space-between}::ng-deep .vx-form-group .tab-group .upload-file .image{width:80px}::ng-deep .vx-form-group .tab-group .upload-file .browse span{display:inline-block;font-size:12px;color:#747576;line-height:16px;padding:0 4px}::ng-deep .vx-form-group .tab-group .upload-file .browse .label{font-size:11px;color:#1e5dd3;line-height:16px;font-weight:600;text-transform:uppercase;margin:0;padding:0}::ng-deep .vx-form-group .tab-group .upload-file .browse .label input{opacity:0;position:absolute;margin:0;padding:0;inset:0;cursor:pointer;width:100%}::ng-deep .vx-form-group .tab-group.active{border-color:#1e5dd3}::ng-deep .vx-form-group .tab-group.uploaded{margin-top:4px}::ng-deep .vx-form-group .tab-group.uploaded .upload-file{padding:8px 0!important;text-align:center}::ng-deep .vx-form-group .tab-group.uploaded .upload-file .image{display:none}::ng-deep .vx-form-group .tab-group.uploaded .upload-file .browse{width:100%;text-align:center}::ng-deep .vx-form-group .tab-group+label.vx-form-group{margin-top:8px;margin-bottom:4px}::ng-deep .vx-form-group .file-list{background:#fbfbfb;border:1px solid #f1f1f1;border-radius:4px;padding:12px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;position:relative}::ng-deep .vx-form-group .file-list span.file-name{color:#747576;line-height:16px;font-size:11px;font-weight:400;cursor:pointer;max-width:calc(100% - 20px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}::ng-deep .vx-form-group .file-list .button-group{display:flex}::ng-deep .vx-form-group .file-list button{font-size:12px;color:#eb2424;cursor:pointer;display:flex;padding:0;border:none;outline:none;background:transparent}::ng-deep .vx-form-group .file-list button.edit{color:#1e5dd3}::ng-deep .vx-form-group .file-list button+button{margin-left:16px}::ng-deep .vx-form-group .file-list+.file-list{margin-top:4px}::ng-deep .vx-form-group .file-list .file-container{display:flex;justify-content:space-between;width:100%}::ng-deep .vx-form-group .file-list.policy{background:#fff}::ng-deep .vx-form-group .file-list cs-select{position:relative;margin-top:8px;width:100%}::ng-deep .vx-form-group .file-list cs-select .selection-wrap .input-group input.value{height:32px!important;font-size:13px!important}::ng-deep .vx-form-group .file-list cs-select .selection-wrap .input-group i{right:12px!important;top:12px!important}::ng-deep .vx-form-group .file-list app-line-loader{display:block;position:absolute;left:10px;right:10px;bottom:0}::ng-deep .vx-form-group label.vx-control-panel{color:#161b2f;font-size:11px;font-weight:500;line-height:16px;margin-bottom:8px;display:block;text-transform:uppercase;text-align:left}::ng-deep .vx-form-group label.vx-control-panel.custom-tag{font-size:10px}::ng-deep .vx-form-group label.vx-control-panel.vx-mt-8{margin-top:8px}::ng-deep .vx-form-group label.vx-control-panel span.required{color:#eb2424;font-size:14px;font-weight:500;position:relative;top:-2px}::ng-deep .vx-form-group label.vx-control-panel .button{background:transparent;border:none;display:inline-flex;float:right;color:#1e5dd3;text-transform:uppercase;font-weight:600;cursor:pointer;font-size:11px;padding:0;margin:0}::ng-deep .vx-form-group label.vx-control-panel app-cs-switch{float:right;display:block}::ng-deep .vx-form-group label.vx-control-panel i{margin-left:8px;font-size:12px;color:#1e5dd3;cursor:pointer;position:relative;top:1px}::ng-deep .vx-form-group label.vx-control-panel i.depreciation-icon{color:#e4b700;font-size:16px;position:relative;top:3px}::ng-deep .vx-form-group label.vx-control-panel .checkpoint-version{background:#f1f1f1;border-radius:2px;color:#042e7d;font-size:10px;font-weight:600;line-height:14px;margin-left:4px;padding:0 2px}::ng-deep .vx-form-group input[type=text],::ng-deep .vx-form-group .input{height:40px;border-radius:4px;border:1px solid #dbdbdb;background:#fff;outline:none;padding:8px 12px;line-height:20px;font-size:13px;color:#747576;transition:all .2s ease-in-out;width:100%;font-weight:400}::ng-deep .vx-form-group input[type=text]::placeholder,::ng-deep .vx-form-group .input::placeholder{color:#747576;font-weight:400}::ng-deep .vx-form-group input[type=text]:focus,::ng-deep .vx-form-group .input:focus,::ng-deep .vx-form-group input[type=text]:hover,::ng-deep .vx-form-group .input:hover{border-color:#1e5dd3!important;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .vx-form-group input[type=text].error,::ng-deep .vx-form-group .input.error{border-color:#eb2424;color:#eb2424;margin-bottom:4px}::ng-deep .vx-form-group input[type=text].error:focus,::ng-deep .vx-form-group .input.error:focus{box-shadow:0 0 5px #d31e1e45}::ng-deep .vx-form-group input[type=text]:disabled,::ng-deep .vx-form-group .input:disabled{background:#f1f1f1;cursor:not-allowed;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group input[type=text]:disabled:hover,::ng-deep .vx-form-group .input:disabled:hover{border-color:#dbdbdb;box-shadow:none}::ng-deep .vx-form-group input[type=text] span.text,::ng-deep .vx-form-group .input span.text{font-size:13px;color:#747576;font-weight:400;display:block;width:100%}::ng-deep .vx-form-group input[type=text] .input-group,::ng-deep .vx-form-group .input .input-group{display:flex;align-items:center}::ng-deep .vx-form-group input[type=text] .input-group.counter,::ng-deep .vx-form-group .input .input-group.counter{min-width:96px;width:96px}::ng-deep .vx-form-group input[type=text] .input-group.counter button,::ng-deep .vx-form-group .input .input-group.counter button{height:24px;width:24px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#747576;font-size:8px;cursor:pointer;outline:none}::ng-deep .vx-form-group input[type=text] .input-group.counter input,::ng-deep .vx-form-group .input .input-group.counter input{-webkit-appearance:textfield;-moz-appearance:textfield;height:24px;width:calc(100% - 48px);border:1px solid #f1f1f1;outline:none;padding:0 6px;text-align:center}::ng-deep .vx-form-group input[type=text] .input-group.counter input::-webkit-inner-spin-button,::ng-deep .vx-form-group .input .input-group.counter input::-webkit-inner-spin-button,::ng-deep .vx-form-group input[type=text] .input-group.counter input::-webkit-outer-spin-button,::ng-deep .vx-form-group .input .input-group.counter input::-webkit-outer-spin-button{appearance:none;margin:0}::ng-deep .vx-form-group input[type=text]+.file-list,::ng-deep .vx-form-group .input+.file-list{margin-top:8px}::ng-deep .vx-form-group input[type=text]::placeholder,::ng-deep .vx-form-group .input::placeholder{font-size:13px}::ng-deep .vx-form-group input[type=text]:-ms-input-placeholder,::ng-deep .vx-form-group .input:-ms-input-placeholder{font-size:13px}::ng-deep .vx-form-group input[type=text]::-ms-input-placeholder,::ng-deep .vx-form-group .input::-ms-input-placeholder{font-size:13px}::ng-deep .vx-form-group .classification{height:40px;border-radius:4px;border:1px solid #dbdbdb;background:#fff;padding:8px 12px;display:flex;justify-content:space-between}::ng-deep .vx-form-group .classification label{margin:0 4px 0 0;width:100%;position:relative;z-index:1}::ng-deep .vx-form-group .classification label span{display:block;width:100%;height:24px;border:1px solid #f1f1f1;border-radius:2px;line-height:24px;font-size:10px;text-align:center;color:#747576;font-weight:500;position:relative;text-transform:uppercase}::ng-deep .vx-form-group .classification label span:before{height:2px;content:\"\";top:0;right:0;left:0;border-radius:2px;position:absolute;transition:all .2s ease-in-out}::ng-deep .vx-form-group .classification label input{opacity:0;position:absolute;inset:0;margin:0;padding:0;width:100%;height:100%;cursor:pointer;z-index:1}::ng-deep .vx-form-group .classification label input:checked+span{color:#fff}::ng-deep .vx-form-group .classification label input:checked+span:before{bottom:0;height:100%;z-index:-1}::ng-deep .vx-form-group .classification label.low span:before{background:#34aa44}::ng-deep .vx-form-group .classification label.low-med span:before{background:#f2bf19}::ng-deep .vx-form-group .classification label.med-high span:before{background:#f29619}::ng-deep .vx-form-group .classification label.high span:before{background:#eb2424}::ng-deep .vx-form-group .classification label:last-of-type{margin-right:0}::ng-deep .vx-form-group .input{display:flex;align-items:center}::ng-deep .vx-form-group .selected{height:40px;border-radius:4px;border:1px solid #f1f1f1;background:#fbfbfb;outline:none;padding:8px;line-height:20px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%;display:flex;align-items:center;position:relative;justify-content:space-between}::ng-deep .vx-form-group .selected.first-field{z-index:2}::ng-deep .vx-form-group .selected .chip-container{display:flex;width:calc(100% - 60px);align-items:center}::ng-deep .vx-form-group .selected .chip-container.checkpoints{width:calc(100% - 120px)}::ng-deep .vx-form-group .selected .chip-container span.chip{background:#fff;border-radius:2px;box-shadow:0 0 3px #1e5dd31a;height:24px;padding:0 8px;color:#1e5dd3;font-size:12px;display:block;width:auto;max-width:100%;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:24px}::ng-deep .vx-form-group .selected .chip-container span.chip.disabled{background:#f1f1f1;box-shadow:none;color:#747576;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group .selected .chip-container span.chip i{font-weight:400;margin-right:8px;cursor:pointer;font-size:10px;position:relative;top:1px}::ng-deep .vx-form-group .selected .chip-container span.chip span.step{background:#1e5dd3;border-radius:2px;color:#fff;font-size:9px;line-height:14px;padding:0 4px;font-weight:400;text-align:center;min-width:auto;margin-right:4px}::ng-deep .vx-form-group .selected .chip-container span.chip+span.chip{margin-left:4px}::ng-deep .vx-form-group .selected .chip-container span.chip.with-question{display:flex;align-items:center;justify-content:space-between;width:100%}::ng-deep .vx-form-group .selected .chip-container span.chip.with-question span.value{color:#1e5dd3;font-size:12px;font-weight:400;line-height:24px;padding:0;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;max-width:calc(100% - 80px)}::ng-deep .vx-form-group .selected .chip-container span.chip.with-question span.label{background:#f1f1f1;border-radius:2px;color:#042e7d;font-size:9px;font-weight:600;text-transform:uppercase;padding-left:4px;padding-right:4px;line-height:12px;margin-left:8px}::ng-deep .vx-form-group .selected .chip-container span.value{color:#747576;font-size:13px;line-height:20px;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:calc(100% - 52px);padding:0 4px}::ng-deep .vx-form-group .selected .chip-container span.checkpoint-point-text{color:#747576;font-size:10px;font-weight:500;padding:0 8px;width:122px;line-height:14px}::ng-deep .vx-form-group .selected .chip-container span.checkpoint-point-text.first{position:relative;min-width:162px}::ng-deep .vx-form-group .selected .chip-container span.checkpoint-point-text.first:before{background:#f1f1f1;content:\"\";position:absolute;top:0;right:0;height:calc(100% + 12px);width:1px}::ng-deep .vx-form-group .selected .chip-container span.checkpoint-point-text .no{color:#1e5dd3}::ng-deep .vx-form-group .selected .chip-container.plus span.chip{max-width:calc(50% - 35px)}::ng-deep .vx-form-group .selected .chip-container.more-one span.chip{max-width:50%}::ng-deep .vx-form-group .selected .chip-container .chip-inner{background:#fff;border-radius:2px;box-shadow:0 2px 4px #1e5dd31a;line-height:24px;padding:0 4px 0 8px;display:flex;align-items:center}::ng-deep .vx-form-group .selected .chip-container .chip-inner .chip{background:transparent;border-radius:0;box-shadow:none;height:auto;line-height:unset;padding:0;color:#747576;max-width:100px}::ng-deep .vx-form-group .selected .chip-container .chip-inner button.count{border-radius:20px;height:16px;padding:0 6px;border:none;font-size:9px;line-height:16px;margin-left:4px;min-width:20px}::ng-deep .vx-form-group .selected .chip-container .chip-inner button.count.user{background:#34aa44}::ng-deep .vx-form-group .selected .chip-container .chip-inner i.cross{cursor:pointer;position:relative;top:1px;font-size:8px}::ng-deep .vx-form-group .selected button.count{background:#1e5dd3;border-radius:2px;height:24px;padding:0 8px;border:1px solid #1e5dd3;cursor:pointer;outline:none;color:#fff;font:13px;font-weight:500;line-height:20px;white-space:nowrap;margin-left:8px}::ng-deep .vx-form-group .selected button.edit{border:none;border-radius:0;background:transparent;outline:none;cursor:pointer;display:block;font-size:11px;font-weight:600;color:#1e5dd3;text-transform:uppercase;white-space:nowrap;margin-left:8px}::ng-deep .vx-form-group .selected button.edit i{font-weight:400;font-size:8px;margin-right:4px}::ng-deep .vx-form-group .selected button.close-btn{background:transparent;border:none;padding:0;margin-left:8px;font-size:10px;color:#c7381b;display:flex;align-items:center}::ng-deep .vx-form-group .selected .workflow-label{min-width:92px;padding:4px;text-align:center;margin-left:-8px;margin-right:8px;border-right:1px solid #f1f1f1}::ng-deep .vx-form-group .selected .workflow-label p{margin:0;display:block;text-transform:uppercase}::ng-deep .vx-form-group .selected .workflow-label p.title{font-size:9px;line-height:12px;color:#161b2f;font-weight:500}::ng-deep .vx-form-group .selected .workflow-label p.description{font-size:11px;line-height:16px;color:#161b2f;font-weight:600}::ng-deep .vx-form-group .selected .workflow-label+.chip-container{width:calc(100% - 148px)}::ng-deep .vx-form-group .selected+.selected{margin-top:8px}::ng-deep .vx-form-group .selected+app-cs-switch{display:block;margin-top:8px}::ng-deep .vx-form-group .selected+app-cs-switch label.cs-switch span.value{white-space:nowrap;margin-right:5px;text-transform:uppercase}::ng-deep .vx-form-group .selected+app-cs-switch.who-toggle label.cs-switch span.value{color:#747576}::ng-deep .vx-form-group .selected+app-cs-radio{margin-top:8px!important}::ng-deep .vx-form-group .selected~app-cs-radio{margin-top:4px;display:block;width:100%}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item span.radio{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item span.value{font-size:11px;text-transform:uppercase;border:1px solid #dbdbdb;border-radius:4px;padding:8px 8px 8px 36px;width:100%;display:flex;justify-content:space-between;margin:0;max-width:100%;font-weight:500;color:#707070}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item span.value i{font-size:12px;color:#1e5dd3}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item svg{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group .selected~app-cs-radio label.radio-item input:checked~span.value{background:#eefcf0;border-color:#34aa44}::ng-deep .vx-form-group .selected.readOnly{pointer-events:none}::ng-deep .vx-form-group .selected span.chip{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .vx-form-group .select-list{position:absolute;background:#fff;box-shadow:0 0 5px #1e5dd345;top:100%;right:0;left:0;z-index:2}::ng-deep .vx-form-group .select-list .vx-radio-group label.vx-radio-item{width:100%;padding:12px 16px}::ng-deep .vx-form-group .select-list .vx-radio-group label.vx-radio-item:hover{background:#f8f8f8}::ng-deep .vx-form-group ::ng-deep vcomply-editor{margin-top:8px;display:block;pointer-events:auto!important;z-index:1}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container{border-radius:4px;border:1px solid #dbdbdb}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block{min-height:60px;padding:11px 15px;max-height:100px;line-height:20px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block ul{padding:0 0 0 10px;margin-top:0}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block ul li{list-style:disc}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block ol{padding:0 0 0 10px;margin-top:0}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editable-block ol li{list-style:decimal}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools{z-index:1;border-top:1px solid #dbdbdb;transition:none;border-radius:0 0 3px 3px;position:static}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button{height:22px!important;width:22px!important;padding:0 5px}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button svg{height:22px;width:12px}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button.submit{width:80px!important;line-height:22px;justify-content:center}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col .popover.small ul.option-list li button{width:100%!important;height:auto!important}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container:focus-within{border-color:#1e5dd3!important;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container:focus-within .editor-tools{border-color:#1e5dd3!important}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container:hover{border-color:#1e5dd3!important;box-shadow:0 3px 6px #1e5dd31a}::ng-deep .vx-form-group ::ng-deep vcomply-editor .editor-container:hover .editor-tools{border-color:#1e5dd3!important}::ng-deep .vx-form-group ::ng-deep vcomply-editor+app-cs-switch{margin-top:8px}::ng-deep .vx-form-group app-cs-switch label.cs-switch span.value{font-size:11px;color:#747576;text-transform:uppercase}::ng-deep .vx-form-group app-cs-switch+app-cs-switch{margin-top:8px}::ng-deep .vx-form-group .date-time-picker{display:flex;justify-content:space-between;height:40px;border-radius:4px;border:1px solid #dbdbdb;padding:11px 0;background:#fff}::ng-deep .vx-form-group .date-time-picker:focus-within{border-color:#1e5dd3;box-shadow:0 0 5px #1e5dd345}::ng-deep .vx-form-group .date-time-picker .picker-group{width:50%;position:relative;display:flex;align-items:center}::ng-deep .vx-form-group .date-time-picker .picker-group:first-of-type{border-right:1px solid #dbdbdb}::ng-deep .vx-form-group .date-time-picker .picker-group:only-of-type{border:none;width:100%}::ng-deep .vx-form-group .date-time-picker .picker-group input{height:38px;background:transparent;line-height:38px;font-size:13px;color:#747576;transition:all .2s ease-in-out;width:100%;font-weight:400;border:none;padding:0 12px 0 34px;outline:none}::ng-deep .vx-form-group .date-time-picker .picker-group input:focus,::ng-deep .vx-form-group .date-time-picker .picker-group input:hover{box-shadow:none;border:none}::ng-deep .vx-form-group .date-time-picker .picker-group input::placeholder{color:#999;font-size:13px}::ng-deep .vx-form-group .date-time-picker .picker-group input:-ms-input-placeholder{color:#999;font-size:13px}::ng-deep .vx-form-group .date-time-picker .picker-group input::-ms-input-placeholder{color:#999;font-size:13px}::ng-deep .vx-form-group .date-time-picker .picker-group i{display:flex;justify-content:center;align-items:center;height:16px;width:12px;position:absolute;left:12px;top:0;color:#747576;font-size:12px;pointer-events:none}::ng-deep .vx-form-group app-cs-radio.main-filed{margin-top:4px;display:block;width:100%}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item{width:100%;position:relative}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item span.radio{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item span.value{font-size:11px;text-transform:uppercase;border:1px solid #dbdbdb;border-radius:4px;padding:8px 8px 8px 36px;width:100%;display:flex;justify-content:space-between;margin:0;max-width:100%;color:#707070}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item span.value i{font-size:12px;color:#1e5dd3}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item svg{position:absolute;top:8px;left:12px}::ng-deep .vx-form-group app-cs-radio.main-filed label.radio-item input:checked~span.value{background:#eefcf0;border-color:#34aa44}::ng-deep .vx-form-group app-cs-radio.disabled{pointer-events:none;opacity:.5;filter:grayscale(1);background:#f1f1f1}::ng-deep .vx-form-group .switch-row{display:flex}::ng-deep .vx-form-group .switch-row app-cs-switch{display:block;margin-top:8px}::ng-deep .vx-form-group .switch-row app-cs-switch label.cs-switch span.value{white-space:nowrap;margin-right:0;text-transform:uppercase;color:#747576!important}::ng-deep .vx-form-group .switch-row app-cs-switch label.cs-switch span.value i{display:inline-flex;font-size:11px;cursor:pointer;color:#1e5dd3;align-items:center;line-height:16px;margin:0 4px}::ng-deep .vx-form-group .switch-row app-cs-switch+app-cs-switch{margin-left:8px}::ng-deep .vx-form-group .switch-row.align-right{justify-content:flex-end}::ng-deep .vx-form-group .switch-row.align-right label.cs-switch span.value{margin-right:8px}::ng-deep .vx-form-group .risk-type-field{background:#f8f8f8;border:1px solid #dbdbdb;border-radius:4px;height:40px;display:flex;align-items:center;padding:4px;position:relative;z-index:1}::ng-deep .vx-form-group .risk-type-field .type-item{width:50%;position:relative}::ng-deep .vx-form-group .risk-type-field .type-item button{background:transparent;border:none;border-radius:0;color:#747576;font-size:11px;font-weight:600;text-transform:uppercase;width:100%;height:32px;padding:0 12px;text-align:left}::ng-deep .vx-form-group .risk-type-field .type-item button.disabled{background:transparent!important;color:#dbdbdb!important;filter:unset!important;opacity:unset!important;pointer-events:none;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group .risk-type-field .type-item .info{color:#1e5dd3;font-size:12px;position:absolute;top:10px;right:12px;cursor:pointer}::ng-deep .vx-form-group .risk-type-field .type-item .info.disabled{background:transparent!important;color:#dbdbdb!important;filter:unset!important;opacity:unset!important;pointer-events:none;-webkit-user-select:none;user-select:none}::ng-deep .vx-form-group .risk-type-field .type-item.active button{color:#1e5dd3!important}::ng-deep .vx-form-group .risk-type-field .type-item:nth-child(2).active~.background-glider{transform:translate(100%)}::ng-deep .vx-form-group .risk-type-field .background-glider{background:#fff;border-radius:4px;box-shadow:0 1px 3px #161b2f26;position:absolute;display:flex;width:212px;height:32px;z-index:-1;transition:.25s ease-out}.left{width:36px;height:36px;margin-top:26px;margin-left:-58px;margin-right:20px;display:flex;justify-content:center;align-items:center;position:relative;z-index:10;border-radius:50%}.left.deadline-completed{margin-top:18px}.left.checked{background:transparent}.left img{width:36px}.left .checkIcon{width:32px;height:32px;background:#fff;border-radius:50%;stroke-width:4;stroke:#34aa44;stroke-miterlimit:10;box-shadow:inset 0 0 #34aa44;animation:fillCheck .4s ease-in-out .4s forwards,scale .3s ease-in-out .9s both;margin-top:0}.left .checkIcon__circle{stroke-dasharray:166;stroke-dashoffset:166;stroke-width:2;stroke-miterlimit:10;stroke:#34aa44;fill:none;animation:strokeCheck .6s cubic-bezier(.65,0,.45,1) forwards}.left .checkIcon__check{transform-origin:50% 50%;stroke-dasharray:48;stroke-dashoffset:48;animation:strokeCheck .3s cubic-bezier(.65,0,.45,1) .8s forwards}.right{width:100%}.right span.indicator{position:absolute;top:36px;left:-16px;font-size:12px;color:#f0b819;cursor:pointer}.form-group-row{display:flex;position:relative;transition:all .2s ease-in-out}.form-group-row.disabled{-webkit-user-select:none;user-select:none;pointer-events:none;filter:grayscale(1);z-index:2}.form-group-row.disabled .left{position:relative}.form-group-row.disabled .left:before{content:\"\";position:absolute;inset:2px 0 0 2px;background:#fff;opacity:.7;border-radius:50%;width:32px;height:32px}.form-group-row.disabled .right{opacity:.3}.form-group-row.active{pointer-events:none;filter:grayscale(0);z-index:2;opacity:1}.form-group-row.active .right .vx-form-group input,.form-group-row.active .right .vx-form-group .custom-input,.form-group-row.active .right .vx-form-group .selectBoxEnable{border-color:#1e5dd3;box-shadow:0 3px 6px #1e5dd31a}.form-group-row.active .right .vx-form-group .selectBoxEnable.disabled{border-color:#dbdbdb;box-shadow:none}::ng-deep .radio-group-selector app-cs-radio{margin-top:4px;display:block;width:100%}::ng-deep .radio-group-selector app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .radio-group-selector app-cs-radio label.radio-item .radio,::ng-deep .radio-group-selector app-cs-radio label.radio-item .radiomark{position:absolute!important;top:9px;left:12px}::ng-deep .radio-group-selector app-cs-radio label.radio-item .value{font-size:11px!important;text-transform:uppercase;border:1px solid #dbdbdb;border-radius:4px;padding:8px 8px 8px 36px;width:100%;display:flex;justify-content:space-between;margin:0!important;max-width:100%!important;font-weight:500!important;color:#707070!important}::ng-deep .radio-group-selector app-cs-radio label.radio-item .value i{font-size:12px;color:#1e5dd3}::ng-deep .radio-group-selector app-cs-radio label.radio-item input:checked~span.value{background:#eefcf0;border-color:#34aa44}@keyframes strokeCheck{to{stroke-dashoffset:0}}@keyframes fillCheck{to{box-shadow:inset 0 0 0 2px #34aa44}}::ng-deep .wf-action-list{width:220px}::ng-deep .wf-action-list ul{padding:0;margin:0;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both;background:#fff;box-shadow:0 3px 6px #1c5bd140;border-radius:4px;max-height:220px;overflow:auto}::ng-deep .wf-action-list ul.action-item{display:block}::ng-deep .wf-action-list ul.action-item li{list-style:none;border:none;border-bottom:1px solid #f1f1f1;display:block;width:100%;padding:0;background:transparent;border-radius:0;margin:0;height:auto;justify-content:flex-start;box-shadow:none}::ng-deep .wf-action-list ul.action-item li button{color:#6e717e;text-align:left;text-decoration:none;cursor:pointer;background:transparent;font-size:12px;text-transform:capitalize;display:flex;width:100%;padding:7.5px 11px;border:none}::ng-deep .wf-action-list ul.action-item li button i{font-size:16px;margin-right:10px;color:#1e5dd3}::ng-deep .wf-action-list ul.action-item li button:hover{background:#f3f3f3}::ng-deep .wf-action-list ul.action-item li .avatar-card{display:flex;align-items:center;width:100%;padding:7.5px}::ng-deep .wf-action-list ul.action-item li .avatar-card.within-con{display:block}::ng-deep .wf-action-list ul.action-item li .avatar-card .avatar{height:24px;width:24px!important;overflow:hidden;background:#1e5dd3;color:#fff;font-size:10px;display:inline-flex;margin-right:5px;border-radius:50%;align-items:center;justify-content:center;text-transform:uppercase}::ng-deep .wf-action-list ul.action-item li .avatar-card .avatar img{width:100%}::ng-deep .wf-action-list ul.action-item li .avatar-card .avatar+span.value{width:calc(100% - 29px)}::ng-deep .wf-action-list ul.action-item li .avatar-card span.value{width:100%;color:#6e717e;text-decoration:none;background:transparent;font-size:12px;text-transform:capitalize;display:block;font-weight:400;text-align-last:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:20px}::ng-deep .wf-action-list ul.action-item li .avatar-card span.value i{font-size:8px;color:#747576;cursor:pointer;margin-right:5px}::ng-deep .wf-action-list ul.action-item li .avatar-card.no-image{display:block}::ng-deep .wf-action-list ul.action-item li .avatar-card.no-image span.value{width:100%;display:block}::ng-deep .wf-action-list ul.action-item li .chip-item{color:#1e5dd3;padding:10px;display:flex;align-items:center}::ng-deep .wf-action-list ul.action-item li .chip-item i{color:#747576;margin-right:7px;font-size:10px;cursor:pointer;display:inline-flex}::ng-deep .wf-action-list ul.action-item li .chip-item span{display:block;width:auto;max-width:calc(100% - 17px);font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}::ng-deep .wf-action-list ul.action-item li .chip-item span.chip-block{display:block;width:100%}::ng-deep .wf-action-list ul.action-item li .chip-item span.id{font-size:9px}::ng-deep .wf-action-list ul.action-item li .within{display:flex;align-items:center;justify-content:flex-start}::ng-deep .wf-action-list ul.action-item li .within .block{background:#f1f1f1;border-radius:2px;padding:0 2px;line-height:14px;font-size:9px;font-weight:500;color:#042e7d;margin-right:6px;display:block;text-transform:uppercase}::ng-deep .wf-action-list ul.action-item li .within .data{width:100%;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#747576;font-size:11px;font-weight:400;line-height:17px}::ng-deep .wf-action-list ul.action-item li:first-child{animation:action-list-open .25s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(2){animation:action-list-open .35s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(3){animation:action-list-open .45s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(4){animation:action-list-open .55s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(5){animation:action-list-open .65s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(6){animation:action-list-open .75s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(7){animation:action-list-open .85s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(8){animation:action-list-open .95s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(9){animation:action-list-open 1.05s cubic-bezier(.25,.46,.45,.94) both}::ng-deep .wf-action-list ul.action-item li:nth-child(10){animation:action-list-open 1.15s cubic-bezier(.25,.46,.45,.94) both}@keyframes action-list-open{0%{transform:translateY(50px)}to{transform:translateY(0)}}@keyframes scale-up-center{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}p.error-message{font-size:11px;font-weight:400;color:#eb2424;line-height:16px;margin-top:8px;margin-bottom:0}.edit-loader{position:absolute;top:-3px;left:-3px;width:46px;height:46px;transform:rotate(180deg)}.circular-loader{animation:rotate 2s linear infinite;height:100%;transform-origin:center center;width:100%;position:absolute;top:0;left:0;margin:auto}.loader-path{stroke-dasharray:150,200;stroke-dashoffset:-10;animation:dash 1.5s ease-in-out infinite;stroke-linecap:round}@keyframes rotate{to{transform:rotate(360deg)}}@keyframes dash{0%{stroke-dasharray:1,200;stroke-dashoffset:0}50%{stroke-dasharray:89,200;stroke-dashoffset:-35}to{stroke-dasharray:89,200;stroke-dashoffset:-124}}::ng-deep .dropdown{position:fixed;background:#fff;box-shadow:0 3px 6px #00000029;padding:24px 0;z-index:9;max-height:calc(100vh - 200px);overflow:auto}::ng-deep .dropdown ul.dropdown-list{padding:0 20px;margin:0;display:block}::ng-deep .dropdown ul.dropdown-list li{list-style:none}::ng-deep .dropdown ul.dropdown-list li app-cs-radio{display:flex}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item{width:100%;position:relative}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item span.radio{position:absolute;top:12px;left:12px}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item span.value{padding:11px 12px 11px 32px;width:100%;border:1px solid #bcbcbc;border-radius:4px;margin-left:0;max-width:100%}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item svg{position:absolute;top:12px;left:12px}::ng-deep .dropdown ul.dropdown-list li app-cs-radio label.radio-item input[type=radio]:checked~span.value{background:#e8feeb;border-color:#34aa44}::ng-deep .dropdown ul.dropdown-list li+li{margin-top:8px}app-smiley-dialog{position:relative;z-index:10}app-smiley-dialog-inline{position:absolute;top:-3px;right:0;bottom:0;z-index:999;width:520px;height:calc(100vh + 3px)}::ng-deep .vx-overlay{position:fixed;z-index:3;inset:0}::ng-deep dp-date-picker{width:100%;position:fixed!important;z-index:14;top:-40px;left:0}::ng-deep dp-date-picker input{width:100%;border:none;opacity:0;pointer-events:none}::ng-deep dp-date-picker input:focus{outline:none}::ng-deep dp-date-picker .dp-popup{width:412px;box-shadow:0 0 20px #161b2f26;background-color:#fff;border-radius:4px;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both}::ng-deep dp-date-picker .dp-popup dp-day-calendar,::ng-deep dp-date-picker .dp-popup dp-month-calendar{width:100%;pointer-events:auto}::ng-deep dp-date-picker .dp-popup dp-day-calendar button,::ng-deep dp-date-picker .dp-popup dp-month-calendar button{background:transparent;border:none;outline:none}::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-current-location-btn,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-current-location-btn,::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-calendar-nav-left,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-calendar-nav-left,::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-calendar-nav-right,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-calendar-nav-right{width:40px;height:40px;display:flex;justify-content:center;align-items:center;border-radius:50%;font-size:14px}::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-current-location-btn:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-current-location-btn:hover,::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-calendar-nav-left:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-calendar-nav-left:hover,::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-calendar-nav-right:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-calendar-nav-right:hover{background-color:#f3f3f3}::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-current-location-btn,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-current-location-btn{display:none}::ng-deep dp-date-picker .dp-popup dp-day-calendar button.dp-current-location-btn:before,::ng-deep dp-date-picker .dp-popup dp-month-calendar button.dp-current-location-btn:before{content:\"\";height:10px;width:10px;border-radius:50%;background:#000;display:inline-flex}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week{display:flex;justify-content:space-around}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays .dp-calendar-weekday,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays .dp-calendar-weekday,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week .dp-calendar-weekday,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week .dp-calendar-weekday{width:52px;border-left:none;border-bottom-color:#fff;color:#747576;font-size:11px;font-weight:600;text-transform:uppercase}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays button,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week button{width:40px;height:40px;border-radius:50%;display:inline-flex;justify-content:center;align-items:center}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays button:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays button:hover,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week button:hover,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week button:hover{background-color:#f3f3f3}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays button.dp-selected,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays button.dp-selected,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week button.dp-selected,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week button.dp-selected{background:#1e5dd3}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-weekdays button.dp-current-day,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-weekdays button.dp-current-day,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-week button.dp-current-day,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-week button.dp-current-day{border:1px solid rgba(0,0,0,.38);color:#1e5dd3;background-color:#fff}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-day-calendar-container,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-day-calendar-container{padding:20px;border-radius:2px}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-nav-container,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-nav-container{display:flex;margin:0 0 20px;border:none}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-nav-container .dp-nav-header button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-nav-container .dp-nav-header button{color:#000;font-size:17px;font-weight:500;margin:0 0 0 12px;padding:0}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-nav-btns-container,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-nav-btns-container{width:80px;display:flex}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-nav-btns-container .dp-calendar-nav-container-left button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-nav-btns-container .dp-calendar-nav-container-left button,::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-nav-btns-container .dp-calendar-nav-container-right button,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-nav-btns-container .dp-calendar-nav-container-right button{margin:0!important}::ng-deep dp-date-picker .dp-popup dp-day-calendar .dp-calendar-wrapper,::ng-deep dp-date-picker .dp-popup dp-month-calendar .dp-calendar-wrapper{border:none}::ng-deep dp-date-picker .dp-open+div{position:fixed!important;inset:0!important;display:flex;justify-content:center;align-items:center;z-index:99;pointer-events:none;background:#0000004d}::ng-deep .cdk-overlay-container{z-index:2147483002!important}::ng-deep .dp-popup{z-index:999;display:flex!important;align-items:center;justify-content:center;width:100vw;height:100vh;background:#0000004d!important;box-shadow:unset!important}::ng-deep .dp-popup dp-day-calendar{width:412px!important;box-shadow:0 0 20px #161b2f26;background-color:#fff;border-radius:4px;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both}::ng-deep .dp-popup dp-day-calendar,::ng-deep .dp-popup dp-month-calendar{width:100%;pointer-events:auto}::ng-deep .dp-popup dp-day-calendar button,::ng-deep .dp-popup dp-month-calendar button{background:transparent;border:none;outline:none}::ng-deep .dp-popup dp-day-calendar button.dp-current-location-btn,::ng-deep .dp-popup dp-month-calendar button.dp-current-location-btn,::ng-deep .dp-popup dp-day-calendar button.dp-calendar-nav-left,::ng-deep .dp-popup dp-month-calendar button.dp-calendar-nav-left,::ng-deep .dp-popup dp-day-calendar button.dp-calendar-nav-right,::ng-deep .dp-popup dp-month-calendar button.dp-calendar-nav-right{width:40px;height:40px;display:flex;justify-content:center;align-items:center;border-radius:50%;font-size:14px}::ng-deep .dp-popup dp-day-calendar button.dp-current-location-btn:hover,::ng-deep .dp-popup dp-month-calendar button.dp-current-location-btn:hover,::ng-deep .dp-popup dp-day-calendar button.dp-calendar-nav-left:hover,::ng-deep .dp-popup dp-month-calendar button.dp-calendar-nav-left:hover,::ng-deep .dp-popup dp-day-calendar button.dp-calendar-nav-right:hover,::ng-deep .dp-popup dp-month-calendar button.dp-calendar-nav-right:hover{background-color:#f3f3f3}::ng-deep .dp-popup dp-day-calendar button.dp-current-location-btn,::ng-deep .dp-popup dp-month-calendar button.dp-current-location-btn{display:none}::ng-deep .dp-popup dp-day-calendar button.dp-current-location-btn:before,::ng-deep .dp-popup dp-month-calendar button.dp-current-location-btn:before{content:\"\";height:10px;width:10px;border-radius:50%;background:#000;display:inline-flex}::ng-deep .dp-popup dp-day-calendar .dp-weekdays,::ng-deep .dp-popup dp-month-calendar .dp-weekdays,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week{display:flex;justify-content:space-around}::ng-deep .dp-popup dp-day-calendar .dp-weekdays .dp-calendar-weekday,::ng-deep .dp-popup dp-month-calendar .dp-weekdays .dp-calendar-weekday,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week .dp-calendar-weekday,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week .dp-calendar-weekday{width:52px;border-left:none;border-bottom-color:#fff;color:#747576;font-size:11px;font-weight:600;text-transform:uppercase}::ng-deep .dp-popup dp-day-calendar .dp-weekdays button,::ng-deep .dp-popup dp-month-calendar .dp-weekdays button,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week button,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week button{width:40px;height:40px;border-radius:50%;display:inline-flex;justify-content:center;align-items:center}::ng-deep .dp-popup dp-day-calendar .dp-weekdays button:hover,::ng-deep .dp-popup dp-month-calendar .dp-weekdays button:hover,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week button:hover,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week button:hover{background-color:#f3f3f3}::ng-deep .dp-popup dp-day-calendar .dp-weekdays button.dp-selected,::ng-deep .dp-popup dp-month-calendar .dp-weekdays button.dp-selected,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week button.dp-selected,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week button.dp-selected{background:#1e5dd3}::ng-deep .dp-popup dp-day-calendar .dp-weekdays button.dp-current-day,::ng-deep .dp-popup dp-month-calendar .dp-weekdays button.dp-current-day,::ng-deep .dp-popup dp-day-calendar .dp-calendar-week button.dp-current-day,::ng-deep .dp-popup dp-month-calendar .dp-calendar-week button.dp-current-day{border:1px solid rgba(0,0,0,.38);color:#1e5dd3;background-color:#fff}::ng-deep .dp-popup dp-day-calendar .dp-day-calendar-container,::ng-deep .dp-popup dp-month-calendar .dp-day-calendar-container{padding:20px;border-radius:2px}::ng-deep .dp-popup dp-day-calendar .dp-calendar-nav-container,::ng-deep .dp-popup dp-month-calendar .dp-calendar-nav-container{display:flex;margin:0 0 20px;border:none}::ng-deep .dp-popup dp-day-calendar .dp-calendar-nav-container .dp-nav-header button,::ng-deep .dp-popup dp-month-calendar .dp-calendar-nav-container .dp-nav-header button{color:#000;font-size:17px;font-weight:500;margin:0 0 0 12px;padding:0}::ng-deep .dp-popup dp-day-calendar .dp-nav-btns-container,::ng-deep .dp-popup dp-month-calendar .dp-nav-btns-container{width:80px;display:flex}::ng-deep .dp-popup dp-day-calendar .dp-nav-btns-container .dp-calendar-nav-container-left button,::ng-deep .dp-popup dp-month-calendar .dp-nav-btns-container .dp-calendar-nav-container-left button,::ng-deep .dp-popup dp-day-calendar .dp-nav-btns-container .dp-calendar-nav-container-right button,::ng-deep .dp-popup dp-month-calendar .dp-nav-btns-container .dp-calendar-nav-container-right button{margin:0!important}::ng-deep .dp-popup dp-day-calendar .dp-calendar-wrapper,::ng-deep .dp-popup dp-month-calendar .dp-calendar-wrapper{border:none}@keyframes slide-bottom{0%{transform:translateY(-100px)}to{transform:translateY(0)}}::ng-deep span.file{display:block;width:20px;min-width:20px;border-radius:0 0 2px 2px;border:1px solid transparent;border-color:#747576;position:relative;margin-right:5px;border-top:none;margin-top:5px;background:#fff}::ng-deep span.file.table{margin-right:8px;width:18px;min-width:18px}::ng-deep span.file.table i{font-size:8px}::ng-deep span.file.table .format{height:8px;font-size:7px;line-height:8px;font-weight:400}::ng-deep span.file:before{position:absolute;border-radius:0;top:-4px;right:-1px;content:\"\";height:4px;width:4px;display:block;background:linear-gradient(45deg,#747576 0% 1%,#747576 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file:after{height:4px;left:-1px;right:3px;border-top:1px solid;border-right:none;border-left:1px solid;content:\"\";top:-4px;position:absolute;border-radius:2px 0 0;background:#fff}::ng-deep span.file .format{height:10px;font-size:6px;text-transform:uppercase;background:transparent;font-weight:600;text-align:center;display:block;line-height:10px}::ng-deep span.file i{font-size:10px;height:10px;display:flex;align-items:center;justify-content:center;color:#dbdbdb}::ng-deep span.file.docx{width:22px!important}::ng-deep span.file.pdf,::ng-deep span.file.template{border-color:#f31c39}::ng-deep span.file.pdf:before,::ng-deep span.file.template:before{background:linear-gradient(45deg,#f31c39 0% 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#f31c39\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.pdf:after,::ng-deep span.file.template:after{border-color:#f31c39}::ng-deep span.file.pdf .format,::ng-deep span.file.template .format{color:#f31c39}::ng-deep span.file.xlsx,::ng-deep span.file.xls,::ng-deep span.file.css,::ng-deep span.file.scss,::ng-deep span.file.less{border-color:#34aa44}::ng-deep span.file.xlsx:before,::ng-deep span.file.xls:before,::ng-deep span.file.css:before,::ng-deep span.file.scss:before,::ng-deep span.file.less:before{background:linear-gradient(45deg,#34aa44 0% 1%,#34aa44 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.xlsx:after,::ng-deep span.file.xls:after,::ng-deep span.file.css:after,::ng-deep span.file.scss:after,::ng-deep span.file.less:after{border-color:#34aa44;color:#34aa44}::ng-deep span.file.xlsx .format,::ng-deep span.file.xls .format,::ng-deep span.file.css .format,::ng-deep span.file.scss .format,::ng-deep span.file.less .format{color:#34aa44}::ng-deep span.file.doc,::ng-deep span.file.docx,::ng-deep span.file.psd{border-color:#1e5dd3}::ng-deep span.file.doc:before,::ng-deep span.file.docx:before,::ng-deep span.file.psd:before{background:linear-gradient(45deg,#1e5dd3 0% 1%,#1e5dd3 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.doc:after,::ng-deep span.file.docx:after,::ng-deep span.file.psd:after{border-color:#1e5dd3}::ng-deep span.file.doc .format,::ng-deep span.file.docx .format,::ng-deep span.file.psd .format{color:#1e5dd3}::ng-deep span.file.ppt,::ng-deep span.file.ai,::ng-deep span.file.html,::ng-deep span.file.jpg,::ng-deep span.file.jpeg,::ng-deep span.file.png{border-color:#f6882f}::ng-deep span.file.ppt:before,::ng-deep span.file.ai:before,::ng-deep span.file.html:before,::ng-deep span.file.jpg:before,::ng-deep span.file.jpeg:before,::ng-deep span.file.png:before{background:linear-gradient(45deg,#f6882f 0% 1%,#f6882f 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.ppt:after,::ng-deep span.file.ai:after,::ng-deep span.file.html:after,::ng-deep span.file.jpg:after,::ng-deep span.file.jpeg:after,::ng-deep span.file.png:after{border-color:#f6882f}::ng-deep span.file.ppt .format,::ng-deep span.file.ai .format,::ng-deep span.file.html .format,::ng-deep span.file.jpg .format,::ng-deep span.file.jpeg .format,::ng-deep span.file.png .format{color:#f6882f}::ng-deep span.file.php{border-color:#7aa6f7}::ng-deep span.file.php:before{background:linear-gradient(45deg,#7aa6f7 0% 1%,#7aa6f7 50%,#2989d800 51%,#7db9e800);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=\"#34aa44\",endColorstr=\"#007db9e8\",GradientType=1)}::ng-deep span.file.php:after{border-color:#7aa6f7}::ng-deep span.file.php .format{color:#7aa6f7}::ng-deep ngx-material-timepicker-container .timepicker-backdrop-overlay{background-color:#0000000d!important;z-index:9999999999!important}::ng-deep ngx-material-timepicker-container .timepicker-overlay{z-index:9999999999!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker{width:232px!important;border-radius:2px!important;box-shadow:0 4px 30px #161b2f26!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header{background-color:#fff!important;padding:0!important;border-radius:2px 2px 0 0}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container{display:block!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time{color:#000!important;width:150px!important;margin:0 auto;line-height:60px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time ngx-material-timepicker-dial-control .timepicker-dial__control{font-size:40px;background-color:transparent!important;color:#000!important;font-weight:600;text-align:right;caret-color:transparent;outline:none;font-family:Poppins;line-height:56px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time ngx-material-timepicker-dial-control .timepicker-dial__control:focus,::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time ngx-material-timepicker-dial-control .timepicker-dial__control:hover{background-color:transparent!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time ngx-material-timepicker-dial-control:last-of-type .timepicker-dial__control{text-align:left}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__time span{padding:0 8px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period{display:flex!important;width:182px;margin:0 auto!important;background:#f1f1f1;padding:4px 10px;border-radius:20px;position:relative}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period:before{background:#f1f1f1;content:\"\";position:absolute;top:15px;left:-25px;width:calc(100% + 50px);height:2px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period{flex-direction:unset!important;position:relative;z-index:1}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period:after{content:\"\";position:absolute;right:-12px;top:0;border-left:solid 14px #f1f1f1;border-bottom:solid 12px transparent;border-top:solid 12px transparent;z-index:-1}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period:before{content:\"\";position:absolute;left:-18px;top:0;border-right:solid 14px #f1f1f1;border-bottom:solid 12px transparent;border-top:solid 12px transparent;z-index:-1}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period button{font-size:11px;background-color:transparent;padding:0;border-radius:20px;color:#747576;font-weight:600;font-family:Poppins;width:84px;height:24px}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period button.timepicker-dial__item_active{background:#fff!important;color:#1e5dd3!important;box-shadow:0 1px 2px #dbdbdb}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__header .timepicker-dial__container .timepicker-dial__period .timepicker-period button+button{margin-left:0!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face{width:200px!important;height:200px!important;padding:10px!important;background:transparent!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__number--outer{height:92px!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__number--outer span{color:#000}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__number--outer span.active{color:#fff}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__clock-hand{height:80px!important;top:calc(50% - 80px)!important;background-color:#1e5dd3!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__number>span.active{background-color:#1e5dd3!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .clock-face .clock-face__clock-hand_minute:before{border:4px solid #1e5dd3!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .timepicker__actions{display:flex!important;padding:10px 0 0!important;background:#fff!important;justify-content:space-around!important;border-radius:0 0 2px 2px!important;overflow:hidden}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .timepicker__actions div:first-child ngx-material-timepicker-button button.timepicker-button{background:#f8f8f8;color:#1e5dd3}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .timepicker__actions div ngx-material-timepicker-button button.timepicker-button{line-height:28px!important;width:100%;background:#1e5dd3;color:#fff;border-radius:0!important;height:32px!important;width:116px!important}::ng-deep ngx-material-timepicker-container ngx-material-timepicker-content .timepicker .timepicker__main-content .timepicker__actions div ngx-material-timepicker-button button.timepicker-button span{font-weight:500!important;font-size:11px;font-family:Poppins}::ng-deep vcomply-editor{display:block}::ng-deep vcomply-editor .editor-container{border-radius:4px;border:1px solid #dbdbdb;transition:all .2s ease-in-out}::ng-deep vcomply-editor .editor-container:hover,::ng-deep vcomply-editor .editor-container:focus-within{border:1px solid #1e5dd3;box-shadow:0 3px 6px #1e5dd31a}::ng-deep vcomply-editor .editor-container mention-list ul li a{font-size:16px!important}::ng-deep vcomply-editor .editor-container .editable-block{background:#fff;min-height:60px;padding:8px 12px;line-height:20px;font-size:13px;color:#747576;font-weight:400;transition:all .2s ease-in-out;width:100%}::ng-deep vcomply-editor .editor-container .editable-block:before{color:#747576!important}::ng-deep vcomply-editor .editor-container .editor-tools{border-top:1px solid #dbdbdb;border-radius:0 0 3px 3px}::ng-deep vcomply-editor .editor-container .editor-tools:hover{border-color:#1e5dd3}::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button{height:22px!important;width:22px!important;padding:0 5px}::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button svg{height:22px;width:12px}::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col button.submit{width:80px!important;line-height:22px;justify-content:center}::ng-deep vcomply-editor .editor-container .editor-tools app-editor-menu .editor-menu .col .popover.small ul.option-list li button{width:100%!important;height:auto!important}::ng-deep marx-modal .popup-modal-background{background-color:#161b2fcc!important}::ng-deep .within-box{background:#f1f1f1;border-radius:.125rem;color:#042e7d}::ng-deep .within-value{overflow:hidden;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;word-break:break-word}.wf-tooltip{pointer-events:none;position:absolute;max-width:300px;font-size:12px;text-align:left;color:#fff;padding:8px 12px;background:#000;border-radius:2px;z-index:-222;top:0;opacity:0;white-space:break-spaces;word-break:break-word}.wf-tooltip *{color:#fff!important}.wf-tooltip:empty{display:none!important}.wf-tooltip.white{box-shadow:0 2px 8px #1c5bd159;color:#747576;background:#fff;text-align:left}.wf-tooltip.white b{color:#747576!important}.wf-tooltip.animate-top{animation:animate-top .5s cubic-bezier(.25,.46,.45,.94) both}.wf-tooltip.animate-right{animation:animate-right .3s cubic-bezier(.25,.46,.45,.94) both}.wf-tooltip.animate-bottom{animation:animate-bottom .5s cubic-bezier(.25,.46,.45,.94) both}.wf-tooltip.animate-left{animation:animate-left .5s cubic-bezier(.25,.46,.45,.94) both}.wf-tooltip-top:after{top:100%;left:50%;margin-left:-5px;border-width:5px;border-color:#000000 transparent transparent transparent}.wf-tooltip-top.white:after{border-color:#f1f1f1 transparent transparent transparent}.wf-tooltip-bottom:after{bottom:100%;left:50%;margin-left:-5px;border-width:5px;border-color:transparent transparent #000000 transparent}.wf-tooltip-bottom.white:after{border-color:transparent transparent #f1f1f1 transparent}.wf-tooltip-left.white:after{border-color:transparent transparent transparent #f1f1f1}.wf-tooltip-left:after{top:50%;left:100%;margin-top:-5px;border-width:5px;border-color:transparent transparent transparent #000000}.wf-tooltip-right.white:after{border-color:transparent #f1f1f1 transparent transparent}.wf-tooltip-right:after{top:50%;right:100%;margin-top:-5px;border-width:5px;border-color:transparent #000000 transparent transparent}.wf-tooltip-bottom-right:after{bottom:100%;left:100%;margin-left:-20px;border-width:5px;border-color:transparent transparent #000000 transparent}.wf-tooltip-bottom-right.white:after{border-color:transparent transparent #f1f1f1 transparent}.wf-tooltip-bottom-left:after{bottom:100%;left:0;margin-left:10px;border-width:5px;border-color:transparent transparent #000000 transparent}.wf-tooltip-bottom-left.white:after{border-color:transparent transparent #f1f1f1 transparent}.wf-tooltip-top-left:after{top:100%;left:0;margin-left:10px;border-width:5px;border-color:#000000 transparent transparent transparent}.wf-tooltip-top-left.white:after{border-color:#f1f1f1 transparent transparent transparent}.wf-tooltip-top-right:after{top:100%;left:100%;margin-left:-5px;border-width:5px;border-color:#000000 transparent transparent transparent}.wf-tooltip-top-right.white:after{border-color:#f1f1f1 transparent transparent transparent}.wf-tooltip:after{content:\"\";position:absolute;border-style:solid}.wf-tooltip span.within{font-size:80%;display:block;width:100%}.wf-tooltip .small{display:block;font-size:10px}.wf-tooltip .within-box{background:#f1f1f1;border-radius:2px;color:#042e7d!important;font-size:9px;font-weight:500;text-transform:uppercase;padding:0 2px;margin-right:2px}.wf-tooltip-show{pointer-events:none;opacity:1;z-index:2147483001}\n"] }]
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\">&#xe90b;</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 >&#xe970;</i\n >\n <i *ngIf=\"expandedRows.includes(role?._id)\" class=\"icons\"\n >&#xe9e8;</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 >&#xe90d;</i\n >\n {{\n featureflagrole && data?.permissionGroupName\n ? data?.permissionGroupName\n : data?.roleName\n }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </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\">&#xe930;</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\">&#xe90b;</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 >&#xe970;</i\n >\n <i *ngIf=\"expandedRows.includes(role?._id)\" class=\"icons\"\n >&#xe9e8;</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 >&#xe90d;</i\n >\n {{\n featureflagrole && data?.permissionGroupName\n ? data?.permissionGroupName\n : data?.roleName\n }}\n </span>\n </div>\n </li>\n </ul>\n </div>\n </app-popover>\n </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\">&#xe930;</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\">&#xe91d;</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\">&#xe90b;</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\">&#xeae5;</i> Preview\n </button>\n <!-- <button class=\"action-btn\"><i class=\"icons\">&#xe90c;</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 >&#xe970;</i\n >\n <i *ngIf=\"openedCategory.includes(data?.id)\" class=\"icons\"\n >&#xe9e8;</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\">&#xeae5;</i> Preview\n </button>\n <!-- <button class=\"action-btn\"><i class=\"icons\">&#xe9ba;</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)\">&#xe90d;</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\">&#xe91d;</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\">&#xe90b;</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\">&#xeae5;</i> Preview\n </button>\n <!-- <button class=\"action-btn\"><i class=\"icons\">&#xe90c;</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 >&#xe970;</i\n >\n <i *ngIf=\"openedCategory.includes(data?.id)\" class=\"icons\"\n >&#xe9e8;</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\">&#xeae5;</i> Preview\n </button>\n <!-- <button class=\"action-btn\"><i class=\"icons\">&#xe9ba;</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)\">&#xe90d;</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] }); }