vcomply-workflow-engine 3.4.47 → 3.4.48

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.
@@ -175,7 +175,8 @@ export class WorkflowAssessmentComponent {
175
175
  }
176
176
  validateAssessment() {
177
177
  this.submitted = true;
178
- if (!this.assessmentForm.name || this.assessmentForm.category.length == 0) {
178
+ if (!this.assessmentForm.name.trim() ||
179
+ this.assessmentForm.category.length == 0) {
179
180
  return false;
180
181
  }
181
182
  else {
@@ -186,7 +187,7 @@ export class WorkflowAssessmentComponent {
186
187
  this.loader = true;
187
188
  this.uiKitService.isLoader = false;
188
189
  const payload = {
189
- assessment_name: assessmentForm.name,
190
+ assessment_name: assessmentForm.name.trim(),
190
191
  description: assessmentForm.description,
191
192
  assessment_type: assessmentForm.assessmentType,
192
193
  category_arr: this.assessmentForm.category.map((ele) => ele.id),
@@ -250,4 +251,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
250
251
  }], closeWorkflow: [{
251
252
  type: Output
252
253
  }] } });
253
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow-assessment.component.js","sourceRoot":"","sources":["../../../../../projects/vx-workflow-engine/src/lib/workflow-assessment/workflow-assessment.component.ts","../../../../../projects/vx-workflow-engine/src/lib/workflow-assessment/workflow-assessment.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,YAAY,EACZ,KAAK,EAEL,QAAQ,EACR,MAAM,GACP,MAAM,eAAe,CAAC;;;;;;;;;;;;;;;;;;;;;AAcvB,MAAM,OAAO,2BAA2B;IA+BtC,YACS,iBAAoC,EACnC,WAAwB,EACxB,YAA0B,EAC1B,QAAyB,EACrB,MAAuB;QAJ5B,sBAAiB,GAAjB,iBAAiB,CAAmB;QACnC,gBAAW,GAAX,WAAW,CAAa;QACxB,iBAAY,GAAZ,YAAY,CAAc;QAC1B,aAAQ,GAAR,QAAQ,CAAiB;QAlCnC,mBAAc,GAAQ,EAAE,CAAC;QACzB,cAAS,GAAG,KAAK,CAAC;QAClB,WAAM,GAAG,KAAK,CAAC;QACf,eAAU,GAAG,KAAK,CAAC;QACV,SAAI,GAAG,MAAM,CAAC;QACd,iBAAY,GAAG,EAAE,CAAC;QAClB,eAAU,GAAG,EAAE,CAAC;QACf,sBAAiB,GAAG,IAAI,YAAY,EAAE,CAAC;QACjD,yBAAoB,GAAQ,CAAC,UAAU,CAAC,CAAC;QACzC,kBAAa,GAAG;YACd,6EAA6E;YAC7E;gBACE,UAAU,EAAE,2BAA2B;gBACvC,KAAK,EAAE,UAAU;gBACjB,EAAE,EAAE,gBAAgB;aACrB;SACF,CAAC;QACF,gCAA2B,GAAG,IAAI,CAAC;QAEzB,kBAAa,GAAG,IAAI,YAAY,EAAE,CAAC;QACnC,kBAAa,GAAG,IAAI,YAAY,EAAE,CAAC;QAC7C,mBAAc,GAAQ;YACpB,cAAc,EAAE,YAAY;YAC5B,IAAI,EAAE,EAAE;YACR,WAAW,EAAE,EAAE;YACf,QAAQ,EAAE,EAAE;YACZ,UAAU,EAAE,EAAE;SACf,CAAC;QAEF,mBAAc,GAAG,CAAC,CAAC;QAUnB,mBAAc,GAAG;YACf,kBAAkB,EAAE;gBAClB,UAAU,EAAE,+BAA+B;gBAC3C,cAAc,EAAE,oBAAoB;gBACpC,YAAY,EAAE,sBAAsB;gBACpC,UAAU,EAAE,eAAe;gBAC3B,aAAa,EAAE,IAAI;gBACnB,SAAS,EAAE,kBAAkB;gBAC7B,gBAAgB,EAAE,aAAa;gBAC/B,iBAAiB,EAAE,gCAAgC;gBACnD,UAAU,EAAE,iCAAiC;aAC9C;SACF,CAAC;QAmFF,gBAAW,GAAiB;YAC1B,IAAI,EAAE,OAAO;YACb,YAAY,EAAE,IAAI;YAClB,IAAI,EAAE,IAAI;YACV,WAAW,EAAE,mBAAmB;SACjC,CAAC;QAtGA,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,eAAe,EAAE,CAAC;IACrD,CAAC;IAcD,QAAQ;QACN,qBAAqB;QACrB,IAAI,IAAI,CAAC,IAAI,KAAK,QAAQ,EAAE;YAC1B,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,WAAW,CAAC,iBAAiB,EAAE,CAAC;SAC5D;QACD,+CAA+C;QAC/C,IAAI,IAAI,CAAC,IAAI,KAAK,MAAM,EAAE;YACxB,IAAI,CAAC,oBAAoB,EAAE,CAAC;SAC7B;IACH,CAAC;IAED,oBAAoB;QAClB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,IAAI,CAAC,iBAAiB,CAAC,oBAAoB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,SAAS,CAAC;YACvE,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,IAAI,CAAC,cAAc,CAAC,IAAI,GAAG,GAAG,EAAE,eAAe,IAAI,EAAE,CAAC;gBACtD,IAAI,CAAC,cAAc,CAAC,WAAW,GAAG,GAAG,EAAE,WAAW,IAAI,EAAE,CAAC;gBACzD,IAAI,CAAC,cAAc,CAAC,cAAc;oBAChC,GAAG,EAAE,eAAe,IAAI,YAAY,CAAC;gBACvC,IAAI,CAAC,cAAc,CAAC,QAAQ,GAAG,GAAG,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE;oBAC/D,OAAO,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,aAAa,EAAE,GAAG,EAAE,aAAa,EAAE,CAAC;gBAC7D,CAAC,CAAC,CAAC;gBACH,IAAI,CAAC,2BAA2B;oBAC9B,GAAG,EAAE,eAAe,KAAK,YAAY,CAAC;gBACxC,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;YACtB,CAAC;YACD,KAAK,EAAE,CAAC,GAAQ,EAAE,EAAE;gBAClB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAChB,kGAAkG,EAClG,OAAO,CACR,CAAC;gBACF,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;YACtB,CAAC;SACF,CAAC,CAAC;IACL,CAAC;IAED,kEAAkE;IAClE,WAAW,CAAC,GAAQ;QAClB,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC;YACnC,YAAY,EAAE,GAAG,CAAC,SAAS;YAC3B,OAAO,EAAE,GAAG,CAAC,IAAI;SAClB,CAAC,CAAC;IACL,CAAC;IAED,gBAAgB,CAAC,IAAS,EAAE,KAAc;QACxC,IAAI,IAAI,KAAK,UAAU,EAAE;YACvB,IAAI,CAAC,WAAW,CAAC,EAAE,SAAS,EAAE,EAAE,EAAE,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC;SAC9C;QACD,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;QACxC,IAAI,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE;YAC5C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SAChC;IACH,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;QACzB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAED,IAAI,CAAC,IAAY,EAAE,OAAY;QAC7B,QAAQ,IAAI,EAAE;YACZ,KAAK,UAAU,CAAC,CAAC;gBACf,IAAI,CAAC,gBAAgB,EAAE,CAAC;gBACxB,IAAI,CAAC,cAAc,CAAC,QAAQ,GAAG,OAAO,CAAC;gBACvC,IAAI,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,MAAM,GAAG,CAAC,EAAE;oBAC5C,IAAI,CAAC,cAAc,CAAC,QAAQ,GAAG,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,MAAM,CAChE,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,aAAa,IAAI,eAAe,CACpD,CAAC;iBACH;aACF;SACF;IACH,CAAC;IAED,MAAM,CAAC,IAAS,EAAE,KAAU;QAC1B,QAAQ,IAAI,EAAE;YACZ,KAAK,UAAU;gBACb,IAAI,CAAC,cAAc,CAAC,QAAQ,GAAG,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,MAAM,CAChE,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,EAAE,KAAK,KAAK,EAAE,EAAE,CACpC,CAAC;SACL;IACH,CAAC;IASD,gBAAgB,CAAC,IAAY;QAC3B,IAAI,CAAC,cAAc,GAAG;YACpB,GAAG,IAAI,CAAC,cAAc;YACtB,GAAG,EAAE,cAAc,EAAE,IAAI,EAAE,iBAAiB,EAAE,EAAE;SACjD,CAAC;QACF,OAAO,CAAC,GAAG,CAAC,0BAA0B,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;IAC/D,CAAC;IACD,WAAW,CAAC,GAAQ;QAClB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,YAAY,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;IACtE,CAAC;IAED,MAAM,CAAC,GAAQ;QACb,IAAI,GAAG,KAAK,gBAAgB,EAAE;YAC5B,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACnC,MAAM,CAAC,QAAQ,CAAC,IAAI,GAAG,WAAW,MAAM,CAAC,QAAQ,CAAC,QAAQ,uCAAuC,IAAI,CAAC,YAAY,EAAE,CAAC;SACtH;IACH,CAAC;IAED,gBAAgB;QACd,IAAI,IAAI,CAAC,cAAc,CAAC,WAAW,IAAI,MAAM,EAAE;YAC7C,IAAI,CAAC,cAAc,CAAC,WAAW,GAAG,EAAE,CAAC;SACtC;IACH,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,MAAM,KAAK,GAAG,IAAI,CAAC,kBAAkB,EAAE,CAAC;QACxC,IAAI,CAAC,KAAK,EAAE;YACV,OAAO,KAAK,CAAC;SACd;aAAM;YACL,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;SAC5C;IACH,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,IAAI,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,MAAM,IAAI,CAAC,EAAE;YACzE,OAAO,KAAK,CAAC;SACd;aAAM;YACL,OAAO,IAAI,CAAC;SACb;IACH,CAAC;IAED,gBAAgB,CAAC,cAAmB;QAClC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,IAAI,CAAC,YAAY,CAAC,QAAQ,GAAG,KAAK,CAAC;QAEnC,MAAM,OAAO,GAAG;YACd,eAAe,EAAE,cAAc,CAAC,IAAI;YACpC,WAAW,EAAE,cAAc,CAAC,WAAW;YACvC,eAAe,EAAE,cAAc,CAAC,cAAc;YAC9C,YAAY,EAAE,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC;YACpE,qBAAqB,EAAE;gBACrB,IAAI,EAAE,MAAM;aACb;YACD,iBAAiB,EAAE,IAAI;YACvB,WAAW,EAAE,YAAY;SAC1B,CAAC;QACF,IAAI,IAAI,CAAC,IAAI,IAAI,QAAQ,EAAE;YACzB,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,SAAS,CACrD,CAAC,GAAQ,EAAE,EAAE;gBACX,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBACnC,IAAI,CAAC,YAAY,GAAG,GAAG,EAAE,GAAG,CAAC;gBAC7B,MAAM,CAAC,QAAQ,CAAC,IAAI,GAAG,WAAW,MAAM,CAAC,QAAQ,CAAC,QAAQ,sBAAsB,GAAG,EAAE,GAAG,EAAE,CAAC;gBAC3F,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;YACtB,CAAC,EACD,CAAC,GAAQ,EAAE,EAAE;gBACX,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;gBACnB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;gBACpB,IAAI,CAAC,YAAY,CAAC,QAAQ,GAAG,KAAK,CAAC;gBACnC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAChB,kGAAkG,EAClG,OAAO,CACR,CAAC;YACJ,CAAC,CACF,CAAC;SACH;aAAM,IAAI,IAAI,CAAC,IAAI,KAAK,MAAM,EAAE;YAC/B,IAAI,CAAC,iBAAiB;iBACnB,gBAAgB,CAAC,IAAI,CAAC,YAAY,EAAE,OAAO,CAAC;iBAC5C,SAAS,CAAC;gBACT,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;oBACjB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;oBACpB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;gBACzB,CAAC;gBACD,KAAK,EAAE,CAAC,GAAQ,EAAE,EAAE;oBAClB,IAAI,GAAG,EAAE,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,YAAY,CAAC,EAAE;wBAC/C,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;wBACpB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;qBACxB;yBAAM;wBACL,IAAI,CAAC,QAAQ,CAAC,IAAI,CAChB,kGAAkG,EAClG,OAAO,CACR,CAAC;qBACH;gBACH,CAAC;aACF,CAAC,CAAC;SACN;IACH,CAAC;;wHA/OU,2BAA2B;4GAA3B,2BAA2B,sQCrBxC,sngBAgbA;2FD3Za,2BAA2B;kBALvC,SAAS;+BACE,yBAAyB;;0BAwChC,QAAQ;4CA/BF,IAAI;sBAAZ,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACI,iBAAiB;sBAA1B,MAAM;gBAYG,aAAa;sBAAtB,MAAM;gBACG,aAAa;sBAAtB,MAAM","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Optional,\r\n  Output,\r\n} from '@angular/core';\r\n\r\nimport { EditorConfig } from 'vcomply-editor';\r\nimport { Configurations } from '../configurations';\r\nimport { SnackBarService } from '../ui-kit/snack-bar/snack-bar.service';\r\nimport { AssessmentService } from '../workflow-services/assessment.service';\r\nimport { AuthService } from '../workflow-services/auth.service';\r\nimport { UiKitService } from '../workflow-services/ui-kit.service';\r\n\r\n@Component({\r\n  selector: 'app-workflow-assessment',\r\n  templateUrl: './workflow-assessment.component.html',\r\n  styleUrls: ['./workflow-assessment.component.less', '../forms.less'],\r\n})\r\nexport class WorkflowAssessmentComponent implements OnInit {\r\n  activeSelector: any = '';\r\n  submitted = false;\r\n  loader = false;\r\n  showSmiley = false;\r\n  @Input() mode = 'EDIT';\r\n  @Input() assessmentId = '';\r\n  @Input() openedFrom = '';\r\n  @Output() disconnectRefresh = new EventEmitter();\r\n  sideSelectorElements: any = ['category'];\r\n  actionButtons = [\r\n    // { buttonText: 'Add More Assessments', class: 'white-btn', id: 'addMore' },\r\n    {\r\n      buttonText: 'Go to assessment workroom',\r\n      class: 'blue-btn',\r\n      id: 'viewAssessment',\r\n    },\r\n  ];\r\n  assessmentTypeChangeAllowed = true;\r\n  timezone!: string;\r\n  @Output() pickerChanged = new EventEmitter();\r\n  @Output() closeWorkflow = new EventEmitter();\r\n  assessmentForm: any = {\r\n    assessmentType: 'compliance',\r\n    name: '',\r\n    description: '',\r\n    category: [],\r\n    customTags: [],\r\n  };\r\n  assessmentData: any;\r\n  organizationId = 0;\r\n  constructor(\r\n    public assessmentService: AssessmentService,\r\n    private authService: AuthService,\r\n    private uiKitService: UiKitService,\r\n    private snackBar: SnackBarService,\r\n    @Optional() config?: Configurations\r\n  ) {\r\n    this.timezone = this.authService.getUserTimeZone();\r\n  }\r\n  selectorConfig = {\r\n    ASSESSMENT_CATGORY: {\r\n      panelTitle: 'Select an Assessment Category',\r\n      entitySingular: 'Category selected.',\r\n      entityPlural: 'Categories selected.',\r\n      displayKey: 'category_name',\r\n      identifierKey: 'id',\r\n      parentKey: 'category_parents',\r\n      parentDisplayKey: 'parent_tree',\r\n      searchPlaceholder: 'Search an assessment category.',\r\n      noDataText: 'No assessment categories found.',\r\n    },\r\n  };\r\n  ngOnInit(): void {\r\n    //this.loader = true;\r\n    if (this.mode === 'CREATE') {\r\n      this.organizationId = this.authService.getOrganizationId();\r\n    }\r\n    //this.setCategory({ searchKey: '', page: 1 });\r\n    if (this.mode === 'EDIT') {\r\n      this.getAssessmentDetails();\r\n    }\r\n  }\r\n\r\n  getAssessmentDetails() {\r\n    this.loader = true;\r\n    this.assessmentService.getAssessmentDetails(this.assessmentId).subscribe({\r\n      next: (res: any) => {\r\n        this.assessmentForm.name = res?.assessment_name ?? '';\r\n        this.assessmentForm.description = res?.description ?? '';\r\n        this.assessmentForm.assessmentType =\r\n          res?.assessment_type ?? 'compliance';\r\n        this.assessmentForm.category = res.category_arr.map((ele: any) => {\r\n          return { id: ele?._id, category_name: ele?.category_name };\r\n        });\r\n        this.assessmentTypeChangeAllowed =\r\n          res?.assessment_type === 'compliance';\r\n        this.loader = false;\r\n      },\r\n      error: (err: any) => {\r\n        this.snackBar.show(\r\n          'OOPS! Something went wrong and the page could not be loaded. Could you please try one more time?',\r\n          'alert'\r\n        );\r\n        this.loader = false;\r\n      },\r\n    });\r\n  }\r\n\r\n  //This function is responsible for fetching the list of categories\r\n  setCategory(evt: any) {\r\n    this.assessmentService.fetchCategory({\r\n      search_title: evt.searchKey,\r\n      page_no: evt.page,\r\n    });\r\n  }\r\n\r\n  activateSelector(type: any, event: boolean) {\r\n    if (type === 'category') {\r\n      this.setCategory({ searchKey: '', page: 1 });\r\n    }\r\n    this.activeSelector = event ? type : '';\r\n    if (this.sideSelectorElements.includes(type)) {\r\n      this.pickerChanged.emit(event);\r\n    }\r\n  }\r\n\r\n  activeDeselector() {\r\n    this.activeSelector = '';\r\n    this.pickerChanged.emit(false);\r\n  }\r\n\r\n  next(type: string, payload: any) {\r\n    switch (type) {\r\n      case 'CATEGORY': {\r\n        this.activeDeselector();\r\n        this.assessmentForm.category = payload;\r\n        if (this.assessmentForm.category?.length > 1) {\r\n          this.assessmentForm.category = this.assessmentForm.category.filter(\r\n            (ele: any) => ele?.category_name != 'uncategorized'\r\n          );\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  remove(type: any, event: any) {\r\n    switch (type) {\r\n      case 'category':\r\n        this.assessmentForm.category = this.assessmentForm.category.filter(\r\n          (ele: any) => ele?.id !== event?.id\r\n        );\r\n    }\r\n  }\r\n\r\n  description: EditorConfig = {\r\n    mode: 'prime',\r\n    colorPalette: true,\r\n    link: true,\r\n    placeholder: 'Add a description',\r\n  };\r\n\r\n  changeAssessment(type: string) {\r\n    this.assessmentForm = {\r\n      ...this.assessmentForm,\r\n      ...{ assessmentType: type?.toLocaleLowerCase() },\r\n    };\r\n    console.log('this.assessmentForm ===>', this.assessmentForm);\r\n  }\r\n  closeSmiley(evt: any) {\r\n    this.closeWorkflow.emit({ evt: this.assessmentId, confirm: false });\r\n  }\r\n\r\n  action(evt: any) {\r\n    if (evt === 'viewAssessment') {\r\n      this.disconnectRefresh.emit(false);\r\n      window.location.href = `https://${window.location.hostname}/assessment/assessment-workroom/?id=${this.assessmentId}`;\r\n    }\r\n  }\r\n\r\n  checkDescription() {\r\n    if (this.assessmentForm.description == '<br>') {\r\n      this.assessmentForm.description = '';\r\n    }\r\n  }\r\n\r\n  submitAssessment() {\r\n    this.submitted = true;\r\n    const valid = this.validateAssessment();\r\n    if (!valid) {\r\n      return false;\r\n    } else {\r\n      this.createAssessment(this.assessmentForm);\r\n    }\r\n  }\r\n\r\n  validateAssessment() {\r\n    this.submitted = true;\r\n    if (!this.assessmentForm.name || this.assessmentForm.category.length == 0) {\r\n      return false;\r\n    } else {\r\n      return true;\r\n    }\r\n  }\r\n\r\n  createAssessment(assessmentForm: any) {\r\n    this.loader = true;\r\n    this.uiKitService.isLoader = false;\r\n\r\n    const payload = {\r\n      assessment_name: assessmentForm.name,\r\n      description: assessmentForm.description,\r\n      assessment_type: assessmentForm.assessmentType,\r\n      category_arr: this.assessmentForm.category.map((ele: any) => ele.id),\r\n      approval_workflow_arr: {\r\n        test: 'test',\r\n      },\r\n      approval_required: true,\r\n      source_page: 'compliance',\r\n    };\r\n    if (this.mode == 'CREATE') {\r\n      this.assessmentService.addAssessment(payload).subscribe(\r\n        (res: any) => {\r\n          this.disconnectRefresh.emit(false);\r\n          this.assessmentId = res?._id;\r\n          window.location.href = `https://${window.location.hostname}/assessment/create/${res?._id}`;\r\n          this.loader = false;\r\n        },\r\n        (err: any) => {\r\n          console.error(err);\r\n          this.loader = false;\r\n          this.uiKitService.isLoader = false;\r\n          this.snackBar.show(\r\n            'OOPS! Something went wrong and the page could not be loaded. Could you please try one more time?',\r\n            'alert'\r\n          );\r\n        }\r\n      );\r\n    } else if (this.mode === 'EDIT') {\r\n      this.assessmentService\r\n        .updateAssessment(this.assessmentId, payload)\r\n        .subscribe({\r\n          next: (res: any) => {\r\n            this.loader = false;\r\n            this.showSmiley = true;\r\n          },\r\n          error: (err: any) => {\r\n            if (err?.error.message.startsWith('No changes')) {\r\n              this.loader = false;\r\n              this.showSmiley = true;\r\n            } else {\r\n              this.snackBar.show(\r\n                'OOPS! Something went wrong and the page could not be loaded. Could you please try one more time?',\r\n                'alert'\r\n              );\r\n            }\r\n          },\r\n        });\r\n    }\r\n  }\r\n}\r\n","<div class=\"workflow-assessment\">\r\n  <!-- Assessment Type -->\r\n  <div class=\"form-group-row\" [class.active]=\"false\" [class.disabled]=\"false\">\r\n    <div class=\"left checked\">\r\n      <svg\r\n        class=\"checkIcon\"\r\n        xmlns=\"http://www.w3.org/2000/svg\"\r\n        viewBox=\"0 0 52 52\"\r\n      >\r\n        <circle class=\"checkIcon__circle\" cx=\"26\" cy=\"26\" r=\"25\" fill=\"none\" />\r\n        <path\r\n          class=\"checkIcon__check\"\r\n          fill=\"none\"\r\n          d=\"M14.1 27.2l7.1 7.2 16.7-16.8\"\r\n        />\r\n      </svg>\r\n    </div>\r\n    <div class=\"right\">\r\n      <div class=\"vx-form-group\">\r\n        <label class=\"vx-control-panel\"\r\n          >ASSESSMENT TYPE <span class=\"required\">*</span></label\r\n        >\r\n        <div class=\"risk-type-field\">\r\n          <div\r\n            class=\"type-item\"\r\n            [class.active]=\"\r\n              assessmentForm?.assessmentType === 'compliance_audit'\r\n            \"\r\n          >\r\n            <button\r\n              [class.disabled]=\"!assessmentTypeChangeAllowed\"\r\n              (click)=\"changeAssessment('compliance_audit')\"\r\n            >\r\n              COMPLIANCE AUDIT\r\n            </button>\r\n            <i\r\n              class=\"icons info\"\r\n              [appTooltip]=\"'Compliance assessment info text here...'\"\r\n              placement=\"bottom-right\"\r\n              delay=\"0\"\r\n              type=\"white\"\r\n              [tooltipMandatory]=\"true\"\r\n              >&#xe932;</i\r\n            >\r\n          </div>\r\n          <div\r\n            class=\"type-item\"\r\n            [appTooltip]=\"\r\n              assessmentTypeChangeAllowed\r\n                ? ''\r\n                : 'You Cannot change the assessment type.'\r\n            \"\r\n            placement=\"bottom-left\"\r\n            delay=\"0\"\r\n            type=\"black\"\r\n            [tooltipMandatory]=\"true\"\r\n            [class.active]=\"assessmentForm?.assessmentType === 'compliance'\"\r\n          >\r\n            <button\r\n              [class.disabled]=\"!assessmentTypeChangeAllowed\"\r\n              (click)=\"changeAssessment('compliance')\"\r\n            >\r\n              Other\r\n            </button>\r\n            <i\r\n              class=\"icons info\"\r\n              [class.disabled]=\"!assessmentTypeChangeAllowed\"\r\n              [appTooltip]=\"'Risk assessment info text here...'\"\r\n              placement=\"bottom-right\"\r\n              delay=\"0\"\r\n              type=\"white\"\r\n              [tooltipMandatory]=\"true\"\r\n              >&#xe932;</i\r\n            >\r\n          </div>\r\n          <span class=\"background-glider\"></span>\r\n        </div>\r\n        <p *ngIf=\"false\" class=\"error-message\">Add an assessment type</p>\r\n      </div>\r\n    </div>\r\n  </div>\r\n\r\n  <!-- Assessment Name -->\r\n  <div\r\n    class=\"form-group-row\"\r\n    [class.active]=\"false\"\r\n    [class.disabled]=\"\r\n      activeSelector &&\r\n      activeSelector !== 'name' &&\r\n      sideSelectorElements.includes(activeSelector)\r\n    \"\r\n  >\r\n    <div class=\"left\" [class.checked]=\"false\">\r\n      <img\r\n        src=\"https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/what.svg\"\r\n        alt=\"im\"\r\n        *ngIf=\"!assessmentForm.name.trim() || activeSelector === 'name'\"\r\n      />\r\n\r\n      <svg\r\n        *ngIf=\"assessmentForm.name.trim() && activeSelector !== 'name'\"\r\n        class=\"checkIcon\"\r\n        xmlns=\"http://www.w3.org/2000/svg\"\r\n        viewBox=\"0 0 52 52\"\r\n      >\r\n        <circle class=\"checkIcon__circle\" cx=\"26\" cy=\"26\" r=\"25\" fill=\"none\" />\r\n        <path\r\n          class=\"checkIcon__check\"\r\n          fill=\"none\"\r\n          d=\"M14.1 27.2l7.1 7.2 16.7-16.8\"\r\n        />\r\n      </svg>\r\n    </div>\r\n    <div class=\"right\">\r\n      <div class=\"vx-form-group\">\r\n        <label class=\"vx-control-panel\"\r\n          >Assessment Name <span class=\"required\">*</span></label\r\n        >\r\n        <input\r\n          type=\"text\"\r\n          (keydown)=\"activeSelector = 'name'\"\r\n          (focusin)=\"activateSelector('name', true)\"\r\n          (focusout)=\"activateSelector('name', false)\"\r\n          [(ngModel)]=\"assessmentForm.name\"\r\n          placeholder=\"Add an assessment name\"\r\n          *ngIf=\"assessmentForm.name == '' || activeSelector === 'name'\"\r\n        />\r\n        <div\r\n          class=\"selected\"\r\n          *ngIf=\"assessmentForm.name.length && activeSelector !== 'name'\"\r\n        >\r\n          <div class=\"chip-container\">\r\n            <span class=\"value\">{{ assessmentForm.name }}</span>\r\n          </div>\r\n          <button\r\n            class=\"edit\"\r\n            (click)=\"activateSelector('name', true)\"\r\n            type=\"button\"\r\n          >\r\n            <i class=\"icons\">&#xe9ba;</i> Edit\r\n          </button>\r\n        </div>\r\n        <p\r\n          *ngIf=\"submitted && !assessmentForm.name.trim()\"\r\n          class=\"error-message\"\r\n        >\r\n          Enter a name for this Assessment.\r\n        </p>\r\n        <vcomply-editor\r\n          [(ngModel)]=\"assessmentForm.description\"\r\n          [editorConfig]=\"description\"\r\n          (clickOutside)=\"checkDescription()\"\r\n        ></vcomply-editor>\r\n        <!-- <p *ngIf=\"submitted && (assessmentForm.assessmentType ==='COMPLIANCE' && !assessmentForm?.description?.trim()?.length)\" class=\"error-message\">Add an assessment description</p> -->\r\n      </div>\r\n    </div>\r\n  </div>\r\n\r\n  <!-- Assessment Category -->\r\n  <div\r\n    class=\"form-group-row\"\r\n    [class.active]=\"activeSelector === 'category'\"\r\n    [class.disabled]=\"\r\n      activeSelector &&\r\n      activeSelector !== 'category' &&\r\n      sideSelectorElements.includes(activeSelector)\r\n    \"\r\n  >\r\n    <div class=\"left\" [class.checked]=\"assessmentForm?.category?.length\">\r\n      <img\r\n        *ngIf=\"\r\n          !assessmentForm?.category?.length || activeSelector === 'category'\r\n        \"\r\n        src=\"https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/category.svg\"\r\n        alt=\"\"\r\n      />\r\n\r\n      <svg\r\n        class=\"checkIcon\"\r\n        *ngIf=\"\r\n          assessmentForm?.category?.length && activeSelector !== 'category'\r\n        \"\r\n        xmlns=\"http://www.w3.org/2000/svg\"\r\n        viewBox=\"0 0 52 52\"\r\n      >\r\n        <circle class=\"checkIcon__circle\" cx=\"26\" cy=\"26\" r=\"25\" fill=\"none\" />\r\n        <path\r\n          class=\"checkIcon__check\"\r\n          fill=\"none\"\r\n          d=\"M14.1 27.2l7.1 7.2 16.7-16.8\"\r\n        />\r\n      </svg>\r\n    </div>\r\n    <div class=\"right\">\r\n      <div class=\"vx-form-group\">\r\n        <label class=\"vx-control-panel\"\r\n          >ASSESSMENT CATEGORY <span class=\"required\">*</span></label\r\n        >\r\n        <div class=\"select\" *ngIf=\"!assessmentForm?.category?.length\">\r\n          <input\r\n            type=\"text\"\r\n            (click)=\"activateSelector('category', true)\"\r\n            placeholder=\"Select category for this assessment\"\r\n            readonly\r\n          />\r\n        </div>\r\n        <div class=\"selected\" *ngIf=\"assessmentForm?.category?.length\">\r\n          <div class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\">\r\n            <i\r\n              class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\r\n              *ngIf=\"\r\n                assessmentForm?.category[0]?.category_name !== 'uncategorized'\r\n              \"\r\n              (click)=\"remove('category', assessmentForm.category[0])\"\r\n              >&#xe9ae;</i\r\n            >\r\n            <span\r\n              class=\"chipName vx-fs-11 vx-label-txt\"\r\n              [appTooltip]=\"assessmentForm?.category[0]?.category_name\"\r\n              placement=\"bottom-left\"\r\n              delay=\"0\"\r\n              type=\"black\"\r\n              [tooltipMandatory]=\"false\"\r\n              >{{ assessmentForm?.category[0]?.category_name }}</span\r\n            >\r\n            <button\r\n              class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\r\n              appPopover\r\n              (click)=\"category.popover()\"\r\n              placement=\"right\"\r\n              *ngIf=\"assessmentForm?.category?.length > 1\"\r\n            >\r\n              +{{ assessmentForm?.category?.length - 1 }}\r\n            </button>\r\n          </div>\r\n\r\n          <!-- <div class=\"chip-container\">\r\n                        <span class=\"chip\"><i *ngIf=\"assessmentForm?.category[0]?.category_name !== 'uncategorized'\" class=\"icons\" (click)=\"remove('category',assessmentForm.category[0])\">&#xe90d;</i>{{assessmentForm?.category[0]?.category_name}}</span>\r\n                        <button class=\"count\" *ngIf=\"assessmentForm?.category?.length > 1\" appPopover (click)=\"category.popover()\" placement=\"right\">+{{assessmentForm?.category?.length -1}}</button>\r\n                    </div> -->\r\n          <button\r\n            *ngIf=\"activeSelector !== 'category'\"\r\n            class=\"edit\"\r\n            type=\"button\"\r\n            (click)=\"activateSelector('category', true)\"\r\n          >\r\n            <i class=\"icons\">&#xe9ba;</i> Edit\r\n          </button>\r\n        </div>\r\n        <p\r\n          *ngIf=\"submitted && !assessmentForm?.category?.length\"\r\n          class=\"error-message\"\r\n        >\r\n          Select the Assessment Category.\r\n        </p>\r\n        <app-popover #category [dontCloseonClick]=\"true\">\r\n          <div class=\"wf-action-list\">\r\n            <ul class=\"action-item\">\r\n              <li\r\n                *ngFor=\"\r\n                  let category of assessmentForm?.category | slice : 1;\r\n                  let j = index\r\n                \"\r\n              >\r\n                <div class=\"avatar-card\">\r\n                  <span class=\"value\">\r\n                    <i class=\"icons\" (click)=\"remove('category', category)\"\r\n                      >&#xe90d;</i\r\n                    >\r\n                    {{ category?.category_name }}\r\n                  </span>\r\n                </div>\r\n              </li>\r\n            </ul>\r\n          </div>\r\n        </app-popover>\r\n      </div>\r\n      <ng-container *ngIf=\"assessmentForm?.customTags?.length > 0\">\r\n        <div\r\n          class=\"vx-form-group\"\r\n          *ngFor=\"let tag of assessmentForm.customTags\"\r\n        >\r\n          <label class=\"vx-control-panel\">{{ tag.custom_tag_name }}</label>\r\n          <input\r\n            type=\"text\"\r\n            [(ngModel)]=\"tag.custom_tag_value\"\r\n            [placeholder]=\"tag.custom_tag_name\"\r\n          />\r\n        </div>\r\n      </ng-container>\r\n    </div>\r\n  </div>\r\n\r\n  <!-- Assessment Approval Workflow -->\r\n  <div\r\n    *ngIf=\"false\"\r\n    class=\"form-group-row\"\r\n    [class.active]=\"false\"\r\n    [class.disabled]=\"false\"\r\n  >\r\n    <div class=\"left\" [class.checked]=\"false\">\r\n      <img\r\n        *ngIf=\"true\"\r\n        src=\"https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/approval.svg\"\r\n        alt=\"im\"\r\n      />\r\n\r\n      <svg\r\n        *ngIf=\"false\"\r\n        class=\"checkIcon\"\r\n        xmlns=\"http://www.w3.org/2000/svg\"\r\n        viewBox=\"0 0 52 52\"\r\n      >\r\n        <circle class=\"checkIcon__circle\" cx=\"26\" cy=\"26\" r=\"25\" fill=\"none\" />\r\n        <path\r\n          class=\"checkIcon__check\"\r\n          fill=\"none\"\r\n          d=\"M14.1 27.2l7.1 7.2 16.7-16.8\"\r\n        />\r\n      </svg>\r\n    </div>\r\n    <div class=\"right\">\r\n      <div class=\"vx-form-group approval-workflow\" [class.disabled]=\"false\">\r\n        <label class=\"vx-control-panel\">\r\n          Approval workflow <span class=\"required\">*</span>\r\n          <button class=\"button\">CREATE A NEW APPROVAL WORKFLOW</button>\r\n        </label>\r\n        <div class=\"select\" [class.disabled]=\"false\" *ngIf=\"true\">\r\n          <cs-select [placeholder]=\"'Select approvers for this assessment'\">\r\n            <cs-option>test</cs-option>\r\n            <cs-option>Create a new approval workflow</cs-option>\r\n          </cs-select>\r\n        </div>\r\n        <app-cs-switch\r\n          >APPROVAL NOT REQUIRED\r\n          <i\r\n            class=\"icons\"\r\n            [appTooltip]=\"'Approval workflow info text here...'\"\r\n            placement=\"bottom-right\"\r\n            type=\"white\"\r\n            delay=\"0\"\r\n            [tooltipMandatory]=\"true\"\r\n            >&#xe932;</i\r\n          ></app-cs-switch\r\n        >\r\n        <ng-container *ngIf=\"true\">\r\n          <div class=\"selected\">\r\n            <div class=\"workflow-label\">\r\n              <p class=\"title\">Level 1</p>\r\n              <p class=\"description\">lavel name</p>\r\n            </div>\r\n            <div class=\"vx-d-flex vx-align-center\">\r\n              <div class=\"chip-container\">\r\n                <span class=\"chip\">\r\n                  <i class=\"icons\">&#xe90d;</i>\r\n                  <span class=\"step\" *ngIf=\"true\">1</span>approval name\r\n                </span>\r\n\r\n                <button\r\n                  class=\"count\"\r\n                  *ngIf=\"true\"\r\n                  type=\"button\"\r\n                  appPopover\r\n                  (click)=\"labelName.popover()\"\r\n                  placement=\"right\"\r\n                >\r\n                  +8\r\n                </button>\r\n                <app-popover #labelName [dontCloseonClick]=\"true\">\r\n                  <div class=\"wf-action-list\">\r\n                    <ul class=\"action-item\">\r\n                      <li *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\r\n                        <div class=\"avatar-card\">\r\n                          <span class=\"value\">\r\n                            <i class=\"icons\">&#xe90d;</i>\r\n                            <span class=\"step\">2</span>approval name\r\n                          </span>\r\n                        </div>\r\n                      </li>\r\n                    </ul>\r\n                  </div>\r\n                </app-popover>\r\n              </div>\r\n              <button class=\"edit\" type=\"button\">\r\n                <i class=\"icons\">&#xe9ba;</i>Edit\r\n              </button>\r\n              <button class=\"close-btn\"><i class=\"icons\">&#xe90d;</i></button>\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n\r\n        <p *ngIf=\"true\" class=\"error-message\">\r\n          Select or create an approval workflow for this assessment.\r\n        </p>\r\n\r\n        <label class=\"vx-control-panel\" *ngIf=\"true\">\r\n          <button class=\"button\">+ Add More Levels</button>\r\n        </label>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n<ng-container\r\n  *ngIf=\"assessmentService?.categoriesListData$ | async as categories\"\r\n>\r\n  <app-radio-list-with-pagination\r\n    *ngIf=\"activeSelector === 'category'\"\r\n    [categoryList]=\"categories?.data\"\r\n    [config]=\"selectorConfig?.ASSESSMENT_CATGORY\"\r\n    [currentPage]=\"categories?.currentPage\"\r\n    [recordStart]=\"categories?.start_value\"\r\n    [recordEnd]=\"categories?.end_value\"\r\n    [totalRecords]=\"categories?.totalRecords\"\r\n    [totalPages]=\"categories?.totalPage\"\r\n    [loading]=\"assessmentService?.categoriesLoading$ | async\"\r\n    (fetchData)=\"setCategory($event)\"\r\n    (next)=\"next('CATEGORY', $event)\"\r\n    [selectedList]=\"assessmentForm?.category | uncategorizedFilter\"\r\n    (cancel)=\"activeDeselector()\"\r\n    (back)=\"activeDeselector()\"\r\n  ></app-radio-list-with-pagination>\r\n</ng-container>\r\n<app-loader-inline *ngIf=\"loader\"></app-loader-inline>\r\n<app-smiley-dialog-inline\r\n  *ngIf=\"showSmiley\"\r\n  [message]=\"smileyMessage\"\r\n  [actionButtons]=\"actionButtons\"\r\n  (action)=\"action($event)\"\r\n  (closeSmiley)=\"closeSmiley($event)\"\r\n>\r\n</app-smiley-dialog-inline>\r\n<!-- <app-create-assessment-container></app-create-assessment-container> -->\r\n"]}
254
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow-assessment.component.js","sourceRoot":"","sources":["../../../../../projects/vx-workflow-engine/src/lib/workflow-assessment/workflow-assessment.component.ts","../../../../../projects/vx-workflow-engine/src/lib/workflow-assessment/workflow-assessment.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Optional,\r\n  Output,\r\n} from '@angular/core';\r\n\r\nimport { EditorConfig } from 'vcomply-editor';\r\nimport { Configurations } from '../configurations';\r\nimport { SnackBarService } from '../ui-kit/snack-bar/snack-bar.service';\r\nimport { AssessmentService } from '../workflow-services/assessment.service';\r\nimport { AuthService } from '../workflow-services/auth.service';\r\nimport { UiKitService } from '../workflow-services/ui-kit.service';\r\n\r\n@Component({\r\n  selector: 'app-workflow-assessment',\r\n  templateUrl: './workflow-assessment.component.html',\r\n  styleUrls: ['./workflow-assessment.component.less', '../forms.less'],\r\n})\r\nexport class WorkflowAssessmentComponent implements OnInit {\r\n  activeSelector: any = '';\r\n  submitted = false;\r\n  loader = false;\r\n  showSmiley = false;\r\n  @Input() mode = 'EDIT';\r\n  @Input() assessmentId = '';\r\n  @Input() openedFrom = '';\r\n  @Output() disconnectRefresh = new EventEmitter();\r\n  sideSelectorElements: any = ['category'];\r\n  actionButtons = [\r\n    // { buttonText: 'Add More Assessments', class: 'white-btn', id: 'addMore' },\r\n    {\r\n      buttonText: 'Go to assessment workroom',\r\n      class: 'blue-btn',\r\n      id: 'viewAssessment',\r\n    },\r\n  ];\r\n  assessmentTypeChangeAllowed = true;\r\n  timezone!: string;\r\n  @Output() pickerChanged = new EventEmitter();\r\n  @Output() closeWorkflow = new EventEmitter();\r\n  assessmentForm: any = {\r\n    assessmentType: 'compliance',\r\n    name: '',\r\n    description: '',\r\n    category: [],\r\n    customTags: [],\r\n  };\r\n  assessmentData: any;\r\n  organizationId = 0;\r\n  constructor(\r\n    public assessmentService: AssessmentService,\r\n    private authService: AuthService,\r\n    private uiKitService: UiKitService,\r\n    private snackBar: SnackBarService,\r\n    @Optional() config?: Configurations\r\n  ) {\r\n    this.timezone = this.authService.getUserTimeZone();\r\n  }\r\n  selectorConfig = {\r\n    ASSESSMENT_CATGORY: {\r\n      panelTitle: 'Select an Assessment Category',\r\n      entitySingular: 'Category selected.',\r\n      entityPlural: 'Categories selected.',\r\n      displayKey: 'category_name',\r\n      identifierKey: 'id',\r\n      parentKey: 'category_parents',\r\n      parentDisplayKey: 'parent_tree',\r\n      searchPlaceholder: 'Search an assessment category.',\r\n      noDataText: 'No assessment categories found.',\r\n    },\r\n  };\r\n  ngOnInit(): void {\r\n    //this.loader = true;\r\n    if (this.mode === 'CREATE') {\r\n      this.organizationId = this.authService.getOrganizationId();\r\n    }\r\n    //this.setCategory({ searchKey: '', page: 1 });\r\n    if (this.mode === 'EDIT') {\r\n      this.getAssessmentDetails();\r\n    }\r\n  }\r\n\r\n  getAssessmentDetails() {\r\n    this.loader = true;\r\n    this.assessmentService.getAssessmentDetails(this.assessmentId).subscribe({\r\n      next: (res: any) => {\r\n        this.assessmentForm.name = res?.assessment_name ?? '';\r\n        this.assessmentForm.description = res?.description ?? '';\r\n        this.assessmentForm.assessmentType =\r\n          res?.assessment_type ?? 'compliance';\r\n        this.assessmentForm.category = res.category_arr.map((ele: any) => {\r\n          return { id: ele?._id, category_name: ele?.category_name };\r\n        });\r\n        this.assessmentTypeChangeAllowed =\r\n          res?.assessment_type === 'compliance';\r\n        this.loader = false;\r\n      },\r\n      error: (err: any) => {\r\n        this.snackBar.show(\r\n          'OOPS! Something went wrong and the page could not be loaded. Could you please try one more time?',\r\n          'alert'\r\n        );\r\n        this.loader = false;\r\n      },\r\n    });\r\n  }\r\n\r\n  //This function is responsible for fetching the list of categories\r\n  setCategory(evt: any) {\r\n    this.assessmentService.fetchCategory({\r\n      search_title: evt.searchKey,\r\n      page_no: evt.page,\r\n    });\r\n  }\r\n\r\n  activateSelector(type: any, event: boolean) {\r\n    if (type === 'category') {\r\n      this.setCategory({ searchKey: '', page: 1 });\r\n    }\r\n    this.activeSelector = event ? type : '';\r\n    if (this.sideSelectorElements.includes(type)) {\r\n      this.pickerChanged.emit(event);\r\n    }\r\n  }\r\n\r\n  activeDeselector() {\r\n    this.activeSelector = '';\r\n    this.pickerChanged.emit(false);\r\n  }\r\n\r\n  next(type: string, payload: any) {\r\n    switch (type) {\r\n      case 'CATEGORY': {\r\n        this.activeDeselector();\r\n        this.assessmentForm.category = payload;\r\n        if (this.assessmentForm.category?.length > 1) {\r\n          this.assessmentForm.category = this.assessmentForm.category.filter(\r\n            (ele: any) => ele?.category_name != 'uncategorized'\r\n          );\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  remove(type: any, event: any) {\r\n    switch (type) {\r\n      case 'category':\r\n        this.assessmentForm.category = this.assessmentForm.category.filter(\r\n          (ele: any) => ele?.id !== event?.id\r\n        );\r\n    }\r\n  }\r\n\r\n  description: EditorConfig = {\r\n    mode: 'prime',\r\n    colorPalette: true,\r\n    link: true,\r\n    placeholder: 'Add a description',\r\n  };\r\n\r\n  changeAssessment(type: string) {\r\n    this.assessmentForm = {\r\n      ...this.assessmentForm,\r\n      ...{ assessmentType: type?.toLocaleLowerCase() },\r\n    };\r\n    console.log('this.assessmentForm ===>', this.assessmentForm);\r\n  }\r\n  closeSmiley(evt: any) {\r\n    this.closeWorkflow.emit({ evt: this.assessmentId, confirm: false });\r\n  }\r\n\r\n  action(evt: any) {\r\n    if (evt === 'viewAssessment') {\r\n      this.disconnectRefresh.emit(false);\r\n      window.location.href = `https://${window.location.hostname}/assessment/assessment-workroom/?id=${this.assessmentId}`;\r\n    }\r\n  }\r\n\r\n  checkDescription() {\r\n    if (this.assessmentForm.description == '<br>') {\r\n      this.assessmentForm.description = '';\r\n    }\r\n  }\r\n\r\n  submitAssessment() {\r\n    this.submitted = true;\r\n    const valid = this.validateAssessment();\r\n    if (!valid) {\r\n      return false;\r\n    } else {\r\n      this.createAssessment(this.assessmentForm);\r\n    }\r\n  }\r\n\r\n  validateAssessment() {\r\n    this.submitted = true;\r\n    if (\r\n      !this.assessmentForm.name.trim() ||\r\n      this.assessmentForm.category.length == 0\r\n    ) {\r\n      return false;\r\n    } else {\r\n      return true;\r\n    }\r\n  }\r\n\r\n  createAssessment(assessmentForm: any) {\r\n    this.loader = true;\r\n    this.uiKitService.isLoader = false;\r\n\r\n    const payload = {\r\n      assessment_name: assessmentForm.name.trim(),\r\n      description: assessmentForm.description,\r\n      assessment_type: assessmentForm.assessmentType,\r\n      category_arr: this.assessmentForm.category.map((ele: any) => ele.id),\r\n      approval_workflow_arr: {\r\n        test: 'test',\r\n      },\r\n      approval_required: true,\r\n      source_page: 'compliance',\r\n    };\r\n    if (this.mode == 'CREATE') {\r\n      this.assessmentService.addAssessment(payload).subscribe(\r\n        (res: any) => {\r\n          this.disconnectRefresh.emit(false);\r\n          this.assessmentId = res?._id;\r\n          window.location.href = `https://${window.location.hostname}/assessment/create/${res?._id}`;\r\n          this.loader = false;\r\n        },\r\n        (err: any) => {\r\n          console.error(err);\r\n          this.loader = false;\r\n          this.uiKitService.isLoader = false;\r\n          this.snackBar.show(\r\n            'OOPS! Something went wrong and the page could not be loaded. Could you please try one more time?',\r\n            'alert'\r\n          );\r\n        }\r\n      );\r\n    } else if (this.mode === 'EDIT') {\r\n      this.assessmentService\r\n        .updateAssessment(this.assessmentId, payload)\r\n        .subscribe({\r\n          next: (res: any) => {\r\n            this.loader = false;\r\n            this.showSmiley = true;\r\n          },\r\n          error: (err: any) => {\r\n            if (err?.error.message.startsWith('No changes')) {\r\n              this.loader = false;\r\n              this.showSmiley = true;\r\n            } else {\r\n              this.snackBar.show(\r\n                'OOPS! Something went wrong and the page could not be loaded. Could you please try one more time?',\r\n                'alert'\r\n              );\r\n            }\r\n          },\r\n        });\r\n    }\r\n  }\r\n}\r\n","<div class=\"workflow-assessment\">\r\n  <!-- Assessment Type -->\r\n  <div class=\"form-group-row\" [class.active]=\"false\" [class.disabled]=\"false\">\r\n    <div class=\"left checked\">\r\n      <svg\r\n        class=\"checkIcon\"\r\n        xmlns=\"http://www.w3.org/2000/svg\"\r\n        viewBox=\"0 0 52 52\"\r\n      >\r\n        <circle class=\"checkIcon__circle\" cx=\"26\" cy=\"26\" r=\"25\" fill=\"none\" />\r\n        <path\r\n          class=\"checkIcon__check\"\r\n          fill=\"none\"\r\n          d=\"M14.1 27.2l7.1 7.2 16.7-16.8\"\r\n        />\r\n      </svg>\r\n    </div>\r\n    <div class=\"right\">\r\n      <div class=\"vx-form-group\">\r\n        <label class=\"vx-control-panel\"\r\n          >ASSESSMENT TYPE <span class=\"required\">*</span></label\r\n        >\r\n        <div class=\"risk-type-field\">\r\n          <div\r\n            class=\"type-item\"\r\n            [class.active]=\"\r\n              assessmentForm?.assessmentType === 'compliance_audit'\r\n            \"\r\n          >\r\n            <button\r\n              [class.disabled]=\"!assessmentTypeChangeAllowed\"\r\n              (click)=\"changeAssessment('compliance_audit')\"\r\n            >\r\n              COMPLIANCE AUDIT\r\n            </button>\r\n            <i\r\n              class=\"icons info\"\r\n              [appTooltip]=\"'Compliance assessment info text here...'\"\r\n              placement=\"bottom-right\"\r\n              delay=\"0\"\r\n              type=\"white\"\r\n              [tooltipMandatory]=\"true\"\r\n              >&#xe932;</i\r\n            >\r\n          </div>\r\n          <div\r\n            class=\"type-item\"\r\n            [appTooltip]=\"\r\n              assessmentTypeChangeAllowed\r\n                ? ''\r\n                : 'You Cannot change the assessment type.'\r\n            \"\r\n            placement=\"bottom-left\"\r\n            delay=\"0\"\r\n            type=\"black\"\r\n            [tooltipMandatory]=\"true\"\r\n            [class.active]=\"assessmentForm?.assessmentType === 'compliance'\"\r\n          >\r\n            <button\r\n              [class.disabled]=\"!assessmentTypeChangeAllowed\"\r\n              (click)=\"changeAssessment('compliance')\"\r\n            >\r\n              Other\r\n            </button>\r\n            <i\r\n              class=\"icons info\"\r\n              [class.disabled]=\"!assessmentTypeChangeAllowed\"\r\n              [appTooltip]=\"'Risk assessment info text here...'\"\r\n              placement=\"bottom-right\"\r\n              delay=\"0\"\r\n              type=\"white\"\r\n              [tooltipMandatory]=\"true\"\r\n              >&#xe932;</i\r\n            >\r\n          </div>\r\n          <span class=\"background-glider\"></span>\r\n        </div>\r\n        <p *ngIf=\"false\" class=\"error-message\">Add an assessment type</p>\r\n      </div>\r\n    </div>\r\n  </div>\r\n\r\n  <!-- Assessment Name -->\r\n  <div\r\n    class=\"form-group-row\"\r\n    [class.active]=\"false\"\r\n    [class.disabled]=\"\r\n      activeSelector &&\r\n      activeSelector !== 'name' &&\r\n      sideSelectorElements.includes(activeSelector)\r\n    \"\r\n  >\r\n    <div class=\"left\" [class.checked]=\"false\">\r\n      <img\r\n        src=\"https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/what.svg\"\r\n        alt=\"im\"\r\n        *ngIf=\"!assessmentForm.name.trim() || activeSelector === 'name'\"\r\n      />\r\n\r\n      <svg\r\n        *ngIf=\"assessmentForm.name.trim() && activeSelector !== 'name'\"\r\n        class=\"checkIcon\"\r\n        xmlns=\"http://www.w3.org/2000/svg\"\r\n        viewBox=\"0 0 52 52\"\r\n      >\r\n        <circle class=\"checkIcon__circle\" cx=\"26\" cy=\"26\" r=\"25\" fill=\"none\" />\r\n        <path\r\n          class=\"checkIcon__check\"\r\n          fill=\"none\"\r\n          d=\"M14.1 27.2l7.1 7.2 16.7-16.8\"\r\n        />\r\n      </svg>\r\n    </div>\r\n    <div class=\"right\">\r\n      <div class=\"vx-form-group\">\r\n        <label class=\"vx-control-panel\"\r\n          >Assessment Name <span class=\"required\">*</span></label\r\n        >\r\n        <input\r\n          type=\"text\"\r\n          (keydown)=\"activeSelector = 'name'\"\r\n          (focusin)=\"activateSelector('name', true)\"\r\n          (focusout)=\"activateSelector('name', false)\"\r\n          [(ngModel)]=\"assessmentForm.name\"\r\n          placeholder=\"Add an assessment name\"\r\n          *ngIf=\"assessmentForm.name == '' || activeSelector === 'name'\"\r\n        />\r\n        <div\r\n          class=\"selected\"\r\n          *ngIf=\"assessmentForm.name.length && activeSelector !== 'name'\"\r\n        >\r\n          <div class=\"chip-container\">\r\n            <span class=\"value\">{{ assessmentForm.name }}</span>\r\n          </div>\r\n          <button\r\n            class=\"edit\"\r\n            (click)=\"activateSelector('name', true)\"\r\n            type=\"button\"\r\n          >\r\n            <i class=\"icons\">&#xe9ba;</i> Edit\r\n          </button>\r\n        </div>\r\n        <p\r\n          *ngIf=\"submitted && !assessmentForm.name.trim()\"\r\n          class=\"error-message\"\r\n        >\r\n          Enter a name for this Assessment.\r\n        </p>\r\n        <vcomply-editor\r\n          [(ngModel)]=\"assessmentForm.description\"\r\n          [editorConfig]=\"description\"\r\n          (clickOutside)=\"checkDescription()\"\r\n        ></vcomply-editor>\r\n        <!-- <p *ngIf=\"submitted && (assessmentForm.assessmentType ==='COMPLIANCE' && !assessmentForm?.description?.trim()?.length)\" class=\"error-message\">Add an assessment description</p> -->\r\n      </div>\r\n    </div>\r\n  </div>\r\n\r\n  <!-- Assessment Category -->\r\n  <div\r\n    class=\"form-group-row\"\r\n    [class.active]=\"activeSelector === 'category'\"\r\n    [class.disabled]=\"\r\n      activeSelector &&\r\n      activeSelector !== 'category' &&\r\n      sideSelectorElements.includes(activeSelector)\r\n    \"\r\n  >\r\n    <div class=\"left\" [class.checked]=\"assessmentForm?.category?.length\">\r\n      <img\r\n        *ngIf=\"\r\n          !assessmentForm?.category?.length || activeSelector === 'category'\r\n        \"\r\n        src=\"https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/category.svg\"\r\n        alt=\"\"\r\n      />\r\n\r\n      <svg\r\n        class=\"checkIcon\"\r\n        *ngIf=\"\r\n          assessmentForm?.category?.length && activeSelector !== 'category'\r\n        \"\r\n        xmlns=\"http://www.w3.org/2000/svg\"\r\n        viewBox=\"0 0 52 52\"\r\n      >\r\n        <circle class=\"checkIcon__circle\" cx=\"26\" cy=\"26\" r=\"25\" fill=\"none\" />\r\n        <path\r\n          class=\"checkIcon__check\"\r\n          fill=\"none\"\r\n          d=\"M14.1 27.2l7.1 7.2 16.7-16.8\"\r\n        />\r\n      </svg>\r\n    </div>\r\n    <div class=\"right\">\r\n      <div class=\"vx-form-group\">\r\n        <label class=\"vx-control-panel\"\r\n          >ASSESSMENT CATEGORY <span class=\"required\">*</span></label\r\n        >\r\n        <div class=\"select\" *ngIf=\"!assessmentForm?.category?.length\">\r\n          <input\r\n            type=\"text\"\r\n            (click)=\"activateSelector('category', true)\"\r\n            placeholder=\"Select category for this assessment\"\r\n            readonly\r\n          />\r\n        </div>\r\n        <div class=\"selected\" *ngIf=\"assessmentForm?.category?.length\">\r\n          <div class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\">\r\n            <i\r\n              class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\r\n              *ngIf=\"\r\n                assessmentForm?.category[0]?.category_name !== 'uncategorized'\r\n              \"\r\n              (click)=\"remove('category', assessmentForm.category[0])\"\r\n              >&#xe9ae;</i\r\n            >\r\n            <span\r\n              class=\"chipName vx-fs-11 vx-label-txt\"\r\n              [appTooltip]=\"assessmentForm?.category[0]?.category_name\"\r\n              placement=\"bottom-left\"\r\n              delay=\"0\"\r\n              type=\"black\"\r\n              [tooltipMandatory]=\"false\"\r\n              >{{ assessmentForm?.category[0]?.category_name }}</span\r\n            >\r\n            <button\r\n              class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\r\n              appPopover\r\n              (click)=\"category.popover()\"\r\n              placement=\"right\"\r\n              *ngIf=\"assessmentForm?.category?.length > 1\"\r\n            >\r\n              +{{ assessmentForm?.category?.length - 1 }}\r\n            </button>\r\n          </div>\r\n\r\n          <!-- <div class=\"chip-container\">\r\n                        <span class=\"chip\"><i *ngIf=\"assessmentForm?.category[0]?.category_name !== 'uncategorized'\" class=\"icons\" (click)=\"remove('category',assessmentForm.category[0])\">&#xe90d;</i>{{assessmentForm?.category[0]?.category_name}}</span>\r\n                        <button class=\"count\" *ngIf=\"assessmentForm?.category?.length > 1\" appPopover (click)=\"category.popover()\" placement=\"right\">+{{assessmentForm?.category?.length -1}}</button>\r\n                    </div> -->\r\n          <button\r\n            *ngIf=\"activeSelector !== 'category'\"\r\n            class=\"edit\"\r\n            type=\"button\"\r\n            (click)=\"activateSelector('category', true)\"\r\n          >\r\n            <i class=\"icons\">&#xe9ba;</i> Edit\r\n          </button>\r\n        </div>\r\n        <p\r\n          *ngIf=\"submitted && !assessmentForm?.category?.length\"\r\n          class=\"error-message\"\r\n        >\r\n          Select the Assessment Category.\r\n        </p>\r\n        <app-popover #category [dontCloseonClick]=\"true\">\r\n          <div class=\"wf-action-list\">\r\n            <ul class=\"action-item\">\r\n              <li\r\n                *ngFor=\"\r\n                  let category of assessmentForm?.category | slice : 1;\r\n                  let j = index\r\n                \"\r\n              >\r\n                <div class=\"avatar-card\">\r\n                  <span class=\"value\">\r\n                    <i class=\"icons\" (click)=\"remove('category', category)\"\r\n                      >&#xe90d;</i\r\n                    >\r\n                    {{ category?.category_name }}\r\n                  </span>\r\n                </div>\r\n              </li>\r\n            </ul>\r\n          </div>\r\n        </app-popover>\r\n      </div>\r\n      <ng-container *ngIf=\"assessmentForm?.customTags?.length > 0\">\r\n        <div\r\n          class=\"vx-form-group\"\r\n          *ngFor=\"let tag of assessmentForm.customTags\"\r\n        >\r\n          <label class=\"vx-control-panel\">{{ tag.custom_tag_name }}</label>\r\n          <input\r\n            type=\"text\"\r\n            [(ngModel)]=\"tag.custom_tag_value\"\r\n            [placeholder]=\"tag.custom_tag_name\"\r\n          />\r\n        </div>\r\n      </ng-container>\r\n    </div>\r\n  </div>\r\n\r\n  <!-- Assessment Approval Workflow -->\r\n  <div\r\n    *ngIf=\"false\"\r\n    class=\"form-group-row\"\r\n    [class.active]=\"false\"\r\n    [class.disabled]=\"false\"\r\n  >\r\n    <div class=\"left\" [class.checked]=\"false\">\r\n      <img\r\n        *ngIf=\"true\"\r\n        src=\"https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/approval.svg\"\r\n        alt=\"im\"\r\n      />\r\n\r\n      <svg\r\n        *ngIf=\"false\"\r\n        class=\"checkIcon\"\r\n        xmlns=\"http://www.w3.org/2000/svg\"\r\n        viewBox=\"0 0 52 52\"\r\n      >\r\n        <circle class=\"checkIcon__circle\" cx=\"26\" cy=\"26\" r=\"25\" fill=\"none\" />\r\n        <path\r\n          class=\"checkIcon__check\"\r\n          fill=\"none\"\r\n          d=\"M14.1 27.2l7.1 7.2 16.7-16.8\"\r\n        />\r\n      </svg>\r\n    </div>\r\n    <div class=\"right\">\r\n      <div class=\"vx-form-group approval-workflow\" [class.disabled]=\"false\">\r\n        <label class=\"vx-control-panel\">\r\n          Approval workflow <span class=\"required\">*</span>\r\n          <button class=\"button\">CREATE A NEW APPROVAL WORKFLOW</button>\r\n        </label>\r\n        <div class=\"select\" [class.disabled]=\"false\" *ngIf=\"true\">\r\n          <cs-select [placeholder]=\"'Select approvers for this assessment'\">\r\n            <cs-option>test</cs-option>\r\n            <cs-option>Create a new approval workflow</cs-option>\r\n          </cs-select>\r\n        </div>\r\n        <app-cs-switch\r\n          >APPROVAL NOT REQUIRED\r\n          <i\r\n            class=\"icons\"\r\n            [appTooltip]=\"'Approval workflow info text here...'\"\r\n            placement=\"bottom-right\"\r\n            type=\"white\"\r\n            delay=\"0\"\r\n            [tooltipMandatory]=\"true\"\r\n            >&#xe932;</i\r\n          ></app-cs-switch\r\n        >\r\n        <ng-container *ngIf=\"true\">\r\n          <div class=\"selected\">\r\n            <div class=\"workflow-label\">\r\n              <p class=\"title\">Level 1</p>\r\n              <p class=\"description\">lavel name</p>\r\n            </div>\r\n            <div class=\"vx-d-flex vx-align-center\">\r\n              <div class=\"chip-container\">\r\n                <span class=\"chip\">\r\n                  <i class=\"icons\">&#xe90d;</i>\r\n                  <span class=\"step\" *ngIf=\"true\">1</span>approval name\r\n                </span>\r\n\r\n                <button\r\n                  class=\"count\"\r\n                  *ngIf=\"true\"\r\n                  type=\"button\"\r\n                  appPopover\r\n                  (click)=\"labelName.popover()\"\r\n                  placement=\"right\"\r\n                >\r\n                  +8\r\n                </button>\r\n                <app-popover #labelName [dontCloseonClick]=\"true\">\r\n                  <div class=\"wf-action-list\">\r\n                    <ul class=\"action-item\">\r\n                      <li *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\r\n                        <div class=\"avatar-card\">\r\n                          <span class=\"value\">\r\n                            <i class=\"icons\">&#xe90d;</i>\r\n                            <span class=\"step\">2</span>approval name\r\n                          </span>\r\n                        </div>\r\n                      </li>\r\n                    </ul>\r\n                  </div>\r\n                </app-popover>\r\n              </div>\r\n              <button class=\"edit\" type=\"button\">\r\n                <i class=\"icons\">&#xe9ba;</i>Edit\r\n              </button>\r\n              <button class=\"close-btn\"><i class=\"icons\">&#xe90d;</i></button>\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n\r\n        <p *ngIf=\"true\" class=\"error-message\">\r\n          Select or create an approval workflow for this assessment.\r\n        </p>\r\n\r\n        <label class=\"vx-control-panel\" *ngIf=\"true\">\r\n          <button class=\"button\">+ Add More Levels</button>\r\n        </label>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n<ng-container\r\n  *ngIf=\"assessmentService?.categoriesListData$ | async as categories\"\r\n>\r\n  <app-radio-list-with-pagination\r\n    *ngIf=\"activeSelector === 'category'\"\r\n    [categoryList]=\"categories?.data\"\r\n    [config]=\"selectorConfig?.ASSESSMENT_CATGORY\"\r\n    [currentPage]=\"categories?.currentPage\"\r\n    [recordStart]=\"categories?.start_value\"\r\n    [recordEnd]=\"categories?.end_value\"\r\n    [totalRecords]=\"categories?.totalRecords\"\r\n    [totalPages]=\"categories?.totalPage\"\r\n    [loading]=\"assessmentService?.categoriesLoading$ | async\"\r\n    (fetchData)=\"setCategory($event)\"\r\n    (next)=\"next('CATEGORY', $event)\"\r\n    [selectedList]=\"assessmentForm?.category | uncategorizedFilter\"\r\n    (cancel)=\"activeDeselector()\"\r\n    (back)=\"activeDeselector()\"\r\n  ></app-radio-list-with-pagination>\r\n</ng-container>\r\n<app-loader-inline *ngIf=\"loader\"></app-loader-inline>\r\n<app-smiley-dialog-inline\r\n  *ngIf=\"showSmiley\"\r\n  [message]=\"smileyMessage\"\r\n  [actionButtons]=\"actionButtons\"\r\n  (action)=\"action($event)\"\r\n  (closeSmiley)=\"closeSmiley($event)\"\r\n>\r\n</app-smiley-dialog-inline>\r\n<!-- <app-create-assessment-container></app-create-assessment-container> -->\r\n"]}