vcomply-workflow-engine 6.1.16 → 6.1.18

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 (21) hide show
  1. package/esm2022/lib/report-a-case/components/case-resolution-deadline/case-resolution-deadline.component.mjs +25 -3
  2. package/esm2022/lib/report-a-case/components/due-date/due-date.component.mjs +19 -5
  3. package/esm2022/lib/report-a-case/components/report-date/report-date.component.mjs +3 -1
  4. package/esm2022/lib/report-a-case/constants/api.constants.mjs +3 -2
  5. package/esm2022/lib/report-a-case/constants/report-case.constants.mjs +2 -1
  6. package/esm2022/lib/report-a-case/report-case.module.mjs +5 -2
  7. package/esm2022/lib/report-a-case/services/report-a-case.service.mjs +7 -1
  8. package/esm2022/lib/report-a-case/workflow-case/workflow-case.component.mjs +3 -3
  9. package/esm2022/lib/ui-kit/banner/banner.component.mjs +44 -0
  10. package/fesm2022/vcomply-workflow-engine.mjs +202 -114
  11. package/fesm2022/vcomply-workflow-engine.mjs.map +1 -1
  12. package/lib/report-a-case/components/case-resolution-deadline/case-resolution-deadline.component.d.ts +7 -3
  13. package/lib/report-a-case/components/due-date/due-date.component.d.ts +7 -2
  14. package/lib/report-a-case/components/report-date/report-date.component.d.ts +2 -0
  15. package/lib/report-a-case/constants/api.constants.d.ts +1 -0
  16. package/lib/report-a-case/constants/report-case.constants.d.ts +1 -0
  17. package/lib/report-a-case/report-case.module.d.ts +22 -21
  18. package/lib/report-a-case/services/report-a-case.service.d.ts +1 -0
  19. package/lib/ui-kit/banner/banner.component.d.ts +8 -0
  20. package/lib/workflow-risk/workflow-risk.component.d.ts +1 -1
  21. package/package.json +1 -1
@@ -1,5 +1,6 @@
1
1
  import { Component, ElementRef, Input, ViewChild, Output, EventEmitter, HostListener, } from '@angular/core';
2
- import { REPORT_CASE, HELPER_TEXT, EMAIL_REMINDERS, } from '../../constants/report-case.constants';
2
+ import * as dayjs from 'dayjs';
3
+ import { REPORT_CASE, HELPER_TEXT, EMAIL_REMINDERS, BANNER_CASE_RESOLUTION_DEADLINE_WARNING, } from '../../constants/report-case.constants';
3
4
  import { ASSETS } from '../../../constants/assets.constants';
4
5
  import * as i0 from "@angular/core";
5
6
  import * as i1 from "../../../services/common.service";
@@ -11,6 +12,7 @@ import * as i6 from "ng2-date-picker";
11
12
  import * as i7 from "@angular/forms";
12
13
  import * as i8 from "../../../sharedComponents/v-loader/loader-inline/loader-inline.component";
13
14
  import * as i9 from "../assignee/assignee.component";
