vcomply-workflow-engine 3.4.22 → 3.4.24

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (101) hide show
  1. package/esm2020/lib/add-multiple-responsibility/add-multiple-responsibility.component.mjs +2 -4
  2. package/esm2020/lib/add-multiple-risk/add-multiple-risk.component.mjs +2 -3
  3. package/esm2020/lib/formgroup/cs-select/cs-select.component.mjs +5 -5
  4. package/esm2020/lib/formgroup/cs-switch/cs-switch.component.mjs +1 -4
  5. package/esm2020/lib/log-an-issue/log-an-issue.component.mjs +1 -11
  6. package/esm2020/lib/more-option/more-option.component.mjs +5 -6
  7. package/esm2020/lib/pipes/filter.pipe.mjs +1 -2
  8. package/esm2020/lib/pipes/search.pipe.mjs +3 -5
  9. package/esm2020/lib/sharedComponents/approval-workflow/approval-create-form/approval-create-form.component.mjs +3 -7
  10. package/esm2020/lib/sharedComponents/approval-workflow/approval-workflow-list/approval-workflow-list.component.mjs +1 -5
  11. package/esm2020/lib/sharedComponents/approval-workflow/approval-workflow.component.mjs +1 -7
  12. package/esm2020/lib/sharedComponents/assessment-editor/create-assessment-container/create-assessment-container.component.mjs +80 -36
  13. package/esm2020/lib/sharedComponents/assessment-list/assessment-list.component.mjs +27 -21
  14. package/esm2020/lib/sharedComponents/assessment-preview/preview/preview.component.mjs +7 -4
  15. package/esm2020/lib/sharedComponents/audit-category-list/audit-category-list.component.mjs +3 -4
  16. package/esm2020/lib/sharedComponents/bulk-responsibility-view/bulk-responsibility-view.component.mjs +3 -9
  17. package/esm2020/lib/sharedComponents/bulk-view/bulk-view.component.mjs +9 -7
  18. package/esm2020/lib/sharedComponents/category-multiselect/category-multi-select.component.mjs +6 -8
  19. package/esm2020/lib/sharedComponents/checkpoint/checkpoints/checkpoints.component.mjs +93 -27
  20. package/esm2020/lib/sharedComponents/checkpoint/checkpoints-questions/checkpoints-questions.component.mjs +11 -9
  21. package/esm2020/lib/sharedComponents/checkpoint-policy/checkpoints-policy-container/checkpoints-policy-container.component.mjs +13 -12
  22. package/esm2020/lib/sharedComponents/checkpoint-policy/checkpoints-policy-questions/checkpoints-policy-questions.component.mjs +28 -19
  23. package/esm2020/lib/sharedComponents/floating-bar/floating-bar.component.mjs +8 -8
  24. package/esm2020/lib/sharedComponents/format-and-evidence/format-and-evidence.component.mjs +35 -37
  25. package/esm2020/lib/sharedComponents/framework-list/parent-table/parent-table.component.mjs +7 -7
  26. package/esm2020/lib/sharedComponents/frequency/frequency-biannual/frequency-biannual.component.mjs +1 -12
  27. package/esm2020/lib/sharedComponents/frequency/frequency-container/frequency-container.component.mjs +1 -3
  28. package/esm2020/lib/sharedComponents/frequency/frequency-daily/frequency-daily.component.mjs +1 -13
  29. package/esm2020/lib/sharedComponents/frequency/frequency-due-date/frequency-due-date.component.mjs +1 -7
  30. package/esm2020/lib/sharedComponents/frequency/frequency-lifecycle/frequency-lifecycle.component.mjs +1 -26
  31. package/esm2020/lib/sharedComponents/frequency/frequency-monthly/frequency-monthly.component.mjs +1 -15
  32. package/esm2020/lib/sharedComponents/frequency/frequency-one-time/frequency-one-time.component.mjs +1 -14
  33. package/esm2020/lib/sharedComponents/frequency/frequency-ongoing/frequency-ongoing.component.mjs +14 -8
  34. package/esm2020/lib/sharedComponents/frequency/frequency-quarterly/frequency-quarterly.component.mjs +1 -13
  35. package/esm2020/lib/sharedComponents/frequency/frequency-radio-list/frequency-radio-list.component.mjs +1 -2
  36. package/esm2020/lib/sharedComponents/frequency/frequency-random/frequency-random.component.mjs +1 -18
  37. package/esm2020/lib/sharedComponents/frequency/frequency-top/frequency-top.component.mjs +2 -2
  38. package/esm2020/lib/sharedComponents/frequency/frequency-weekly/frequency-weekly.component.mjs +1 -12
  39. package/esm2020/lib/sharedComponents/frequency/frequency.service.mjs +2 -11
  40. package/esm2020/lib/sharedComponents/frequency-dialog/frequency-dialog-annual/frequency-dialog-annual.component.mjs +1 -2
  41. package/esm2020/lib/sharedComponents/frequency-dialog/frequency-dialog-biannual/frequency-dialog-biannual.component.mjs +1 -2
  42. package/esm2020/lib/sharedComponents/frequency-dialog/frequency-dialog-monthly/frequency-dialog-monthly.component.mjs +1 -2
  43. package/esm2020/lib/sharedComponents/frequency-dialog/frequency-dialog-one-time/frequency-dialog-one-time.component.mjs +1 -2
  44. package/esm2020/lib/sharedComponents/frequency-dialog/frequency-dialog-quarterly/frequency-dialog-quarterly.component.mjs +1 -2
  45. package/esm2020/lib/sharedComponents/frequency-dialog/frequency-dialog-radio-list/frequency-dialog-radio-list.component.mjs +1 -2
  46. package/esm2020/lib/sharedComponents/frequency-dialog/frequency-dialog-top/frequency-dialog-top.component.mjs +2 -2
  47. package/esm2020/lib/sharedComponents/group-users-list/group-users-list.component.mjs +1 -3
  48. package/esm2020/lib/sharedComponents/link-program/link-program/link-program.component.mjs +48 -38
  49. package/esm2020/lib/sharedComponents/link-program/restapi.service.mjs +31 -16
  50. package/esm2020/lib/sharedComponents/no-data/no-data.component.mjs +2 -4
  51. package/esm2020/lib/sharedComponents/owner-list/owner-list.component.mjs +12 -10
  52. package/esm2020/lib/sharedComponents/program-listing/program-listing.component.mjs +127 -58
  53. package/esm2020/lib/sharedComponents/radio-list-with-pagination/radio-list.component.mjs +4 -7
  54. package/esm2020/lib/sharedComponents/risk-classification/risk-classification.component.mjs +11 -6
  55. package/esm2020/lib/sharedComponents/select-approvers/select-approvers.component.mjs +1 -2
  56. package/esm2020/lib/sharedComponents/users-radio-list/users-radio-list.component.mjs +2 -3
  57. package/esm2020/lib/ui-kit/formgroup/cs-switch/cs-switch.component.mjs +1 -4
  58. package/esm2020/lib/ui-kit/popover/popover-longpress.directive.mjs +1 -3
  59. package/esm2020/lib/ui-kit/popover/popover.component.mjs +26 -12
  60. package/esm2020/lib/ui-kit/tooltip/tooltip.directive.mjs +8 -5
  61. package/esm2020/lib/workflow/shared/components/attributes/attributes.component.mjs +1 -2
  62. package/esm2020/lib/workflow/shared/components/edit-mode/edit-mode.component.mjs +1 -4
  63. package/esm2020/lib/workflow/shared/components/grc-object-list/grc-object-list.component.mjs +1 -2
  64. package/esm2020/lib/workflow/shared/components/list-popup/list-popup.component.mjs +1 -4
  65. package/esm2020/lib/workflow/shared/components/table-card/table-card.component.mjs +4 -8
  66. package/esm2020/lib/workflow-assessment/import-an-assessment/import-an-assessment.component.mjs +245 -108
  67. package/esm2020/lib/workflow-assessment/workflow-assessment.component.mjs +2 -4
  68. package/esm2020/lib/workflow-compliance/workflow-compliance.component.mjs +10 -8
  69. package/esm2020/lib/workflow-engine-container/workflow-engine-container.component.mjs +1 -5
  70. package/esm2020/lib/workflow-policy/workflow-policy.component.mjs +5 -5
  71. package/esm2020/lib/workflow-program/create-program-ui/assessment-picker/assessment-picker.component.mjs +45 -45
  72. package/esm2020/lib/workflow-program/create-program-ui/define-framework-listing/define-framework-listing.component.mjs +43 -25
  73. package/esm2020/lib/workflow-program/create-program-ui/define-framework-listing/pipes/sub-cat-indeter.pipe.mjs +4 -4
  74. package/esm2020/lib/workflow-program/create-program-ui/floating-bar/floating-bar.component.mjs +1 -2
  75. package/esm2020/lib/workflow-program/create-program-ui/pagination/pagination/pagination.component.mjs +25 -14
  76. package/esm2020/lib/workflow-program/create-program-ui/pipes/assessment-resolver.pipe.mjs +6 -3
  77. package/esm2020/lib/workflow-program/create-program-ui/role-list/role-list.component.mjs +25 -19
  78. package/esm2020/lib/workflow-program/create-program-ui/user-group-list/user-group-list.component.mjs +1 -4
  79. package/esm2020/lib/workflow-program/workflow-program.component.mjs +232 -110
  80. package/esm2020/lib/workflow-services/add-risk.service.mjs +1 -2
  81. package/esm2020/lib/workflow-services/assessment.service.mjs +1 -5
  82. package/esm2020/lib/workflow-services/programs.service.mjs +173 -57
  83. package/fesm2015/vcomply-workflow-engine.mjs +1380 -938
  84. package/fesm2015/vcomply-workflow-engine.mjs.map +1 -1
  85. package/fesm2020/vcomply-workflow-engine.mjs +1390 -943
  86. package/fesm2020/vcomply-workflow-engine.mjs.map +1 -1
  87. package/lib/formgroup/cs-switch/cs-switch.component.d.ts +2 -3
  88. package/lib/sharedComponents/assessment-list/assessment-list.component.d.ts +4 -5
  89. package/lib/sharedComponents/bulk-responsibility-view/bulk-responsibility-view.component.d.ts +2 -3
  90. package/lib/sharedComponents/bulk-view/bulk-view.component.d.ts +2 -3
  91. package/lib/sharedComponents/frequency/frequency-lifecycle/frequency-lifecycle.component.d.ts +2 -4
  92. package/lib/sharedComponents/frequency/frequency-ongoing/frequency-ongoing.component.d.ts +1 -1
  93. package/lib/sharedComponents/link-program/restapi.service.d.ts +3 -3
  94. package/lib/sharedComponents/no-data/no-data.component.d.ts +2 -4
  95. package/lib/ui-kit/formgroup/cs-switch/cs-switch.component.d.ts +2 -3
  96. package/lib/workflow/shared/components/edit-mode/edit-mode.component.d.ts +2 -3
  97. package/lib/workflow/shared/components/list-popup/list-popup.component.d.ts +2 -3
  98. package/lib/workflow/shared/components/table-card/table-card.component.d.ts +2 -5
  99. package/lib/workflow-program/create-program-ui/assessment-picker/assessment-picker.component.d.ts +8 -9
  100. package/lib/workflow-program/create-program-ui/pagination/pagination/pagination.component.d.ts +2 -4
  101. package/package.json +1 -1
