vcomply-workflow-engine 6.0.52 → 6.0.53

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 (73) hide show
  1. package/esm2022/lib/add-multiple-responsibility-container/add-multiple-responsibility-container.component.mjs +2 -2
  2. package/esm2022/lib/add-multiple-risk/add-multiple-risk.component.mjs +2 -2
  3. package/esm2022/lib/constants/assets.constants.mjs +57 -0
  4. package/esm2022/lib/constants/link-responsibility.constants.mjs +2 -2
  5. package/esm2022/lib/log-an-issue/log-an-issue.component.mjs +2 -2
  6. package/esm2022/lib/more-option/more-option.component.mjs +2 -2
  7. package/esm2022/lib/report-a-case/components/assignee/assignee.component.mjs +2 -2
  8. package/esm2022/lib/report-a-case/components/case-assignees/case-assignees.component.mjs +2 -2
  9. package/esm2022/lib/report-a-case/components/case-category/case-category.component.mjs +2 -2
  10. package/esm2022/lib/report-a-case/components/case-details/case-details.component.mjs +2 -2
  11. package/esm2022/lib/report-a-case/components/case-owners/case-owners.component.mjs +2 -2
  12. package/esm2022/lib/report-a-case/components/case-priority/case-priority.component.mjs +2 -2
  13. package/esm2022/lib/report-a-case/components/case-resolution-deadline/case-resolution-deadline.component.mjs +2 -2
  14. package/esm2022/lib/report-a-case/components/case-type-dropdown/case-dropdown.component.mjs +2 -2
  15. package/esm2022/lib/report-a-case/components/due-date/due-date.component.mjs +2 -2
  16. package/esm2022/lib/report-a-case/components/field-holder/field-holder.component.mjs +2 -2
  17. package/esm2022/lib/report-a-case/components/linked assessment/linked-assessment.component.mjs +2 -2
  18. package/esm2022/lib/report-a-case/components/linked-responsibilities/linked-responsibilities.component.mjs +2 -2
  19. package/esm2022/lib/report-a-case/components/rc-details/rc-details.component.mjs +2 -2
  20. package/esm2022/lib/report-a-case/components/report-date/report-date.component.mjs +2 -2
  21. package/esm2022/lib/report-a-case/workflow-case/workflow-case.component.mjs +2 -2
  22. package/esm2022/lib/sharedComponents/approval-workflow/approval-create-form/approval-create-form.component.mjs +2 -2
  23. package/esm2022/lib/sharedComponents/assessment-editor/components/build/image-choice/image-choice.component.mjs +2 -2
  24. package/esm2022/lib/sharedComponents/assessment-editor/components/build/thank-you/thank-you.component.mjs +2 -2
  25. package/esm2022/lib/sharedComponents/assessment-editor/components/build/welcome/welcome.component.mjs +2 -2
  26. package/esm2022/lib/sharedComponents/assessment-editor/components/logic/logic.component.mjs +2 -2
  27. package/esm2022/lib/sharedComponents/assessment-editor/components/logic-questions/logic-image-choice/logic-image-choice.component.mjs +2 -2
  28. package/esm2022/lib/sharedComponents/assessment-editor/components/preview/thank-you/thank-you.component.mjs +2 -2
  29. package/esm2022/lib/sharedComponents/assessment-editor/components/preview/welcome/welcome.component.mjs +2 -2
  30. package/esm2022/lib/sharedComponents/assessment-editor/components/welcome-thankyou/welcome-thankyou.component.mjs +2 -2
  31. package/esm2022/lib/sharedComponents/assessment-list/assessment-list.component.mjs +2 -2
  32. package/esm2022/lib/sharedComponents/audit-category-list/audit-category-list.component.mjs +2 -2
  33. package/esm2022/lib/sharedComponents/category-list/category-list.component.mjs +2 -2
  34. package/esm2022/lib/sharedComponents/category-list-selection/category-list-selection/category-list-selection.component.mjs +2 -2
  35. package/esm2022/lib/sharedComponents/category-multiselect/category-multi-select.component.mjs +2 -2
  36. package/esm2022/lib/sharedComponents/checkbox-list/checkbox-list.component.mjs +2 -2
  37. package/esm2022/lib/sharedComponents/format-and-evidence/format-and-evidence.component.mjs +2 -2
  38. package/esm2022/lib/sharedComponents/framework-list/framework-list.component.mjs +2 -2
  39. package/esm2022/lib/sharedComponents/frequency/frequency-responsibility-list/frequency-responsibility-list.component.mjs +2 -2
  40. package/esm2022/lib/sharedComponents/group-users-list/group-users-list.component.mjs +2 -2
  41. package/esm2022/lib/sharedComponents/link-program/link-program/link-program.component.mjs +2 -2
  42. package/esm2022/lib/sharedComponents/owner-list/owner-list.component.mjs +2 -2
  43. package/esm2022/lib/sharedComponents/policy-access/policy-access.component.mjs +2 -2
  44. package/esm2022/lib/sharedComponents/policy-template/constants/template.constant.mjs +2 -2
  45. package/esm2022/lib/sharedComponents/program-listing/program-listing.component.mjs +2 -2
  46. package/esm2022/lib/sharedComponents/radio-list/radio-list.component.mjs +2 -2
  47. package/esm2022/lib/sharedComponents/radio-list-with-pagination/radio-list.component.mjs +2 -2
  48. package/esm2022/lib/sharedComponents/responsibility-centers-list/responsibility-centers-list.component.mjs +2 -2
  49. package/esm2022/lib/sharedComponents/responsibility-risk-selector/responsibility-risk-selector.component.mjs +2 -2
  50. package/esm2022/lib/sharedComponents/review-frequency/review-frequency.component.mjs +2 -2
  51. package/esm2022/lib/sharedComponents/roles-list/roles-list.component.mjs +2 -2
  52. package/esm2022/lib/sharedComponents/select-approvers/select-approvers.component.mjs +2 -2
  53. package/esm2022/lib/sharedComponents/users-radio-list/users-radio-list.component.mjs +2 -2
  54. package/esm2022/lib/ui-kit/pagination/pagination/pagination.component.mjs +2 -2
  55. package/esm2022/lib/workflow/shared/components/attributes/attributes-checkbox/attributes-checkbox.component.mjs +2 -2
  56. package/esm2022/lib/workflow/shared/constants/cdn-link.constant.mjs +2 -2
  57. package/esm2022/lib/workflow-assessment/import-an-assessment/import-an-assessment.component.mjs +2 -2
  58. package/esm2022/lib/workflow-assessment/workflow-assessment.component.mjs +2 -2
  59. package/esm2022/lib/workflow-compliance/workflow-compliance.component.mjs +2 -2
  60. package/esm2022/lib/workflow-policy/workflow-policy.component.mjs +2 -2
  61. package/esm2022/lib/workflow-program/create-program-ui/assessment-picker/assessment-picker.component.mjs +2 -2
  62. package/esm2022/lib/workflow-program/create-program-ui/define-framework-listing/define-framework-listing.component.mjs +2 -2
  63. package/esm2022/lib/workflow-program/create-program-ui/pagination/pagination/pagination.component.mjs +2 -2
  64. package/esm2022/lib/workflow-program/create-program-ui/role-list/role-list.component.mjs +2 -2
  65. package/esm2022/lib/workflow-program/create-program-ui/user-group-list/user-group-list.component.mjs +2 -2
  66. package/esm2022/lib/workflow-program/workflow-program.component.mjs +2 -2
  67. package/esm2022/lib/workflow-risk/workflow-risk.component.mjs +2 -2
  68. package/esm2022/lib/workflow-survey-form/workflow-survey-form.component.mjs +2 -2
  69. package/fesm2022/vcomply-workflow-engine.mjs +14 -15
  70. package/fesm2022/vcomply-workflow-engine.mjs.map +1 -1
  71. package/package.json +1 -1
  72. package/esm2022/lib/constants/assessts.constants.mjs +0 -57
  73. /package/lib/constants/{assessts.constants.d.ts → assets.constants.d.ts} +0 -0