15
+ import * as i10 from "../../../ui-kit/banner/banner.component";
14
16
  export class DueDateComponent {
15
17
  set initialSelection(value) {
16
18
  this.dueDate = value?.resolution_deadline?.due_date;
@@ -44,14 +46,16 @@ export class DueDateComponent {
44
46
  this.escalationEmail = EMAIL_REMINDERS.escalation_email_reminder;
45
47
  this.showError = false;
46
48
  this.showAssigneeError = false;
49
+ this.CaseDeadlineWarning = BANNER_CASE_RESOLUTION_DEADLINE_WARNING;
47
50
  this.userList = [];
48
51
  this.groupList = [];
49
52
  this.mode = '';
53
+ this.min = '';
50
54
  this.closeDueDateResolution = new EventEmitter();
51
55
  this.closeDueDateEvent = new EventEmitter();
52
56
  }
53
57
  ngOnInit() {
54
- this.dateConfig.min = this.frequencyService.formatDate();
58
+ this.setMinDate();
55
59
  setTimeout(() => {
56
60
  this.animation = false;
57
61
  }, 300);
@@ -78,6 +82,14 @@ export class DueDateComponent {
78
82
  const stageAssigneeMap = this.createStageAssigneeMap(deadline.stages_assignees);
79
83
  this.mapWorkflowStages(stageAssigneeMap);
80
84
  }
85
+ setMinDate() {
86
+ if (this.min) {
87
+ this.dateConfig.min = dayjs(this.min);
88
+ }
89
+ else {
90
+ this.dateConfig.min = this.frequencyService.formatDate();
91
+ }
92
+ }
81
93
  createStageAssigneeMap(stagesAssignees) {
82
94
  return new Map(stagesAssignees.map((stage) => [stage?.stage_id, stage?.assignee_id]));
83
95
  }
@@ -286,11 +298,11 @@ export class DueDateComponent {
286
298
  }
287
299
  }
288
300
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DueDateComponent, deps: [{ token: i1.CommonService }, { token: i2.FrequencyService }], target: i0.ɵɵFactoryTarget.Component }); }
289
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DueDateComponent, selector: "app-due-date", inputs: { payload: "payload", dueDate: "dueDate", workflowDetails: "workflowDetails", userList: "userList", groupList: "groupList", mode: "mode", initialSelection: "initialSelection" }, outputs: { closeDueDateResolution: "closeDueDateResolution", closeDueDateEvent: "closeDueDateEvent" }, host: { listeners: { "document:click": "documentClick($event)" } }, viewQueries: [{ propertyName: "datePicker", first: true, predicate: ["deadlineDatePicker"], descendants: true }, { propertyName: "ASSETS", first: true, predicate: ["deadlineDatePicker"], descendants: true, read: ElementRef }], ngImport: i0, template: "<div class=\"configure-resolution\">\n <div\n class=\"configure-resolution-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\"\n >\n <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">\n Configure Resolution Deadline & Stage Details\n </div>\n </div>\n <div class=\"configure-resolution-body\">\n <div class=\"configure-resolution-body-inner\">\n <app-loader-inline *ngIf=\"false\"></app-loader-inline>\n <app-no-data\n *ngIf=\"false\"\n [noDataImage]=\"ASSETS.search_data\"\n [noDataText]=\"'No data to display'\"\n ></app-no-data>\n\n <ng-container>\n <div\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\n >\n SPECIFY THE DEADLINE TO CLOSE THIS CASE\n <span class=\"required vx-fs-16 vx-fw-400\">*</span>\n </div>\n <div class=\"case-calendar vx-mb-3\">\n <div class=\"case-calendar-inner vx-d-flex vx-align-center\">\n <input\n type=\"text\"\n readonly\n placeholder=\"{{\n dueDateTexts.case_details.due_date.deadline_placeholder\n }}\"\n (click)=\"openDatePicker()\"\n [value]=\"dueDate | date : 'dd MMM yyyy'\"\n id=\"deadline-date\"\n />\n <i class=\"icons\">&#xe92d;</i>\n <dp-date-picker\n #deadlineDatePicker\n (onSelect)=\"datePickerOverlay = false; closeDatePicker($event)\"\n [config]=\"dateConfig\"\n [(ngModel)]=\"dueDate\"\n >\n </dp-date-picker>\n <div\n class=\"vx-overlay\"\n (click)=\"closeDatePicker($event)\"\n *ngIf=\"datePickerOverlay\"\n ></div>\n </div>\n <div *ngIf=\"showError\" class=\"errorMsg vx-fs-11 vx-lh-4 vx-mt-1\">\n {{ dueDateTexts.errorMessage.dueDate }}\n </div>\n </div>\n <div class=\"vx-d-flex vx-align-center vx-justify-between vx-mb-1\">\n <div\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-tt-uppercase\"\n >\n CONFIGURE DEADLINE & ASSIGNEE FOR EACH STAGE IN THE WORKFLOW\n <span class=\"required vx-fs-16 vx-fw-400\">*</span>\n </div>\n <!-- <div class=\"toggle-area vx-d-flex vx-align-center\">\n <app-cs-switch>Allow Reopening of Previous Stage</app-cs-switch>\n <i\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-2\"\n [appTooltip]=\"\n 'If enabled, this option allows the assignee to revisit and reopen a previously completed stage. The stage will be reset, and the assigned user will need to complete it again.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </div> -->\n </div>\n <div class=\"configure-resolution-table\">\n <div class=\"table-header\">\n <div class=\"table-row\">\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\"\n >\n #\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center stage-name\"\n >\n STAGE NAME\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center status\"\n >\n TRANSITION STATUS\n <i\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\n [appTooltip]=\"helperText.transition_status\"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center assignee\"\n >\n ASSIGNEE\n <i\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\n [appTooltip]=\"helperText.assignee\"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center deadline\"\n >\n DEADLINE\n <i\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\n [appTooltip]=\"helperText.deadline\"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </div>\n </div>\n </div>\n <div class=\"table-body\">\n <div\n class=\"table-row\"\n *ngFor=\"\n let data of workflowDetails?.stages_assignees;\n let i = index\n \"\n >\n <div\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\"\n >\n <div\n class=\"sr-no vx-fs-13 vx-d-flex vx-align-center vx-justify-center\"\n [appTooltip]=\"i + 1\"\n placement=\"bottom\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"true\"\n >\n {{ i + 1 }}\n </div>\n </div>\n <div\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center stage-name\"\n >\n <div\n class=\"value vx-fs-13 vx-pr-2\"\n [appTooltip]=\"data?.name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >\n {{ data?.name }}\n </div>\n </div>\n <div\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center status\"\n >\n <div class=\"value vx-fs-12\">\n {{ data?.status_transition?.fromName }}<br /><span\n class=\"vx-mr-1\"\n >To</span\n >{{ data?.status_transition?.toName }}\n </div>\n </div>\n <div\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center assignee\"\n (click)=\"activateSelector(true, i)\"\n >\n <div\n *ngIf=\"!assigneeData[i]?.length\"\n class=\"select-box vx-d-flex vx-align-center vx-justify-between vx-pl-3 vx-pr-3\"\n >\n <div class=\"value vx-fs-13\">Select a User</div>\n <i class=\"icons arrow vx-fs-12\">&#xe9e8;</i>\n </div>\n <div\n *ngIf=\"assigneeData[i]?.length > 0\"\n class=\"after-select-box vx-d-flex vx-align-center vx-justify-between vx-pl-3 vx-pr-2\"\n >\n <div\n class=\"value-chip vx-fs-11 vx-pl-2 vx-pr-2 vx-lh-6\"\n [appTooltip]=\"assigneeData[i][0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >\n {{ assigneeData[i][0]?.member_name }}\n </div>\n <button\n (click)=\"activateSelector(true, i)\"\n class=\"edit-btn vx-fs-11 vx-fw-500 vx-txt-blue vx-tt-uppercase vx-p-0 vx-m-0 vx-d-flex vx-align-center\"\n >\n <i class=\"icons vx-fs-12 vx-txt-blue vx-mr-1\">&#xe9ba;</i\n >EDIT\n </button>\n </div>\n </div>\n <div\n class=\"table-column vx-pl-1 vx-pr-2 vx-d-flex vx-align-center deadline\"\n >\n <div\n class=\"case-calendar vx-d-flex vx-justify-between vx-pt-3 vx-pb-3\"\n >\n <div\n class=\"case-calendar-inner vx-d-flex vx-align-center\"\n [class.disabled]=\"true\"\n >\n <input\n type=\"text\"\n readonly\n value=\"{{ dueDate | date : 'dd MMM yyyy' }}\"\n (click)=\"openDatePicker()\"\n id=\"stage-deadline-date\"\n />\n <i class=\"icons\">&#xe92d;</i>\n <dp-date-picker\n #datePicker\n (onSelect)=\"\n datePickerOverlay = false; closeDatePicker($event)\n \"\n [config]=\"dateConfig\"\n >\n </dp-date-picker>\n <div\n class=\"vx-overlay\"\n (click)=\"closeDatePicker($event)\"\n *ngIf=\"datePickerOverlay\"\n ></div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div\n *ngIf=\"showAssigneeError\"\n class=\"errorMsg vx-fs-11 vx-lh-4 vx-mt-1\"\n >\n {{ dueDateTexts.errorMessage.stageAssignee }}\n </div>\n </div>\n <div\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\n >\n EMAIL REMINDER CONFIGURATION\n <span class=\"required vx-fs-16 vx-fw-400\">*</span>\n </div>\n <div class=\"divider vx-mb-2\"></div>\n <div\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\n >\n REMINDER EMAIL\n </div>\n <div\n class=\"email-configure-box vx-d-flex vx-align-center vx-flex-wrap vx-p-2 vx-pl-3 vx-pr-3 vx-mb-2\"\n >\n <div class=\"vx-fs-13 vx-mr-1\">\n Send regular email reminders to the assignee\n </div>\n <input\n type=\"number\"\n [(ngModel)]=\"emailReminder\"\n onkeydown=\"return event.key !== '.'\"\n oninput=\"this.value = Math.abs(this.value)\"\n (change)=\"onInputChange()\"\n />\n <div class=\"vx-fs-13 vx-ml-1\">\n <span class=\"black-text\">days</span> before the stage deadline.\n </div>\n </div>\n <div\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\n >\n ESCALATION EMAIL\n </div>\n <div\n class=\"email-configure-box vx-d-flex vx-align-center vx-flex-wrap vx-p-2 vx-pl-3 vx-pr-3 vx-mb-2\"\n >\n <div class=\"vx-fs-13 vx-mr-1\">\n Send email escalation to the Case Owner\n </div>\n <input\n type=\"number\"\n [(ngModel)]=\"escalationEmail\"\n onkeydown=\"return event.key !== '.'\"\n oninput=\"this.value = Math.abs(this.value)\"\n (change)=\"onInputChange()\"\n />\n <div class=\"vx-fs-13 vx-ml-1\">\n <span class=\"black-text\">days</span> before the overall case\n deadline, if the case is still open.\n </div>\n </div>\n </ng-container>\n </div>\n <app-floating-bar\n (closeList)=\"closeDueDate()\"\n (closeEvent)=\"saveCaseResolutionDeadline()\"\n ></app-floating-bar>\n </div>\n</div>\n<app-assignee\n *ngIf=\"assigneeClicked\"\n [payload]=\"payload\"\n [assigneeList]=\"assigneeList\"\n [activeAssignee]=\"activeAssignee\"\n (selectedAssigneeEvent)=\"selectedAssignee($event)\"\n (closeEvent)=\"activateSelector(false)\"\n></app-assignee>\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";::ng-deep .configure-resolution{background:#fff;position:fixed;inset:0 500px 0 0;z-index:1}::ng-deep .configure-resolution:before{background:#1e5dd3;content:\"\";position:absolute;top:0;left:0;right:0;width:100%;height:3px}::ng-deep .configure-resolution.animate{animation:animate-right .2s cubic-bezier(.25,.46,.45,.94) both;z-index:-1}::ng-deep .configure-resolution-head{background:#fbfbfb;border-bottom:1px solid #f1f1f1;height:2.75rem}::ng-deep .configure-resolution-body{background:#fff;height:calc(100vh - 2.75rem);padding:2rem}::ng-deep .configure-resolution-body-inner{height:calc(100% - 3rem);padding:0 2rem 1rem 0;width:calc(100% + 2rem);overflow-y:auto;scrollbar-width:thin}::ng-deep .configure-resolution-body-inner .divider{background:#e3e3e9;width:100%;height:1px}::ng-deep .configure-resolution-body .label-top .required{color:#c7381b}::ng-deep .configure-resolution-body .errorMsg{color:#a82a1d}::ng-deep .configure-resolution-body .toggle-area{cursor:pointer}::ng-deep .configure-resolution-body .toggle-area app-cs-switch .cs-switch .switch{order:1;width:24px!important;min-width:24px!important;height:16px!important}::ng-deep .configure-resolution-body .toggle-area app-cs-switch .cs-switch .switch .switch-box{background:#cdced6!important;border:1px solid #cdced6!important}::ng-deep .configure-resolution-body .toggle-area app-cs-switch .cs-switch .switch .switch-ball{height:12px!important;width:12px!important;border:none!important;left:2px!important;top:2px!important;bottom:2px!important}::ng-deep .configure-resolution-body .toggle-area app-cs-switch .cs-switch .switch input:checked+span.switch-box{background:#34aa44!important;border-color:#34aa44!important}::ng-deep .configure-resolution-body .toggle-area app-cs-switch .cs-switch .switch input:checked+span.switch-box .switch-ball{left:10px!important}::ng-deep .configure-resolution-body .toggle-area app-cs-switch .cs-switch .value{order:2;color:#000!important;cursor:pointer;font-size:11px!important;margin-left:.5rem;width:unset!important}::ng-deep .configure-resolution-body .toggle-area i.info{cursor:pointer}::ng-deep .configure-resolution-body .case-calendar{background:#fff;border-radius:.25rem}::ng-deep .configure-resolution-body .case-calendar-inner{position:relative;width:100%}::ng-deep .configure-resolution-body .case-calendar-inner input{background:transparent;border-radius:.25rem;border:1px solid #cdced6;color:#747576;font-size:13px;font-weight:400;height:2.5rem;line-height:2.5rem;padding:0 .75rem 0 2rem;outline:none;width:100%;transition:all .2s ease-in-out}::ng-deep .configure-resolution-body .case-calendar-inner input::placeholder{color:#a9aab6}::ng-deep .configure-resolution-body .case-calendar-inner input:hover,::ng-deep .configure-resolution-body .case-calendar-inner input:focus{border-color:#1e5dd3}::ng-deep .configure-resolution-body .case-calendar-inner i{display:flex;justify-content:center;align-items:center;height:.75rem;width:.75rem;position:absolute;left:.75rem;top:.75rem;color:#747576;font-size:12px;pointer-events:none}::ng-deep .configure-resolution-body .case-calendar-inner.disabled{background:#f2f2f5;pointer-events:none;opacity:1}::ng-deep .configure-resolution-body .case-calendar-inner.disabled input,::ng-deep .configure-resolution-body .case-calendar-inner.disabled i{color:#a9aab6}::ng-deep .configure-resolution-body .email-configure-box{border-radius:.25rem;border:1px solid #dbdbdb;color:#787a8c}::ng-deep .configure-resolution-body .email-configure-box input{-moz-appearance:textfield;border-radius:.25rem;border:1px solid #dbdbdb;color:#343952;display:inline-block;font-size:13px;text-align:center;width:2.25rem;height:1.75rem;padding:.125rem;outline:none}::ng-deep .configure-resolution-body .email-configure-box input::-webkit-inner-spin-button,::ng-deep .configure-resolution-body .email-configure-box input::-webkit-outer-spin-button{-webkit-appearance:none}::ng-deep .configure-resolution-body .email-configure-box input::placeholder{color:#787a8c}::ng-deep .configure-resolution-body .email-configure-box .black-text{color:#000}::ng-deep .configure-resolution-table{margin-bottom:.75rem}::ng-deep .configure-resolution-table .table-header{background:#fff;border-radius:.25rem .25rem 0 0;border:1px solid #f2f2f5;border-bottom:1px solid #f2f2f5}::ng-deep .configure-resolution-table .table-header .table-column{color:#787a8c!important;line-height:.75rem!important;min-height:2rem!important}::ng-deep .configure-resolution-table .table-body{border-radius:0 0 .25rem .25rem;border:1px solid #f2f2f5;border-top:none}::ng-deep .configure-resolution-table .table-row{display:flex;justify-content:space-between;position:relative;border-bottom:1px solid #f2f2f5}::ng-deep .configure-resolution-table .table-row:last-of-type .table-column,::ng-deep .configure-resolution-table .table-row:only-child .table-column{border-bottom:none}::ng-deep .configure-resolution-table .table-row .table-column{border-bottom:1px solid #f2f2f5;color:#000;min-height:3.25rem;position:relative;width:100%}::ng-deep .configure-resolution-table .table-row .table-column i.info{cursor:pointer}::ng-deep .configure-resolution-table .table-row .table-column.serial{width:2rem;max-width:2rem;justify-content:center}::ng-deep .configure-resolution-table .table-row .table-column.serial .sr-no{width:1rem;height:3.25rem}::ng-deep .configure-resolution-table .table-row .table-column.stage-name{width:calc(100% - 37rem);min-width:calc(100% - 37rem)}::ng-deep .configure-resolution-table .table-row .table-column.stage-name .value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .configure-resolution-table .table-row .table-column.status{width:10rem;min-width:10rem}::ng-deep .configure-resolution-table .table-row .table-column.status .value span{color:#787a8c}::ng-deep .configure-resolution-table .table-row .table-column.assignee{width:15rem;min-width:15rem}::ng-deep .configure-resolution-table .table-row .table-column.assignee .select-box{border-radius:.25rem;border:1px solid #cdced6;cursor:pointer;height:2.5rem;width:100%}::ng-deep .configure-resolution-table .table-row .table-column.assignee .select-box .value{color:#a9aab6}::ng-deep .configure-resolution-table .table-row .table-column.assignee .select-box .arrow{color:#787a8c}::ng-deep .configure-resolution-table .table-row .table-column.assignee .after-select-box{background:#f9f9fa;border-radius:.25rem;border:1px solid #cdced6;height:2.5rem;width:100%}::ng-deep .configure-resolution-table .table-row .table-column.assignee .after-select-box .value-chip{background:#fff;border-radius:.125rem;border:1px solid #f4f8ff;box-shadow:0 0 2px #1e5dd326;color:#000;height:1.5rem;max-width:9.5rem;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .configure-resolution-table .table-row .table-column.assignee .after-select-box button.edit-btn{background:transparent;border-radius:0;border:none}::ng-deep .configure-resolution-table .table-row .table-column.deadline{width:10rem;min-width:10rem}@keyframes animate-right{0%{transform:translate(100%)}to{transform:translate(0)}}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.ToolTipDirective, selector: "[appTooltip]", inputs: ["appTooltip", "placement", "type", "tooltipMandatory", "showTooltip", "animate"] }, { kind: "component", type: i5.FloatingBarComponent, selector: "app-floating-bar", inputs: ["selectedData", "selectedGroups", "displayElementKey", "elementId", "singularText", "pluralText", "showNextButton", "showFrequencyText", "showWorkflow", "workflowText", "currentFrequency", "isDisabled", "workflowList", "selectedWorkflow", "workflowPlaceHolder", "mode", "defaultSelected", "groupsEnabled", "nonRemovableUsersList", "removePosition"], outputs: ["closeEvent", "deleteEvent", "closeList", "deleteGroupEvent", "workflowTypeChanged"] }, { kind: "component", type: i6.DatePickerComponent, selector: "dp-date-picker", inputs: ["config", "mode", "placeholder", "disabled", "displayDate", "theme", "minDate", "maxDate", "minTime", "maxTime"], outputs: ["open", "close", "onChange", "onGoToCurrent", "onLeftNav", "onRightNav", "onSelect"] }, { kind: "directive", type: i7.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i7.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i7.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i8.LoaderInlineComponent, selector: "app-loader-inline" }, { kind: "component", type: i9.AssigneeComponent, selector: "app-assignee", inputs: ["assigneeList", "activeAssignee", "payload"], outputs: ["closeEvent", "selectedAssigneeEvent"] }, { kind: "pipe", type: i3.DatePipe, name: "date" }] }); }
301
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DueDateComponent, selector: "app-due-date", inputs: { payload: "payload", dueDate: "dueDate", workflowDetails: "workflowDetails", userList: "userList", groupList: "groupList", mode: "mode", initialSelection: "initialSelection", min: "min" }, outputs: { closeDueDateResolution: "closeDueDateResolution", closeDueDateEvent: "closeDueDateEvent" }, host: { listeners: { "document:click": "documentClick($event)" } }, viewQueries: [{ propertyName: "datePicker", first: true, predicate: ["deadlineDatePicker"], descendants: true }, { propertyName: "ASSETS", first: true, predicate: ["deadlineDatePicker"], descendants: true, read: ElementRef }], ngImport: i0, template: "<div class=\"configure-resolution\">\n <div\n class=\"configure-resolution-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\"\n >\n <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">\n Configure Resolution Deadline & Stage Details\n </div>\n </div>\n <div class=\"configure-resolution-body\">\n <div class=\"configure-resolution-body-inner\">\n <app-loader-inline *ngIf=\"false\"></app-loader-inline>\n <app-no-data\n *ngIf=\"false\"\n [noDataImage]=\"ASSETS.search_data\"\n [noDataText]=\"'No data to display'\"\n ></app-no-data>\n\n <ng-container>\n <div\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\n >\n SPECIFY THE DEADLINE TO CLOSE THIS CASE\n <span class=\"required vx-fs-16 vx-fw-400\">*</span>\n </div>\n <app-banner *ngIf=\"mode === 'EDIT'\">\n <p banner>\n {{ CaseDeadlineWarning }}\n </p>\n </app-banner>\n <div class=\"case-calendar vx-mb-3\">\n <div class=\"case-calendar-inner vx-d-flex vx-align-center\">\n <input\n type=\"text\"\n readonly\n placeholder=\"{{\n dueDateTexts.case_details.due_date.deadline_placeholder\n }}\"\n (click)=\"openDatePicker()\"\n [value]=\"dueDate | date : 'dd MMM yyyy'\"\n id=\"deadline-date\"\n />\n <i class=\"icons\">&#xe92d;</i>\n <dp-date-picker\n #deadlineDatePicker\n (onSelect)=\"datePickerOverlay = false; closeDatePicker($event)\"\n [config]=\"dateConfig\"\n [(ngModel)]=\"dueDate\"\n >\n </dp-date-picker>\n <div\n class=\"vx-overlay\"\n (click)=\"closeDatePicker($event)\"\n *ngIf=\"datePickerOverlay\"\n ></div>\n </div>\n <div *ngIf=\"showError\" class=\"errorMsg vx-fs-11 vx-lh-4 vx-mt-1\">\n {{ dueDateTexts.errorMessage.dueDate }}\n </div>\n </div>\n <div class=\"vx-d-flex vx-align-center vx-justify-between vx-mb-1\">\n <div\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-tt-uppercase\"\n >\n CONFIGURE DEADLINE & ASSIGNEE FOR EACH STAGE IN THE WORKFLOW\n <span class=\"required vx-fs-16 vx-fw-400\">*</span>\n </div>\n <!-- <div class=\"toggle-area vx-d-flex vx-align-center\">\n <app-cs-switch>Allow Reopening of Previous Stage</app-cs-switch>\n <i\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-2\"\n [appTooltip]=\"\n 'If enabled, this option allows the assignee to revisit and reopen a previously completed stage. The stage will be reset, and the assigned user will need to complete it again.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </div> -->\n </div>\n <div class=\"configure-resolution-table\">\n <div class=\"table-header\">\n <div class=\"table-row\">\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\"\n >\n #\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center stage-name\"\n >\n STAGE NAME\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center status\"\n >\n TRANSITION STATUS\n <i\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\n [appTooltip]=\"helperText.transition_status\"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center assignee\"\n >\n ASSIGNEE\n <i\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\n [appTooltip]=\"helperText.assignee\"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center deadline\"\n >\n DEADLINE\n <i\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\n [appTooltip]=\"helperText.deadline\"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </div>\n </div>\n </div>\n <div class=\"table-body\">\n <div\n class=\"table-row\"\n *ngFor=\"\n let data of workflowDetails?.stages_assignees;\n let i = index\n \"\n >\n <div\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\"\n >\n <div\n class=\"sr-no vx-fs-13 vx-d-flex vx-align-center vx-justify-center\"\n [appTooltip]=\"i + 1\"\n placement=\"bottom\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"true\"\n >\n {{ i + 1 }}\n </div>\n </div>\n <div\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center stage-name\"\n >\n <div\n class=\"value vx-fs-13 vx-pr-2\"\n [appTooltip]=\"data?.name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >\n {{ data?.name }}\n </div>\n </div>\n <div\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center status\"\n >\n <div class=\"value vx-fs-12\">\n {{ data?.status_transition?.fromName }}<br /><span\n class=\"vx-mr-1\"\n >To</span\n >{{ data?.status_transition?.toName }}\n </div>\n </div>\n <div\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center assignee\"\n (click)=\"activateSelector(true, i)\"\n >\n <div\n *ngIf=\"!assigneeData[i]?.length\"\n class=\"select-box vx-d-flex vx-align-center vx-justify-between vx-pl-3 vx-pr-3\"\n >\n <div class=\"value vx-fs-13\">Select a User</div>\n <i class=\"icons arrow vx-fs-12\">&#xe9e8;</i>\n </div>\n <div\n *ngIf=\"assigneeData[i]?.length > 0\"\n class=\"after-select-box vx-d-flex vx-align-center vx-justify-between vx-pl-3 vx-pr-2\"\n >\n <div\n class=\"value-chip vx-fs-11 vx-pl-2 vx-pr-2 vx-lh-6\"\n [appTooltip]=\"assigneeData[i][0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >\n {{ assigneeData[i][0]?.member_name }}\n </div>\n <button\n (click)=\"activateSelector(true, i)\"\n class=\"edit-btn vx-fs-11 vx-fw-500 vx-txt-blue vx-tt-uppercase vx-p-0 vx-m-0 vx-d-flex vx-align-center\"\n >\n <i class=\"icons vx-fs-12 vx-txt-blue vx-mr-1\">&#xe9ba;</i\n >EDIT\n </button>\n </div>\n </div>\n <div\n class=\"table-column vx-pl-1 vx-pr-2 vx-d-flex vx-align-center deadline\"\n >\n <div\n class=\"case-calendar vx-d-flex vx-justify-between vx-pt-3 vx-pb-3\"\n >\n <div\n class=\"case-calendar-inner vx-d-flex vx-align-center\"\n [class.disabled]=\"true\"\n >\n <input\n type=\"text\"\n readonly\n value=\"{{ dueDate | date : 'dd MMM yyyy' }}\"\n (click)=\"openDatePicker()\"\n id=\"stage-deadline-date\"\n />\n <i class=\"icons\">&#xe92d;</i>\n <dp-date-picker\n #datePicker\n (onSelect)=\"\n datePickerOverlay = false; closeDatePicker($event)\n \"\n [config]=\"dateConfig\"\n >\n </dp-date-picker>\n <div\n class=\"vx-overlay\"\n (click)=\"closeDatePicker($event)\"\n *ngIf=\"datePickerOverlay\"\n ></div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div\n *ngIf=\"showAssigneeError\"\n class=\"errorMsg vx-fs-11 vx-lh-4 vx-mt-1\"\n >\n {{ dueDateTexts.errorMessage.stageAssignee }}\n </div>\n </div>\n <div\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\n >\n EMAIL REMINDER CONFIGURATION\n <span class=\"required vx-fs-16 vx-fw-400\">*</span>\n </div>\n <div class=\"divider vx-mb-2\"></div>\n <div\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\n >\n REMINDER EMAIL\n </div>\n <div\n class=\"email-configure-box vx-d-flex vx-align-center vx-flex-wrap vx-p-2 vx-pl-3 vx-pr-3 vx-mb-2\"\n >\n <div class=\"vx-fs-13 vx-mr-1\">\n Send regular email reminders to the assignee\n </div>\n <input\n type=\"number\"\n [(ngModel)]=\"emailReminder\"\n onkeydown=\"return event.key !== '.'\"\n oninput=\"this.value = Math.abs(this.value)\"\n (change)=\"onInputChange()\"\n />\n <div class=\"vx-fs-13 vx-ml-1\">\n <span class=\"black-text\">days</span> before the stage deadline.\n </div>\n </div>\n <div\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\n >\n ESCALATION EMAIL\n </div>\n <div\n class=\"email-configure-box vx-d-flex vx-align-center vx-flex-wrap vx-p-2 vx-pl-3 vx-pr-3 vx-mb-2\"\n >\n <div class=\"vx-fs-13 vx-mr-1\">\n Send email escalation to the Case Owner\n </div>\n <input\n type=\"number\"\n [(ngModel)]=\"escalationEmail\"\n onkeydown=\"return event.key !== '.'\"\n oninput=\"this.value = Math.abs(this.value)\"\n (change)=\"onInputChange()\"\n />\n <div class=\"vx-fs-13 vx-ml-1\">\n <span class=\"black-text\">days</span> before the overall case\n deadline, if the case is still open.\n </div>\n </div>\n </ng-container>\n </div>\n <app-floating-bar\n (closeList)=\"closeDueDate()\"\n (closeEvent)=\"saveCaseResolutionDeadline()\"\n ></app-floating-bar>\n </div>\n</div>\n<app-assignee\n *ngIf=\"assigneeClicked\"\n [payload]=\"payload\"\n [assigneeList]=\"assigneeList\"\n [activeAssignee]=\"activeAssignee\"\n (selectedAssigneeEvent)=\"selectedAssignee($event)\"\n (closeEvent)=\"activateSelector(false)\"\n></app-assignee>\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";::ng-deep .configure-resolution{background:#fff;position:fixed;inset:0 500px 0 0;z-index:1}::ng-deep .configure-resolution:before{background:#1e5dd3;content:\"\";position:absolute;top:0;left:0;right:0;width:100%;height:3px}::ng-deep .configure-resolution.animate{animation:animate-right .2s cubic-bezier(.25,.46,.45,.94) both;z-index:-1}::ng-deep .configure-resolution-head{background:#fbfbfb;border-bottom:1px solid #f1f1f1;height:2.75rem}::ng-deep .configure-resolution-body{background:#fff;height:calc(100vh - 2.75rem);padding:2rem}::ng-deep .configure-resolution-body-inner{height:calc(100% - 3rem);padding:0 2rem 1rem 0;width:calc(100% + 2rem);overflow-y:auto;scrollbar-width:thin}::ng-deep .configure-resolution-body-inner .divider{background:#e3e3e9;width:100%;height:1px}::ng-deep .configure-resolution-body .label-top .required{color:#c7381b}::ng-deep .configure-resolution-body .errorMsg{color:#a82a1d}::ng-deep .configure-resolution-body .toggle-area{cursor:pointer}::ng-deep .configure-resolution-body .toggle-area app-cs-switch .cs-switch .switch{order:1;width:24px!important;min-width:24px!important;height:16px!important}::ng-deep .configure-resolution-body .toggle-area app-cs-switch .cs-switch .switch .switch-box{background:#cdced6!important;border:1px solid #cdced6!important}::ng-deep .configure-resolution-body .toggle-area app-cs-switch .cs-switch .switch .switch-ball{height:12px!important;width:12px!important;border:none!important;left:2px!important;top:2px!important;bottom:2px!important}::ng-deep .configure-resolution-body .toggle-area app-cs-switch .cs-switch .switch input:checked+span.switch-box{background:#34aa44!important;border-color:#34aa44!important}::ng-deep .configure-resolution-body .toggle-area app-cs-switch .cs-switch .switch input:checked+span.switch-box .switch-ball{left:10px!important}::ng-deep .configure-resolution-body .toggle-area app-cs-switch .cs-switch .value{order:2;color:#000!important;cursor:pointer;font-size:11px!important;margin-left:.5rem;width:unset!important}::ng-deep .configure-resolution-body .toggle-area i.info{cursor:pointer}::ng-deep .configure-resolution-body .case-calendar{background:#fff;border-radius:.25rem}::ng-deep .configure-resolution-body .case-calendar-inner{position:relative;width:100%}::ng-deep .configure-resolution-body .case-calendar-inner input{background:transparent;border-radius:.25rem;border:1px solid #cdced6;color:#747576;font-size:13px;font-weight:400;height:2.5rem;line-height:2.5rem;padding:0 .75rem 0 2rem;outline:none;width:100%;transition:all .2s ease-in-out}::ng-deep .configure-resolution-body .case-calendar-inner input::placeholder{color:#a9aab6}::ng-deep .configure-resolution-body .case-calendar-inner input:hover,::ng-deep .configure-resolution-body .case-calendar-inner input:focus{border-color:#1e5dd3}::ng-deep .configure-resolution-body .case-calendar-inner i{display:flex;justify-content:center;align-items:center;height:.75rem;width:.75rem;position:absolute;left:.75rem;top:.75rem;color:#747576;font-size:12px;pointer-events:none}::ng-deep .configure-resolution-body .case-calendar-inner.disabled{background:#f2f2f5;pointer-events:none;opacity:1}::ng-deep .configure-resolution-body .case-calendar-inner.disabled input,::ng-deep .configure-resolution-body .case-calendar-inner.disabled i{color:#a9aab6}::ng-deep .configure-resolution-body .email-configure-box{border-radius:.25rem;border:1px solid #dbdbdb;color:#787a8c}::ng-deep .configure-resolution-body .email-configure-box input{-moz-appearance:textfield;border-radius:.25rem;border:1px solid #dbdbdb;color:#343952;display:inline-block;font-size:13px;text-align:center;width:2.25rem;height:1.75rem;padding:.125rem;outline:none}::ng-deep .configure-resolution-body .email-configure-box input::-webkit-inner-spin-button,::ng-deep .configure-resolution-body .email-configure-box input::-webkit-outer-spin-button{-webkit-appearance:none}::ng-deep .configure-resolution-body .email-configure-box input::placeholder{color:#787a8c}::ng-deep .configure-resolution-body .email-configure-box .black-text{color:#000}::ng-deep .configure-resolution-table{margin-bottom:.75rem}::ng-deep .configure-resolution-table .table-header{background:#fff;border-radius:.25rem .25rem 0 0;border:1px solid #f2f2f5;border-bottom:1px solid #f2f2f5}::ng-deep .configure-resolution-table .table-header .table-column{color:#787a8c!important;line-height:.75rem!important;min-height:2rem!important}::ng-deep .configure-resolution-table .table-body{border-radius:0 0 .25rem .25rem;border:1px solid #f2f2f5;border-top:none}::ng-deep .configure-resolution-table .table-row{display:flex;justify-content:space-between;position:relative;border-bottom:1px solid #f2f2f5}::ng-deep .configure-resolution-table .table-row:last-of-type .table-column,::ng-deep .configure-resolution-table .table-row:only-child .table-column{border-bottom:none}::ng-deep .configure-resolution-table .table-row .table-column{border-bottom:1px solid #f2f2f5;color:#000;min-height:3.25rem;position:relative;width:100%}::ng-deep .configure-resolution-table .table-row .table-column i.info{cursor:pointer}::ng-deep .configure-resolution-table .table-row .table-column.serial{width:2rem;max-width:2rem;justify-content:center}::ng-deep .configure-resolution-table .table-row .table-column.serial .sr-no{width:1rem;height:3.25rem}::ng-deep .configure-resolution-table .table-row .table-column.stage-name{width:calc(100% - 37rem);min-width:calc(100% - 37rem)}::ng-deep .configure-resolution-table .table-row .table-column.stage-name .value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .configure-resolution-table .table-row .table-column.status{width:10rem;min-width:10rem}::ng-deep .configure-resolution-table .table-row .table-column.status .value span{color:#787a8c}::ng-deep .configure-resolution-table .table-row .table-column.assignee{width:15rem;min-width:15rem}::ng-deep .configure-resolution-table .table-row .table-column.assignee .select-box{border-radius:.25rem;border:1px solid #cdced6;cursor:pointer;height:2.5rem;width:100%}::ng-deep .configure-resolution-table .table-row .table-column.assignee .select-box .value{color:#a9aab6}::ng-deep .configure-resolution-table .table-row .table-column.assignee .select-box .arrow{color:#787a8c}::ng-deep .configure-resolution-table .table-row .table-column.assignee .after-select-box{background:#f9f9fa;border-radius:.25rem;border:1px solid #cdced6;height:2.5rem;width:100%}::ng-deep .configure-resolution-table .table-row .table-column.assignee .after-select-box .value-chip{background:#fff;border-radius:.125rem;border:1px solid #f4f8ff;box-shadow:0 0 2px #1e5dd326;color:#000;height:1.5rem;max-width:9.5rem;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .configure-resolution-table .table-row .table-column.assignee .after-select-box button.edit-btn{background:transparent;border-radius:0;border:none}::ng-deep .configure-resolution-table .table-row .table-column.deadline{width:10rem;min-width:10rem}@keyframes animate-right{0%{transform:translate(100%)}to{transform:translate(0)}}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.ToolTipDirective, selector: "[appTooltip]", inputs: ["appTooltip", "placement", "type", "tooltipMandatory", "showTooltip", "animate"] }, { kind: "component", type: i5.FloatingBarComponent, selector: "app-floating-bar", inputs: ["selectedData", "selectedGroups", "displayElementKey", "elementId", "singularText", "pluralText", "showNextButton", "showFrequencyText", "showWorkflow", "workflowText", "currentFrequency", "isDisabled", "workflowList", "selectedWorkflow", "workflowPlaceHolder", "mode", "defaultSelected", "groupsEnabled", "nonRemovableUsersList", "removePosition"], outputs: ["closeEvent", "deleteEvent", "closeList", "deleteGroupEvent", "workflowTypeChanged"] }, { kind: "component", type: i6.DatePickerComponent, selector: "dp-date-picker", inputs: ["config", "mode", "placeholder", "disabled", "displayDate", "theme", "minDate", "maxDate", "minTime", "maxTime"], outputs: ["open", "close", "onChange", "onGoToCurrent", "onLeftNav", "onRightNav", "onSelect"] }, { kind: "directive", type: i7.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i7.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i7.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i8.LoaderInlineComponent, selector: "app-loader-inline" }, { kind: "component", type: i9.AssigneeComponent, selector: "app-assignee", inputs: ["assigneeList", "activeAssignee", "payload"], outputs: ["closeEvent", "selectedAssigneeEvent"] }, { kind: "component", type: i10.BannerComponent, selector: "app-banner", inputs: ["icon", "bannerClass", "isCenter"] }, { kind: "pipe", type: i3.DatePipe, name: "date" }] }); }
290
302
  }
291
303
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DueDateComponent, decorators: [{
292
304
  type: Component,
293
- args: [{ selector: 'app-due-date', template: "<div class=\"configure-resolution\">\n <div\n class=\"configure-resolution-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\"\n >\n <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">\n Configure Resolution Deadline & Stage Details\n </div>\n </div>\n <div class=\"configure-resolution-body\">\n <div class=\"configure-resolution-body-inner\">\n <app-loader-inline *ngIf=\"false\"></app-loader-inline>\n <app-no-data\n *ngIf=\"false\"\n [noDataImage]=\"ASSETS.search_data\"\n [noDataText]=\"'No data to display'\"\n ></app-no-data>\n\n <ng-container>\n <div\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\n >\n SPECIFY THE DEADLINE TO CLOSE THIS CASE\n <span class=\"required vx-fs-16 vx-fw-400\">*</span>\n </div>\n <div class=\"case-calendar vx-mb-3\">\n <div class=\"case-calendar-inner vx-d-flex vx-align-center\">\n <input\n type=\"text\"\n readonly\n placeholder=\"{{\n dueDateTexts.case_details.due_date.deadline_placeholder\n }}\"\n (click)=\"openDatePicker()\"\n [value]=\"dueDate | date : 'dd MMM yyyy'\"\n id=\"deadline-date\"\n />\n <i class=\"icons\">&#xe92d;</i>\n <dp-date-picker\n #deadlineDatePicker\n (onSelect)=\"datePickerOverlay = false; closeDatePicker($event)\"\n [config]=\"dateConfig\"\n [(ngModel)]=\"dueDate\"\n >\n </dp-date-picker>\n <div\n class=\"vx-overlay\"\n (click)=\"closeDatePicker($event)\"\n *ngIf=\"datePickerOverlay\"\n ></div>\n </div>\n <div *ngIf=\"showError\" class=\"errorMsg vx-fs-11 vx-lh-4 vx-mt-1\">\n {{ dueDateTexts.errorMessage.dueDate }}\n </div>\n </div>\n <div class=\"vx-d-flex vx-align-center vx-justify-between vx-mb-1\">\n <div\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-tt-uppercase\"\n >\n CONFIGURE DEADLINE & ASSIGNEE FOR EACH STAGE IN THE WORKFLOW\n <span class=\"required vx-fs-16 vx-fw-400\">*</span>\n </div>\n <!-- <div class=\"toggle-area vx-d-flex vx-align-center\">\n <app-cs-switch>Allow Reopening of Previous Stage</app-cs-switch>\n <i\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-2\"\n [appTooltip]=\"\n 'If enabled, this option allows the assignee to revisit and reopen a previously completed stage. The stage will be reset, and the assigned user will need to complete it again.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </div> -->\n </div>\n <div class=\"configure-resolution-table\">\n <div class=\"table-header\">\n <div class=\"table-row\">\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\"\n >\n #\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center stage-name\"\n >\n STAGE NAME\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center status\"\n >\n TRANSITION STATUS\n <i\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\n [appTooltip]=\"helperText.transition_status\"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center assignee\"\n >\n ASSIGNEE\n <i\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\n [appTooltip]=\"helperText.assignee\"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center deadline\"\n >\n DEADLINE\n <i\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\n [appTooltip]=\"helperText.deadline\"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </div>\n </div>\n </div>\n <div class=\"table-body\">\n <div\n class=\"table-row\"\n *ngFor=\"\n let data of workflowDetails?.stages_assignees;\n let i = index\n \"\n >\n <div\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\"\n >\n <div\n class=\"sr-no vx-fs-13 vx-d-flex vx-align-center vx-justify-center\"\n [appTooltip]=\"i + 1\"\n placement=\"bottom\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"true\"\n >\n {{ i + 1 }}\n </div>\n </div>\n <div\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center stage-name\"\n >\n <div\n class=\"value vx-fs-13 vx-pr-2\"\n [appTooltip]=\"data?.name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >\n {{ data?.name }}\n </div>\n </div>\n <div\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center status\"\n >\n <div class=\"value vx-fs-12\">\n {{ data?.status_transition?.fromName }}<br /><span\n class=\"vx-mr-1\"\n >To</span\n >{{ data?.status_transition?.toName }}\n </div>\n </div>\n <div\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center assignee\"\n (click)=\"activateSelector(true, i)\"\n >\n <div\n *ngIf=\"!assigneeData[i]?.length\"\n class=\"select-box vx-d-flex vx-align-center vx-justify-between vx-pl-3 vx-pr-3\"\n >\n <div class=\"value vx-fs-13\">Select a User</div>\n <i class=\"icons arrow vx-fs-12\">&#xe9e8;</i>\n </div>\n <div\n *ngIf=\"assigneeData[i]?.length > 0\"\n class=\"after-select-box vx-d-flex vx-align-center vx-justify-between vx-pl-3 vx-pr-2\"\n >\n <div\n class=\"value-chip vx-fs-11 vx-pl-2 vx-pr-2 vx-lh-6\"\n [appTooltip]=\"assigneeData[i][0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >\n {{ assigneeData[i][0]?.member_name }}\n </div>\n <button\n (click)=\"activateSelector(true, i)\"\n class=\"edit-btn vx-fs-11 vx-fw-500 vx-txt-blue vx-tt-uppercase vx-p-0 vx-m-0 vx-d-flex vx-align-center\"\n >\n <i class=\"icons vx-fs-12 vx-txt-blue vx-mr-1\">&#xe9ba;</i\n >EDIT\n </button>\n </div>\n </div>\n <div\n class=\"table-column vx-pl-1 vx-pr-2 vx-d-flex vx-align-center deadline\"\n >\n <div\n class=\"case-calendar vx-d-flex vx-justify-between vx-pt-3 vx-pb-3\"\n >\n <div\n class=\"case-calendar-inner vx-d-flex vx-align-center\"\n [class.disabled]=\"true\"\n >\n <input\n type=\"text\"\n readonly\n value=\"{{ dueDate | date : 'dd MMM yyyy' }}\"\n (click)=\"openDatePicker()\"\n id=\"stage-deadline-date\"\n />\n <i class=\"icons\">&#xe92d;</i>\n <dp-date-picker\n #datePicker\n (onSelect)=\"\n datePickerOverlay = false; closeDatePicker($event)\n \"\n [config]=\"dateConfig\"\n >\n </dp-date-picker>\n <div\n class=\"vx-overlay\"\n (click)=\"closeDatePicker($event)\"\n *ngIf=\"datePickerOverlay\"\n ></div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div\n *ngIf=\"showAssigneeError\"\n class=\"errorMsg vx-fs-11 vx-lh-4 vx-mt-1\"\n >\n {{ dueDateTexts.errorMessage.stageAssignee }}\n </div>\n </div>\n <div\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\n >\n EMAIL REMINDER CONFIGURATION\n <span class=\"required vx-fs-16 vx-fw-400\">*</span>\n </div>\n <div class=\"divider vx-mb-2\"></div>\n <div\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\n >\n REMINDER EMAIL\n </div>\n <div\n class=\"email-configure-box vx-d-flex vx-align-center vx-flex-wrap vx-p-2 vx-pl-3 vx-pr-3 vx-mb-2\"\n >\n <div class=\"vx-fs-13 vx-mr-1\">\n Send regular email reminders to the assignee\n </div>\n <input\n type=\"number\"\n [(ngModel)]=\"emailReminder\"\n onkeydown=\"return event.key !== '.'\"\n oninput=\"this.value = Math.abs(this.value)\"\n (change)=\"onInputChange()\"\n />\n <div class=\"vx-fs-13 vx-ml-1\">\n <span class=\"black-text\">days</span> before the stage deadline.\n </div>\n </div>\n <div\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\n >\n ESCALATION EMAIL\n </div>\n <div\n class=\"email-configure-box vx-d-flex vx-align-center vx-flex-wrap vx-p-2 vx-pl-3 vx-pr-3 vx-mb-2\"\n >\n <div class=\"vx-fs-13 vx-mr-1\">\n Send email escalation to the Case Owner\n </div>\n <input\n type=\"number\"\n [(ngModel)]=\"escalationEmail\"\n onkeydown=\"return event.key !== '.'\"\n oninput=\"this.value = Math.abs(this.value)\"\n (change)=\"onInputChange()\"\n />\n <div class=\"vx-fs-13 vx-ml-1\">\n <span class=\"black-text\">days</span> before the overall case\n deadline, if the case is still open.\n </div>\n </div>\n </ng-container>\n </div>\n <app-floating-bar\n (closeList)=\"closeDueDate()\"\n (closeEvent)=\"saveCaseResolutionDeadline()\"\n ></app-floating-bar>\n </div>\n</div>\n<app-assignee\n *ngIf=\"assigneeClicked\"\n [payload]=\"payload\"\n [assigneeList]=\"assigneeList\"\n [activeAssignee]=\"activeAssignee\"\n (selectedAssigneeEvent)=\"selectedAssignee($event)\"\n (closeEvent)=\"activateSelector(false)\"\n></app-assignee>\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";::ng-deep .configure-resolution{background:#fff;position:fixed;inset:0 500px 0 0;z-index:1}::ng-deep .configure-resolution:before{background:#1e5dd3;content:\"\";position:absolute;top:0;left:0;right:0;width:100%;height:3px}::ng-deep .configure-resolution.animate{animation:animate-right .2s cubic-bezier(.25,.46,.45,.94) both;z-index:-1}::ng-deep .configure-resolution-head{background:#fbfbfb;border-bottom:1px solid #f1f1f1;height:2.75rem}::ng-deep .configure-resolution-body{background:#fff;height:calc(100vh - 2.75rem);padding:2rem}::ng-deep .configure-resolution-body-inner{height:calc(100% - 3rem);padding:0 2rem 1rem 0;width:calc(100% + 2rem);overflow-y:auto;scrollbar-width:thin}::ng-deep .configure-resolution-body-inner .divider{background:#e3e3e9;width:100%;height:1px}::ng-deep .configure-resolution-body .label-top .required{color:#c7381b}::ng-deep .configure-resolution-body .errorMsg{color:#a82a1d}::ng-deep .configure-resolution-body .toggle-area{cursor:pointer}::ng-deep .configure-resolution-body .toggle-area app-cs-switch .cs-switch .switch{order:1;width:24px!important;min-width:24px!important;height:16px!important}::ng-deep .configure-resolution-body .toggle-area app-cs-switch .cs-switch .switch .switch-box{background:#cdced6!important;border:1px solid #cdced6!important}::ng-deep .configure-resolution-body .toggle-area app-cs-switch .cs-switch .switch .switch-ball{height:12px!important;width:12px!important;border:none!important;left:2px!important;top:2px!important;bottom:2px!important}::ng-deep .configure-resolution-body .toggle-area app-cs-switch .cs-switch .switch input:checked+span.switch-box{background:#34aa44!important;border-color:#34aa44!important}::ng-deep .configure-resolution-body .toggle-area app-cs-switch .cs-switch .switch input:checked+span.switch-box .switch-ball{left:10px!important}::ng-deep .configure-resolution-body .toggle-area app-cs-switch .cs-switch .value{order:2;color:#000!important;cursor:pointer;font-size:11px!important;margin-left:.5rem;width:unset!important}::ng-deep .configure-resolution-body .toggle-area i.info{cursor:pointer}::ng-deep .configure-resolution-body .case-calendar{background:#fff;border-radius:.25rem}::ng-deep .configure-resolution-body .case-calendar-inner{position:relative;width:100%}::ng-deep .configure-resolution-body .case-calendar-inner input{background:transparent;border-radius:.25rem;border:1px solid #cdced6;color:#747576;font-size:13px;font-weight:400;height:2.5rem;line-height:2.5rem;padding:0 .75rem 0 2rem;outline:none;width:100%;transition:all .2s ease-in-out}::ng-deep .configure-resolution-body .case-calendar-inner input::placeholder{color:#a9aab6}::ng-deep .configure-resolution-body .case-calendar-inner input:hover,::ng-deep .configure-resolution-body .case-calendar-inner input:focus{border-color:#1e5dd3}::ng-deep .configure-resolution-body .case-calendar-inner i{display:flex;justify-content:center;align-items:center;height:.75rem;width:.75rem;position:absolute;left:.75rem;top:.75rem;color:#747576;font-size:12px;pointer-events:none}::ng-deep .configure-resolution-body .case-calendar-inner.disabled{background:#f2f2f5;pointer-events:none;opacity:1}::ng-deep .configure-resolution-body .case-calendar-inner.disabled input,::ng-deep .configure-resolution-body .case-calendar-inner.disabled i{color:#a9aab6}::ng-deep .configure-resolution-body .email-configure-box{border-radius:.25rem;border:1px solid #dbdbdb;color:#787a8c}::ng-deep .configure-resolution-body .email-configure-box input{-moz-appearance:textfield;border-radius:.25rem;border:1px solid #dbdbdb;color:#343952;display:inline-block;font-size:13px;text-align:center;width:2.25rem;height:1.75rem;padding:.125rem;outline:none}::ng-deep .configure-resolution-body .email-configure-box input::-webkit-inner-spin-button,::ng-deep .configure-resolution-body .email-configure-box input::-webkit-outer-spin-button{-webkit-appearance:none}::ng-deep .configure-resolution-body .email-configure-box input::placeholder{color:#787a8c}::ng-deep .configure-resolution-body .email-configure-box .black-text{color:#000}::ng-deep .configure-resolution-table{margin-bottom:.75rem}::ng-deep .configure-resolution-table .table-header{background:#fff;border-radius:.25rem .25rem 0 0;border:1px solid #f2f2f5;border-bottom:1px solid #f2f2f5}::ng-deep .configure-resolution-table .table-header .table-column{color:#787a8c!important;line-height:.75rem!important;min-height:2rem!important}::ng-deep .configure-resolution-table .table-body{border-radius:0 0 .25rem .25rem;border:1px solid #f2f2f5;border-top:none}::ng-deep .configure-resolution-table .table-row{display:flex;justify-content:space-between;position:relative;border-bottom:1px solid #f2f2f5}::ng-deep .configure-resolution-table .table-row:last-of-type .table-column,::ng-deep .configure-resolution-table .table-row:only-child .table-column{border-bottom:none}::ng-deep .configure-resolution-table .table-row .table-column{border-bottom:1px solid #f2f2f5;color:#000;min-height:3.25rem;position:relative;width:100%}::ng-deep .configure-resolution-table .table-row .table-column i.info{cursor:pointer}::ng-deep .configure-resolution-table .table-row .table-column.serial{width:2rem;max-width:2rem;justify-content:center}::ng-deep .configure-resolution-table .table-row .table-column.serial .sr-no{width:1rem;height:3.25rem}::ng-deep .configure-resolution-table .table-row .table-column.stage-name{width:calc(100% - 37rem);min-width:calc(100% - 37rem)}::ng-deep .configure-resolution-table .table-row .table-column.stage-name .value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .configure-resolution-table .table-row .table-column.status{width:10rem;min-width:10rem}::ng-deep .configure-resolution-table .table-row .table-column.status .value span{color:#787a8c}::ng-deep .configure-resolution-table .table-row .table-column.assignee{width:15rem;min-width:15rem}::ng-deep .configure-resolution-table .table-row .table-column.assignee .select-box{border-radius:.25rem;border:1px solid #cdced6;cursor:pointer;height:2.5rem;width:100%}::ng-deep .configure-resolution-table .table-row .table-column.assignee .select-box .value{color:#a9aab6}::ng-deep .configure-resolution-table .table-row .table-column.assignee .select-box .arrow{color:#787a8c}::ng-deep .configure-resolution-table .table-row .table-column.assignee .after-select-box{background:#f9f9fa;border-radius:.25rem;border:1px solid #cdced6;height:2.5rem;width:100%}::ng-deep .configure-resolution-table .table-row .table-column.assignee .after-select-box .value-chip{background:#fff;border-radius:.125rem;border:1px solid #f4f8ff;box-shadow:0 0 2px #1e5dd326;color:#000;height:1.5rem;max-width:9.5rem;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .configure-resolution-table .table-row .table-column.assignee .after-select-box button.edit-btn{background:transparent;border-radius:0;border:none}::ng-deep .configure-resolution-table .table-row .table-column.deadline{width:10rem;min-width:10rem}@keyframes animate-right{0%{transform:translate(100%)}to{transform:translate(0)}}\n"] }]
305
+ args: [{ selector: 'app-due-date', template: "<div class=\"configure-resolution\">\n <div\n class=\"configure-resolution-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\"\n >\n <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">\n Configure Resolution Deadline & Stage Details\n </div>\n </div>\n <div class=\"configure-resolution-body\">\n <div class=\"configure-resolution-body-inner\">\n <app-loader-inline *ngIf=\"false\"></app-loader-inline>\n <app-no-data\n *ngIf=\"false\"\n [noDataImage]=\"ASSETS.search_data\"\n [noDataText]=\"'No data to display'\"\n ></app-no-data>\n\n <ng-container>\n <div\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\n >\n SPECIFY THE DEADLINE TO CLOSE THIS CASE\n <span class=\"required vx-fs-16 vx-fw-400\">*</span>\n </div>\n <app-banner *ngIf=\"mode === 'EDIT'\">\n <p banner>\n {{ CaseDeadlineWarning }}\n </p>\n </app-banner>\n <div class=\"case-calendar vx-mb-3\">\n <div class=\"case-calendar-inner vx-d-flex vx-align-center\">\n <input\n type=\"text\"\n readonly\n placeholder=\"{{\n dueDateTexts.case_details.due_date.deadline_placeholder\n }}\"\n (click)=\"openDatePicker()\"\n [value]=\"dueDate | date : 'dd MMM yyyy'\"\n id=\"deadline-date\"\n />\n <i class=\"icons\">&#xe92d;</i>\n <dp-date-picker\n #deadlineDatePicker\n (onSelect)=\"datePickerOverlay = false; closeDatePicker($event)\"\n [config]=\"dateConfig\"\n [(ngModel)]=\"dueDate\"\n >\n </dp-date-picker>\n <div\n class=\"vx-overlay\"\n (click)=\"closeDatePicker($event)\"\n *ngIf=\"datePickerOverlay\"\n ></div>\n </div>\n <div *ngIf=\"showError\" class=\"errorMsg vx-fs-11 vx-lh-4 vx-mt-1\">\n {{ dueDateTexts.errorMessage.dueDate }}\n </div>\n </div>\n <div class=\"vx-d-flex vx-align-center vx-justify-between vx-mb-1\">\n <div\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-tt-uppercase\"\n >\n CONFIGURE DEADLINE & ASSIGNEE FOR EACH STAGE IN THE WORKFLOW\n <span class=\"required vx-fs-16 vx-fw-400\">*</span>\n </div>\n <!-- <div class=\"toggle-area vx-d-flex vx-align-center\">\n <app-cs-switch>Allow Reopening of Previous Stage</app-cs-switch>\n <i\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-2\"\n [appTooltip]=\"\n 'If enabled, this option allows the assignee to revisit and reopen a previously completed stage. The stage will be reset, and the assigned user will need to complete it again.'\n \"\n placement=\"bottom-right\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </div> -->\n </div>\n <div class=\"configure-resolution-table\">\n <div class=\"table-header\">\n <div class=\"table-row\">\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\"\n >\n #\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center stage-name\"\n >\n STAGE NAME\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center status\"\n >\n TRANSITION STATUS\n <i\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\n [appTooltip]=\"helperText.transition_status\"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center assignee\"\n >\n ASSIGNEE\n <i\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\n [appTooltip]=\"helperText.assignee\"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </div>\n <div\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center deadline\"\n >\n DEADLINE\n <i\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\n [appTooltip]=\"helperText.deadline\"\n placement=\"bottom\"\n delay=\"0\"\n type=\"white\"\n [tooltipMandatory]=\"true\"\n >&#xe91f;</i\n >\n </div>\n </div>\n </div>\n <div class=\"table-body\">\n <div\n class=\"table-row\"\n *ngFor=\"\n let data of workflowDetails?.stages_assignees;\n let i = index\n \"\n >\n <div\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\"\n >\n <div\n class=\"sr-no vx-fs-13 vx-d-flex vx-align-center vx-justify-center\"\n [appTooltip]=\"i + 1\"\n placement=\"bottom\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"true\"\n >\n {{ i + 1 }}\n </div>\n </div>\n <div\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center stage-name\"\n >\n <div\n class=\"value vx-fs-13 vx-pr-2\"\n [appTooltip]=\"data?.name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >\n {{ data?.name }}\n </div>\n </div>\n <div\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center status\"\n >\n <div class=\"value vx-fs-12\">\n {{ data?.status_transition?.fromName }}<br /><span\n class=\"vx-mr-1\"\n >To</span\n >{{ data?.status_transition?.toName }}\n </div>\n </div>\n <div\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center assignee\"\n (click)=\"activateSelector(true, i)\"\n >\n <div\n *ngIf=\"!assigneeData[i]?.length\"\n class=\"select-box vx-d-flex vx-align-center vx-justify-between vx-pl-3 vx-pr-3\"\n >\n <div class=\"value vx-fs-13\">Select a User</div>\n <i class=\"icons arrow vx-fs-12\">&#xe9e8;</i>\n </div>\n <div\n *ngIf=\"assigneeData[i]?.length > 0\"\n class=\"after-select-box vx-d-flex vx-align-center vx-justify-between vx-pl-3 vx-pr-2\"\n >\n <div\n class=\"value-chip vx-fs-11 vx-pl-2 vx-pr-2 vx-lh-6\"\n [appTooltip]=\"assigneeData[i][0]?.member_name\"\n placement=\"bottom-left\"\n delay=\"0\"\n type=\"black\"\n [tooltipMandatory]=\"false\"\n >\n {{ assigneeData[i][0]?.member_name }}\n </div>\n <button\n (click)=\"activateSelector(true, i)\"\n class=\"edit-btn vx-fs-11 vx-fw-500 vx-txt-blue vx-tt-uppercase vx-p-0 vx-m-0 vx-d-flex vx-align-center\"\n >\n <i class=\"icons vx-fs-12 vx-txt-blue vx-mr-1\">&#xe9ba;</i\n >EDIT\n </button>\n </div>\n </div>\n <div\n class=\"table-column vx-pl-1 vx-pr-2 vx-d-flex vx-align-center deadline\"\n >\n <div\n class=\"case-calendar vx-d-flex vx-justify-between vx-pt-3 vx-pb-3\"\n >\n <div\n class=\"case-calendar-inner vx-d-flex vx-align-center\"\n [class.disabled]=\"true\"\n >\n <input\n type=\"text\"\n readonly\n value=\"{{ dueDate | date : 'dd MMM yyyy' }}\"\n (click)=\"openDatePicker()\"\n id=\"stage-deadline-date\"\n />\n <i class=\"icons\">&#xe92d;</i>\n <dp-date-picker\n #datePicker\n (onSelect)=\"\n datePickerOverlay = false; closeDatePicker($event)\n \"\n [config]=\"dateConfig\"\n >\n </dp-date-picker>\n <div\n class=\"vx-overlay\"\n (click)=\"closeDatePicker($event)\"\n *ngIf=\"datePickerOverlay\"\n ></div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div\n *ngIf=\"showAssigneeError\"\n class=\"errorMsg vx-fs-11 vx-lh-4 vx-mt-1\"\n >\n {{ dueDateTexts.errorMessage.stageAssignee }}\n </div>\n </div>\n <div\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\n >\n EMAIL REMINDER CONFIGURATION\n <span class=\"required vx-fs-16 vx-fw-400\">*</span>\n </div>\n <div class=\"divider vx-mb-2\"></div>\n <div\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\n >\n REMINDER EMAIL\n </div>\n <div\n class=\"email-configure-box vx-d-flex vx-align-center vx-flex-wrap vx-p-2 vx-pl-3 vx-pr-3 vx-mb-2\"\n >\n <div class=\"vx-fs-13 vx-mr-1\">\n Send regular email reminders to the assignee\n </div>\n <input\n type=\"number\"\n [(ngModel)]=\"emailReminder\"\n onkeydown=\"return event.key !== '.'\"\n oninput=\"this.value = Math.abs(this.value)\"\n (change)=\"onInputChange()\"\n />\n <div class=\"vx-fs-13 vx-ml-1\">\n <span class=\"black-text\">days</span> before the stage deadline.\n </div>\n </div>\n <div\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\n >\n ESCALATION EMAIL\n </div>\n <div\n class=\"email-configure-box vx-d-flex vx-align-center vx-flex-wrap vx-p-2 vx-pl-3 vx-pr-3 vx-mb-2\"\n >\n <div class=\"vx-fs-13 vx-mr-1\">\n Send email escalation to the Case Owner\n </div>\n <input\n type=\"number\"\n [(ngModel)]=\"escalationEmail\"\n onkeydown=\"return event.key !== '.'\"\n oninput=\"this.value = Math.abs(this.value)\"\n (change)=\"onInputChange()\"\n />\n <div class=\"vx-fs-13 vx-ml-1\">\n <span class=\"black-text\">days</span> before the overall case\n deadline, if the case is still open.\n </div>\n </div>\n </ng-container>\n </div>\n <app-floating-bar\n (closeList)=\"closeDueDate()\"\n (closeEvent)=\"saveCaseResolutionDeadline()\"\n ></app-floating-bar>\n </div>\n</div>\n<app-assignee\n *ngIf=\"assigneeClicked\"\n [payload]=\"payload\"\n [assigneeList]=\"assigneeList\"\n [activeAssignee]=\"activeAssignee\"\n (selectedAssigneeEvent)=\"selectedAssignee($event)\"\n (closeEvent)=\"activateSelector(false)\"\n></app-assignee>\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";::ng-deep .configure-resolution{background:#fff;position:fixed;inset:0 500px 0 0;z-index:1}::ng-deep .configure-resolution:before{background:#1e5dd3;content:\"\";position:absolute;top:0;left:0;right:0;width:100%;height:3px}::ng-deep .configure-resolution.animate{animation:animate-right .2s cubic-bezier(.25,.46,.45,.94) both;z-index:-1}::ng-deep .configure-resolution-head{background:#fbfbfb;border-bottom:1px solid #f1f1f1;height:2.75rem}::ng-deep .configure-resolution-body{background:#fff;height:calc(100vh - 2.75rem);padding:2rem}::ng-deep .configure-resolution-body-inner{height:calc(100% - 3rem);padding:0 2rem 1rem 0;width:calc(100% + 2rem);overflow-y:auto;scrollbar-width:thin}::ng-deep .configure-resolution-body-inner .divider{background:#e3e3e9;width:100%;height:1px}::ng-deep .configure-resolution-body .label-top .required{color:#c7381b}::ng-deep .configure-resolution-body .errorMsg{color:#a82a1d}::ng-deep .configure-resolution-body .toggle-area{cursor:pointer}::ng-deep .configure-resolution-body .toggle-area app-cs-switch .cs-switch .switch{order:1;width:24px!important;min-width:24px!important;height:16px!important}::ng-deep .configure-resolution-body .toggle-area app-cs-switch .cs-switch .switch .switch-box{background:#cdced6!important;border:1px solid #cdced6!important}::ng-deep .configure-resolution-body .toggle-area app-cs-switch .cs-switch .switch .switch-ball{height:12px!important;width:12px!important;border:none!important;left:2px!important;top:2px!important;bottom:2px!important}::ng-deep .configure-resolution-body .toggle-area app-cs-switch .cs-switch .switch input:checked+span.switch-box{background:#34aa44!important;border-color:#34aa44!important}::ng-deep .configure-resolution-body .toggle-area app-cs-switch .cs-switch .switch input:checked+span.switch-box .switch-ball{left:10px!important}::ng-deep .configure-resolution-body .toggle-area app-cs-switch .cs-switch .value{order:2;color:#000!important;cursor:pointer;font-size:11px!important;margin-left:.5rem;width:unset!important}::ng-deep .configure-resolution-body .toggle-area i.info{cursor:pointer}::ng-deep .configure-resolution-body .case-calendar{background:#fff;border-radius:.25rem}::ng-deep .configure-resolution-body .case-calendar-inner{position:relative;width:100%}::ng-deep .configure-resolution-body .case-calendar-inner input{background:transparent;border-radius:.25rem;border:1px solid #cdced6;color:#747576;font-size:13px;font-weight:400;height:2.5rem;line-height:2.5rem;padding:0 .75rem 0 2rem;outline:none;width:100%;transition:all .2s ease-in-out}::ng-deep .configure-resolution-body .case-calendar-inner input::placeholder{color:#a9aab6}::ng-deep .configure-resolution-body .case-calendar-inner input:hover,::ng-deep .configure-resolution-body .case-calendar-inner input:focus{border-color:#1e5dd3}::ng-deep .configure-resolution-body .case-calendar-inner i{display:flex;justify-content:center;align-items:center;height:.75rem;width:.75rem;position:absolute;left:.75rem;top:.75rem;color:#747576;font-size:12px;pointer-events:none}::ng-deep .configure-resolution-body .case-calendar-inner.disabled{background:#f2f2f5;pointer-events:none;opacity:1}::ng-deep .configure-resolution-body .case-calendar-inner.disabled input,::ng-deep .configure-resolution-body .case-calendar-inner.disabled i{color:#a9aab6}::ng-deep .configure-resolution-body .email-configure-box{border-radius:.25rem;border:1px solid #dbdbdb;color:#787a8c}::ng-deep .configure-resolution-body .email-configure-box input{-moz-appearance:textfield;border-radius:.25rem;border:1px solid #dbdbdb;color:#343952;display:inline-block;font-size:13px;text-align:center;width:2.25rem;height:1.75rem;padding:.125rem;outline:none}::ng-deep .configure-resolution-body .email-configure-box input::-webkit-inner-spin-button,::ng-deep .configure-resolution-body .email-configure-box input::-webkit-outer-spin-button{-webkit-appearance:none}::ng-deep .configure-resolution-body .email-configure-box input::placeholder{color:#787a8c}::ng-deep .configure-resolution-body .email-configure-box .black-text{color:#000}::ng-deep .configure-resolution-table{margin-bottom:.75rem}::ng-deep .configure-resolution-table .table-header{background:#fff;border-radius:.25rem .25rem 0 0;border:1px solid #f2f2f5;border-bottom:1px solid #f2f2f5}::ng-deep .configure-resolution-table .table-header .table-column{color:#787a8c!important;line-height:.75rem!important;min-height:2rem!important}::ng-deep .configure-resolution-table .table-body{border-radius:0 0 .25rem .25rem;border:1px solid #f2f2f5;border-top:none}::ng-deep .configure-resolution-table .table-row{display:flex;justify-content:space-between;position:relative;border-bottom:1px solid #f2f2f5}::ng-deep .configure-resolution-table .table-row:last-of-type .table-column,::ng-deep .configure-resolution-table .table-row:only-child .table-column{border-bottom:none}::ng-deep .configure-resolution-table .table-row .table-column{border-bottom:1px solid #f2f2f5;color:#000;min-height:3.25rem;position:relative;width:100%}::ng-deep .configure-resolution-table .table-row .table-column i.info{cursor:pointer}::ng-deep .configure-resolution-table .table-row .table-column.serial{width:2rem;max-width:2rem;justify-content:center}::ng-deep .configure-resolution-table .table-row .table-column.serial .sr-no{width:1rem;height:3.25rem}::ng-deep .configure-resolution-table .table-row .table-column.stage-name{width:calc(100% - 37rem);min-width:calc(100% - 37rem)}::ng-deep .configure-resolution-table .table-row .table-column.stage-name .value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .configure-resolution-table .table-row .table-column.status{width:10rem;min-width:10rem}::ng-deep .configure-resolution-table .table-row .table-column.status .value span{color:#787a8c}::ng-deep .configure-resolution-table .table-row .table-column.assignee{width:15rem;min-width:15rem}::ng-deep .configure-resolution-table .table-row .table-column.assignee .select-box{border-radius:.25rem;border:1px solid #cdced6;cursor:pointer;height:2.5rem;width:100%}::ng-deep .configure-resolution-table .table-row .table-column.assignee .select-box .value{color:#a9aab6}::ng-deep .configure-resolution-table .table-row .table-column.assignee .select-box .arrow{color:#787a8c}::ng-deep .configure-resolution-table .table-row .table-column.assignee .after-select-box{background:#f9f9fa;border-radius:.25rem;border:1px solid #cdced6;height:2.5rem;width:100%}::ng-deep .configure-resolution-table .table-row .table-column.assignee .after-select-box .value-chip{background:#fff;border-radius:.125rem;border:1px solid #f4f8ff;box-shadow:0 0 2px #1e5dd326;color:#000;height:1.5rem;max-width:9.5rem;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .configure-resolution-table .table-row .table-column.assignee .after-select-box button.edit-btn{background:transparent;border-radius:0;border:none}::ng-deep .configure-resolution-table .table-row .table-column.deadline{width:10rem;min-width:10rem}@keyframes animate-right{0%{transform:translate(100%)}to{transform:translate(0)}}\n"] }]
294
306
  }], ctorParameters: function () { return [{ type: i1.CommonService }, { type: i2.FrequencyService }]; }, propDecorators: { datePicker: [{
295
307
  type: ViewChild,
296
308
  args: ['deadlineDatePicker']
@@ -311,6 +323,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
311
323
  type: Input
312
324
  }], initialSelection: [{
313
325
  type: Input
326
+ }], min: [{
327
+ type: Input
314
328
  }], closeDueDateResolution: [{
315
329
  type: Output
316
330
  }], closeDueDateEvent: [{
@@ -319,4 +333,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
319
333
  type: HostListener,
320
334
  args: ['document:click', ['$event']]
321
335
  }] } });
322
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"due-date.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/report-a-case/components/due-date/due-date.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/report-a-case/components/due-date/due-date.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,UAAU,EACV,KAAK,EAEL,SAAS,EACT,MAAM,EACN,YAAY,EACZ,YAAY,GACb,MAAM,eAAe,CAAC;AAGvB,OAAO,EACL,WAAW,EACX,WAAW,EACX,eAAe,GAEhB,MAAM,uCAAuC,CAAC;AAG/C,OAAO,EAAE,MAAM,EAAE,MAAM,qCAAqC,CAAC;;;;;;;;;;;AAO7D,MAAM,OAAO,gBAAgB;IAkC3B,IAAa,gBAAgB,CAAC,KAAU;QACtC,IAAI,CAAC,OAAO,GAAG,KAAK,EAAE,mBAAmB,EAAE,QAAQ,CAAC;QACpD,IAAI,IAAI,CAAC,IAAI,KAAK,MAAM,EAAE;YACxB,IAAI,CAAC,aAAa,GAAG,KAAK,EAAE,mBAAmB,EAAE,sBAAsB,CAAC;YACxE,IAAI,CAAC,eAAe,GAAG,KAAK,EAAE,mBAAmB,EAAE,mBAAmB,CAAC;SACxE;IACH,CAAC;IAKD,YACU,iBAAgC,EAChC,gBAAkC;QADlC,sBAAiB,GAAjB,iBAAiB,CAAe;QAChC,qBAAgB,GAAhB,gBAAgB,CAAkB;QA5C5C,WAAM,GAAG,MAAM,CAAC;QAChB,cAAS,GAAG,IAAI,CAAC;QAEjB,sBAAiB,GAAG,KAAK,CAAC;QAC1B,eAAU,GAAsB;YAC9B,eAAe,EAAE,IAAI;YACrB,MAAM,EAAE,YAAY;YACpB,eAAe,EAAE,IAAI;YACrB,WAAW,EAAE,KAAK;YAClB,WAAW,EAAE,KAAK;YAClB,GAAG,EAAE,EAAE;SACR,CAAC;QAEF,iBAAY,GAAG,WAAW,CAAC;QAC3B,eAAU,GAAG,WAAW,CAAC;QACzB,oBAAe,GAAY,KAAK,CAAC;QACjC,iBAAY,GAAU,EAAE,CAAC;QACzB,iBAAY,GAA6B,EAAE,CAAC;QAC5C,sBAAiB,GAAW,CAAC,CAAC,CAAC;QAC/B,mBAAc,GAAU,EAAE,CAAC;QAC3B,kBAAa,GAAW,eAAe,CAAC,cAAc,CAAC;QACvD,oBAAe,GAAW,eAAe,CAAC,yBAAyB,CAAC;QACpE,cAAS,GAAY,KAAK,CAAC;QAC3B,sBAAiB,GAAY,KAAK,CAAC;QAK1B,aAAQ,GAAU,EAAE,CAAC;QACrB,cAAS,GAAU,EAAE,CAAC;QACtB,SAAI,GAAW,EAAE,CAAC;QASjB,2BAAsB,GAAG,IAAI,YAAY,EAAE,CAAC;QAC5C,sBAAiB,GAAG,IAAI,YAAY,EAAE,CAAC;IAK7C,CAAC;IAEL,QAAQ;QACN,IAAI,CAAC,UAAU,CAAC,GAAG,GAAG,IAAI,CAAC,gBAAgB,CAAC,UAAU,EAAE,CAAC;QACzD,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACzB,CAAC,EAAE,GAAG,CAAC,CAAC;QACR,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAEO,kBAAkB;QACxB,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,cAAc,EAAE,mBAAmB,EAAE,QAAQ;YAAE,OAAO;QAEzE,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,mBAAmB,CAAC;QACjE,IAAI,CAAC,wBAAwB,CAAC,QAAQ,CAAC,CAAC;QACxC,IAAI,CAAC,wBAAwB,CAAC,QAAQ,CAAC,CAAC;IAC1C,CAAC;IAEO,wBAAwB,CAAC,QAAa;QAC5C,IAAI,CAAC,OAAO,GAAG,IAAI,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QAC5C,IAAI,CAAC,aAAa;YAChB,QAAQ,CAAC,sBAAsB,IAAI,eAAe,CAAC,cAAc,CAAC;QACpE,IAAI,CAAC,eAAe;YAClB,QAAQ,CAAC,mBAAmB,IAAI,eAAe,CAAC,yBAAyB,CAAC;IAC9E,CAAC;IAEO,wBAAwB,CAAC,QAAa;QAC5C,IAAI,CAAC,QAAQ,EAAE,gBAAgB,EAAE,MAAM;YAAE,OAAO;QAEhD,MAAM,gBAAgB,GAAG,IAAI,CAAC,sBAAsB,CAClD,QAAQ,CAAC,gBAAgB,CAC1B,CAAC;QACF,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,CAAC,CAAC;IAC3C,CAAC;IAEO,sBAAsB,CAAC,eAAsB;QACnD,OAAO,IAAI,GAAG,CACZ,eAAe,CAAC,GAAG,CAAC,CAAC,KAAU,EAAE,EAAE,CAAC,CAAC,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,WAAW,CAAC,CAAC,CAC3E,CAAC;IACJ,CAAC;IAEO,iBAAiB,CAAC,gBAAqC;QAC7D,IAAI,CAAC,eAAe,EAAE,gBAAgB,EAAE,OAAO,CAC7C,CAAC,aAAkB,EAAE,KAAa,EAAE,EAAE;YACpC,MAAM,UAAU,GAAG,gBAAgB,EAAE,GAAG,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;YAClE,IAAI,CAAC,UAAU;gBAAE,OAAO;YAExB,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,EAAE,IAAI,CACtC,CAAC,QAAa,EAAE,EAAE,CAAC,QAAQ,EAAE,GAAG,KAAK,UAAU,CAChD,CAAC;YACF,IAAI,QAAQ,EAAE;gBACZ,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;aACvC;QACH,CAAC,CACF,CAAC;IACJ,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,UAAU,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC;QAC7B,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;IAChC,CAAC;IAED;;OAEG;IACH,eAAe,CAAC,GAAQ;QACtB,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAE/B,IAAI,CAAC,GAAG,EAAE;YACR,OAAO;SACR;QACD,IAAI,GAAG,EAAE,IAAI,EAAE,EAAE,EAAE;YACjB,IAAI,UAAU,GAAG;gBACf,KAAK;gBACL,KAAK;gBACL,KAAK;gBACL,KAAK;gBACL,KAAK;gBACL,KAAK;gBACL,KAAK;gBACL,KAAK;gBACL,KAAK;gBACL,KAAK;gBACL,KAAK;aACN,CAAC;YACF,MAAM,SAAS,GAAG,IAAI,IAAI,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC;YACpD,MAAM,UAAU,GAAG,UAAU,CAAC,IAAI,IAAI,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC;YAClE,MAAM,SAAS,GAAG,IAAI,IAAI,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC,WAAW,EAAE,CAAC;YACxD,MAAM,OAAO,GAAG,GAAG,SAAS,IAAI,UAAU,IAAI,SAAS,EAAE,CAAC;SAC3D;QACD,IAAI,GAAG,EAAE,IAAI,EAAE,EAAE,EAAE;YACjB,IAAI,CAAC,OAAO,GAAG,IAAI,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACrC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;SACxB;QACD,IAAI,CAAC,UAAU,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC;IAChC,CAAC;IAED,YAAY;QACV,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,CAAC;IAChC,CAAC;IAED,gBAAgB,CAAC,MAAe,EAAE,UAAmB;QACnD,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC;QAC9B,IAAI,MAAM,EAAE;YACV,IAAI,CAAC,iBAAiB,GAAG,UAAU,IAAI,CAAC,CAAC,CAAC;YAC1C,IAAI,CAAC,cAAc;gBACjB,IAAI,CAAC,iBAAiB,KAAK,CAAC,CAAC;oBAC3B,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,iBAAiB,CAAC;oBAC3C,CAAC,CAAC,EAAE,CAAC;SACV;IACH,CAAC;IAED,eAAe;QACb,MAAM,eAAe,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QAC5C,MAAM,cAAc,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAChD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,kBAAkB,CACzC,eAAe,EACf,cAAc,CACf,CAAC;IACJ,CAAC;IAED,YAAY;QACV,MAAM,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,cAAc,EAAE,SAAS,IAAI,EAAE,CAAC;QAEjE,OAAO,CACL,IAAI,CAAC,QAAQ;YACX,EAAE,MAAM,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;YACxD,EAAE,GAAG,CAAC,CAAC,IAAS,EAAE,EAAE;YAClB,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;YAC5C,OAAO;gBACL,GAAG,IAAI;gBACP,gBAAgB,EAAE,UAAU;aAC7B,CAAC;QACJ,CAAC,CAAC,IAAI,EAAE,CACX,CAAC;IACJ,CAAC;IAED,aAAa,CAAC,IAAS;QACrB,OAAO,IAAI,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC,KAAU,EAAE,EAAE,CAC3C,IAAI,EAAE,YAAY,EAAE,QAAQ,CAAC,KAAK,EAAE,QAAQ,CAAC,CAC9C,CAAC;IACJ,CAAC;IAED,iBAAiB;QACf,MAAM,gBAAgB,GAAG,IAAI,CAAC,OAAO,CAAC,cAAc,EAAE,eAAe,IAAI,EAAE,CAAC;QAE5E,OAAO,CACL,gBAAgB,CAAC,OAAO,CAAC,CAAC,OAAe,EAAE,EAAE;YAC3C,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;YAC1C,OAAO,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAC;QAC3C,CAAC,CAAC,IAAI,EAAE,CACT,CAAC;IACJ,CAAC;IAED,aAAa,CAAC,OAAe;QAC3B,OAAO,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC,KAAU,EAAE,EAAE,CAAC,KAAK,EAAE,GAAG,KAAK,OAAO,CAAC,CAAC;IACtE,CAAC;IAED,qBAAqB,CAAC,KAAU;QAC9B,OAAO,CACL,KAAK,EAAE,eAAe;YACpB,EAAE,GAAG,CAAC,CAAC,IAAS,EAAE,EAAE;YAClB,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,CAAC,CAAC;YAC1D,IAAI,YAAY,EAAE;gBAChB,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC;gBACpD,OAAO;oBACL,GAAG,YAAY;oBACf,gBAAgB,EAAE,UAAU;iBAC7B,CAAC;aACH;YACD,OAAO,IAAI,CAAC;QACd,CAAC,CAAC;aACD,MAAM,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,IAAI,KAAK,IAAI,CAAC,IAAI,EAAE,CAC9C,CAAC;IACJ,CAAC;IAED,YAAY,CAAC,MAAc;QACzB,OAAO,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,IAAI,EAAE,GAAG,KAAK,MAAM,CAAC,CAAC;IAClE,CAAC;IAED,kBAAkB,CAAC,eAAsB,EAAE,cAAqB;QAC9D,OAAO,CAAC,GAAG,eAAe,EAAE,GAAG,cAAc,CAAC,CAAC,MAAM,CACnD,CAAC,GAAU,EAAE,IAAS,EAAE,EAAE;YACxB,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,KAAK,IAAI,EAAE,GAAG,CAAC,EAAE;gBAC/C,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;aAChB;YACD,OAAO,GAAG,CAAC;QACb,CAAC,EACD,EAAE,CACH,CAAC;IACJ,CAAC;IAED,gBAAgB,CAAC,KAAY;QAC3B,IAAI,IAAI,CAAC,iBAAiB,KAAK,CAAC,CAAC,EAAE;YACjC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,iBAAiB,CAAC,GAAG,KAAK,CAAC;SACnD;QACD,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QAC7B,IAAI,KAAK,EAAE,MAAM,GAAG,CAAC,EAAE;YACrB,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;SAChC;IACH,CAAC;IAED,0BAA0B;QACxB,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE;YAC1B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;YACtB,OAAO;SACR;aAAM,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE,EAAE;YACpC,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;YAC9B,OAAO;SACR;QACD,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,CAAC,sBAAsB,CAAC,IAAI,EAAE,CAAC;IACrC,CAAC;IAED,cAAc;QACZ,OAAO,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IAED,iBAAiB;QACf,OAAO,IAAI,CAAC,eAAe,EAAE,gBAAgB,EAAE,KAAK,CAClD,CAAC,KAAU,EAAE,KAAa,EAAE,EAAE,CAC5B,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,EAAE,MAAM,GAAG,CAAC,CACnE,CAAC;IACJ,CAAC;IAED,aAAa,CAAC,IAAS;QACrB,MAAM,SAAS,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,CAAC;QACjC,0BAA0B;QAC1B,SAAS,CAAC,OAAO,CAAC,SAAS,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,CAAC;QAC3C,uBAAuB;QACvB,SAAS,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAC/B,OAAO,SAAS,CAAC,WAAW,EAAE,CAAC;IACjC,CAAC;IAED,oBAAoB;QAClB,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,mBAAmB,CAAC,sBAAsB;YACpE,IAAI,CAAC,aAAa,CAAC;QACrB,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,mBAAmB,CAAC,mBAAmB;YACjE,IAAI,CAAC,eAAe,CAAC;IACzB,CAAC;IAED,kBAAkB;QAChB,OAAO,IAAI,CAAC,eAAe,EAAE,gBAAgB;aAC1C,GAAG,CAAC,CAAC,KAAU,EAAE,KAAa,EAAE,EAAE;YACjC,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;YAC9C,OAAO,YAAY;gBACjB,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,KAAK,EAAE,YAAY,CAAC;gBAC/C,CAAC,CAAC,IAAI,CAAC;QACX,CAAC,CAAC;aACD,MAAM,CAAC,OAAO,CAAC,CAAC;IACrB,CAAC;IAED,mBAAmB,CAAC,KAAU,EAAE,YAAmB;QACjD,OAAO;YACL,QAAQ,EAAE,KAAK,EAAE,QAAQ,IAAI,EAAE;YAC/B,WAAW,EAAE,YAAY,CAAC,CAAC,CAAC,EAAE,GAAG,IAAI,EAAE;YACvC,QAAQ,EAAE,KAAK,EAAE,QAAQ,IAAI,EAAE;SAChC,CAAC;IACJ,CAAC;IAED,UAAU;QACR,MAAM,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC;QACnC,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,mBAAmB,CAAC,QAAQ,GAAG,aAAa,CAAC;QACzE,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,MAAM,eAAe,GAAG,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAClD,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,mBAAmB,CAAC,gBAAgB;YAC9D,eAAe,CAAC;QAClB,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,WAAW,GAAG,IAAI,CAAC,eAAe,EAAE,GAAG,CAAC;IACtE,CAAC;IAGD,aAAa,CAAC,KAAU;QACtB,MAAM,gBAAgB,GAAG;YACvB,KAAK,EAAE,KAAK;YACZ,KAAK,EAAE,eAAe;YACtB,KAAK,EAAE,IAAI,CAAC,eAAe;YAC3B,SAAS,EAAE,IAAI,CAAC,UAAU;YAC1B,OAAO,EAAE,IAAI,CAAC,iBAAiB;SAChC,CAAC;QACF,IAAI,CAAC,iBAAiB,CAAC,mBAAmB,CAAC,gBAAgB,CAAC,CAAC;IAC/D,CAAC;IAED,aAAa;QACX,IAAI,IAAI,CAAC,aAAa,KAAK,CAAC,EAAE;YAC5B,IAAI,CAAC,aAAa,GAAG,eAAe,CAAC,cAAc,CAAC;SACrD;QACD,IAAI,IAAI,CAAC,eAAe,KAAK,CAAC,EAAE;YAC9B,IAAI,CAAC,eAAe,GAAG,eAAe,CAAC,yBAAyB,CAAC;SAClE;IACH,CAAC;+GApVU,gBAAgB;mGAAhB,gBAAgB,qlBAEc,UAAU,6BC7BrD,k+YAoUA;;4FDzSa,gBAAgB;kBAL5B,SAAS;+BACE,cAAc;mIAKS,UAAU;sBAA1C,SAAS;uBAAC,oBAAoB;gBAE/B,MAAM;sBADL,SAAS;uBAAC,oBAAoB,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE;gBA0B3D,OAAO;sBAAf,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACO,gBAAgB;sBAA5B,KAAK;gBAQI,sBAAsB;sBAA/B,MAAM;gBACG,iBAAiB;sBAA1B,MAAM;gBAuRP,aAAa;sBADZ,YAAY;uBAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import {\n  Component,\n  ElementRef,\n  Input,\n  OnInit,\n  ViewChild,\n  Output,\n  EventEmitter,\n  HostListener,\n} from '@angular/core';\nimport { DatePickerComponent, IDatePickerConfig } from 'ng2-date-picker';\n\nimport {\n  REPORT_CASE,\n  HELPER_TEXT,\n  EMAIL_REMINDERS,\n  MONTH_NAMES,\n} from '../../constants/report-case.constants';\nimport { CommonService } from '../../../services/common.service';\nimport { FrequencyService } from '../../../sharedComponents/frequency/frequency.service';\nimport { ASSETS } from '../../../constants/assets.constants';\n\n@Component({\n  selector: 'app-due-date',\n  templateUrl: './due-date.component.html',\n  styleUrls: ['./due-date.component.less'],\n})\nexport class DueDateComponent implements OnInit {\n  @ViewChild('deadlineDatePicker') datePicker!: DatePickerComponent;\n  @ViewChild('deadlineDatePicker', { read: ElementRef, static: false })\n  ASSETS = ASSETS;\n  animation = true;\n  datePickerPopUp!: ElementRef;\n  datePickerOverlay = false;\n  dateConfig: IDatePickerConfig = {\n    disableKeypress: true,\n    format: 'DD MM YYYY',\n    unSelectOnClick: true,\n    openOnClick: false,\n    openOnFocus: false,\n    min: '',\n  };\n  commonService: any;\n  dueDateTexts = REPORT_CASE;\n  helperText = HELPER_TEXT;\n  assigneeClicked: boolean = false;\n  assigneeList: any[] = [];\n  assigneeData: { [key: number]: any[] } = {};\n  currentStageIndex: number = -1;\n  activeAssignee: any[] = [];\n  emailReminder: number = EMAIL_REMINDERS.email_reminder;\n  escalationEmail: number = EMAIL_REMINDERS.escalation_email_reminder;\n  showError: boolean = false;\n  showAssigneeError: boolean = false;\n\n  @Input() payload: any;\n  @Input() dueDate: any;\n  @Input() workflowDetails: any;\n  @Input() userList: any[] = [];\n  @Input() groupList: any[] = [];\n  @Input() mode: string = '';\n  @Input() set initialSelection(value: any) {\n    this.dueDate = value?.resolution_deadline?.due_date;\n    if (this.mode === 'EDIT') {\n      this.emailReminder = value?.resolution_deadline?.assignee_remind_before;\n      this.escalationEmail = value?.resolution_deadline?.owner_remind_before;\n    }\n  }\n\n  @Output() closeDueDateResolution = new EventEmitter();\n  @Output() closeDueDateEvent = new EventEmitter();\n\n  constructor(\n    private commonDateService: CommonService,\n    private frequencyService: FrequencyService\n  ) { }\n\n  ngOnInit(): void {\n    this.dateConfig.min = this.frequencyService.formatDate();\n    setTimeout(() => {\n      this.animation = false;\n    }, 300);\n    this.setAssigneeList();\n    this.initializeEditMode();\n  }\n\n  private initializeEditMode() {\n    if (!this.payload?.caseToWorkflow?.resolution_deadline?.due_date) return;\n\n    const deadline = this.payload.caseToWorkflow.resolution_deadline;\n    this.initializeDeadlineValues(deadline);\n    this.initializeStageAssignees(deadline);\n  }\n\n  private initializeDeadlineValues(deadline: any) {\n    this.dueDate = new Date(deadline?.due_date);\n    this.emailReminder =\n      deadline.assignee_remind_before || EMAIL_REMINDERS.email_reminder;\n    this.escalationEmail =\n      deadline.owner_remind_before || EMAIL_REMINDERS.escalation_email_reminder;\n  }\n\n  private initializeStageAssignees(deadline: any) {\n    if (!deadline?.stages_assignees?.length) return;\n\n    const stageAssigneeMap = this.createStageAssigneeMap(\n      deadline.stages_assignees\n    );\n    this.mapWorkflowStages(stageAssigneeMap);\n  }\n\n  private createStageAssigneeMap(stagesAssignees: any[]): Map<string, string> {\n    return new Map(\n      stagesAssignees.map((stage: any) => [stage?.stage_id, stage?.assignee_id])\n    );\n  }\n\n  private mapWorkflowStages(stageAssigneeMap: Map<string, string>) {\n    this.workflowDetails?.stages_assignees?.forEach(\n      (workflowStage: any, index: number) => {\n        const assigneeId = stageAssigneeMap?.get(workflowStage?.stage_id);\n        if (!assigneeId) return;\n\n        const assignee = this.assigneeList?.find(\n          (assignee: any) => assignee?._id === assigneeId\n        );\n        if (assignee) {\n          this.assigneeData[index] = [assignee];\n        }\n      }\n    );\n  }\n\n  openDatePicker() {\n    this.datePicker?.api?.open();\n    this.datePickerOverlay = true;\n  }\n\n  /**\n   * closes the date picker from policy form\n   */\n  closeDatePicker(evt: any) {\n    this.datePickerOverlay = false;\n\n    if (!evt) {\n      return;\n    }\n    if (evt?.date?.$d) {\n      let monthArray = [\n        'Jan',\n        'Feb',\n        'Mar',\n        'Apr',\n        'Jun',\n        'Jul',\n        'Aug',\n        'Sep',\n        'Oct',\n        'Nov',\n        'Dec',\n      ];\n      const dateValue = new Date(evt?.date?.$d).getDate();\n      const monthValue = monthArray[new Date(evt?.date?.$d).getMonth()];\n      const yearValue = new Date(evt?.date?.$d).getFullYear();\n      const dateStr = `${dateValue} ${monthValue} ${yearValue}`;\n    }\n    if (evt?.date?.$d) {\n      this.dueDate = new Date(evt.date.$d);\n      this.showError = false;\n    }\n    this.datePicker?.api?.close();\n  }\n\n  closeDueDate() {\n    this.closeDueDateEvent.emit();\n  }\n\n  activateSelector(active: boolean, stageIndex?: number) {\n    this.assigneeClicked = active;\n    if (active) {\n      this.currentStageIndex = stageIndex ?? -1;\n      this.activeAssignee =\n        this.currentStageIndex !== -1\n          ? this.assigneeData[this.currentStageIndex]\n          : [];\n    }\n  }\n\n  setAssigneeList() {\n    const directAssignees = this.getAssignees();\n    const groupAssignees = this.getGroupAssignees();\n    this.assigneeList = this.getUniqueAssignees(\n      directAssignees,\n      groupAssignees\n    );\n  }\n\n  getAssignees(): any[] {\n    const assigneeIds = this.payload.caseToWorkflow?.assignees || [];\n\n    return (\n      this.userList\n        ?.filter((user: any) => assigneeIds.includes(user?._id))\n        ?.map((user: any) => {\n          const userGroups = this.getUserGroups(user);\n          return {\n            ...user,\n            associatedGroups: userGroups,\n          };\n        }) || []\n    );\n  }\n\n  getUserGroups(user: any): any[] {\n    return this.groupList?.filter((group: any) =>\n      user?.usergroup_id?.includes(group?.group_id)\n    );\n  }\n\n  getGroupAssignees(): any[] {\n    const assigneeGroupIds = this.payload.caseToWorkflow?.assignees_group || [];\n\n    return (\n      assigneeGroupIds.flatMap((groupId: string) => {\n        const group = this.findGroupById(groupId);\n        return this.getAssigneesFromGroup(group);\n      }) || []\n    );\n  }\n\n  findGroupById(groupId: string): any {\n    return this.groupList?.find((group: any) => group?._id === groupId);\n  }\n\n  getAssigneesFromGroup(group: any): any[] {\n    return (\n      group?.associatedUsers\n        ?.map((user: any) => {\n          const userFromList = this.findUserById(user?.userId?._id);\n          if (userFromList) {\n            const userGroups = this.getUserGroups(userFromList);\n            return {\n              ...userFromList,\n              associatedGroups: userGroups,\n            };\n          }\n          return null;\n        })\n        .filter((user: any) => user !== null) || []\n    );\n  }\n\n  findUserById(userId: string): any {\n    return this.userList?.find((user: any) => user?._id === userId);\n  }\n\n  getUniqueAssignees(directAssignees: any[], groupAssignees: any[]): any[] {\n    return [...directAssignees, ...groupAssignees].reduce(\n      (acc: any[], user: any) => {\n        if (!acc.some((u: any) => u?._id === user?._id)) {\n          acc.push(user);\n        }\n        return acc;\n      },\n      []\n    );\n  }\n\n  selectedAssignee(event: any[]) {\n    if (this.currentStageIndex !== -1) {\n      this.assigneeData[this.currentStageIndex] = event;\n    }\n    this.assigneeClicked = false;\n    if (event?.length > 0) {\n      this.showAssigneeError = false;\n    }\n  }\n\n  saveCaseResolutionDeadline() {\n    if (!this.isDueDateValid()) {\n      this.showError = true;\n      return;\n    } else if (!this.areAssigneesValid()) {\n      this.showAssigneeError = true;\n      return;\n    }\n    this.showError = false;\n    this.showAssigneeError = false;\n    this.setPayload();\n    this.closeDueDateResolution.emit();\n  }\n\n  isDueDateValid(): boolean {\n    return !!this.dueDate;\n  }\n\n  areAssigneesValid(): boolean {\n    return this.workflowDetails?.stages_assignees?.every(\n      (stage: any, index: number) =>\n        this.assigneeData[index] && this.assigneeData[index]?.length > 0\n    );\n  }\n\n  formatDueDate(date: any): string {\n    const localDate = new Date(date);\n    // Add one day to the date\n    localDate.setDate(localDate.getDate() + 1);\n    // Set time to midnight\n    localDate.setHours(0, 0, 0, 0);\n    return localDate.toISOString();\n  }\n\n  setDeadlineReminders(): void {\n    this.payload.caseToWorkflow.resolution_deadline.assignee_remind_before =\n      this.emailReminder;\n    this.payload.caseToWorkflow.resolution_deadline.owner_remind_before =\n      this.escalationEmail;\n  }\n\n  setStagesAssignees(): any[] {\n    return this.workflowDetails?.stages_assignees\n      .map((stage: any, index: number) => {\n        const assigneeData = this.assigneeData[index];\n        return assigneeData\n          ? this.createStageAssignee(stage, assigneeData)\n          : null;\n      })\n      .filter(Boolean);\n  }\n\n  createStageAssignee(stage: any, assigneeData: any[]): any {\n    return {\n      stage_id: stage?.stage_id || '',\n      assignee_id: assigneeData[0]?._id || '',\n      due_date: stage?.due_date || '',\n    };\n  }\n\n  setPayload() {\n    const formattedDate = this.dueDate;\n    this.payload.caseToWorkflow.resolution_deadline.due_date = formattedDate;\n    this.setDeadlineReminders();\n    const stagesAssignees = this.setStagesAssignees();\n    this.payload.caseToWorkflow.resolution_deadline.stages_assignees =\n      stagesAssignees;\n    this.payload.caseToWorkflow.workflow_id = this.workflowDetails?._id;\n  }\n\n  @HostListener('document:click', ['$event'])\n  documentClick(event: any): void {\n    const datePickerObject = {\n      event: event,\n      class: 'deadline-date',\n      popup: this.datePickerPopUp,\n      component: this.datePicker,\n      overlay: this.datePickerOverlay,\n    };\n    this.commonDateService.handleDocumentClick(datePickerObject);\n  }\n\n  onInputChange() {\n    if (this.emailReminder === 0) {\n      this.emailReminder = EMAIL_REMINDERS.email_reminder;\n    }\n    if (this.escalationEmail === 0) {\n      this.escalationEmail = EMAIL_REMINDERS.escalation_email_reminder;\n    }\n  }\n}\n","<div class=\"configure-resolution\">\n  <div\n    class=\"configure-resolution-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\"\n  >\n    <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">\n      Configure Resolution Deadline & Stage Details\n    </div>\n  </div>\n  <div class=\"configure-resolution-body\">\n    <div class=\"configure-resolution-body-inner\">\n      <app-loader-inline *ngIf=\"false\"></app-loader-inline>\n      <app-no-data\n        *ngIf=\"false\"\n        [noDataImage]=\"ASSETS.search_data\"\n        [noDataText]=\"'No data to display'\"\n      ></app-no-data>\n\n      <ng-container>\n        <div\n          class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\n        >\n          SPECIFY THE DEADLINE TO CLOSE THIS CASE\n          <span class=\"required vx-fs-16 vx-fw-400\">*</span>\n        </div>\n        <div class=\"case-calendar vx-mb-3\">\n          <div class=\"case-calendar-inner vx-d-flex vx-align-center\">\n            <input\n              type=\"text\"\n              readonly\n              placeholder=\"{{\n                dueDateTexts.case_details.due_date.deadline_placeholder\n              }}\"\n              (click)=\"openDatePicker()\"\n              [value]=\"dueDate | date : 'dd MMM yyyy'\"\n              id=\"deadline-date\"\n            />\n            <i class=\"icons\">&#xe92d;</i>\n            <dp-date-picker\n              #deadlineDatePicker\n              (onSelect)=\"datePickerOverlay = false; closeDatePicker($event)\"\n              [config]=\"dateConfig\"\n              [(ngModel)]=\"dueDate\"\n            >\n            </dp-date-picker>\n            <div\n              class=\"vx-overlay\"\n              (click)=\"closeDatePicker($event)\"\n              *ngIf=\"datePickerOverlay\"\n            ></div>\n          </div>\n          <div *ngIf=\"showError\" class=\"errorMsg vx-fs-11 vx-lh-4 vx-mt-1\">\n            {{ dueDateTexts.errorMessage.dueDate }}\n          </div>\n        </div>\n        <div class=\"vx-d-flex vx-align-center vx-justify-between vx-mb-1\">\n          <div\n            class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-tt-uppercase\"\n          >\n            CONFIGURE DEADLINE & ASSIGNEE FOR EACH STAGE IN THE WORKFLOW\n            <span class=\"required vx-fs-16 vx-fw-400\">*</span>\n          </div>\n          <!-- <div class=\"toggle-area vx-d-flex vx-align-center\">\n            <app-cs-switch>Allow Reopening of Previous Stage</app-cs-switch>\n            <i\n              class=\"icons info vx-fs-12 vx-txt-blue vx-ml-2\"\n              [appTooltip]=\"\n                'If enabled, this option allows the assignee to revisit and reopen a previously completed stage. The stage will be reset, and the assigned user will need to complete it again.'\n              \"\n              placement=\"bottom-right\"\n              delay=\"0\"\n              type=\"white\"\n              [tooltipMandatory]=\"true\"\n              >&#xe91f;</i\n            >\n          </div> -->\n        </div>\n        <div class=\"configure-resolution-table\">\n          <div class=\"table-header\">\n            <div class=\"table-row\">\n              <div\n                class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\"\n              >\n                #\n              </div>\n              <div\n                class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center stage-name\"\n              >\n                STAGE NAME\n              </div>\n              <div\n                class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center status\"\n              >\n                TRANSITION STATUS\n                <i\n                  class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\n                  [appTooltip]=\"helperText.transition_status\"\n                  placement=\"bottom\"\n                  delay=\"0\"\n                  type=\"white\"\n                  [tooltipMandatory]=\"true\"\n                  >&#xe91f;</i\n                >\n              </div>\n              <div\n                class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center assignee\"\n              >\n                ASSIGNEE\n                <i\n                  class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\n                  [appTooltip]=\"helperText.assignee\"\n                  placement=\"bottom\"\n                  delay=\"0\"\n                  type=\"white\"\n                  [tooltipMandatory]=\"true\"\n                  >&#xe91f;</i\n                >\n              </div>\n              <div\n                class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center deadline\"\n              >\n                DEADLINE\n                <i\n                  class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\n                  [appTooltip]=\"helperText.deadline\"\n                  placement=\"bottom\"\n                  delay=\"0\"\n                  type=\"white\"\n                  [tooltipMandatory]=\"true\"\n                  >&#xe91f;</i\n                >\n              </div>\n            </div>\n          </div>\n          <div class=\"table-body\">\n            <div\n              class=\"table-row\"\n              *ngFor=\"\n                let data of workflowDetails?.stages_assignees;\n                let i = index\n              \"\n            >\n              <div\n                class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\"\n              >\n                <div\n                  class=\"sr-no vx-fs-13 vx-d-flex vx-align-center vx-justify-center\"\n                  [appTooltip]=\"i + 1\"\n                  placement=\"bottom\"\n                  delay=\"0\"\n                  type=\"black\"\n                  [tooltipMandatory]=\"true\"\n                >\n                  {{ i + 1 }}\n                </div>\n              </div>\n              <div\n                class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center stage-name\"\n              >\n                <div\n                  class=\"value vx-fs-13 vx-pr-2\"\n                  [appTooltip]=\"data?.name\"\n                  placement=\"bottom-left\"\n                  delay=\"0\"\n                  type=\"black\"\n                  [tooltipMandatory]=\"false\"\n                >\n                  {{ data?.name }}\n                </div>\n              </div>\n              <div\n                class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center status\"\n              >\n                <div class=\"value vx-fs-12\">\n                  {{ data?.status_transition?.fromName }}<br /><span\n                    class=\"vx-mr-1\"\n                    >To</span\n                  >{{ data?.status_transition?.toName }}\n                </div>\n              </div>\n              <div\n                class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center assignee\"\n                (click)=\"activateSelector(true, i)\"\n              >\n                <div\n                  *ngIf=\"!assigneeData[i]?.length\"\n                  class=\"select-box vx-d-flex vx-align-center vx-justify-between vx-pl-3 vx-pr-3\"\n                >\n                  <div class=\"value vx-fs-13\">Select a User</div>\n                  <i class=\"icons arrow vx-fs-12\">&#xe9e8;</i>\n                </div>\n                <div\n                  *ngIf=\"assigneeData[i]?.length > 0\"\n                  class=\"after-select-box vx-d-flex vx-align-center vx-justify-between vx-pl-3 vx-pr-2\"\n                >\n                  <div\n                    class=\"value-chip vx-fs-11 vx-pl-2 vx-pr-2 vx-lh-6\"\n                    [appTooltip]=\"assigneeData[i][0]?.member_name\"\n                    placement=\"bottom-left\"\n                    delay=\"0\"\n                    type=\"black\"\n                    [tooltipMandatory]=\"false\"\n                  >\n                    {{ assigneeData[i][0]?.member_name }}\n                  </div>\n                  <button\n                    (click)=\"activateSelector(true, i)\"\n                    class=\"edit-btn vx-fs-11 vx-fw-500 vx-txt-blue vx-tt-uppercase vx-p-0 vx-m-0 vx-d-flex vx-align-center\"\n                  >\n                    <i class=\"icons vx-fs-12 vx-txt-blue vx-mr-1\">&#xe9ba;</i\n                    >EDIT\n                  </button>\n                </div>\n              </div>\n              <div\n                class=\"table-column vx-pl-1 vx-pr-2 vx-d-flex vx-align-center deadline\"\n              >\n                <div\n                  class=\"case-calendar vx-d-flex vx-justify-between vx-pt-3 vx-pb-3\"\n                >\n                  <div\n                    class=\"case-calendar-inner vx-d-flex vx-align-center\"\n                    [class.disabled]=\"true\"\n                  >\n                    <input\n                      type=\"text\"\n                      readonly\n                      value=\"{{ dueDate | date : 'dd MMM yyyy' }}\"\n                      (click)=\"openDatePicker()\"\n                      id=\"stage-deadline-date\"\n                    />\n                    <i class=\"icons\">&#xe92d;</i>\n                    <dp-date-picker\n                      #datePicker\n                      (onSelect)=\"\n                        datePickerOverlay = false; closeDatePicker($event)\n                      \"\n                      [config]=\"dateConfig\"\n                    >\n                    </dp-date-picker>\n                    <div\n                      class=\"vx-overlay\"\n                      (click)=\"closeDatePicker($event)\"\n                      *ngIf=\"datePickerOverlay\"\n                    ></div>\n                  </div>\n                </div>\n              </div>\n            </div>\n          </div>\n          <div\n            *ngIf=\"showAssigneeError\"\n            class=\"errorMsg vx-fs-11 vx-lh-4 vx-mt-1\"\n          >\n            {{ dueDateTexts.errorMessage.stageAssignee }}\n          </div>\n        </div>\n        <div\n          class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\n        >\n          EMAIL REMINDER CONFIGURATION\n          <span class=\"required vx-fs-16 vx-fw-400\">*</span>\n        </div>\n        <div class=\"divider vx-mb-2\"></div>\n        <div\n          class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\n        >\n          REMINDER EMAIL\n        </div>\n        <div\n          class=\"email-configure-box vx-d-flex vx-align-center vx-flex-wrap vx-p-2 vx-pl-3 vx-pr-3 vx-mb-2\"\n        >\n          <div class=\"vx-fs-13 vx-mr-1\">\n            Send regular email reminders to the assignee\n          </div>\n          <input\n            type=\"number\"\n            [(ngModel)]=\"emailReminder\"\n            onkeydown=\"return event.key !== '.'\"\n            oninput=\"this.value = Math.abs(this.value)\"\n            (change)=\"onInputChange()\"\n          />\n          <div class=\"vx-fs-13 vx-ml-1\">\n            <span class=\"black-text\">days</span> before the stage deadline.\n          </div>\n        </div>\n        <div\n          class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\n        >\n          ESCALATION EMAIL\n        </div>\n        <div\n          class=\"email-configure-box vx-d-flex vx-align-center vx-flex-wrap vx-p-2 vx-pl-3 vx-pr-3 vx-mb-2\"\n        >\n          <div class=\"vx-fs-13 vx-mr-1\">\n            Send email escalation to the Case Owner\n          </div>\n          <input\n            type=\"number\"\n            [(ngModel)]=\"escalationEmail\"\n            onkeydown=\"return event.key !== '.'\"\n            oninput=\"this.value = Math.abs(this.value)\"\n            (change)=\"onInputChange()\"\n          />\n          <div class=\"vx-fs-13 vx-ml-1\">\n            <span class=\"black-text\">days</span> before the overall case\n            deadline, if the case is still open.\n          </div>\n        </div>\n      </ng-container>\n    </div>\n    <app-floating-bar\n      (closeList)=\"closeDueDate()\"\n      (closeEvent)=\"saveCaseResolutionDeadline()\"\n    ></app-floating-bar>\n  </div>\n</div>\n<app-assignee\n  *ngIf=\"assigneeClicked\"\n  [payload]=\"payload\"\n  [assigneeList]=\"assigneeList\"\n  [activeAssignee]=\"activeAssignee\"\n  (selectedAssigneeEvent)=\"selectedAssignee($event)\"\n  (closeEvent)=\"activateSelector(false)\"\n></app-assignee>\n"]}
336
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"due-date.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/report-a-case/components/due-date/due-date.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/report-a-case/components/due-date/due-date.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  Input,\n  OnInit,\n  ViewChild,\n  Output,\n  EventEmitter,\n  HostListener,\n} from '@angular/core';\nimport { DatePickerComponent, IDatePickerConfig } from 'ng2-date-picker';\nimport * as dayjs from 'dayjs';\n\nimport {\n  REPORT_CASE,\n  HELPER_TEXT,\n  EMAIL_REMINDERS,\n  MONTH_NAMES,\n  BANNER_CASE_RESOLUTION_DEADLINE_WARNING,\n} from '../../constants/report-case.constants';\nimport { CommonService } from '../../../services/common.service';\nimport { FrequencyService } from '../../../sharedComponents/frequency/frequency.service';\nimport { ASSETS } from '../../../constants/assets.constants';\n\n@Component({\n  selector: 'app-due-date',\n  templateUrl: './due-date.component.html',\n  styleUrls: ['./due-date.component.less'],\n})\nexport class DueDateComponent implements OnInit {\n  @ViewChild('deadlineDatePicker') datePicker!: DatePickerComponent;\n  @ViewChild('deadlineDatePicker', { read: ElementRef, static: false })\n  ASSETS = ASSETS;\n  animation = true;\n  datePickerPopUp!: ElementRef;\n  datePickerOverlay = false;\n  dateConfig: IDatePickerConfig = {\n    disableKeypress: true,\n    format: 'DD MM YYYY',\n    unSelectOnClick: true,\n    openOnClick: false,\n    openOnFocus: false,\n    min: '',\n  };\n  commonService: any;\n  dueDateTexts = REPORT_CASE;\n  helperText = HELPER_TEXT;\n  assigneeClicked: boolean = false;\n  assigneeList: any[] = [];\n  assigneeData: { [key: number]: any[] } = {};\n  currentStageIndex: number = -1;\n  activeAssignee: any[] = [];\n  emailReminder: number = EMAIL_REMINDERS.email_reminder;\n  escalationEmail: number = EMAIL_REMINDERS.escalation_email_reminder;\n  showError: boolean = false;\n  showAssigneeError: boolean = false;\n  public CaseDeadlineWarning = BANNER_CASE_RESOLUTION_DEADLINE_WARNING;\n\n  @Input() payload: any;\n  @Input() dueDate: any;\n  @Input() workflowDetails: any;\n  @Input() userList: any[] = [];\n  @Input() groupList: any[] = [];\n  @Input() mode: string = '';\n  @Input() set initialSelection(value: any) {\n    this.dueDate = value?.resolution_deadline?.due_date;\n    if (this.mode === 'EDIT') {\n      this.emailReminder = value?.resolution_deadline?.assignee_remind_before;\n      this.escalationEmail = value?.resolution_deadline?.owner_remind_before;\n    }\n  }\n  @Input() min: string = '';\n\n  @Output() closeDueDateResolution = new EventEmitter();\n  @Output() closeDueDateEvent = new EventEmitter();\n\n  constructor(\n    private commonDateService: CommonService,\n    private frequencyService: FrequencyService\n  ) { }\n\n  ngOnInit(): void {\n    this.setMinDate();\n    setTimeout(() => {\n      this.animation = false;\n    }, 300);\n    this.setAssigneeList();\n    this.initializeEditMode();\n  }\n\n  private initializeEditMode() {\n    if (!this.payload?.caseToWorkflow?.resolution_deadline?.due_date) return;\n\n    const deadline = this.payload.caseToWorkflow.resolution_deadline;\n    this.initializeDeadlineValues(deadline);\n    this.initializeStageAssignees(deadline);\n  }\n\n  private initializeDeadlineValues(deadline: any) {\n    this.dueDate = new Date(deadline?.due_date);\n    this.emailReminder =\n      deadline.assignee_remind_before || EMAIL_REMINDERS.email_reminder;\n    this.escalationEmail =\n      deadline.owner_remind_before || EMAIL_REMINDERS.escalation_email_reminder;\n  }\n\n  private initializeStageAssignees(deadline: any) {\n    if (!deadline?.stages_assignees?.length) return;\n\n    const stageAssigneeMap = this.createStageAssigneeMap(\n      deadline.stages_assignees\n    );\n    this.mapWorkflowStages(stageAssigneeMap);\n  }\n\n  private setMinDate() {\n    if (this.min) {\n      this.dateConfig.min = dayjs(this.min);\n    } else {\n      this.dateConfig.min = this.frequencyService.formatDate();\n    }\n  }\n\n  private createStageAssigneeMap(stagesAssignees: any[]): Map<string, string> {\n    return new Map(\n      stagesAssignees.map((stage: any) => [stage?.stage_id, stage?.assignee_id])\n    );\n  }\n\n  private mapWorkflowStages(stageAssigneeMap: Map<string, string>) {\n    this.workflowDetails?.stages_assignees?.forEach(\n      (workflowStage: any, index: number) => {\n        const assigneeId = stageAssigneeMap?.get(workflowStage?.stage_id);\n        if (!assigneeId) return;\n\n        const assignee = this.assigneeList?.find(\n          (assignee: any) => assignee?._id === assigneeId\n        );\n        if (assignee) {\n          this.assigneeData[index] = [assignee];\n        }\n      }\n    );\n  }\n\n  openDatePicker() {\n    this.datePicker?.api?.open();\n    this.datePickerOverlay = true;\n  }\n\n  /**\n   * closes the date picker from policy form\n   */\n  closeDatePicker(evt: any) {\n    this.datePickerOverlay = false;\n\n    if (!evt) {\n      return;\n    }\n    if (evt?.date?.$d) {\n      let monthArray = [\n        'Jan',\n        'Feb',\n        'Mar',\n        'Apr',\n        'Jun',\n        'Jul',\n        'Aug',\n        'Sep',\n        'Oct',\n        'Nov',\n        'Dec',\n      ];\n      const dateValue = new Date(evt?.date?.$d).getDate();\n      const monthValue = monthArray[new Date(evt?.date?.$d).getMonth()];\n      const yearValue = new Date(evt?.date?.$d).getFullYear();\n      const dateStr = `${dateValue} ${monthValue} ${yearValue}`;\n    }\n    if (evt?.date?.$d) {\n      this.dueDate = new Date(evt.date.$d);\n      this.showError = false;\n    }\n    this.datePicker?.api?.close();\n  }\n\n  closeDueDate() {\n    this.closeDueDateEvent.emit();\n  }\n\n  activateSelector(active: boolean, stageIndex?: number) {\n    this.assigneeClicked = active;\n    if (active) {\n      this.currentStageIndex = stageIndex ?? -1;\n      this.activeAssignee =\n        this.currentStageIndex !== -1\n          ? this.assigneeData[this.currentStageIndex]\n          : [];\n    }\n  }\n\n  setAssigneeList() {\n    const directAssignees = this.getAssignees();\n    const groupAssignees = this.getGroupAssignees();\n    this.assigneeList = this.getUniqueAssignees(\n      directAssignees,\n      groupAssignees\n    );\n  }\n\n  getAssignees(): any[] {\n    const assigneeIds = this.payload.caseToWorkflow?.assignees || [];\n\n    return (\n      this.userList\n        ?.filter((user: any) => assigneeIds.includes(user?._id))\n        ?.map((user: any) => {\n          const userGroups = this.getUserGroups(user);\n          return {\n            ...user,\n            associatedGroups: userGroups,\n          };\n        }) || []\n    );\n  }\n\n  getUserGroups(user: any): any[] {\n    return this.groupList?.filter((group: any) =>\n      user?.usergroup_id?.includes(group?.group_id)\n    );\n  }\n\n  getGroupAssignees(): any[] {\n    const assigneeGroupIds = this.payload.caseToWorkflow?.assignees_group || [];\n\n    return (\n      assigneeGroupIds.flatMap((groupId: string) => {\n        const group = this.findGroupById(groupId);\n        return this.getAssigneesFromGroup(group);\n      }) || []\n    );\n  }\n\n  findGroupById(groupId: string): any {\n    return this.groupList?.find((group: any) => group?._id === groupId);\n  }\n\n  getAssigneesFromGroup(group: any): any[] {\n    return (\n      group?.associatedUsers\n        ?.map((user: any) => {\n          const userFromList = this.findUserById(user?.userId?._id);\n          if (userFromList) {\n            const userGroups = this.getUserGroups(userFromList);\n            return {\n              ...userFromList,\n              associatedGroups: userGroups,\n            };\n          }\n          return null;\n        })\n        .filter((user: any) => user !== null) || []\n    );\n  }\n\n  findUserById(userId: string): any {\n    return this.userList?.find((user: any) => user?._id === userId);\n  }\n\n  getUniqueAssignees(directAssignees: any[], groupAssignees: any[]): any[] {\n    return [...directAssignees, ...groupAssignees].reduce(\n      (acc: any[], user: any) => {\n        if (!acc.some((u: any) => u?._id === user?._id)) {\n          acc.push(user);\n        }\n        return acc;\n      },\n      []\n    );\n  }\n\n  selectedAssignee(event: any[]) {\n    if (this.currentStageIndex !== -1) {\n      this.assigneeData[this.currentStageIndex] = event;\n    }\n    this.assigneeClicked = false;\n    if (event?.length > 0) {\n      this.showAssigneeError = false;\n    }\n  }\n\n  saveCaseResolutionDeadline() {\n    if (!this.isDueDateValid()) {\n      this.showError = true;\n      return;\n    } else if (!this.areAssigneesValid()) {\n      this.showAssigneeError = true;\n      return;\n    }\n    this.showError = false;\n    this.showAssigneeError = false;\n    this.setPayload();\n    this.closeDueDateResolution.emit();\n  }\n\n  isDueDateValid(): boolean {\n    return !!this.dueDate;\n  }\n\n  areAssigneesValid(): boolean {\n    return this.workflowDetails?.stages_assignees?.every(\n      (stage: any, index: number) =>\n        this.assigneeData[index] && this.assigneeData[index]?.length > 0\n    );\n  }\n\n  formatDueDate(date: any): string {\n    const localDate = new Date(date);\n    // Add one day to the date\n    localDate.setDate(localDate.getDate() + 1);\n    // Set time to midnight\n    localDate.setHours(0, 0, 0, 0);\n    return localDate.toISOString();\n  }\n\n  setDeadlineReminders(): void {\n    this.payload.caseToWorkflow.resolution_deadline.assignee_remind_before =\n      this.emailReminder;\n    this.payload.caseToWorkflow.resolution_deadline.owner_remind_before =\n      this.escalationEmail;\n  }\n\n  setStagesAssignees(): any[] {\n    return this.workflowDetails?.stages_assignees\n      .map((stage: any, index: number) => {\n        const assigneeData = this.assigneeData[index];\n        return assigneeData\n          ? this.createStageAssignee(stage, assigneeData)\n          : null;\n      })\n      .filter(Boolean);\n  }\n\n  createStageAssignee(stage: any, assigneeData: any[]): any {\n    return {\n      stage_id: stage?.stage_id || '',\n      assignee_id: assigneeData[0]?._id || '',\n      due_date: stage?.due_date || '',\n    };\n  }\n\n  setPayload() {\n    const formattedDate = this.dueDate;\n    this.payload.caseToWorkflow.resolution_deadline.due_date = formattedDate;\n    this.setDeadlineReminders();\n    const stagesAssignees = this.setStagesAssignees();\n    this.payload.caseToWorkflow.resolution_deadline.stages_assignees =\n      stagesAssignees;\n    this.payload.caseToWorkflow.workflow_id = this.workflowDetails?._id;\n  }\n\n  @HostListener('document:click', ['$event'])\n  documentClick(event: any): void {\n    const datePickerObject = {\n      event: event,\n      class: 'deadline-date',\n      popup: this.datePickerPopUp,\n      component: this.datePicker,\n      overlay: this.datePickerOverlay,\n    };\n    this.commonDateService.handleDocumentClick(datePickerObject);\n  }\n\n  onInputChange() {\n    if (this.emailReminder === 0) {\n      this.emailReminder = EMAIL_REMINDERS.email_reminder;\n    }\n    if (this.escalationEmail === 0) {\n      this.escalationEmail = EMAIL_REMINDERS.escalation_email_reminder;\n    }\n  }\n}\n","<div class=\"configure-resolution\">\n  <div\n    class=\"configure-resolution-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\"\n  >\n    <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">\n      Configure Resolution Deadline & Stage Details\n    </div>\n  </div>\n  <div class=\"configure-resolution-body\">\n    <div class=\"configure-resolution-body-inner\">\n      <app-loader-inline *ngIf=\"false\"></app-loader-inline>\n      <app-no-data\n        *ngIf=\"false\"\n        [noDataImage]=\"ASSETS.search_data\"\n        [noDataText]=\"'No data to display'\"\n      ></app-no-data>\n\n      <ng-container>\n        <div\n          class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\n        >\n          SPECIFY THE DEADLINE TO CLOSE THIS CASE\n          <span class=\"required vx-fs-16 vx-fw-400\">*</span>\n        </div>\n        <app-banner *ngIf=\"mode === 'EDIT'\">\n          <p banner>\n            {{ CaseDeadlineWarning }}\n          </p>\n        </app-banner>\n        <div class=\"case-calendar vx-mb-3\">\n          <div class=\"case-calendar-inner vx-d-flex vx-align-center\">\n            <input\n              type=\"text\"\n              readonly\n              placeholder=\"{{\n                dueDateTexts.case_details.due_date.deadline_placeholder\n              }}\"\n              (click)=\"openDatePicker()\"\n              [value]=\"dueDate | date : 'dd MMM yyyy'\"\n              id=\"deadline-date\"\n            />\n            <i class=\"icons\">&#xe92d;</i>\n            <dp-date-picker\n              #deadlineDatePicker\n              (onSelect)=\"datePickerOverlay = false; closeDatePicker($event)\"\n              [config]=\"dateConfig\"\n              [(ngModel)]=\"dueDate\"\n            >\n            </dp-date-picker>\n            <div\n              class=\"vx-overlay\"\n              (click)=\"closeDatePicker($event)\"\n              *ngIf=\"datePickerOverlay\"\n            ></div>\n          </div>\n          <div *ngIf=\"showError\" class=\"errorMsg vx-fs-11 vx-lh-4 vx-mt-1\">\n            {{ dueDateTexts.errorMessage.dueDate }}\n          </div>\n        </div>\n        <div class=\"vx-d-flex vx-align-center vx-justify-between vx-mb-1\">\n          <div\n            class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-tt-uppercase\"\n          >\n            CONFIGURE DEADLINE & ASSIGNEE FOR EACH STAGE IN THE WORKFLOW\n            <span class=\"required vx-fs-16 vx-fw-400\">*</span>\n          </div>\n          <!-- <div class=\"toggle-area vx-d-flex vx-align-center\">\n            <app-cs-switch>Allow Reopening of Previous Stage</app-cs-switch>\n            <i\n              class=\"icons info vx-fs-12 vx-txt-blue vx-ml-2\"\n              [appTooltip]=\"\n                'If enabled, this option allows the assignee to revisit and reopen a previously completed stage. The stage will be reset, and the assigned user will need to complete it again.'\n              \"\n              placement=\"bottom-right\"\n              delay=\"0\"\n              type=\"white\"\n              [tooltipMandatory]=\"true\"\n              >&#xe91f;</i\n            >\n          </div> -->\n        </div>\n        <div class=\"configure-resolution-table\">\n          <div class=\"table-header\">\n            <div class=\"table-row\">\n              <div\n                class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\"\n              >\n                #\n              </div>\n              <div\n                class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center stage-name\"\n              >\n                STAGE NAME\n              </div>\n              <div\n                class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center status\"\n              >\n                TRANSITION STATUS\n                <i\n                  class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\n                  [appTooltip]=\"helperText.transition_status\"\n                  placement=\"bottom\"\n                  delay=\"0\"\n                  type=\"white\"\n                  [tooltipMandatory]=\"true\"\n                  >&#xe91f;</i\n                >\n              </div>\n              <div\n                class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center assignee\"\n              >\n                ASSIGNEE\n                <i\n                  class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\n                  [appTooltip]=\"helperText.assignee\"\n                  placement=\"bottom\"\n                  delay=\"0\"\n                  type=\"white\"\n                  [tooltipMandatory]=\"true\"\n                  >&#xe91f;</i\n                >\n              </div>\n              <div\n                class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center deadline\"\n              >\n                DEADLINE\n                <i\n                  class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\n                  [appTooltip]=\"helperText.deadline\"\n                  placement=\"bottom\"\n                  delay=\"0\"\n                  type=\"white\"\n                  [tooltipMandatory]=\"true\"\n                  >&#xe91f;</i\n                >\n              </div>\n            </div>\n          </div>\n          <div class=\"table-body\">\n            <div\n              class=\"table-row\"\n              *ngFor=\"\n                let data of workflowDetails?.stages_assignees;\n                let i = index\n              \"\n            >\n              <div\n                class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\"\n              >\n                <div\n                  class=\"sr-no vx-fs-13 vx-d-flex vx-align-center vx-justify-center\"\n                  [appTooltip]=\"i + 1\"\n                  placement=\"bottom\"\n                  delay=\"0\"\n                  type=\"black\"\n                  [tooltipMandatory]=\"true\"\n                >\n                  {{ i + 1 }}\n                </div>\n              </div>\n              <div\n                class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center stage-name\"\n              >\n                <div\n                  class=\"value vx-fs-13 vx-pr-2\"\n                  [appTooltip]=\"data?.name\"\n                  placement=\"bottom-left\"\n                  delay=\"0\"\n                  type=\"black\"\n                  [tooltipMandatory]=\"false\"\n                >\n                  {{ data?.name }}\n                </div>\n              </div>\n              <div\n                class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center status\"\n              >\n                <div class=\"value vx-fs-12\">\n                  {{ data?.status_transition?.fromName }}<br /><span\n                    class=\"vx-mr-1\"\n                    >To</span\n                  >{{ data?.status_transition?.toName }}\n                </div>\n              </div>\n              <div\n                class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center assignee\"\n                (click)=\"activateSelector(true, i)\"\n              >\n                <div\n                  *ngIf=\"!assigneeData[i]?.length\"\n                  class=\"select-box vx-d-flex vx-align-center vx-justify-between vx-pl-3 vx-pr-3\"\n                >\n                  <div class=\"value vx-fs-13\">Select a User</div>\n                  <i class=\"icons arrow vx-fs-12\">&#xe9e8;</i>\n                </div>\n                <div\n                  *ngIf=\"assigneeData[i]?.length > 0\"\n                  class=\"after-select-box vx-d-flex vx-align-center vx-justify-between vx-pl-3 vx-pr-2\"\n                >\n                  <div\n                    class=\"value-chip vx-fs-11 vx-pl-2 vx-pr-2 vx-lh-6\"\n                    [appTooltip]=\"assigneeData[i][0]?.member_name\"\n                    placement=\"bottom-left\"\n                    delay=\"0\"\n                    type=\"black\"\n                    [tooltipMandatory]=\"false\"\n                  >\n                    {{ assigneeData[i][0]?.member_name }}\n                  </div>\n                  <button\n                    (click)=\"activateSelector(true, i)\"\n                    class=\"edit-btn vx-fs-11 vx-fw-500 vx-txt-blue vx-tt-uppercase vx-p-0 vx-m-0 vx-d-flex vx-align-center\"\n                  >\n                    <i class=\"icons vx-fs-12 vx-txt-blue vx-mr-1\">&#xe9ba;</i\n                    >EDIT\n                  </button>\n                </div>\n              </div>\n              <div\n                class=\"table-column vx-pl-1 vx-pr-2 vx-d-flex vx-align-center deadline\"\n              >\n                <div\n                  class=\"case-calendar vx-d-flex vx-justify-between vx-pt-3 vx-pb-3\"\n                >\n                  <div\n                    class=\"case-calendar-inner vx-d-flex vx-align-center\"\n                    [class.disabled]=\"true\"\n                  >\n                    <input\n                      type=\"text\"\n                      readonly\n                      value=\"{{ dueDate | date : 'dd MMM yyyy' }}\"\n                      (click)=\"openDatePicker()\"\n                      id=\"stage-deadline-date\"\n                    />\n                    <i class=\"icons\">&#xe92d;</i>\n                    <dp-date-picker\n                      #datePicker\n                      (onSelect)=\"\n                        datePickerOverlay = false; closeDatePicker($event)\n                      \"\n                      [config]=\"dateConfig\"\n                    >\n                    </dp-date-picker>\n                    <div\n                      class=\"vx-overlay\"\n                      (click)=\"closeDatePicker($event)\"\n                      *ngIf=\"datePickerOverlay\"\n                    ></div>\n                  </div>\n                </div>\n              </div>\n            </div>\n          </div>\n          <div\n            *ngIf=\"showAssigneeError\"\n            class=\"errorMsg vx-fs-11 vx-lh-4 vx-mt-1\"\n          >\n            {{ dueDateTexts.errorMessage.stageAssignee }}\n          </div>\n        </div>\n        <div\n          class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\n        >\n          EMAIL REMINDER CONFIGURATION\n          <span class=\"required vx-fs-16 vx-fw-400\">*</span>\n        </div>\n        <div class=\"divider vx-mb-2\"></div>\n        <div\n          class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\n        >\n          REMINDER EMAIL\n        </div>\n        <div\n          class=\"email-configure-box vx-d-flex vx-align-center vx-flex-wrap vx-p-2 vx-pl-3 vx-pr-3 vx-mb-2\"\n        >\n          <div class=\"vx-fs-13 vx-mr-1\">\n            Send regular email reminders to the assignee\n          </div>\n          <input\n            type=\"number\"\n            [(ngModel)]=\"emailReminder\"\n            onkeydown=\"return event.key !== '.'\"\n            oninput=\"this.value = Math.abs(this.value)\"\n            (change)=\"onInputChange()\"\n          />\n          <div class=\"vx-fs-13 vx-ml-1\">\n            <span class=\"black-text\">days</span> before the stage deadline.\n          </div>\n        </div>\n        <div\n          class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\n        >\n          ESCALATION EMAIL\n        </div>\n        <div\n          class=\"email-configure-box vx-d-flex vx-align-center vx-flex-wrap vx-p-2 vx-pl-3 vx-pr-3 vx-mb-2\"\n        >\n          <div class=\"vx-fs-13 vx-mr-1\">\n            Send email escalation to the Case Owner\n          </div>\n          <input\n            type=\"number\"\n            [(ngModel)]=\"escalationEmail\"\n            onkeydown=\"return event.key !== '.'\"\n            oninput=\"this.value = Math.abs(this.value)\"\n            (change)=\"onInputChange()\"\n          />\n          <div class=\"vx-fs-13 vx-ml-1\">\n            <span class=\"black-text\">days</span> before the overall case\n            deadline, if the case is still open.\n          </div>\n        </div>\n      </ng-container>\n    </div>\n    <app-floating-bar\n      (closeList)=\"closeDueDate()\"\n      (closeEvent)=\"saveCaseResolutionDeadline()\"\n    ></app-floating-bar>\n  </div>\n</div>\n<app-assignee\n  *ngIf=\"assigneeClicked\"\n  [payload]=\"payload\"\n  [assigneeList]=\"assigneeList\"\n  [activeAssignee]=\"activeAssignee\"\n  (selectedAssigneeEvent)=\"selectedAssignee($event)\"\n  (closeEvent)=\"activateSelector(false)\"\n></app-assignee>\n"]}
@@ -1,4 +1,5 @@
1
1
  import { Component, ElementRef, HostListener, Input, ViewChild, } from '@angular/core';
2
+ import * as moment from 'moment';
2
3
  import { ASSETS } from '../../../constants/assets.constants';
3
4
  import { FIELD_SELECTOR, REPORT_CASE } from '../../constants/report-case.constants';
4
5
  import * as i0 from "@angular/core";
@@ -20,6 +21,7 @@ export class ReportDateComponent {
20
21
  unSelectOnClick: true,
21
22
  openOnClick: false,
22
23
  openOnFocus: false,
24
+ max: moment(),
23
25
  };
24
26
  this.fieldSelector = FIELD_SELECTOR;
25
27
  this.fieldSelected = '';
@@ -179,4 +181,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
179
181
  type: HostListener,
180
182
  args: ['document:click', ['$event']]
181
183
  }] } });