@@ -168,7 +168,6 @@ export class WorkflowAssessmentComponent {
168
168
  }
169
169
  }
170
170
  validateAssessment() {
171
- // console.log("val",this.assessmentForm)
172
171
  this.submitted = true;
173
172
  if (!this.assessmentForm.name || this.assessmentForm.category.length == 0) {
174
173
  return false;
@@ -191,7 +190,6 @@ export class WorkflowAssessmentComponent {
191
190
  approval_required: true,
192
191
  source_page: 'compliance',
193
192
  };
194
- console.log('payload', payload);
195
193
  if (this.mode == 'CREATE') {
196
194
  this.assessmentService.addAssessment(payload).subscribe((res) => {
197
195
  this.disconnectRefresh.emit(false);
@@ -199,7 +197,7 @@ export class WorkflowAssessmentComponent {
199
197
  window.location.href = `https://${window.location.hostname}/assessment/create/${res?._id}`;
200
198
  this.loader = false;
201
199
  }, (err) => {
202
- console.log(err);
200
+ console.error(err);
203
201
  this.loader = false;
204
202
  this.uiKitService.isLoader = false;
205
203
  this.snackBar.show('OOPS! Something went wrong and the page could not be loaded. Could you please try one more time?', 'alert');
@@ -246,4 +244,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
246
244
  }], closeWorkflow: [{
247
245
  type: Output
248
246
  }] } });
249
- //# 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 = false;\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.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 = { ...this.assessmentForm, ...{ riskType: type } };\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    // console.log(\"val\",this.assessmentForm)\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    console.log('payload', payload);\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.log(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 *ngIf=\"false\" class=\"form-group-row\" [class.active]=\"false\" [class.disabled]=\"false\">\r\n        <div class=\"left\" [class.checked]=\"false\">\r\n            <img src=\"https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/associated-risks.svg\" alt=\"im\" *ngIf=\"true\">\r\n\r\n            <svg *ngIf=\"false\" class=\"checkIcon\"\r\n                xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 52 52\">\r\n                <circle class=\"checkIcon__circle\" cx=\"26\" cy=\"26\" r=\"25\" fill=\"none\" />\r\n                <path class=\"checkIcon__check\" fill=\"none\" d=\"M14.1 27.2l7.1 7.2 16.7-16.8\" />\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\">ASSESSMENT TYPE <span class=\"required\">*</span></label>\r\n                <div class=\"risk-type-field\">\r\n                    <div class=\"type-item\" [class.active]=\"assessmentForm?.assessmentType === 'COMPLIANCE'\">\r\n                        <button [class.disabled]=\"!assessmentTypeChangeAllowed\" (click)=\"changeAssessment('COMPLIANCE')\">COMPLIANCE ASSESSMENT</button>\r\n                        <i class=\"icons info\" [appTooltip]=\"'Compliance assessment info text here...'\" placement=\"bottom-right\" delay=\"0\" type=\"white\" [tooltipMandatory]=\"true\">&#xe932;</i>\r\n                    </div>\r\n                    <div class=\"type-item\" [class.active]=\"false\">\r\n                        <button [class.disabled]=\"!assessmentTypeChangeAllowed\" (click)=\"changeAssessment('RISK')\">RISK ASSESSMENT</button>\r\n                        <i class=\"icons info\" [appTooltip]=\"'Risk assessment info text here...'\" placement=\"bottom-right\" delay=\"0\" type=\"white\" [tooltipMandatory]=\"true\">&#xe932;</i>\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 class=\"form-group-row\" [class.active]=\"false\" [class.disabled]=\" activeSelector && activeSelector !== 'name'  && sideSelectorElements.includes(activeSelector)\">\r\n        <div class=\"left\" [class.checked]=\"false\">\r\n            <img src=\"https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/what.svg\" alt=\"im\" *ngIf=\"!assessmentForm.name.trim() || activeSelector === 'name'\">\r\n\r\n            <svg *ngIf=\"assessmentForm.name.trim() && activeSelector !== 'name'\" class=\"checkIcon\"\r\n                xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 52 52\">\r\n                <circle class=\"checkIcon__circle\" cx=\"26\" cy=\"26\" r=\"25\" fill=\"none\" />\r\n                <path class=\"checkIcon__check\" fill=\"none\" d=\"M14.1 27.2l7.1 7.2 16.7-16.8\" />\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\">Assessment Name <span class=\"required\">*</span></label>\r\n                <input type=\"text\" (keydown)=\"activeSelector = 'name'\" (focusin)=\"activateSelector('name',true)\"\r\n                (focusout)=\"activateSelector('name',false)\" [(ngModel)]=\"assessmentForm.name\" placeholder=\"Add an assessment name\" *ngIf=\"assessmentForm.name =='' || activeSelector === 'name'\">\r\n                <div class=\"selected\" *ngIf=\"assessmentForm.name.length && activeSelector !== 'name'\">\r\n                    <div class=\"chip-container\">\r\n                        <span class=\"value\">{{assessmentForm.name}}</span>\r\n                    </div>\r\n                    <button class=\"edit\" (click)=\"activateSelector('name',true)\"type=\"button\"><i class=\"icons\">&#xe9ba;</i> Edit</button>\r\n                </div>\r\n                <p *ngIf=\"submitted && (!assessmentForm.name.trim())\" class=\"error-message\">Enter a name for this Assessment.</p>\r\n                <vcomply-editor [(ngModel)]=\"assessmentForm.description\" [editorConfig]=\"description\" (clickOutside)=\"checkDescription()\"></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 class=\"form-group-row\" [class.active]=\"activeSelector === 'category'\" [class.disabled]=\"activeSelector && activeSelector !== 'category' && sideSelectorElements.includes(activeSelector)\">\r\n        <div class=\"left\" [class.checked]=\"assessmentForm?.category?.length\">\r\n            <img *ngIf=\"!assessmentForm?.category?.length || activeSelector === 'category'\" src=\"https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/category.svg\" alt=\"\" />\r\n\r\n            <svg class=\"checkIcon\" *ngIf=\"assessmentForm?.category?.length && activeSelector !== 'category'\"\r\n                xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 52 52\">\r\n                <circle class=\"checkIcon__circle\" cx=\"26\" cy=\"26\" r=\"25\" fill=\"none\" />\r\n                <path class=\"checkIcon__check\" fill=\"none\" d=\"M14.1 27.2l7.1 7.2 16.7-16.8\" />\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\">ASSESSMENT CATEGORY <span class=\"required\">*</span></label>\r\n                <div class=\"select\" *ngIf=\"!assessmentForm?.category?.length\">\r\n                    <input type=\"text\" (click)=\"activateSelector('category',true)\" placeholder=\"Select category for this assessment\" readonly>\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 class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\" *ngIf=\"assessmentForm?.category[0]?.category_name !== 'uncategorized'\" (click)=\"remove('category',assessmentForm.category[0])\">&#xe9ae;</i>\r\n                        <span class=\"chipName vx-fs-11 vx-label-txt\" [appTooltip]=\"assessmentForm?.category[0]?.category_name\" placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"false\">{{assessmentForm?.category[0]?.category_name}}</span>\r\n                        <button class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\" appPopover (click)=\"category.popover()\" placement=\"right\" *ngIf=\"assessmentForm?.category?.length > 1\">+{{assessmentForm?.category?.length -1}}</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 *ngIf=\"activeSelector !== 'category'\" class=\"edit\" type=\"button\" (click)=\"activateSelector('category',true)\"><i class=\"icons\">&#xe9ba;</i> Edit</button>\r\n                </div>\r\n                <p *ngIf=\"submitted && (!assessmentForm?.category?.length)\" class=\"error-message\">Select the Assessment Category.</p>\r\n                <app-popover #category [dontCloseonClick]=\"true\">\r\n                    <div class=\"wf-action-list\">\r\n                        <ul class=\"action-item\">\r\n                            <li *ngFor=\"let category of assessmentForm?.category | slice: 1; let j = index\">\r\n                                <div class=\"avatar-card\">\r\n                                    <span class=\"value\">\r\n                                        <i class=\"icons\" (click)=\"remove('category',category)\">&#xe90d;</i>\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 class=\"vx-form-group\" *ngFor=\"let tag of assessmentForm.customTags\">\r\n                    <label class=\"vx-control-panel\">{{tag.custom_tag_name}}</label>\r\n                    <input type=\"text\"  [(ngModel)]=\"tag.custom_tag_value\" [placeholder]=\"tag.custom_tag_name\">\r\n                </div>\r\n            </ng-container>\r\n\r\n        </div>\r\n    </div>\r\n\r\n    <!-- Assessment Approval Workflow -->\r\n    <div *ngIf=\"false\" class=\"form-group-row\" [class.active]=\"false\" [class.disabled]=\"false\">\r\n        <div class=\"left\" [class.checked]=\"false\">\r\n            <img *ngIf=\"true\" src=\"https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/approval.svg\" alt=\"im\">\r\n\r\n            <svg *ngIf=\"false\" class=\"checkIcon\"\r\n                xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 52 52\">\r\n                <circle class=\"checkIcon__circle\" cx=\"26\" cy=\"26\" r=\"25\" fill=\"none\" />\r\n                <path class=\"checkIcon__check\" fill=\"none\" d=\"M14.1 27.2l7.1 7.2 16.7-16.8\" />\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>APPROVAL NOT REQUIRED <i class=\"icons\" [appTooltip]=\"'Approval workflow info text here...'\" placement=\"bottom-right\" type=\"white\" delay=\"0\" [tooltipMandatory]=\"true\">&#xe932;</i></app-cs-switch>\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 class=\"count\" *ngIf=\"true\" type=\"button\" appPopover (click)=\"labelName.popover()\" placement=\"right\">+8</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\r\n                            </div>\r\n                            <button class=\"edit\" type=\"button\"><i class=\"icons\">&#xe9ba;</i>Edit</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\">Select or create an approval workflow for this assessment.</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 *ngIf=\"(assessmentService?.categoriesListData$|async) as categories\">\r\n\r\n<app-radio-list-with-pagination  *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</app-smiley-dialog-inline>\r\n<!-- <app-create-assessment-container></app-create-assessment-container> -->\r\n"]}
247
+ //# 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 = false;\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.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 = { ...this.assessmentForm, ...{ riskType: type } };\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 *ngIf=\"false\" class=\"form-group-row\" [class.active]=\"false\" [class.disabled]=\"false\">\r\n        <div class=\"left\" [class.checked]=\"false\">\r\n            <img src=\"https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/associated-risks.svg\" alt=\"im\" *ngIf=\"true\">\r\n\r\n            <svg *ngIf=\"false\" class=\"checkIcon\"\r\n                xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 52 52\">\r\n                <circle class=\"checkIcon__circle\" cx=\"26\" cy=\"26\" r=\"25\" fill=\"none\" />\r\n                <path class=\"checkIcon__check\" fill=\"none\" d=\"M14.1 27.2l7.1 7.2 16.7-16.8\" />\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\">ASSESSMENT TYPE <span class=\"required\">*</span></label>\r\n                <div class=\"risk-type-field\">\r\n                    <div class=\"type-item\" [class.active]=\"assessmentForm?.assessmentType === 'COMPLIANCE'\">\r\n                        <button [class.disabled]=\"!assessmentTypeChangeAllowed\" (click)=\"changeAssessment('COMPLIANCE')\">COMPLIANCE ASSESSMENT</button>\r\n                        <i class=\"icons info\" [appTooltip]=\"'Compliance assessment info text here...'\" placement=\"bottom-right\" delay=\"0\" type=\"white\" [tooltipMandatory]=\"true\">&#xe932;</i>\r\n                    </div>\r\n                    <div class=\"type-item\" [class.active]=\"false\">\r\n                        <button [class.disabled]=\"!assessmentTypeChangeAllowed\" (click)=\"changeAssessment('RISK')\">RISK ASSESSMENT</button>\r\n                        <i class=\"icons info\" [appTooltip]=\"'Risk assessment info text here...'\" placement=\"bottom-right\" delay=\"0\" type=\"white\" [tooltipMandatory]=\"true\">&#xe932;</i>\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 class=\"form-group-row\" [class.active]=\"false\" [class.disabled]=\" activeSelector && activeSelector !== 'name'  && sideSelectorElements.includes(activeSelector)\">\r\n        <div class=\"left\" [class.checked]=\"false\">\r\n            <img src=\"https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/what.svg\" alt=\"im\" *ngIf=\"!assessmentForm.name.trim() || activeSelector === 'name'\">\r\n\r\n            <svg *ngIf=\"assessmentForm.name.trim() && activeSelector !== 'name'\" class=\"checkIcon\"\r\n                xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 52 52\">\r\n                <circle class=\"checkIcon__circle\" cx=\"26\" cy=\"26\" r=\"25\" fill=\"none\" />\r\n                <path class=\"checkIcon__check\" fill=\"none\" d=\"M14.1 27.2l7.1 7.2 16.7-16.8\" />\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\">Assessment Name <span class=\"required\">*</span></label>\r\n                <input type=\"text\" (keydown)=\"activeSelector = 'name'\" (focusin)=\"activateSelector('name',true)\"\r\n                (focusout)=\"activateSelector('name',false)\" [(ngModel)]=\"assessmentForm.name\" placeholder=\"Add an assessment name\" *ngIf=\"assessmentForm.name =='' || activeSelector === 'name'\">\r\n                <div class=\"selected\" *ngIf=\"assessmentForm.name.length && activeSelector !== 'name'\">\r\n                    <div class=\"chip-container\">\r\n                        <span class=\"value\">{{assessmentForm.name}}</span>\r\n                    </div>\r\n                    <button class=\"edit\" (click)=\"activateSelector('name',true)\"type=\"button\"><i class=\"icons\">&#xe9ba;</i> Edit</button>\r\n                </div>\r\n                <p *ngIf=\"submitted && (!assessmentForm.name.trim())\" class=\"error-message\">Enter a name for this Assessment.</p>\r\n                <vcomply-editor [(ngModel)]=\"assessmentForm.description\" [editorConfig]=\"description\" (clickOutside)=\"checkDescription()\"></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 class=\"form-group-row\" [class.active]=\"activeSelector === 'category'\" [class.disabled]=\"activeSelector && activeSelector !== 'category' && sideSelectorElements.includes(activeSelector)\">\r\n        <div class=\"left\" [class.checked]=\"assessmentForm?.category?.length\">\r\n            <img *ngIf=\"!assessmentForm?.category?.length || activeSelector === 'category'\" src=\"https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/category.svg\" alt=\"\" />\r\n\r\n            <svg class=\"checkIcon\" *ngIf=\"assessmentForm?.category?.length && activeSelector !== 'category'\"\r\n                xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 52 52\">\r\n                <circle class=\"checkIcon__circle\" cx=\"26\" cy=\"26\" r=\"25\" fill=\"none\" />\r\n                <path class=\"checkIcon__check\" fill=\"none\" d=\"M14.1 27.2l7.1 7.2 16.7-16.8\" />\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\">ASSESSMENT CATEGORY <span class=\"required\">*</span></label>\r\n                <div class=\"select\" *ngIf=\"!assessmentForm?.category?.length\">\r\n                    <input type=\"text\" (click)=\"activateSelector('category',true)\" placeholder=\"Select category for this assessment\" readonly>\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 class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\" *ngIf=\"assessmentForm?.category[0]?.category_name !== 'uncategorized'\" (click)=\"remove('category',assessmentForm.category[0])\">&#xe9ae;</i>\r\n                        <span class=\"chipName vx-fs-11 vx-label-txt\" [appTooltip]=\"assessmentForm?.category[0]?.category_name\" placement=\"bottom-left\" delay=\"0\" type=\"black\" [tooltipMandatory]=\"false\">{{assessmentForm?.category[0]?.category_name}}</span>\r\n                        <button class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\" appPopover (click)=\"category.popover()\" placement=\"right\" *ngIf=\"assessmentForm?.category?.length > 1\">+{{assessmentForm?.category?.length -1}}</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 *ngIf=\"activeSelector !== 'category'\" class=\"edit\" type=\"button\" (click)=\"activateSelector('category',true)\"><i class=\"icons\">&#xe9ba;</i> Edit</button>\r\n                </div>\r\n                <p *ngIf=\"submitted && (!assessmentForm?.category?.length)\" class=\"error-message\">Select the Assessment Category.</p>\r\n                <app-popover #category [dontCloseonClick]=\"true\">\r\n                    <div class=\"wf-action-list\">\r\n                        <ul class=\"action-item\">\r\n                            <li *ngFor=\"let category of assessmentForm?.category | slice: 1; let j = index\">\r\n                                <div class=\"avatar-card\">\r\n                                    <span class=\"value\">\r\n                                        <i class=\"icons\" (click)=\"remove('category',category)\">&#xe90d;</i>\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 class=\"vx-form-group\" *ngFor=\"let tag of assessmentForm.customTags\">\r\n                    <label class=\"vx-control-panel\">{{tag.custom_tag_name}}</label>\r\n                    <input type=\"text\"  [(ngModel)]=\"tag.custom_tag_value\" [placeholder]=\"tag.custom_tag_name\">\r\n                </div>\r\n            </ng-container>\r\n\r\n        </div>\r\n    </div>\r\n\r\n    <!-- Assessment Approval Workflow -->\r\n    <div *ngIf=\"false\" class=\"form-group-row\" [class.active]=\"false\" [class.disabled]=\"false\">\r\n        <div class=\"left\" [class.checked]=\"false\">\r\n            <img *ngIf=\"true\" src=\"https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/approval.svg\" alt=\"im\">\r\n\r\n            <svg *ngIf=\"false\" class=\"checkIcon\"\r\n                xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 52 52\">\r\n                <circle class=\"checkIcon__circle\" cx=\"26\" cy=\"26\" r=\"25\" fill=\"none\" />\r\n                <path class=\"checkIcon__check\" fill=\"none\" d=\"M14.1 27.2l7.1 7.2 16.7-16.8\" />\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>APPROVAL NOT REQUIRED <i class=\"icons\" [appTooltip]=\"'Approval workflow info text here...'\" placement=\"bottom-right\" type=\"white\" delay=\"0\" [tooltipMandatory]=\"true\">&#xe932;</i></app-cs-switch>\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 class=\"count\" *ngIf=\"true\" type=\"button\" appPopover (click)=\"labelName.popover()\" placement=\"right\">+8</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\r\n                            </div>\r\n                            <button class=\"edit\" type=\"button\"><i class=\"icons\">&#xe9ba;</i>Edit</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\">Select or create an approval workflow for this assessment.</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 *ngIf=\"(assessmentService?.categoriesListData$|async) as categories\">\r\n\r\n<app-radio-list-with-pagination  *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</app-smiley-dialog-inline>\r\n<!-- <app-create-assessment-container></app-create-assessment-container> -->\r\n"]}