@@ -1,5 +1,5 @@
1
1
  import { Component, EventEmitter, Input, Optional, Output, } from '@angular/core';
2
- import { ASSETS } from '../constants/assessts.constants';
2
+ import { ASSETS } from '../constants/assets.constants';
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "../workflow-services/assessment.service";
5
5
  import * as i2 from "../workflow-services/auth.service";
@@ -257,4 +257,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
257
257
  }], closeWorkflow: [{
258
258
  type: Output
259
259
  }] } });
260
- //# 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 {\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Optional,\n  Output,\n} from '@angular/core';\n\nimport { EditorConfig } from 'vcomply-editor';\nimport { Configurations } from '../configurations';\nimport { SnackBarService } from '../ui-kit/snack-bar/snack-bar.service';\nimport { AssessmentService } from '../workflow-services/assessment.service';\nimport { AuthService } from '../workflow-services/auth.service';\nimport { UiKitService } from '../workflow-services/ui-kit.service';\nimport { IframeService } from '../services/iframe.service';\nimport { ASSETS } from '../constants/assessts.constants';\n\n@Component({\n  selector: 'app-workflow-assessment',\n  templateUrl: './workflow-assessment.component.html',\n  styleUrls: ['./workflow-assessment.component.less', '../forms.less'],\n})\nexport class WorkflowAssessmentComponent implements OnInit {\n  ASSETS = ASSETS;\n  activeSelector: any = '';\n  submitted = false;\n  loader = false;\n  showSmiley = false;\n  @Input() mode = 'EDIT';\n  @Input() assessmentId = '';\n  @Input() openedFrom = '';\n  @Output() disconnectRefresh = new EventEmitter();\n  sideSelectorElements: any = ['category'];\n  actionButtons = [\n    // { buttonText: 'Add More Assessments', class: 'white-btn', id: 'addMore' },\n    {\n      buttonText: 'Go to assessment workroom',\n      class: 'blue-btn',\n      id: 'viewAssessment',\n    },\n  ];\n  assessmentTypeChangeAllowed = true;\n  timezone!: string;\n  @Output() pickerChanged = new EventEmitter();\n  @Output() closeWorkflow = new EventEmitter();\n  assessmentForm: any = {\n    assessmentType: 'compliance',\n    name: '',\n    description: '',\n    category: [],\n    customTags: [],\n  };\n  assessmentData: any;\n  organizationId = 0;\n  constructor(\n    public assessmentService: AssessmentService,\n    private authService: AuthService,\n    private uiKitService: UiKitService,\n    private snackBar: SnackBarService,\n    private iframeService: IframeService,\n    @Optional() config?: Configurations\n  ) {\n    this.timezone = this.authService.getUserTimeZone();\n  }\n  selectorConfig = {\n    ASSESSMENT_CATGORY: {\n      panelTitle: 'Select an Assessment Category',\n      entitySingular: 'Category selected.',\n      entityPlural: 'Categories selected.',\n      displayKey: 'category_name',\n      identifierKey: 'id',\n      parentKey: 'category_parents',\n      parentDisplayKey: 'parent_tree',\n      searchPlaceholder: 'Search an assessment category.',\n      noDataText: 'No assessment categories found.',\n    },\n  };\n  ngOnInit(): void {\n    //this.loader = true;\n    if (this.mode === 'CREATE') {\n      this.organizationId = this.authService.getOrganizationId();\n    }\n    //this.setCategory({ searchKey: '', page: 1 });\n    if (this.mode === 'EDIT') {\n      this.getAssessmentDetails();\n    }\n  }\n\n  getAssessmentDetails() {\n    this.loader = true;\n    this.assessmentService.getAssessmentDetails(this.assessmentId).subscribe({\n      next: (res: any) => {\n        this.assessmentForm.name = res?.assessment_name ?? '';\n        this.assessmentForm.description = res?.description ?? '';\n        this.assessmentForm.assessmentType =\n          res?.assessment_type ?? 'compliance';\n        this.assessmentForm.category = res.category_arr.map((ele: any) => {\n          return { id: ele?._id, category_name: ele?.category_name };\n        });\n        this.assessmentTypeChangeAllowed =\n          res?.assessment_type === 'compliance';\n        this.loader = false;\n      },\n      error: (err: any) => {\n        this.snackBar.show(\n          'OOPS! Something went wrong and the page could not be loaded. Could you please try one more time?',\n          'alert'\n        );\n        this.loader = false;\n      },\n    });\n  }\n\n  //This function is responsible for fetching the list of categories\n  setCategory(evt: any) {\n    this.assessmentService.fetchCategory({\n      search_title: evt.searchKey,\n      page_no: evt.page,\n    });\n  }\n\n  activateSelector(type: any, event: boolean) {\n    if (type === 'category') {\n      this.setCategory({ searchKey: '', page: 1 });\n    }\n    this.activeSelector = event ? type : '';\n    if (this.sideSelectorElements.includes(type)) {\n      this.pickerChanged.emit(event);\n    }\n  }\n\n  activeDeselector() {\n    this.activeSelector = '';\n    this.pickerChanged.emit(false);\n  }\n\n  next(type: string, payload: any) {\n    switch (type) {\n      case 'CATEGORY': {\n        this.activeDeselector();\n        this.assessmentForm.category = payload;\n        if (this.assessmentForm.category?.length > 1) {\n          this.assessmentForm.category = this.assessmentForm.category.filter(\n            (ele: any) => ele?.category_name != 'uncategorized'\n          );\n        }\n      }\n    }\n  }\n\n  remove(type: any, event: any) {\n    switch (type) {\n      case 'category':\n        this.assessmentForm.category = this.assessmentForm.category.filter(\n          (ele: any) => ele?.id !== event?.id\n        );\n    }\n  }\n\n  description: EditorConfig = {\n    mode: 'prime',\n    colorPalette: true,\n    link: true,\n    placeholder: 'Add a description',\n  };\n\n  changeAssessment(type: string) {\n    this.assessmentForm = {\n      ...this.assessmentForm,\n      ...{ assessmentType: type?.toLocaleLowerCase() },\n    };\n    console.log('this.assessmentForm ===>', this.assessmentForm);\n  }\n  closeSmiley(evt: any) {\n    this.closeWorkflow.emit({ evt: this.assessmentId, confirm: false });\n  }\n\n  action(evt: any) {\n    if (evt === 'viewAssessment') {\n      this.disconnectRefresh.emit(false);\n      const url = `https://${window.location.hostname}/assessment/assessment-workroom/?id=${this.assessmentId}`;\n      this.iframeService.redirectIfInIframe(url, true);\n    }\n  }\n\n  checkDescription() {\n    if (this.assessmentForm.description == '<br>') {\n      this.assessmentForm.description = '';\n    }\n  }\n\n  submitAssessment() {\n    this.submitted = true;\n    const valid = this.validateAssessment();\n    if (!valid) {\n      return false;\n    } else {\n      this.createAssessment(this.assessmentForm);\n    }\n  }\n\n  validateAssessment() {\n    this.submitted = true;\n    if (\n      !this.assessmentForm.name.trim() ||\n      this.assessmentForm.category.length == 0\n    ) {\n      return false;\n    } else {\n      return true;\n    }\n  }\n\n  createAssessment(assessmentForm: any) {\n    this.loader = true;\n    this.uiKitService.isLoader = false;\n\n    const payload = {\n      assessment_name: assessmentForm.name.trim(),\n      description: assessmentForm.description,\n      assessment_type: assessmentForm.assessmentType,\n      category_arr: this.assessmentForm.category.map((ele: any) => ele.id),\n      approval_workflow_arr: {\n        test: 'test',\n      },\n      approval_required: true,\n      source_page: 'compliance',\n    };\n    if (this.mode == 'CREATE') {\n      this.assessmentService.addAssessment(payload).subscribe(\n        (res: any) => {\n          this.disconnectRefresh.emit(false);\n          this.assessmentId = res?._id;\n          const url = `https://${window.location.hostname}/assessment/create/${res?._id}`;\n          this.iframeService.redirectIfInIframe(url, true);\n          this.loader = false;\n        },\n        (err: any) => {\n          console.error(err);\n          this.loader = false;\n          this.uiKitService.isLoader = false;\n          this.snackBar.show(\n            'OOPS! Something went wrong and the page could not be loaded. Could you please try one more time?',\n            'alert'\n          );\n        }\n      );\n    } else if (this.mode === 'EDIT') {\n      this.assessmentService\n        .updateAssessment(this.assessmentId, payload)\n        .subscribe({\n          next: (res: any) => {\n            this.loader = false;\n            this.showSmiley = true;\n          },\n          error: (err: any) => {\n            if (err?.error.message.startsWith('No changes')) {\n              this.loader = false;\n              this.showSmiley = true;\n            } else {\n              this.snackBar.show(\n                'OOPS! Something went wrong and the page could not be loaded. Could you please try one more time?',\n                'alert'\n              );\n            }\n          },\n        });\n    }\n  }\n}\n","<div class=\"workflow-assessment\">\n  <!-- Assessment Type -->\n  <div class=\"form-group-row\" [class.active]=\"false\" [class.disabled]=\"false\">\n    <div class=\"left checked\">\n      <svg\n        class=\"checkIcon\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n        viewBox=\"0 0 52 52\"\n      >\n        <circle class=\"checkIcon__circle\" cx=\"26\" cy=\"26\" r=\"25\" fill=\"none\" />\n        <path\n          class=\"checkIcon__check\"\n          fill=\"none\"\n          d=\"M14.1 27.2l7.1 7.2 16.7-16.8\"\n        />\n      </svg>\n    </div>\n    <div class=\"right\">\n      <div class=\"vx-form-group\">\n        <label class=\"vx-control-panel\"\n          >ASSESSMENT TYPE <span class=\"required\">*</span></label\n        >\n        <div class=\"risk-type-field\">\n          <div\n            class=\"type-item\"\n            [class.active]=\"\n              assessmentForm?.assessmentType === 'compliance_audit'\n            \"\n          >\n            <button\n              [class.disabled]=\"!assessmentTypeChangeAllowed\"\n              (click)=\"changeAssessment('compliance_audit')\"\n            >\n              COMPLIANCE AUDIT\n            </button>\n            <i\n              class=\"icons info\"\n              appTooltip=\"This option lets you create a 'Compliance Audit Template' that can be used to conduct various site, user and department level audits. Once the assessment template is created, you can directly create the responsibility and assign it to the relevant assignee.<br><b>Note:</b> These compliance audit templates can only be linked with an audit responsibility that is created as a part of the creating such assessments.\"\n              placement=\"bottom-right\"\n              delay=\"0\"\n              type=\"white\"\n              [tooltipMandatory]=\"true\"\n              >&#xe932;</i\n            >\n          </div>\n          <div\n            class=\"type-item\"\n            [appTooltip]=\"\n              assessmentTypeChangeAllowed\n                ? ''\n                : 'You Cannot change the assessment type.'\n            \"\n            placement=\"bottom-left\"\n            delay=\"0\"\n            type=\"black\"\n            [tooltipMandatory]=\"true\"\n            [class.active]=\"assessmentForm?.assessmentType === 'compliance'\"\n          >\n            <button\n              [class.disabled]=\"!assessmentTypeChangeAllowed\"\n              (click)=\"changeAssessment('compliance')\"\n            >\n              Other\n            </button>\n            <i\n              class=\"icons info\"\n              [class.disabled]=\"!assessmentTypeChangeAllowed\"\n              [appTooltip]=\"\n                'This option can be used to create any outcome based questionnaire or self-assessment questionnaires. Once the templates are created, they can be linked with multiple responsibilities.'\n              \"\n              placement=\"bottom-right\"\n              delay=\"0\"\n              type=\"white\"\n              [tooltipMandatory]=\"true\"\n              >&#xe932;</i\n            >\n          </div>\n          <span class=\"background-glider\"></span>\n        </div>\n        <p *ngIf=\"false\" class=\"error-message\">Add an assessment type</p>\n      </div>\n    </div>\n  </div>\n\n  <!-- Assessment Name -->\n  <div\n    class=\"form-group-row\"\n    [class.active]=\"false\"\n    [class.disabled]=\"\n      activeSelector &&\n      activeSelector !== 'name' &&\n      sideSelectorElements.includes(activeSelector)\n    \"\n  >\n    <div class=\"left\" [class.checked]=\"false\">\n      <img\n        [src]=\"ASSETS.what\"\n        alt=\"im\"\n        *ngIf=\"!assessmentForm.name.trim() || activeSelector === 'name'\"\n      />\n\n      <svg\n        *ngIf=\"assessmentForm.name.trim() && activeSelector !== 'name'\"\n        class=\"checkIcon\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n        viewBox=\"0 0 52 52\"\n      >\n        <circle class=\"checkIcon__circle\" cx=\"26\" cy=\"26\" r=\"25\" fill=\"none\" />\n        <path\n          class=\"checkIcon__check\"\n          fill=\"none\"\n          d=\"M14.1 27.2l7.1 7.2 16.7-16.8\"\n        />\n      </svg>\n    </div>\n    <div class=\"right\">\n      <div class=\"vx-form-group\">\n        <label class=\"vx-control-panel\"\n          >Assessment Name <span class=\"required\">*</span></label\n        >\n        <input\n          type=\"text\"\n          (keydown)=\"activeSelector = 'name'\"\n          (focusin)=\"activateSelector('name', true)\"\n          (focusout)=\"activateSelector('name', false)\"\n          [(ngModel)]=\"assessmentForm.name\"\n          placeholder=\"Add an assessment name\"\n          *ngIf=\"assessmentForm.name == '' || activeSelector === 'name'\"\n        />\n        <div\n          class=\"selected\"\n          *ngIf=\"assessmentForm.name.length && activeSelector !== 'name'\"\n        >\n          <div class=\"chip-container\">\n            <span class=\"value\">{{ assessmentForm.name }}</span>\n          </div>\n          <button\n            class=\"edit\"\n            (click)=\"activateSelector('name', true)\"\n            type=\"button\"\n          >\n            <i class=\"icons\">&#xe9ba;</i> Edit\n          </button>\n        </div>\n        <p\n          *ngIf=\"submitted && !assessmentForm.name.trim()\"\n          class=\"error-message\"\n        >\n          Enter a name for this Assessment.\n        </p>\n        <vcomply-editor\n          [(ngModel)]=\"assessmentForm.description\"\n          [editorConfig]=\"description\"\n          (clickOutside)=\"checkDescription()\"\n        ></vcomply-editor>\n        <!-- <p *ngIf=\"submitted && (assessmentForm.assessmentType ==='COMPLIANCE' && !assessmentForm?.description?.trim()?.length)\" class=\"error-message\">Add an assessment description</p> -->\n      </div>\n    </div>\n  </div>\n\n  <!-- Assessment Category -->\n  <div\n    class=\"form-group-row\"\n    [class.active]=\"activeSelector === 'category'\"\n    [class.disabled]=\"\n      activeSelector &&\n      activeSelector !== 'category' &&\n      sideSelectorElements.includes(activeSelector)\n    \"\n  >\n    <div class=\"left\" [class.checked]=\"assessmentForm?.category?.length\">\n      <img\n        *ngIf=\"\n          !assessmentForm?.category?.length || activeSelector === 'category'\n        \"\n        [src]=\"ASSETS.case_category\"\n        alt=\"\"\n      />\n\n      <svg\n        class=\"checkIcon\"\n        *ngIf=\"\n          assessmentForm?.category?.length && activeSelector !== 'category'\n        \"\n        xmlns=\"http://www.w3.org/2000/svg\"\n        viewBox=\"0 0 52 52\"\n      >\n        <circle class=\"checkIcon__circle\" cx=\"26\" cy=\"26\" r=\"25\" fill=\"none\" />\n        <path\n          class=\"checkIcon__check\"\n          fill=\"none\"\n          d=\"M14.1 27.2l7.1 7.2 16.7-16.8\"\n        />\n      </svg>\n    </div>\n    <div class=\"right\">\n      <div class=\"vx-form-group\">\n        <label class=\"vx-control-panel\"\n          >ASSESSMENT CATEGORY <span class=\"required\">*</span></label\n        >\n        <div class=\"select\" *ngIf=\"!assessmentForm?.category?.length\">\n          <input\n            type=\"text\"\n            (click)=\"activateSelector('category', true)\"\n            placeholder=\"Select category for this assessment\"\n            readonly\n          />\n        </div>\n        <div class=\"selected\" *ngIf=\"assessmentForm?.category?.length\">\n          <div class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\">\n            <i\n              class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n              *ngIf=\"\n                assessmentForm?.category[0]?.category_name !== 'uncategorized'\n              \"\n              (click)=\"remove('category', assessmentForm.category[0])\"\n              >&#xe9ae;</i\n            >\n            <span\n              class=\"chipName vx-fs-11 vx-label-txt\"\n              [appTooltip]=\"assessmentForm?.category[0]?.category_name\"\n              placement=\"bottom-left\"\n              delay=\"0\"\n              type=\"black\"\n              [tooltipMandatory]=\"false\"\n              >{{ assessmentForm?.category[0]?.category_name }}</span\n            >\n            <button\n              class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n              appPopover\n              (click)=\"category.popover()\"\n              placement=\"right\"\n              *ngIf=\"assessmentForm?.category?.length > 1\"\n            >\n              +{{ assessmentForm?.category?.length - 1 }}\n            </button>\n          </div>\n\n          <!-- <div class=\"chip-container\">\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>\n                        <button class=\"count\" *ngIf=\"assessmentForm?.category?.length > 1\" appPopover (click)=\"category.popover()\" placement=\"right\">+{{assessmentForm?.category?.length -1}}</button>\n                    </div> -->\n          <button\n            *ngIf=\"activeSelector !== 'category'\"\n            class=\"edit\"\n            type=\"button\"\n            (click)=\"activateSelector('category', true)\"\n          >\n            <i class=\"icons\">&#xe9ba;</i> Edit\n          </button>\n        </div>\n        <p\n          *ngIf=\"submitted && !assessmentForm?.category?.length\"\n          class=\"error-message\"\n        >\n          Select the Assessment Category.\n        </p>\n        <app-popover #category [dontCloseonClick]=\"true\">\n          <div class=\"wf-action-list\">\n            <ul class=\"action-item\">\n              <li\n                *ngFor=\"\n                  let category of assessmentForm?.category | slice : 1;\n                  let j = index\n                \"\n              >\n                <div class=\"avatar-card\">\n                  <span class=\"value\">\n                    <i class=\"icons\" (click)=\"remove('category', category)\"\n                      >&#xe90d;</i\n                    >\n                    {{ category?.category_name }}\n                  </span>\n                </div>\n              </li>\n            </ul>\n          </div>\n        </app-popover>\n      </div>\n      <ng-container *ngIf=\"assessmentForm?.customTags?.length > 0\">\n        <div\n          class=\"vx-form-group\"\n          *ngFor=\"let tag of assessmentForm.customTags\"\n        >\n          <label class=\"vx-control-panel\">{{ tag.custom_tag_name }}</label>\n          <input\n            type=\"text\"\n            [(ngModel)]=\"tag.custom_tag_value\"\n            [placeholder]=\"tag.custom_tag_name\"\n          />\n        </div>\n      </ng-container>\n    </div>\n  </div>\n\n  <!-- Assessment Approval Workflow -->\n  <div\n    *ngIf=\"false\"\n    class=\"form-group-row\"\n    [class.active]=\"false\"\n    [class.disabled]=\"false\"\n  >\n    <div class=\"left\" [class.checked]=\"false\">\n      <img *ngIf=\"true\" [src]=\"ASSETS.approval\" alt=\"im\" />\n\n      <svg\n        *ngIf=\"false\"\n        class=\"checkIcon\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n        viewBox=\"0 0 52 52\"\n      >\n        <circle class=\"checkIcon__circle\" cx=\"26\" cy=\"26\" r=\"25\" fill=\"none\" />\n        <path\n          class=\"checkIcon__check\"\n          fill=\"none\"\n          d=\"M14.1 27.2l7.1 7.2 16.7-16.8\"\n        />\n      </svg>\n    </div>\n    <div class=\"right\">\n      <div class=\"vx-form-group approval-workflow\" [class.disabled]=\"false\">\n        <label class=\"vx-control-panel\">\n          Approval workflow <span class=\"required\">*</span>\n          <button class=\"button\">CREATE A NEW APPROVAL WORKFLOW</button>\n        </label>\n        <div class=\"select\" [class.disabled]=\"false\" *ngIf=\"true\">\n          <cs-select [placeholder]=\"'Select approvers for this assessment'\">\n            <cs-option>test</cs-option>\n            <cs-option>Create a new approval workflow</cs-option>\n          </cs-select>\n        </div>\n        <app-cs-switch\n          >APPROVAL NOT REQUIRED\n          <i\n            class=\"icons\"\n            [appTooltip]=\"'Approval workflow info text here...'\"\n            placement=\"bottom-right\"\n            type=\"white\"\n            delay=\"0\"\n            [tooltipMandatory]=\"true\"\n            >&#xe932;</i\n          ></app-cs-switch\n        >\n        <ng-container *ngIf=\"true\">\n          <div class=\"selected\">\n            <div class=\"workflow-label\">\n              <p class=\"title\">Level 1</p>\n              <p class=\"description\">lavel name</p>\n            </div>\n            <div class=\"vx-d-flex vx-align-center\">\n              <div class=\"chip-container\">\n                <span class=\"chip\">\n                  <i class=\"icons\">&#xe90d;</i>\n                  <span class=\"step\" *ngIf=\"true\">1</span>approval name\n                </span>\n\n                <button\n                  class=\"count\"\n                  *ngIf=\"true\"\n                  type=\"button\"\n                  appPopover\n                  (click)=\"labelName.popover()\"\n                  placement=\"right\"\n                >\n                  +8\n                </button>\n                <app-popover #labelName [dontCloseonClick]=\"true\">\n                  <div class=\"wf-action-list\">\n                    <ul class=\"action-item\">\n                      <li *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\n                        <div class=\"avatar-card\">\n                          <span class=\"value\">\n                            <i class=\"icons\">&#xe90d;</i>\n                            <span class=\"step\">2</span>approval name\n                          </span>\n                        </div>\n                      </li>\n                    </ul>\n                  </div>\n                </app-popover>\n              </div>\n              <button class=\"edit\" type=\"button\">\n                <i class=\"icons\">&#xe9ba;</i>Edit\n              </button>\n              <button class=\"close-btn\"><i class=\"icons\">&#xe90d;</i></button>\n            </div>\n          </div>\n        </ng-container>\n\n        <p *ngIf=\"true\" class=\"error-message\">\n          Select or create an approval workflow for this assessment.\n        </p>\n\n        <label class=\"vx-control-panel\" *ngIf=\"true\">\n          <button class=\"button\">+ Add More Levels</button>\n        </label>\n      </div>\n    </div>\n  </div>\n</div>\n<ng-container\n  *ngIf=\"assessmentService?.categoriesListData$ | async as categories\"\n>\n  <app-radio-list-with-pagination\n    *ngIf=\"activeSelector === 'category'\"\n    [categoryList]=\"categories?.data\"\n    [config]=\"selectorConfig?.ASSESSMENT_CATGORY\"\n    [currentPage]=\"categories?.currentPage\"\n    [recordStart]=\"categories?.start_value\"\n    [recordEnd]=\"categories?.end_value\"\n    [totalRecords]=\"categories?.totalRecords\"\n    [totalPages]=\"categories?.totalPage\"\n    [loading]=\"assessmentService?.categoriesLoading$ | async\"\n    (fetchData)=\"setCategory($event)\"\n    (next)=\"next('CATEGORY', $event)\"\n    [selectedList]=\"assessmentForm?.category | uncategorizedFilter\"\n    (cancel)=\"activeDeselector()\"\n    (back)=\"activeDeselector()\"\n  ></app-radio-list-with-pagination>\n</ng-container>\n<app-loader-inline *ngIf=\"loader\"></app-loader-inline>\n<app-smiley-dialog-inline\n  *ngIf=\"showSmiley\"\n  [message]=\"smileyMessage\"\n  [actionButtons]=\"actionButtons\"\n  (action)=\"action($event)\"\n  (closeSmiley)=\"closeSmiley($event)\"\n>\n</app-smiley-dialog-inline>\n<!-- <app-create-assessment-container></app-create-assessment-container> -->\n"]}
260
+ //# 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 {\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Optional,\n  Output,\n} from '@angular/core';\n\nimport { EditorConfig } from 'vcomply-editor';\nimport { Configurations } from '../configurations';\nimport { SnackBarService } from '../ui-kit/snack-bar/snack-bar.service';\nimport { AssessmentService } from '../workflow-services/assessment.service';\nimport { AuthService } from '../workflow-services/auth.service';\nimport { UiKitService } from '../workflow-services/ui-kit.service';\nimport { IframeService } from '../services/iframe.service';\nimport { ASSETS } from '../constants/assets.constants';\n\n@Component({\n  selector: 'app-workflow-assessment',\n  templateUrl: './workflow-assessment.component.html',\n  styleUrls: ['./workflow-assessment.component.less', '../forms.less'],\n})\nexport class WorkflowAssessmentComponent implements OnInit {\n  ASSETS = ASSETS;\n  activeSelector: any = '';\n  submitted = false;\n  loader = false;\n  showSmiley = false;\n  @Input() mode = 'EDIT';\n  @Input() assessmentId = '';\n  @Input() openedFrom = '';\n  @Output() disconnectRefresh = new EventEmitter();\n  sideSelectorElements: any = ['category'];\n  actionButtons = [\n    // { buttonText: 'Add More Assessments', class: 'white-btn', id: 'addMore' },\n    {\n      buttonText: 'Go to assessment workroom',\n      class: 'blue-btn',\n      id: 'viewAssessment',\n    },\n  ];\n  assessmentTypeChangeAllowed = true;\n  timezone!: string;\n  @Output() pickerChanged = new EventEmitter();\n  @Output() closeWorkflow = new EventEmitter();\n  assessmentForm: any = {\n    assessmentType: 'compliance',\n    name: '',\n    description: '',\n    category: [],\n    customTags: [],\n  };\n  assessmentData: any;\n  organizationId = 0;\n  constructor(\n    public assessmentService: AssessmentService,\n    private authService: AuthService,\n    private uiKitService: UiKitService,\n    private snackBar: SnackBarService,\n    private iframeService: IframeService,\n    @Optional() config?: Configurations\n  ) {\n    this.timezone = this.authService.getUserTimeZone();\n  }\n  selectorConfig = {\n    ASSESSMENT_CATGORY: {\n      panelTitle: 'Select an Assessment Category',\n      entitySingular: 'Category selected.',\n      entityPlural: 'Categories selected.',\n      displayKey: 'category_name',\n      identifierKey: 'id',\n      parentKey: 'category_parents',\n      parentDisplayKey: 'parent_tree',\n      searchPlaceholder: 'Search an assessment category.',\n      noDataText: 'No assessment categories found.',\n    },\n  };\n  ngOnInit(): void {\n    //this.loader = true;\n    if (this.mode === 'CREATE') {\n      this.organizationId = this.authService.getOrganizationId();\n    }\n    //this.setCategory({ searchKey: '', page: 1 });\n    if (this.mode === 'EDIT') {\n      this.getAssessmentDetails();\n    }\n  }\n\n  getAssessmentDetails() {\n    this.loader = true;\n    this.assessmentService.getAssessmentDetails(this.assessmentId).subscribe({\n      next: (res: any) => {\n        this.assessmentForm.name = res?.assessment_name ?? '';\n        this.assessmentForm.description = res?.description ?? '';\n        this.assessmentForm.assessmentType =\n          res?.assessment_type ?? 'compliance';\n        this.assessmentForm.category = res.category_arr.map((ele: any) => {\n          return { id: ele?._id, category_name: ele?.category_name };\n        });\n        this.assessmentTypeChangeAllowed =\n          res?.assessment_type === 'compliance';\n        this.loader = false;\n      },\n      error: (err: any) => {\n        this.snackBar.show(\n          'OOPS! Something went wrong and the page could not be loaded. Could you please try one more time?',\n          'alert'\n        );\n        this.loader = false;\n      },\n    });\n  }\n\n  //This function is responsible for fetching the list of categories\n  setCategory(evt: any) {\n    this.assessmentService.fetchCategory({\n      search_title: evt.searchKey,\n      page_no: evt.page,\n    });\n  }\n\n  activateSelector(type: any, event: boolean) {\n    if (type === 'category') {\n      this.setCategory({ searchKey: '', page: 1 });\n    }\n    this.activeSelector = event ? type : '';\n    if (this.sideSelectorElements.includes(type)) {\n      this.pickerChanged.emit(event);\n    }\n  }\n\n  activeDeselector() {\n    this.activeSelector = '';\n    this.pickerChanged.emit(false);\n  }\n\n  next(type: string, payload: any) {\n    switch (type) {\n      case 'CATEGORY': {\n        this.activeDeselector();\n        this.assessmentForm.category = payload;\n        if (this.assessmentForm.category?.length > 1) {\n          this.assessmentForm.category = this.assessmentForm.category.filter(\n            (ele: any) => ele?.category_name != 'uncategorized'\n          );\n        }\n      }\n    }\n  }\n\n  remove(type: any, event: any) {\n    switch (type) {\n      case 'category':\n        this.assessmentForm.category = this.assessmentForm.category.filter(\n          (ele: any) => ele?.id !== event?.id\n        );\n    }\n  }\n\n  description: EditorConfig = {\n    mode: 'prime',\n    colorPalette: true,\n    link: true,\n    placeholder: 'Add a description',\n  };\n\n  changeAssessment(type: string) {\n    this.assessmentForm = {\n      ...this.assessmentForm,\n      ...{ assessmentType: type?.toLocaleLowerCase() },\n    };\n    console.log('this.assessmentForm ===>', this.assessmentForm);\n  }\n  closeSmiley(evt: any) {\n    this.closeWorkflow.emit({ evt: this.assessmentId, confirm: false });\n  }\n\n  action(evt: any) {\n    if (evt === 'viewAssessment') {\n      this.disconnectRefresh.emit(false);\n      const url = `https://${window.location.hostname}/assessment/assessment-workroom/?id=${this.assessmentId}`;\n      this.iframeService.redirectIfInIframe(url, true);\n    }\n  }\n\n  checkDescription() {\n    if (this.assessmentForm.description == '<br>') {\n      this.assessmentForm.description = '';\n    }\n  }\n\n  submitAssessment() {\n    this.submitted = true;\n    const valid = this.validateAssessment();\n    if (!valid) {\n      return false;\n    } else {\n      this.createAssessment(this.assessmentForm);\n    }\n  }\n\n  validateAssessment() {\n    this.submitted = true;\n    if (\n      !this.assessmentForm.name.trim() ||\n      this.assessmentForm.category.length == 0\n    ) {\n      return false;\n    } else {\n      return true;\n    }\n  }\n\n  createAssessment(assessmentForm: any) {\n    this.loader = true;\n    this.uiKitService.isLoader = false;\n\n    const payload = {\n      assessment_name: assessmentForm.name.trim(),\n      description: assessmentForm.description,\n      assessment_type: assessmentForm.assessmentType,\n      category_arr: this.assessmentForm.category.map((ele: any) => ele.id),\n      approval_workflow_arr: {\n        test: 'test',\n      },\n      approval_required: true,\n      source_page: 'compliance',\n    };\n    if (this.mode == 'CREATE') {\n      this.assessmentService.addAssessment(payload).subscribe(\n        (res: any) => {\n          this.disconnectRefresh.emit(false);\n          this.assessmentId = res?._id;\n          const url = `https://${window.location.hostname}/assessment/create/${res?._id}`;\n          this.iframeService.redirectIfInIframe(url, true);\n          this.loader = false;\n        },\n        (err: any) => {\n          console.error(err);\n          this.loader = false;\n          this.uiKitService.isLoader = false;\n          this.snackBar.show(\n            'OOPS! Something went wrong and the page could not be loaded. Could you please try one more time?',\n            'alert'\n          );\n        }\n      );\n    } else if (this.mode === 'EDIT') {\n      this.assessmentService\n        .updateAssessment(this.assessmentId, payload)\n        .subscribe({\n          next: (res: any) => {\n            this.loader = false;\n            this.showSmiley = true;\n          },\n          error: (err: any) => {\n            if (err?.error.message.startsWith('No changes')) {\n              this.loader = false;\n              this.showSmiley = true;\n            } else {\n              this.snackBar.show(\n                'OOPS! Something went wrong and the page could not be loaded. Could you please try one more time?',\n                'alert'\n              );\n            }\n          },\n        });\n    }\n  }\n}\n","<div class=\"workflow-assessment\">\n  <!-- Assessment Type -->\n  <div class=\"form-group-row\" [class.active]=\"false\" [class.disabled]=\"false\">\n    <div class=\"left checked\">\n      <svg\n        class=\"checkIcon\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n        viewBox=\"0 0 52 52\"\n      >\n        <circle class=\"checkIcon__circle\" cx=\"26\" cy=\"26\" r=\"25\" fill=\"none\" />\n        <path\n          class=\"checkIcon__check\"\n          fill=\"none\"\n          d=\"M14.1 27.2l7.1 7.2 16.7-16.8\"\n        />\n      </svg>\n    </div>\n    <div class=\"right\">\n      <div class=\"vx-form-group\">\n        <label class=\"vx-control-panel\"\n          >ASSESSMENT TYPE <span class=\"required\">*</span></label\n        >\n        <div class=\"risk-type-field\">\n          <div\n            class=\"type-item\"\n            [class.active]=\"\n              assessmentForm?.assessmentType === 'compliance_audit'\n            \"\n          >\n            <button\n              [class.disabled]=\"!assessmentTypeChangeAllowed\"\n              (click)=\"changeAssessment('compliance_audit')\"\n            >\n              COMPLIANCE AUDIT\n            </button>\n            <i\n              class=\"icons info\"\n              appTooltip=\"This option lets you create a 'Compliance Audit Template' that can be used to conduct various site, user and department level audits. Once the assessment template is created, you can directly create the responsibility and assign it to the relevant assignee.<br><b>Note:</b> These compliance audit templates can only be linked with an audit responsibility that is created as a part of the creating such assessments.\"\n              placement=\"bottom-right\"\n              delay=\"0\"\n              type=\"white\"\n              [tooltipMandatory]=\"true\"\n              >&#xe932;</i\n            >\n          </div>\n          <div\n            class=\"type-item\"\n            [appTooltip]=\"\n              assessmentTypeChangeAllowed\n                ? ''\n                : 'You Cannot change the assessment type.'\n            \"\n            placement=\"bottom-left\"\n            delay=\"0\"\n            type=\"black\"\n            [tooltipMandatory]=\"true\"\n            [class.active]=\"assessmentForm?.assessmentType === 'compliance'\"\n          >\n            <button\n              [class.disabled]=\"!assessmentTypeChangeAllowed\"\n              (click)=\"changeAssessment('compliance')\"\n            >\n              Other\n            </button>\n            <i\n              class=\"icons info\"\n              [class.disabled]=\"!assessmentTypeChangeAllowed\"\n              [appTooltip]=\"\n                'This option can be used to create any outcome based questionnaire or self-assessment questionnaires. Once the templates are created, they can be linked with multiple responsibilities.'\n              \"\n              placement=\"bottom-right\"\n              delay=\"0\"\n              type=\"white\"\n              [tooltipMandatory]=\"true\"\n              >&#xe932;</i\n            >\n          </div>\n          <span class=\"background-glider\"></span>\n        </div>\n        <p *ngIf=\"false\" class=\"error-message\">Add an assessment type</p>\n      </div>\n    </div>\n  </div>\n\n  <!-- Assessment Name -->\n  <div\n    class=\"form-group-row\"\n    [class.active]=\"false\"\n    [class.disabled]=\"\n      activeSelector &&\n      activeSelector !== 'name' &&\n      sideSelectorElements.includes(activeSelector)\n    \"\n  >\n    <div class=\"left\" [class.checked]=\"false\">\n      <img\n        [src]=\"ASSETS.what\"\n        alt=\"im\"\n        *ngIf=\"!assessmentForm.name.trim() || activeSelector === 'name'\"\n      />\n\n      <svg\n        *ngIf=\"assessmentForm.name.trim() && activeSelector !== 'name'\"\n        class=\"checkIcon\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n        viewBox=\"0 0 52 52\"\n      >\n        <circle class=\"checkIcon__circle\" cx=\"26\" cy=\"26\" r=\"25\" fill=\"none\" />\n        <path\n          class=\"checkIcon__check\"\n          fill=\"none\"\n          d=\"M14.1 27.2l7.1 7.2 16.7-16.8\"\n        />\n      </svg>\n    </div>\n    <div class=\"right\">\n      <div class=\"vx-form-group\">\n        <label class=\"vx-control-panel\"\n          >Assessment Name <span class=\"required\">*</span></label\n        >\n        <input\n          type=\"text\"\n          (keydown)=\"activeSelector = 'name'\"\n          (focusin)=\"activateSelector('name', true)\"\n          (focusout)=\"activateSelector('name', false)\"\n          [(ngModel)]=\"assessmentForm.name\"\n          placeholder=\"Add an assessment name\"\n          *ngIf=\"assessmentForm.name == '' || activeSelector === 'name'\"\n        />\n        <div\n          class=\"selected\"\n          *ngIf=\"assessmentForm.name.length && activeSelector !== 'name'\"\n        >\n          <div class=\"chip-container\">\n            <span class=\"value\">{{ assessmentForm.name }}</span>\n          </div>\n          <button\n            class=\"edit\"\n            (click)=\"activateSelector('name', true)\"\n            type=\"button\"\n          >\n            <i class=\"icons\">&#xe9ba;</i> Edit\n          </button>\n        </div>\n        <p\n          *ngIf=\"submitted && !assessmentForm.name.trim()\"\n          class=\"error-message\"\n        >\n          Enter a name for this Assessment.\n        </p>\n        <vcomply-editor\n          [(ngModel)]=\"assessmentForm.description\"\n          [editorConfig]=\"description\"\n          (clickOutside)=\"checkDescription()\"\n        ></vcomply-editor>\n        <!-- <p *ngIf=\"submitted && (assessmentForm.assessmentType ==='COMPLIANCE' && !assessmentForm?.description?.trim()?.length)\" class=\"error-message\">Add an assessment description</p> -->\n      </div>\n    </div>\n  </div>\n\n  <!-- Assessment Category -->\n  <div\n    class=\"form-group-row\"\n    [class.active]=\"activeSelector === 'category'\"\n    [class.disabled]=\"\n      activeSelector &&\n      activeSelector !== 'category' &&\n      sideSelectorElements.includes(activeSelector)\n    \"\n  >\n    <div class=\"left\" [class.checked]=\"assessmentForm?.category?.length\">\n      <img\n        *ngIf=\"\n          !assessmentForm?.category?.length || activeSelector === 'category'\n        \"\n        [src]=\"ASSETS.case_category\"\n        alt=\"\"\n      />\n\n      <svg\n        class=\"checkIcon\"\n        *ngIf=\"\n          assessmentForm?.category?.length && activeSelector !== 'category'\n        \"\n        xmlns=\"http://www.w3.org/2000/svg\"\n        viewBox=\"0 0 52 52\"\n      >\n        <circle class=\"checkIcon__circle\" cx=\"26\" cy=\"26\" r=\"25\" fill=\"none\" />\n        <path\n          class=\"checkIcon__check\"\n          fill=\"none\"\n          d=\"M14.1 27.2l7.1 7.2 16.7-16.8\"\n        />\n      </svg>\n    </div>\n    <div class=\"right\">\n      <div class=\"vx-form-group\">\n        <label class=\"vx-control-panel\"\n          >ASSESSMENT CATEGORY <span class=\"required\">*</span></label\n        >\n        <div class=\"select\" *ngIf=\"!assessmentForm?.category?.length\">\n          <input\n            type=\"text\"\n            (click)=\"activateSelector('category', true)\"\n            placeholder=\"Select category for this assessment\"\n            readonly\n          />\n        </div>\n        <div class=\"selected\" *ngIf=\"assessmentForm?.category?.length\">\n          <div class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2\">\n            <i\n              class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n              *ngIf=\"\n                assessmentForm?.category[0]?.category_name !== 'uncategorized'\n              \"\n              (click)=\"remove('category', assessmentForm.category[0])\"\n              >&#xe9ae;</i\n            >\n            <span\n              class=\"chipName vx-fs-11 vx-label-txt\"\n              [appTooltip]=\"assessmentForm?.category[0]?.category_name\"\n              placement=\"bottom-left\"\n              delay=\"0\"\n              type=\"black\"\n              [tooltipMandatory]=\"false\"\n              >{{ assessmentForm?.category[0]?.category_name }}</span\n            >\n            <button\n              class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4\"\n              appPopover\n              (click)=\"category.popover()\"\n              placement=\"right\"\n              *ngIf=\"assessmentForm?.category?.length > 1\"\n            >\n              +{{ assessmentForm?.category?.length - 1 }}\n            </button>\n          </div>\n\n          <!-- <div class=\"chip-container\">\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>\n                        <button class=\"count\" *ngIf=\"assessmentForm?.category?.length > 1\" appPopover (click)=\"category.popover()\" placement=\"right\">+{{assessmentForm?.category?.length -1}}</button>\n                    </div> -->\n          <button\n            *ngIf=\"activeSelector !== 'category'\"\n            class=\"edit\"\n            type=\"button\"\n            (click)=\"activateSelector('category', true)\"\n          >\n            <i class=\"icons\">&#xe9ba;</i> Edit\n          </button>\n        </div>\n        <p\n          *ngIf=\"submitted && !assessmentForm?.category?.length\"\n          class=\"error-message\"\n        >\n          Select the Assessment Category.\n        </p>\n        <app-popover #category [dontCloseonClick]=\"true\">\n          <div class=\"wf-action-list\">\n            <ul class=\"action-item\">\n              <li\n                *ngFor=\"\n                  let category of assessmentForm?.category | slice : 1;\n                  let j = index\n                \"\n              >\n                <div class=\"avatar-card\">\n                  <span class=\"value\">\n                    <i class=\"icons\" (click)=\"remove('category', category)\"\n                      >&#xe90d;</i\n                    >\n                    {{ category?.category_name }}\n                  </span>\n                </div>\n              </li>\n            </ul>\n          </div>\n        </app-popover>\n      </div>\n      <ng-container *ngIf=\"assessmentForm?.customTags?.length > 0\">\n        <div\n          class=\"vx-form-group\"\n          *ngFor=\"let tag of assessmentForm.customTags\"\n        >\n          <label class=\"vx-control-panel\">{{ tag.custom_tag_name }}</label>\n          <input\n            type=\"text\"\n            [(ngModel)]=\"tag.custom_tag_value\"\n            [placeholder]=\"tag.custom_tag_name\"\n          />\n        </div>\n      </ng-container>\n    </div>\n  </div>\n\n  <!-- Assessment Approval Workflow -->\n  <div\n    *ngIf=\"false\"\n    class=\"form-group-row\"\n    [class.active]=\"false\"\n    [class.disabled]=\"false\"\n  >\n    <div class=\"left\" [class.checked]=\"false\">\n      <img *ngIf=\"true\" [src]=\"ASSETS.approval\" alt=\"im\" />\n\n      <svg\n        *ngIf=\"false\"\n        class=\"checkIcon\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n        viewBox=\"0 0 52 52\"\n      >\n        <circle class=\"checkIcon__circle\" cx=\"26\" cy=\"26\" r=\"25\" fill=\"none\" />\n        <path\n          class=\"checkIcon__check\"\n          fill=\"none\"\n          d=\"M14.1 27.2l7.1 7.2 16.7-16.8\"\n        />\n      </svg>\n    </div>\n    <div class=\"right\">\n      <div class=\"vx-form-group approval-workflow\" [class.disabled]=\"false\">\n        <label class=\"vx-control-panel\">\n          Approval workflow <span class=\"required\">*</span>\n          <button class=\"button\">CREATE A NEW APPROVAL WORKFLOW</button>\n        </label>\n        <div class=\"select\" [class.disabled]=\"false\" *ngIf=\"true\">\n          <cs-select [placeholder]=\"'Select approvers for this assessment'\">\n            <cs-option>test</cs-option>\n            <cs-option>Create a new approval workflow</cs-option>\n          </cs-select>\n        </div>\n        <app-cs-switch\n          >APPROVAL NOT REQUIRED\n          <i\n            class=\"icons\"\n            [appTooltip]=\"'Approval workflow info text here...'\"\n            placement=\"bottom-right\"\n            type=\"white\"\n            delay=\"0\"\n            [tooltipMandatory]=\"true\"\n            >&#xe932;</i\n          ></app-cs-switch\n        >\n        <ng-container *ngIf=\"true\">\n          <div class=\"selected\">\n            <div class=\"workflow-label\">\n              <p class=\"title\">Level 1</p>\n              <p class=\"description\">lavel name</p>\n            </div>\n            <div class=\"vx-d-flex vx-align-center\">\n              <div class=\"chip-container\">\n                <span class=\"chip\">\n                  <i class=\"icons\">&#xe90d;</i>\n                  <span class=\"step\" *ngIf=\"true\">1</span>approval name\n                </span>\n\n                <button\n                  class=\"count\"\n                  *ngIf=\"true\"\n                  type=\"button\"\n                  appPopover\n                  (click)=\"labelName.popover()\"\n                  placement=\"right\"\n                >\n                  +8\n                </button>\n                <app-popover #labelName [dontCloseonClick]=\"true\">\n                  <div class=\"wf-action-list\">\n                    <ul class=\"action-item\">\n                      <li *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\n                        <div class=\"avatar-card\">\n                          <span class=\"value\">\n                            <i class=\"icons\">&#xe90d;</i>\n                            <span class=\"step\">2</span>approval name\n                          </span>\n                        </div>\n                      </li>\n                    </ul>\n                  </div>\n                </app-popover>\n              </div>\n              <button class=\"edit\" type=\"button\">\n                <i class=\"icons\">&#xe9ba;</i>Edit\n              </button>\n              <button class=\"close-btn\"><i class=\"icons\">&#xe90d;</i></button>\n            </div>\n          </div>\n        </ng-container>\n\n        <p *ngIf=\"true\" class=\"error-message\">\n          Select or create an approval workflow for this assessment.\n        </p>\n\n        <label class=\"vx-control-panel\" *ngIf=\"true\">\n          <button class=\"button\">+ Add More Levels</button>\n        </label>\n      </div>\n    </div>\n  </div>\n</div>\n<ng-container\n  *ngIf=\"assessmentService?.categoriesListData$ | async as categories\"\n>\n  <app-radio-list-with-pagination\n    *ngIf=\"activeSelector === 'category'\"\n    [categoryList]=\"categories?.data\"\n    [config]=\"selectorConfig?.ASSESSMENT_CATGORY\"\n    [currentPage]=\"categories?.currentPage\"\n    [recordStart]=\"categories?.start_value\"\n    [recordEnd]=\"categories?.end_value\"\n    [totalRecords]=\"categories?.totalRecords\"\n    [totalPages]=\"categories?.totalPage\"\n    [loading]=\"assessmentService?.categoriesLoading$ | async\"\n    (fetchData)=\"setCategory($event)\"\n    (next)=\"next('CATEGORY', $event)\"\n    [selectedList]=\"assessmentForm?.category | uncategorizedFilter\"\n    (cancel)=\"activeDeselector()\"\n    (back)=\"activeDeselector()\"\n  ></app-radio-list-with-pagination>\n</ng-container>\n<app-loader-inline *ngIf=\"loader\"></app-loader-inline>\n<app-smiley-dialog-inline\n  *ngIf=\"showSmiley\"\n  [message]=\"smileyMessage\"\n  [actionButtons]=\"actionButtons\"\n  (action)=\"action($event)\"\n  (closeSmiley)=\"closeSmiley($event)\"\n>\n</app-smiley-dialog-inline>\n<!-- <app-create-assessment-container></app-create-assessment-container> -->\n"]}