182
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"report-date.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/report-a-case/components/report-date/report-date.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  HostListener,\n  Input,\n  ViewChild,\n} from '@angular/core';\nimport { ASSETS } from '../../../constants/assets.constants';\nimport { DatePickerComponent } from 'ng2-date-picker';\nimport { FIELD_SELECTOR, REPORT_CASE } from '../../constants/report-case.constants';\nimport { CommonService } from '../../../services/common.service';\n\n@Component({\n  selector: 'app-report-date',\n  template: `\n    <app-field-holder\n      [image]=\"ASSETS.when\"\n      [disabled]=\"fieldSelector?.includes(fieldSelected)\"\n      [checked]=\"payload?.occurrence_date\"\n    >\n      <ng-container field>\n        <app-vc-label\n          label\n          [labelText]=\"reportTexts.case_details.when.title\"\n          [required]=\"true\"\n        >\n        </app-vc-label>\n        <div class=\"date-time-picker\">\n          <div class=\"picker-group\">\n            <input\n              type=\"text\"\n              readonly\n              [placeholder]=\"reportTexts.case_details.when.placeholder\"\n              [value]=\"payload?.occurrence_date | date : 'dd MMM yyyy'\"\n              (click)=\"openDatePicker()\"\n              id=\"effective-date\"\n            />\n            <i class=\"icons\">&#xe92d;</i>\n            <dp-date-picker\n              #datePicker\n              (onSelect)=\"datePickerOverlay = false; closeDatePicker($event)\"\n              [config]=\"dateConfig\"\n              [(ngModel)]=\"payload.occurrence_date\"\n            >\n            </dp-date-picker>\n            <div\n              class=\"vx-overlay\"\n              (click)=\"closeDatePicker($event)\"\n              *ngIf=\"datePickerOverlay\"\n            ></div>\n          </div>\n        </div>\n        <p *ngIf=\"validationError.reportDate.isError\" class=\"error-message\">\n          {{ validationError.reportDate.message }}\n        </p>\n      </ng-container>\n    </app-field-holder>\n  `,\n  styleUrls: ['./report-date.component.less', '../../../forms.less'],\n})\nexport class ReportDateComponent {\n  ASSETS = ASSETS;\n  reportTexts = REPORT_CASE;\n\n  datePickerOverlay = false;\n  dateConfig = {\n    disableKeypress: true,\n    format: 'DD MM YYYY',\n    unSelectOnClick: true,\n    openOnClick: false,\n    openOnFocus: false,\n  };\n  fieldSelector = FIELD_SELECTOR;\n\n  @Input() payload: any;\n  @Input() fieldSelected: string = '';\n  @Input() validationError: any;\n\n  constructor(private commonService: CommonService) { }\n\n  @ViewChild('datePicker') datePicker!: DatePickerComponent;\n  @ViewChild('datePicker', { read: ElementRef, static: false })\n  datePickerPopUp!: ElementRef;\n\n  openDatePicker() {\n    this.datePicker?.api?.open();\n    this.datePickerOverlay = true;\n  }\n\n  closeDatePicker(evt: any) {\n    this.datePickerOverlay = false;\n\n    if (!evt) {\n      return;\n    }\n    if (evt?.date?.$d) {\n      let monthArray = [\n        'Jan',\n        'Feb',\n        'Mar',\n        'Apr',\n        'Jun',\n        'Jul',\n        'Aug',\n        'Sep',\n        'Oct',\n        'Nov',\n        'Dec',\n      ];\n      const dateValue = new Date(evt?.date?.$d).getDate();\n      const monthValue = monthArray[new Date(evt?.date?.$d).getMonth()];\n      const yearValue = new Date(evt?.date?.$d).getFullYear();\n      const dateStr = `${dateValue} ${monthValue} ${yearValue}`;\n    }\n    if (evt?.date?.$d) {\n      this.payload.occurrence_date = evt?.date?.$d;\n    }\n    this.datePicker?.api?.close();\n    this.resetValidationErrors();\n  }\n\n  resetValidationErrors() {\n    this.validationError.reportDate.isError = false;\n  }\n\n  @HostListener('document:click', ['$event'])\n  documentClick(event: any): void {\n    const datePickerObject = {\n      event: event,\n      class: 'effective-date',\n      popup: this.datePickerPopUp,\n      component: this.datePicker,\n      overlay: this.datePickerOverlay,\n    };\n    this.commonService.handleDocumentClick(datePickerObject);\n  }\n}\n"]}
184
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"report-date.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/report-a-case/components/report-date/report-date.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  HostListener,\n  Input,\n  ViewChild,\n} from '@angular/core';\n\nimport { DatePickerComponent } from 'ng2-date-picker';\nimport * as moment from 'moment';\n\nimport { ASSETS } from '../../../constants/assets.constants';\nimport { FIELD_SELECTOR, REPORT_CASE } from '../../constants/report-case.constants';\n\nimport { CommonService } from '../../../services/common.service';\n\n@Component({\n  selector: 'app-report-date',\n  template: `\n    <app-field-holder\n      [image]=\"ASSETS.when\"\n      [disabled]=\"fieldSelector?.includes(fieldSelected)\"\n      [checked]=\"payload?.occurrence_date\"\n    >\n      <ng-container field>\n        <app-vc-label\n          label\n          [labelText]=\"reportTexts.case_details.when.title\"\n          [required]=\"true\"\n        >\n        </app-vc-label>\n        <div class=\"date-time-picker\">\n          <div class=\"picker-group\">\n            <input\n              type=\"text\"\n              readonly\n              [placeholder]=\"reportTexts.case_details.when.placeholder\"\n              [value]=\"payload?.occurrence_date | date : 'dd MMM yyyy'\"\n              (click)=\"openDatePicker()\"\n              id=\"effective-date\"\n            />\n            <i class=\"icons\">&#xe92d;</i>\n            <dp-date-picker\n              #datePicker\n              (onSelect)=\"datePickerOverlay = false; closeDatePicker($event)\"\n              [config]=\"dateConfig\"\n              [(ngModel)]=\"payload.occurrence_date\"\n            >\n            </dp-date-picker>\n            <div\n              class=\"vx-overlay\"\n              (click)=\"closeDatePicker($event)\"\n              *ngIf=\"datePickerOverlay\"\n            ></div>\n          </div>\n        </div>\n        <p *ngIf=\"validationError.reportDate.isError\" class=\"error-message\">\n          {{ validationError.reportDate.message }}\n        </p>\n      </ng-container>\n    </app-field-holder>\n  `,\n  styleUrls: ['./report-date.component.less', '../../../forms.less'],\n})\nexport class ReportDateComponent {\n  ASSETS = ASSETS;\n  reportTexts = REPORT_CASE;\n\n  datePickerOverlay = false;\n  dateConfig = {\n    disableKeypress: true,\n    format: 'DD MM YYYY',\n    unSelectOnClick: true,\n    openOnClick: false,\n    openOnFocus: false,\n    max: moment(),\n  };\n  fieldSelector = FIELD_SELECTOR;\n\n  @Input() payload: any;\n  @Input() fieldSelected: string = '';\n  @Input() validationError: any;\n\n  constructor(private commonService: CommonService) { }\n\n  @ViewChild('datePicker') datePicker!: DatePickerComponent;\n  @ViewChild('datePicker', { read: ElementRef, static: false })\n  datePickerPopUp!: ElementRef;\n\n  openDatePicker() {\n    this.datePicker?.api?.open();\n    this.datePickerOverlay = true;\n  }\n\n  closeDatePicker(evt: any) {\n    this.datePickerOverlay = false;\n\n    if (!evt) {\n      return;\n    }\n    if (evt?.date?.$d) {\n      let monthArray = [\n        'Jan',\n        'Feb',\n        'Mar',\n        'Apr',\n        'Jun',\n        'Jul',\n        'Aug',\n        'Sep',\n        'Oct',\n        'Nov',\n        'Dec',\n      ];\n      const dateValue = new Date(evt?.date?.$d).getDate();\n      const monthValue = monthArray[new Date(evt?.date?.$d).getMonth()];\n      const yearValue = new Date(evt?.date?.$d).getFullYear();\n      const dateStr = `${dateValue} ${monthValue} ${yearValue}`;\n    }\n    if (evt?.date?.$d) {\n      this.payload.occurrence_date = evt?.date?.$d;\n    }\n    this.datePicker?.api?.close();\n    this.resetValidationErrors();\n  }\n\n  resetValidationErrors() {\n    this.validationError.reportDate.isError = false;\n  }\n\n  @HostListener('document:click', ['$event'])\n  documentClick(event: any): void {\n    const datePickerObject = {\n      event: event,\n      class: 'effective-date',\n      popup: this.datePickerPopUp,\n      component: this.datePicker,\n      overlay: this.datePickerOverlay,\n    };\n    this.commonService.handleDocumentClick(datePickerObject);\n  }\n}\n"]}
@@ -4,6 +4,7 @@ export const API_URLS = {
4
4
  GET_ALL_CATEGORIES: `/category/?fetch_all=true`,
5
5
  GET_STAGE_DETAILS: `/getWorkflow`,
6
6
  GET_CASE_OWNERS: `organizationMembers&manageCase=true&workflow_id=`,
7
- ADD_CASE_TO_WORKFLOW: `/add-to-workflow`
7
+ ADD_CASE_TO_WORKFLOW: `/add-to-workflow`,
8
+ VALIDATE_CASE_DEADLINE: `/validDeadline/`
8
9
  };
9
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLmNvbnN0YW50cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Z4LXdvcmtmbG93LWVuZ2luZS9zcmMvbGliL3JlcG9ydC1hLWNhc2UvY29uc3RhbnRzL2FwaS5jb25zdGFudHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0sUUFBUSxHQUFHO0lBQ3BCLGFBQWEsRUFBRSx1QkFBdUI7SUFDdEMsa0JBQWtCLEVBQUUsMkJBQTJCO0lBQy9DLGtCQUFrQixFQUFFLDJCQUEyQjtJQUMvQyxpQkFBaUIsRUFBRSxjQUFjO0lBQ2pDLGVBQWUsRUFBRSxrREFBa0Q7SUFDbkUsb0JBQW9CLEVBQUUsa0JBQWtCO0NBQzNDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgQVBJX1VSTFMgPSB7XG4gICAgR0VUX0FMTF9UWVBFUzogYC90eXBlLz9mZXRjaF9hbGw9dHJ1ZWAsXG4gICAgR0VUX0FMTF9QUklPUklUSUVTOiBgL3ByaW9yaXR5Lz9mZXRjaF9hbGw9dHJ1ZWAsXG4gICAgR0VUX0FMTF9DQVRFR09SSUVTOiBgL2NhdGVnb3J5Lz9mZXRjaF9hbGw9dHJ1ZWAsXG4gICAgR0VUX1NUQUdFX0RFVEFJTFM6IGAvZ2V0V29ya2Zsb3dgLFxuICAgIEdFVF9DQVNFX09XTkVSUzogYG9yZ2FuaXphdGlvbk1lbWJlcnMmbWFuYWdlQ2FzZT10cnVlJndvcmtmbG93X2lkPWAsXG4gICAgQUREX0NBU0VfVE9fV09SS0ZMT1c6IGAvYWRkLXRvLXdvcmtmbG93YFxufTtcbiJdfQ==
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLmNvbnN0YW50cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Z4LXdvcmtmbG93LWVuZ2luZS9zcmMvbGliL3JlcG9ydC1hLWNhc2UvY29uc3RhbnRzL2FwaS5jb25zdGFudHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0sUUFBUSxHQUFHO0lBQ3BCLGFBQWEsRUFBRSx1QkFBdUI7SUFDdEMsa0JBQWtCLEVBQUUsMkJBQTJCO0lBQy9DLGtCQUFrQixFQUFFLDJCQUEyQjtJQUMvQyxpQkFBaUIsRUFBRSxjQUFjO0lBQ2pDLGVBQWUsRUFBRSxrREFBa0Q7SUFDbkUsb0JBQW9CLEVBQUUsa0JBQWtCO0lBQ3hDLHNCQUFzQixFQUFFLGlCQUFpQjtDQUM1QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IEFQSV9VUkxTID0ge1xuICAgIEdFVF9BTExfVFlQRVM6IGAvdHlwZS8/ZmV0Y2hfYWxsPXRydWVgLFxuICAgIEdFVF9BTExfUFJJT1JJVElFUzogYC9wcmlvcml0eS8/ZmV0Y2hfYWxsPXRydWVgLFxuICAgIEdFVF9BTExfQ0FURUdPUklFUzogYC9jYXRlZ29yeS8/ZmV0Y2hfYWxsPXRydWVgLFxuICAgIEdFVF9TVEFHRV9ERVRBSUxTOiBgL2dldFdvcmtmbG93YCxcbiAgICBHRVRfQ0FTRV9PV05FUlM6IGBvcmdhbml6YXRpb25NZW1iZXJzJm1hbmFnZUNhc2U9dHJ1ZSZ3b3JrZmxvd19pZD1gLFxuICAgIEFERF9DQVNFX1RPX1dPUktGTE9XOiBgL2FkZC10by13b3JrZmxvd2AsXG4gICAgVkFMSURBVEVfQ0FTRV9ERUFETElORTogYC92YWxpZERlYWRsaW5lL2Bcbn07XG4iXX0=