vcomply-workflow-engine 5.0.3 → 5.0.4
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.
- package/esm2022/lib/constants/assessts.constants.mjs +4 -3
- package/esm2022/lib/more-option/more-option.component.mjs +79 -10
- package/esm2022/lib/pipes/pipes.module.mjs +10 -5
- package/esm2022/lib/pipes/user.pipe.mjs +17 -0
- package/esm2022/lib/report-a-case/components/assignee/assignee.component.mjs +42 -6
- package/esm2022/lib/report-a-case/components/case-assignees/case-assignees.component.mjs +131 -25
- package/esm2022/lib/report-a-case/components/case-category/case-category.component.mjs +157 -11
- package/esm2022/lib/report-a-case/components/case-details/case-details.component.mjs +25 -6
- package/esm2022/lib/report-a-case/components/case-owners/case-owners.component.mjs +222 -0
- package/esm2022/lib/report-a-case/components/case-priority/case-priority.component.mjs +61 -6
- package/esm2022/lib/report-a-case/components/case-resolution-deadline/case-resolution-deadline.component.mjs +62 -30
- package/esm2022/lib/report-a-case/components/case-type-dropdown/case-dropdown.component.mjs +51 -5
- package/esm2022/lib/report-a-case/components/chip-capsule/chip-capsule.component.mjs +4 -4
- package/esm2022/lib/report-a-case/components/due-date/due-date.component.mjs +196 -20
- package/esm2022/lib/report-a-case/components/form-selectBox/form-selectBox.component.mjs +28 -3
- package/esm2022/lib/report-a-case/components/information-block/information-block.component.mjs +19 -6
- package/esm2022/lib/report-a-case/components/rc-details/rc-details.component.mjs +229 -10
- package/esm2022/lib/report-a-case/components/report-date/report-date.component.mjs +27 -12
- package/esm2022/lib/report-a-case/constants/api.constants.mjs +3 -2
- package/esm2022/lib/report-a-case/constants/report-case.constants.mjs +124 -7
- package/esm2022/lib/report-a-case/report-case.module.mjs +5 -2
- package/esm2022/lib/report-a-case/services/report-a-case.service.mjs +14 -1
- package/esm2022/lib/report-a-case/workflow-case/workflow-case.component.mjs +378 -175
- package/esm2022/lib/services/RBAC.service.mjs +66 -0
- package/esm2022/lib/services/api.service.mjs +32 -0
- package/esm2022/lib/services/report-case-permission.service.mjs +37 -0
- package/esm2022/lib/sharedComponents/category-list-selection/category-list-selection/category-list-selection.component.mjs +22 -11
- package/esm2022/lib/sharedComponents/format-and-evidence/format-and-evidence.component.mjs +14 -5
- package/esm2022/lib/sharedComponents/radio-list-with-pagination/radio-list-with-pagination.module.mjs +5 -4
- package/esm2022/lib/workflow-engine-container/workflow-engine-container.component.mjs +55 -29
- package/fesm2022/vcomply-workflow-engine.mjs +2956 -1116
- package/fesm2022/vcomply-workflow-engine.mjs.map +1 -1
- package/lib/constants/assessts.constants.d.ts +1 -0
- package/lib/more-option/more-option.component.d.ts +4 -1
- package/lib/pipes/pipes.module.d.ts +3 -2
- package/lib/pipes/user.pipe.d.ts +7 -0
- package/lib/report-a-case/components/assignee/assignee.component.d.ts +14 -2
- package/lib/report-a-case/components/case-assignees/case-assignees.component.d.ts +43 -5
- package/lib/report-a-case/components/case-category/case-category.component.d.ts +43 -2
- package/lib/report-a-case/components/case-details/case-details.component.d.ts +29 -1
- package/lib/report-a-case/components/case-owners/case-owners.component.d.ts +132 -0
- package/lib/report-a-case/components/case-priority/case-priority.component.d.ts +38 -2
- package/lib/report-a-case/components/case-resolution-deadline/case-resolution-deadline.component.d.ts +37 -7
- package/lib/report-a-case/components/case-type-dropdown/case-dropdown.component.d.ts +37 -2
- package/lib/report-a-case/components/case-type-slider/case-type.component.d.ts +24 -0
- package/lib/report-a-case/components/due-date/due-date.component.d.ts +68 -11
- package/lib/report-a-case/components/field-holder/field-holder.component.d.ts +1 -0
- package/lib/report-a-case/components/form-selectBox/form-selectBox.component.d.ts +7 -1
- package/lib/report-a-case/components/information-block/information-block.component.d.ts +6 -0
- package/lib/report-a-case/components/rc-details/rc-details.component.d.ts +40 -1
- package/lib/report-a-case/components/report-date/report-date.component.d.ts +29 -0
- package/lib/report-a-case/constants/api.constants.d.ts +1 -0
- package/lib/report-a-case/constants/report-case.constants.d.ts +120 -2
- package/lib/report-a-case/report-case.module.d.ts +21 -20
- package/lib/report-a-case/services/report-a-case.service.d.ts +3 -0
- package/lib/report-a-case/workflow-case/workflow-case.component.d.ts +125 -48
- package/lib/services/RBAC.service.d.ts +27 -0
- package/lib/services/api.service.d.ts +13 -0
- package/lib/services/report-case-permission.service.d.ts +13 -0
- package/lib/sharedComponents/category-list-selection/category-list-selection/category-list-selection.component.d.ts +2 -1
- package/lib/sharedComponents/radio-list-with-pagination/radio-list-with-pagination.module.d.ts +2 -1
- package/lib/workflow-engine-container/workflow-engine-container.component.d.ts +9 -1
- package/lib/workflow-risk/workflow-risk.component.d.ts +1 -1
- package/package.json +1 -1
|
@@ -1,16 +1,24 @@
|
|
|
1
|
-
import { Component, ElementRef, Input, ViewChild, Output, EventEmitter, } from '@angular/core';
|
|
2
|
-
import { REPORT_CASE } from '../../constants/report-case.constants';
|
|
3
|
-
import { HELPER_TEXT } from '../../constants/report-case.constants';
|
|
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';
|
|
4
3
|
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "
|
|
6
|
-
import * as i2 from "../../../
|
|
7
|
-
import * as i3 from "
|
|
8
|
-
import * as i4 from "
|
|
9
|
-
import * as i5 from "
|
|
10
|
-
import * as i6 from "
|
|
4
|
+
import * as i1 from "../../../services/common.service";
|
|
5
|
+
import * as i2 from "../../../sharedComponents/frequency/frequency.service";
|
|
6
|
+
import * as i3 from "@angular/common";
|
|
7
|
+
import * as i4 from "../../../ui-kit/tooltip/tooltip.directive";
|
|
8
|
+
import * as i5 from "../../../sharedComponents/floating-bar/floating-bar.component";
|
|
9
|
+
import * as i6 from "ng2-date-picker";
|
|
10
|
+
import * as i7 from "@angular/forms";
|
|
11
|
+
import * as i8 from "../../../sharedComponents/v-loader/loader-inline/loader-inline.component";
|
|
12
|
+
import * as i9 from "../assignee/assignee.component";
|
|
11
13
|
export class DueDateComponent {
|
|
12
|
-
|
|
13
|
-
this.
|
|
14
|
+
set initialSelection(value) {
|
|
15
|
+
this.dueDate = value?.resolution_deadline?.due_date;
|
|
16
|
+
this.emailReminder = value?.resolution_deadline?.assignee_remind_before;
|
|
17
|
+
this.escalationEmail = value?.resolution_deadline?.owner_remind_before;
|
|
18
|
+
}
|
|
19
|
+
constructor(commonDateService, frequencyService) {
|
|
20
|
+
this.commonDateService = commonDateService;
|
|
21
|
+
this.frequencyService = frequencyService;
|
|
14
22
|
this.animation = true;
|
|
15
23
|
this.datePickerOverlay = false;
|
|
16
24
|
this.dateConfig = {
|
|
@@ -19,15 +27,65 @@ export class DueDateComponent {
|
|
|
19
27
|
unSelectOnClick: true,
|
|
20
28
|
openOnClick: false,
|
|
21
29
|
openOnFocus: false,
|
|
30
|
+
min: '',
|
|
22
31
|
};
|
|
23
32
|
this.dueDateTexts = REPORT_CASE;
|
|
24
33
|
this.helperText = HELPER_TEXT;
|
|
34
|
+
this.assigneeClicked = false;
|
|
35
|
+
this.assigneeList = [];
|
|
36
|
+
this.assigneeData = {};
|
|
37
|
+
this.currentStageIndex = -1;
|
|
38
|
+
this.activeAssignee = [];
|
|
39
|
+
this.emailReminder = EMAIL_REMINDERS.email_reminder;
|
|
40
|
+
this.escalationEmail = EMAIL_REMINDERS.escalation_email_reminder;
|
|
41
|
+
this.showError = false;
|
|
42
|
+
this.showAssigneeError = false;
|
|
43
|
+
this.userList = [];
|
|
44
|
+
this.groupList = [];
|
|
45
|
+
this.closeDueDateResolution = new EventEmitter();
|
|
46
|
+
this.closeDueDateEvent = new EventEmitter();
|
|
25
47
|
}
|
|
26
48
|
ngOnInit() {
|
|
27
|
-
|
|
49
|
+
this.dateConfig.min = this.frequencyService.formatDate();
|
|
28
50
|
setTimeout(() => {
|
|
29
51
|
this.animation = false;
|
|
30
52
|
}, 300);
|
|
53
|
+
this.setAssigneeList();
|
|
54
|
+
this.initializeEditMode();
|
|
55
|
+
}
|
|
56
|
+
initializeEditMode() {
|
|
57
|
+
if (!this.payload?.caseToWorkflow?.resolution_deadline)
|
|
58
|
+
return;
|
|
59
|
+
const deadline = this.payload.caseToWorkflow.resolution_deadline;
|
|
60
|
+
this.initializeDeadlineValues(deadline);
|
|
61
|
+
this.initializeStageAssignees(deadline);
|
|
62
|
+
}
|
|
63
|
+
initializeDeadlineValues(deadline) {
|
|
64
|
+
this.dueDate = deadline.due_date ? new Date(deadline.due_date) : null;
|
|
65
|
+
this.emailReminder =
|
|
66
|
+
deadline.assignee_remind_before || EMAIL_REMINDERS.email_reminder;
|
|
67
|
+
this.escalationEmail =
|
|
68
|
+
deadline.owner_remind_before || EMAIL_REMINDERS.escalation_email_reminder;
|
|
69
|
+
}
|
|
70
|
+
initializeStageAssignees(deadline) {
|
|
71
|
+
if (!deadline?.stages_assignees?.length)
|
|
72
|
+
return;
|
|
73
|
+
const stageAssigneeMap = this.createStageAssigneeMap(deadline.stages_assignees);
|
|
74
|
+
this.mapWorkflowStages(stageAssigneeMap);
|
|
75
|
+
}
|
|
76
|
+
createStageAssigneeMap(stagesAssignees) {
|
|
77
|
+
return new Map(stagesAssignees.map((stage) => [stage?.stage_id, stage?.assignee_id]));
|
|
78
|
+
}
|
|
79
|
+
mapWorkflowStages(stageAssigneeMap) {
|
|
80
|
+
this.workflowDetails?.stages_assignees?.forEach((workflowStage, index) => {
|
|
81
|
+
const assigneeId = stageAssigneeMap?.get(workflowStage?.stage_id);
|
|
82
|
+
if (!assigneeId)
|
|
83
|
+
return;
|
|
84
|
+
const assignee = this.assigneeList?.find((assignee) => assignee?._id === assigneeId);
|
|
85
|
+
if (assignee) {
|
|
86
|
+
this.assigneeData[index] = [assignee];
|
|
87
|
+
}
|
|
88
|
+
});
|
|
31
89
|
}
|
|
32
90
|
openDatePicker() {
|
|
33
91
|
this.datePicker?.api?.open();
|
|
@@ -62,29 +120,147 @@ export class DueDateComponent {
|
|
|
62
120
|
}
|
|
63
121
|
if (evt?.date?.$d) {
|
|
64
122
|
this.dueDate = evt?.date?.$d;
|
|
123
|
+
this.showError = false;
|
|
65
124
|
}
|
|
66
125
|
this.datePicker?.api?.close();
|
|
67
126
|
}
|
|
68
127
|
closeDueDate() {
|
|
69
128
|
this.closeDueDateEvent.emit();
|
|
70
129
|
}
|
|
71
|
-
|
|
72
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DueDateComponent, selector: "app-due-date", inputs: { payload: "payload", dueDate: "dueDate" }, outputs: { closeDueDateEvent: "closeDueDateEvent" }, viewQueries: [{ propertyName: "datePicker", first: true, predicate: ["datePicker"], descendants: true }, { propertyName: "datePickerPopUp", first: true, predicate: ["datePicker"], descendants: true, read: ElementRef }], ngImport: i0, template: "<div class=\"configure-resolution\" [class.animate]=\"animation\">\r\n <div\r\n class=\"configure-resolution-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\"\r\n >\r\n <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">\r\n Configure Resolution Deadline & Stage Details\r\n </div>\r\n </div>\r\n <div class=\"configure-resolution-body\">\r\n <div class=\"configure-resolution-body-inner\">\r\n <app-loader-inline *ngIf=\"false\"></app-loader-inline>\r\n <app-no-data\r\n *ngIf=\"false\"\r\n [noDataImage]=\"\r\n 'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/search-data.svg'\r\n \"\r\n [noDataText]=\"'No data to display'\"\r\n ></app-no-data>\r\n\r\n <ng-container>\r\n <div\r\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\r\n >\r\n SPECIFY THE DEADLINE TO CLOSE THIS CASE\r\n <span class=\"required vx-fs-16 vx-fw-400\">*</span>\r\n </div>\r\n <div\r\n class=\"case-calendar vx-d-flex vx-justify-between vx-pt-3 vx-pb-3 vx-mb-3\"\r\n >\r\n <div class=\"case-calendar-inner vx-d-flex vx-align-center\">\r\n <input\r\n type=\"text\"\r\n readonly\r\n placeholder=\"{{\r\n dueDateTexts.case_details.due_date.deadline_placeholder\r\n }}\"\r\n (click)=\"openDatePicker()\"\r\n [value]=\"dueDate | date : 'dd MMM yyyy'\"\r\n id=\"effective-date\"\r\n />\r\n <i class=\"icons\"></i>\r\n <dp-date-picker\r\n #datePicker\r\n (onSelect)=\"datePickerOverlay = false; closeDatePicker($event)\"\r\n [config]=\"dateConfig\"\r\n [(ngModel)]=\"dueDate\"\r\n >\r\n </dp-date-picker>\r\n <div\r\n class=\"vx-overlay\"\r\n (click)=\"closeDatePicker($event)\"\r\n *ngIf=\"datePickerOverlay\"\r\n ></div>\r\n </div>\r\n </div>\r\n <div class=\"vx-d-flex vx-align-center vx-justify-between vx-mb-1\">\r\n <div\r\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-tt-uppercase\"\r\n >\r\n CONFIGURE DEADLINE & ASSIGNEE FOR EACH STAGE IN THE WORKFLOW\r\n <span class=\"required vx-fs-16 vx-fw-400\">*</span>\r\n </div>\r\n <!-- <div class=\"toggle-area vx-d-flex vx-align-center\">\r\n <app-cs-switch>Allow Reopening of Previous Stage</app-cs-switch>\r\n <i\r\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-2\"\r\n [appTooltip]=\"\r\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.'\r\n \"\r\n placement=\"bottom-right\"\r\n delay=\"0\"\r\n type=\"white\"\r\n [tooltipMandatory]=\"true\"\r\n ></i\r\n >\r\n </div> -->\r\n </div>\r\n <div class=\"configure-resolution-table\">\r\n <div class=\"table-header\">\r\n <div class=\"table-row\">\r\n <div\r\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\"\r\n >\r\n #\r\n </div>\r\n <div\r\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\"\r\n >\r\n STAGE NAME\r\n </div>\r\n <div\r\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\"\r\n >\r\n TRANSITION STATUS\r\n <i\r\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\r\n [appTooltip]=\"helperText.transition_status\"\r\n placement=\"bottom\"\r\n delay=\"0\"\r\n type=\"white\"\r\n [tooltipMandatory]=\"true\"\r\n ></i\r\n >\r\n </div>\r\n <div\r\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\"\r\n >\r\n ASSIGNEE\r\n <i\r\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\r\n [appTooltip]=\"helperText.assignee\"\r\n placement=\"bottom\"\r\n delay=\"0\"\r\n type=\"white\"\r\n [tooltipMandatory]=\"true\"\r\n ></i\r\n >\r\n </div>\r\n <div\r\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\"\r\n >\r\n DEADLINE\r\n <i\r\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\r\n [appTooltip]=\"helperText.deadline\"\r\n placement=\"bottom\"\r\n delay=\"0\"\r\n type=\"white\"\r\n [tooltipMandatory]=\"true\"\r\n ></i\r\n >\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"table-body\">\r\n <div class=\"table-row\" *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\"\r\n >\r\n <div\r\n class=\"sr-no vx-fs-13 vx-d-flex vx-align-center vx-justify-center\"\r\n [appTooltip]=\"'1'\"\r\n placement=\"bottom\"\r\n delay=\"0\"\r\n type=\"black\"\r\n [tooltipMandatory]=\"true\"\r\n >\r\n 1\r\n </div>\r\n </div>\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center stage-name\"\r\n >\r\n <div\r\n class=\"value vx-fs-13 vx-pr-2\"\r\n [appTooltip]=\"'Communication and Reporting'\"\r\n placement=\"bottom-left\"\r\n delay=\"0\"\r\n type=\"black\"\r\n [tooltipMandatory]=\"false\"\r\n >\r\n Communication and Reporting\r\n </div>\r\n </div>\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center status\"\r\n >\r\n <div class=\"value vx-fs-12\">\r\n In Progress<br /><span class=\"vx-mr-1\">To</span>Closed\r\n </div>\r\n </div>\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center assignee\"\r\n >\r\n <div\r\n *ngIf=\"true\"\r\n class=\"select-box vx-d-flex vx-align-center vx-justify-between vx-pl-3 vx-pr-3\"\r\n >\r\n <div class=\"value vx-fs-13\">Select a User</div>\r\n <i class=\"icons arrow vx-fs-12\"></i>\r\n </div>\r\n <div\r\n *ngIf=\"false\"\r\n class=\"after-select-box vx-d-flex vx-align-center vx-justify-between vx-pl-3 vx-pr-2\"\r\n >\r\n <div\r\n class=\"value-chip vx-fs-11 vx-pl-2 vx-pr-2 vx-lh-6\"\r\n [appTooltip]=\"'Samantha Jones'\"\r\n placement=\"bottom-left\"\r\n delay=\"0\"\r\n type=\"black\"\r\n [tooltipMandatory]=\"false\"\r\n >\r\n Samantha Jones\r\n </div>\r\n <button\r\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\"\r\n >\r\n <i class=\"icons vx-fs-12 vx-txt-blue vx-mr-1\"></i\r\n >EDIT\r\n </button>\r\n </div>\r\n </div>\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-2 vx-d-flex vx-align-center deadline\"\r\n >\r\n <div\r\n class=\"case-calendar vx-d-flex vx-justify-between vx-pt-3 vx-pb-3\"\r\n [class.disabled]=\"true\"\r\n >\r\n <div class=\"case-calendar-inner vx-d-flex vx-align-center\">\r\n <input\r\n type=\"text\"\r\n readonly\r\n value=\"30 Dec 2024\"\r\n (click)=\"openDatePicker()\"\r\n id=\"effective-date\"\r\n />\r\n <i class=\"icons\"></i>\r\n <dp-date-picker\r\n #datePicker\r\n (onSelect)=\"\r\n datePickerOverlay = false; closeDatePicker($event)\r\n \"\r\n [config]=\"dateConfig\"\r\n >\r\n </dp-date-picker>\r\n <div\r\n class=\"vx-overlay\"\r\n (click)=\"closeDatePicker($event)\"\r\n *ngIf=\"datePickerOverlay\"\r\n ></div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div\r\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\r\n >\r\n EMAIL REMINDER CONFIGURATION\r\n <span class=\"required vx-fs-16 vx-fw-400\">*</span>\r\n </div>\r\n <div class=\"divider vx-mb-2\"></div>\r\n <div\r\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\r\n >\r\n REMINDER EMAIL\r\n </div>\r\n <div\r\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\"\r\n >\r\n <div class=\"vx-fs-13 vx-mr-1\">\r\n Send regular email reminders to the assignee\r\n </div>\r\n <input type=\"number\" value=\"5\" />\r\n <div class=\"vx-fs-13 vx-ml-1\">\r\n <span class=\"black-text\">days</span> before the stage deadline.\r\n </div>\r\n </div>\r\n <div\r\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\r\n >\r\n ESCALATION EMAIL\r\n </div>\r\n <div\r\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\"\r\n >\r\n <div class=\"vx-fs-13 vx-mr-1\">\r\n Send email escalation to the Case Owner\r\n </div>\r\n <input type=\"number\" value=\"2\" />\r\n <div class=\"vx-fs-13 vx-ml-1\">\r\n <span class=\"black-text\">days</span> before the overall case\r\n deadline, if the case is still open.\r\n </div>\r\n </div>\r\n </ng-container>\r\n </div>\r\n <app-floating-bar (closeList)=\"closeDueDate()\"></app-floating-bar>\r\n </div>\r\n</div>\r\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 .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;height:2.5rem}::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:.125rem;color:#747576;font-size:12px;pointer-events:none}::ng-deep .configure-resolution-body .case-calendar.disabled{background:#f2f2f5;pointer-events:none;opacity:1}::ng-deep .configure-resolution-body .case-calendar.disabled .case-calendar-inner input,::ng-deep .configure-resolution-body .case-calendar.disabled .case-calendar-inner 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{border-radius:.25rem;border:1px solid #f2f2f5;margin-bottom:1.5rem}::ng-deep .configure-resolution-table .table-header{background:#fff;border-radius:.25rem .25rem 0 0}::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-row{display:flex;justify-content:space-between;position:relative}::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: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ToolTipDirective, selector: "[appTooltip]", inputs: ["appTooltip", "placement", "type", "tooltipMandatory", "showTooltip", "animate"] }, { kind: "component", type: i3.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: i4.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: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i6.LoaderInlineComponent, selector: "app-loader-inline" }, { kind: "pipe", type: i1.DatePipe, name: "date" }] }); }
|
|
130
|
+
activateSelector(active, stageIndex) {
|
|
131
|
+
this.assigneeClicked = active;
|
|
132
|
+
if (active) {
|
|
133
|
+
this.currentStageIndex = stageIndex ?? -1;
|
|
134
|
+
this.activeAssignee =
|
|
135
|
+
this.currentStageIndex !== -1
|
|
136
|
+
? this.assigneeData[this.currentStageIndex]
|
|
137
|
+
: [];
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
setAssigneeList() {
|
|
141
|
+
const assigneeIds = this.payload.caseToWorkflow?.assignees;
|
|
142
|
+
this.assigneeList = this.userList
|
|
143
|
+
?.filter((user) => assigneeIds?.includes(user?._id))
|
|
144
|
+
?.map((user) => {
|
|
145
|
+
const userGroups = this.groupList?.filter((group) => user?.usergroup_id?.includes(group?.group_id));
|
|
146
|
+
return {
|
|
147
|
+
...user,
|
|
148
|
+
associatedGroups: userGroups,
|
|
149
|
+
};
|
|
150
|
+
});
|
|
151
|
+
}
|
|
152
|
+
selectedAssignee(event) {
|
|
153
|
+
if (this.currentStageIndex !== -1) {
|
|
154
|
+
this.assigneeData[this.currentStageIndex] = event;
|
|
155
|
+
}
|
|
156
|
+
this.assigneeClicked = false;
|
|
157
|
+
if (event?.length > 0) {
|
|
158
|
+
this.showAssigneeError = false;
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
saveCaseResolutionDeadline() {
|
|
162
|
+
if (!this.isDueDateValid()) {
|
|
163
|
+
this.showError = true;
|
|
164
|
+
return;
|
|
165
|
+
}
|
|
166
|
+
else if (!this.areAssigneesValid()) {
|
|
167
|
+
this.showAssigneeError = true;
|
|
168
|
+
return;
|
|
169
|
+
}
|
|
170
|
+
this.showError = false;
|
|
171
|
+
this.showAssigneeError = false;
|
|
172
|
+
this.setPayload();
|
|
173
|
+
this.closeDueDateResolution.emit();
|
|
174
|
+
}
|
|
175
|
+
isDueDateValid() {
|
|
176
|
+
return !!this.dueDate;
|
|
177
|
+
}
|
|
178
|
+
areAssigneesValid() {
|
|
179
|
+
return this.workflowDetails?.stages_assignees?.every((stage, index) => this.assigneeData[index] && this.assigneeData[index]?.length > 0);
|
|
180
|
+
}
|
|
181
|
+
formatDueDate(date) {
|
|
182
|
+
return new Date(date).toISOString();
|
|
183
|
+
}
|
|
184
|
+
setDeadlineReminders() {
|
|
185
|
+
this.payload.caseToWorkflow.resolution_deadline.assignee_remind_before =
|
|
186
|
+
this.emailReminder;
|
|
187
|
+
this.payload.caseToWorkflow.resolution_deadline.owner_remind_before =
|
|
188
|
+
this.escalationEmail;
|
|
189
|
+
}
|
|
190
|
+
setStagesAssignees() {
|
|
191
|
+
return this.workflowDetails?.stages_assignees
|
|
192
|
+
.map((stage, index) => {
|
|
193
|
+
const assigneeData = this.assigneeData[index];
|
|
194
|
+
return assigneeData
|
|
195
|
+
? this.createStageAssignee(stage, assigneeData)
|
|
196
|
+
: null;
|
|
197
|
+
})
|
|
198
|
+
.filter(Boolean);
|
|
199
|
+
}
|
|
200
|
+
createStageAssignee(stage, assigneeData) {
|
|
201
|
+
return {
|
|
202
|
+
stage_id: stage?.stage_id || '',
|
|
203
|
+
assignee_id: assigneeData[0]?._id || '',
|
|
204
|
+
due_date: stage?.due_date || '',
|
|
205
|
+
};
|
|
206
|
+
}
|
|
207
|
+
setPayload() {
|
|
208
|
+
const formattedDate = this.formatDueDate(this.dueDate);
|
|
209
|
+
this.payload.caseToWorkflow.resolution_deadline.due_date = formattedDate;
|
|
210
|
+
this.setDeadlineReminders();
|
|
211
|
+
const stagesAssignees = this.setStagesAssignees();
|
|
212
|
+
this.payload.caseToWorkflow.resolution_deadline.stages_assignees =
|
|
213
|
+
stagesAssignees;
|
|
214
|
+
this.payload.caseToWorkflow.workflow_id = this.workflowDetails?._id;
|
|
215
|
+
}
|
|
216
|
+
documentClick(event) {
|
|
217
|
+
const datePickerObject = {
|
|
218
|
+
event: event,
|
|
219
|
+
class: 'effective-date',
|
|
220
|
+
popup: this.datePickerPopUp,
|
|
221
|
+
component: this.datePicker,
|
|
222
|
+
overlay: this.datePickerOverlay,
|
|
223
|
+
};
|
|
224
|
+
this.commonDateService.handleDocumentClick(datePickerObject);
|
|
225
|
+
}
|
|
226
|
+
onInputChange() {
|
|
227
|
+
if (this.emailReminder === 0) {
|
|
228
|
+
this.emailReminder = EMAIL_REMINDERS.email_reminder;
|
|
229
|
+
}
|
|
230
|
+
if (this.escalationEmail === 0) {
|
|
231
|
+
this.escalationEmail = EMAIL_REMINDERS.escalation_email_reminder;
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
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 }); }
|
|
235
|
+
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", initialSelection: "initialSelection" }, outputs: { closeDueDateResolution: "closeDueDateResolution", closeDueDateEvent: "closeDueDateEvent" }, host: { listeners: { "document:click": "documentClick($event)" } }, viewQueries: [{ propertyName: "datePicker", first: true, predicate: ["datePicker"], descendants: true }, { propertyName: "animation", first: true, predicate: ["datePicker"], descendants: true, read: ElementRef }], ngImport: i0, template: "<div class=\"configure-resolution\" [class.animate]=\"animation\">\r\n <div\r\n class=\"configure-resolution-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\"\r\n >\r\n <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">\r\n Configure Resolution Deadline & Stage Details\r\n </div>\r\n </div>\r\n <div class=\"configure-resolution-body\">\r\n <div class=\"configure-resolution-body-inner\">\r\n <app-loader-inline *ngIf=\"false\"></app-loader-inline>\r\n <app-no-data\r\n *ngIf=\"false\"\r\n [noDataImage]=\"\r\n 'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/search-data.svg'\r\n \"\r\n [noDataText]=\"'No data to display'\"\r\n ></app-no-data>\r\n\r\n <ng-container>\r\n <div\r\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\r\n >\r\n SPECIFY THE DEADLINE TO CLOSE THIS CASE\r\n <span class=\"required vx-fs-16 vx-fw-400\">*</span>\r\n </div>\r\n <div\r\n class=\"case-calendar vx-d-flex vx-justify-between vx-pt-3 vx-pb-3 vx-mb-3\"\r\n >\r\n <div class=\"case-calendar-inner vx-d-flex vx-align-center\">\r\n <input\r\n type=\"text\"\r\n readonly\r\n placeholder=\"{{\r\n dueDateTexts.case_details.due_date.deadline_placeholder\r\n }}\"\r\n (click)=\"openDatePicker()\"\r\n [value]=\"dueDate | date : 'dd MMM yyyy'\"\r\n id=\"effective-date\"\r\n />\r\n <i class=\"icons\"></i>\r\n <dp-date-picker\r\n #datePicker\r\n (onSelect)=\"datePickerOverlay = false; closeDatePicker($event)\"\r\n [config]=\"dateConfig\"\r\n [(ngModel)]=\"dueDate\"\r\n >\r\n </dp-date-picker>\r\n <div\r\n class=\"vx-overlay\"\r\n (click)=\"closeDatePicker($event)\"\r\n *ngIf=\"datePickerOverlay\"\r\n ></div>\r\n </div>\r\n </div>\r\n <div *ngIf=\"showError\" class=\"errorMsg vx-fs-11 vx-lh-4 vx-mt-1\">\r\n {{ dueDateTexts.errorMessage.dueDate }}\r\n </div>\r\n <div class=\"vx-d-flex vx-align-center vx-justify-between vx-mb-1\">\r\n <div\r\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-tt-uppercase\"\r\n >\r\n CONFIGURE DEADLINE & ASSIGNEE FOR EACH STAGE IN THE WORKFLOW\r\n <span class=\"required vx-fs-16 vx-fw-400\">*</span>\r\n </div>\r\n <!-- <div class=\"toggle-area vx-d-flex vx-align-center\">\r\n <app-cs-switch>Allow Reopening of Previous Stage</app-cs-switch>\r\n <i\r\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-2\"\r\n [appTooltip]=\"\r\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.'\r\n \"\r\n placement=\"bottom-right\"\r\n delay=\"0\"\r\n type=\"white\"\r\n [tooltipMandatory]=\"true\"\r\n ></i\r\n >\r\n </div> -->\r\n </div>\r\n <div class=\"configure-resolution-table\">\r\n <div class=\"table-header\">\r\n <div class=\"table-row\">\r\n <div\r\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\"\r\n >\r\n #\r\n </div>\r\n <div\r\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\"\r\n >\r\n STAGE NAME\r\n </div>\r\n <div\r\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\"\r\n >\r\n TRANSITION STATUS\r\n <i\r\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\r\n [appTooltip]=\"helperText.transition_status\"\r\n placement=\"bottom\"\r\n delay=\"0\"\r\n type=\"white\"\r\n [tooltipMandatory]=\"true\"\r\n ></i\r\n >\r\n </div>\r\n <div\r\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\"\r\n >\r\n ASSIGNEE\r\n <i\r\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\r\n [appTooltip]=\"helperText.assignee\"\r\n placement=\"bottom\"\r\n delay=\"0\"\r\n type=\"white\"\r\n [tooltipMandatory]=\"true\"\r\n ></i\r\n >\r\n </div>\r\n <div\r\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\"\r\n >\r\n DEADLINE\r\n <i\r\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\r\n [appTooltip]=\"helperText.deadline\"\r\n placement=\"bottom\"\r\n delay=\"0\"\r\n type=\"white\"\r\n [tooltipMandatory]=\"true\"\r\n ></i\r\n >\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"table-body\">\r\n <div\r\n class=\"table-row\"\r\n *ngFor=\"\r\n let data of workflowDetails?.stages_assignees;\r\n let i = index\r\n \"\r\n >\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\"\r\n >\r\n <div\r\n class=\"sr-no vx-fs-13 vx-d-flex vx-align-center vx-justify-center\"\r\n [appTooltip]=\"i + 1\"\r\n placement=\"bottom\"\r\n delay=\"0\"\r\n type=\"black\"\r\n [tooltipMandatory]=\"true\"\r\n >\r\n {{ i + 1 }}\r\n </div>\r\n </div>\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center stage-name\"\r\n >\r\n <div\r\n class=\"value vx-fs-13 vx-pr-2\"\r\n [appTooltip]=\"data?.name\"\r\n placement=\"bottom-left\"\r\n delay=\"0\"\r\n type=\"black\"\r\n [tooltipMandatory]=\"false\"\r\n >\r\n {{ data?.name }}\r\n </div>\r\n </div>\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center status\"\r\n >\r\n <div class=\"value vx-fs-12\">\r\n {{ data?.status_transition?.fromName }}<br /><span\r\n class=\"vx-mr-1\"\r\n >To</span\r\n >{{ data?.status_transition?.toName }}\r\n </div>\r\n </div>\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center assignee\"\r\n (click)=\"activateSelector(true, i)\"\r\n >\r\n <div\r\n *ngIf=\"!assigneeData[i]?.length\"\r\n class=\"select-box vx-d-flex vx-align-center vx-justify-between vx-pl-3 vx-pr-3\"\r\n >\r\n <div class=\"value vx-fs-13\">Select a User</div>\r\n <i class=\"icons arrow vx-fs-12\"></i>\r\n </div>\r\n <div\r\n *ngIf=\"assigneeData[i]?.length > 0\"\r\n class=\"after-select-box vx-d-flex vx-align-center vx-justify-between vx-pl-3 vx-pr-2\"\r\n >\r\n <div\r\n class=\"value-chip vx-fs-11 vx-pl-2 vx-pr-2 vx-lh-6\"\r\n [appTooltip]=\"assigneeData[i][0]?.member_name\"\r\n placement=\"bottom-left\"\r\n delay=\"0\"\r\n type=\"black\"\r\n [tooltipMandatory]=\"false\"\r\n >\r\n {{ assigneeData[i][0]?.member_name }}\r\n </div>\r\n <button\r\n (click)=\"activateSelector(true, i)\"\r\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\"\r\n >\r\n <i class=\"icons vx-fs-12 vx-txt-blue vx-mr-1\"></i\r\n >EDIT\r\n </button>\r\n </div>\r\n </div>\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-2 vx-d-flex vx-align-center deadline\"\r\n >\r\n <div\r\n class=\"case-calendar vx-d-flex vx-justify-between vx-pt-3 vx-pb-3\"\r\n [class.disabled]=\"true\"\r\n >\r\n <div class=\"case-calendar-inner vx-d-flex vx-align-center\">\r\n <input\r\n type=\"text\"\r\n readonly\r\n value=\"{{ data?.due_date | date : 'dd MMM yyyy' }}\"\r\n (click)=\"openDatePicker()\"\r\n id=\"effective-date\"\r\n />\r\n <i class=\"icons\"></i>\r\n <dp-date-picker\r\n #datePicker\r\n (onSelect)=\"\r\n datePickerOverlay = false; closeDatePicker($event)\r\n \"\r\n [config]=\"dateConfig\"\r\n >\r\n </dp-date-picker>\r\n <div\r\n class=\"vx-overlay\"\r\n (click)=\"closeDatePicker($event)\"\r\n *ngIf=\"datePickerOverlay\"\r\n ></div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div\r\n *ngIf=\"showAssigneeError\"\r\n class=\"errorMsg vx-fs-11 vx-lh-4 vx-mt-1\"\r\n >\r\n {{ dueDateTexts.errorMessage.stageAssignee }}\r\n </div>\r\n <div\r\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\r\n >\r\n EMAIL REMINDER CONFIGURATION\r\n <span class=\"required vx-fs-16 vx-fw-400\">*</span>\r\n </div>\r\n <div class=\"divider vx-mb-2\"></div>\r\n <div\r\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\r\n >\r\n REMINDER EMAIL\r\n </div>\r\n <div\r\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\"\r\n >\r\n <div class=\"vx-fs-13 vx-mr-1\">\r\n Send regular email reminders to the assignee\r\n </div>\r\n <input\r\n type=\"number\"\r\n [(ngModel)]=\"emailReminder\"\r\n onkeydown=\"return event.key !== '.'\"\r\n oninput=\"this.value = Math.abs(this.value)\"\r\n (change)=\"onInputChange()\"\r\n />\r\n <div class=\"vx-fs-13 vx-ml-1\">\r\n <span class=\"black-text\">days</span> before the stage deadline.\r\n </div>\r\n </div>\r\n <div\r\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\r\n >\r\n ESCALATION EMAIL\r\n </div>\r\n <div\r\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\"\r\n >\r\n <div class=\"vx-fs-13 vx-mr-1\">\r\n Send email escalation to the Case Owner\r\n </div>\r\n <input\r\n type=\"number\"\r\n [(ngModel)]=\"escalationEmail\"\r\n onkeydown=\"return event.key !== '.'\"\r\n oninput=\"this.value = Math.abs(this.value)\"\r\n (change)=\"onInputChange()\"\r\n />\r\n <div class=\"vx-fs-13 vx-ml-1\">\r\n <span class=\"black-text\">days</span> before the overall case\r\n deadline, if the case is still open.\r\n </div>\r\n </div>\r\n </ng-container>\r\n </div>\r\n <app-floating-bar\r\n (closeList)=\"closeDueDate()\"\r\n (closeEvent)=\"saveCaseResolutionDeadline()\"\r\n ></app-floating-bar>\r\n </div>\r\n</div>\r\n<app-assignee\r\n *ngIf=\"assigneeClicked\"\r\n [payload]=\"payload\"\r\n [assigneeList]=\"assigneeList\"\r\n [activeAssignee]=\"activeAssignee\"\r\n (selectedAssigneeEvent)=\"selectedAssignee($event)\"\r\n (closeEvent)=\"activateSelector(false)\"\r\n></app-assignee>\r\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;height:2.5rem}::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:.125rem;color:#747576;font-size:12px;pointer-events:none}::ng-deep .configure-resolution-body .case-calendar.disabled{background:#f2f2f5;pointer-events:none;opacity:1}::ng-deep .configure-resolution-body .case-calendar.disabled .case-calendar-inner input,::ng-deep .configure-resolution-body .case-calendar.disabled .case-calendar-inner 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{border-radius:.25rem;border:1px solid #f2f2f5;margin-bottom:1.5rem}::ng-deep .configure-resolution-table .table-header{background:#fff;border-radius:.25rem .25rem 0 0}::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-row{display:flex;justify-content:space-between;position:relative}::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" }] }); }
|
|
73
236
|
}
|
|
74
237
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DueDateComponent, decorators: [{
|
|
75
238
|
type: Component,
|
|
76
|
-
args: [{ selector: 'app-due-date', template: "<div class=\"configure-resolution\" [class.animate]=\"animation\">\r\n <div\r\n class=\"configure-resolution-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\"\r\n >\r\n <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">\r\n Configure Resolution Deadline & Stage Details\r\n </div>\r\n </div>\r\n <div class=\"configure-resolution-body\">\r\n <div class=\"configure-resolution-body-inner\">\r\n <app-loader-inline *ngIf=\"false\"></app-loader-inline>\r\n <app-no-data\r\n *ngIf=\"false\"\r\n [noDataImage]=\"\r\n 'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/search-data.svg'\r\n \"\r\n [noDataText]=\"'No data to display'\"\r\n ></app-no-data>\r\n\r\n <ng-container>\r\n <div\r\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\r\n >\r\n SPECIFY THE DEADLINE TO CLOSE THIS CASE\r\n <span class=\"required vx-fs-16 vx-fw-400\">*</span>\r\n </div>\r\n <div\r\n class=\"case-calendar vx-d-flex vx-justify-between vx-pt-3 vx-pb-3 vx-mb-3\"\r\n >\r\n <div class=\"case-calendar-inner vx-d-flex vx-align-center\">\r\n <input\r\n type=\"text\"\r\n readonly\r\n placeholder=\"{{\r\n dueDateTexts.case_details.due_date.deadline_placeholder\r\n }}\"\r\n (click)=\"openDatePicker()\"\r\n [value]=\"dueDate | date : 'dd MMM yyyy'\"\r\n id=\"effective-date\"\r\n />\r\n <i class=\"icons\"></i>\r\n <dp-date-picker\r\n #datePicker\r\n (onSelect)=\"datePickerOverlay = false; closeDatePicker($event)\"\r\n [config]=\"dateConfig\"\r\n [(ngModel)]=\"dueDate\"\r\n >\r\n </dp-date-picker>\r\n <div\r\n class=\"vx-overlay\"\r\n (click)=\"closeDatePicker($event)\"\r\n *ngIf=\"datePickerOverlay\"\r\n ></div>\r\n </div>\r\n </div>\r\n <div class=\"vx-d-flex vx-align-center vx-justify-between vx-mb-1\">\r\n <div\r\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-tt-uppercase\"\r\n >\r\n CONFIGURE DEADLINE & ASSIGNEE FOR EACH STAGE IN THE WORKFLOW\r\n <span class=\"required vx-fs-16 vx-fw-400\">*</span>\r\n </div>\r\n <!-- <div class=\"toggle-area vx-d-flex vx-align-center\">\r\n <app-cs-switch>Allow Reopening of Previous Stage</app-cs-switch>\r\n <i\r\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-2\"\r\n [appTooltip]=\"\r\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.'\r\n \"\r\n placement=\"bottom-right\"\r\n delay=\"0\"\r\n type=\"white\"\r\n [tooltipMandatory]=\"true\"\r\n ></i\r\n >\r\n </div> -->\r\n </div>\r\n <div class=\"configure-resolution-table\">\r\n <div class=\"table-header\">\r\n <div class=\"table-row\">\r\n <div\r\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\"\r\n >\r\n #\r\n </div>\r\n <div\r\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\"\r\n >\r\n STAGE NAME\r\n </div>\r\n <div\r\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\"\r\n >\r\n TRANSITION STATUS\r\n <i\r\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\r\n [appTooltip]=\"helperText.transition_status\"\r\n placement=\"bottom\"\r\n delay=\"0\"\r\n type=\"white\"\r\n [tooltipMandatory]=\"true\"\r\n ></i\r\n >\r\n </div>\r\n <div\r\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\"\r\n >\r\n ASSIGNEE\r\n <i\r\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\r\n [appTooltip]=\"helperText.assignee\"\r\n placement=\"bottom\"\r\n delay=\"0\"\r\n type=\"white\"\r\n [tooltipMandatory]=\"true\"\r\n ></i\r\n >\r\n </div>\r\n <div\r\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\"\r\n >\r\n DEADLINE\r\n <i\r\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\r\n [appTooltip]=\"helperText.deadline\"\r\n placement=\"bottom\"\r\n delay=\"0\"\r\n type=\"white\"\r\n [tooltipMandatory]=\"true\"\r\n ></i\r\n >\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"table-body\">\r\n <div class=\"table-row\" *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\"\r\n >\r\n <div\r\n class=\"sr-no vx-fs-13 vx-d-flex vx-align-center vx-justify-center\"\r\n [appTooltip]=\"'1'\"\r\n placement=\"bottom\"\r\n delay=\"0\"\r\n type=\"black\"\r\n [tooltipMandatory]=\"true\"\r\n >\r\n 1\r\n </div>\r\n </div>\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center stage-name\"\r\n >\r\n <div\r\n class=\"value vx-fs-13 vx-pr-2\"\r\n [appTooltip]=\"'Communication and Reporting'\"\r\n placement=\"bottom-left\"\r\n delay=\"0\"\r\n type=\"black\"\r\n [tooltipMandatory]=\"false\"\r\n >\r\n Communication and Reporting\r\n </div>\r\n </div>\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center status\"\r\n >\r\n <div class=\"value vx-fs-12\">\r\n In Progress<br /><span class=\"vx-mr-1\">To</span>Closed\r\n </div>\r\n </div>\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center assignee\"\r\n >\r\n <div\r\n *ngIf=\"true\"\r\n class=\"select-box vx-d-flex vx-align-center vx-justify-between vx-pl-3 vx-pr-3\"\r\n >\r\n <div class=\"value vx-fs-13\">Select a User</div>\r\n <i class=\"icons arrow vx-fs-12\"></i>\r\n </div>\r\n <div\r\n *ngIf=\"false\"\r\n class=\"after-select-box vx-d-flex vx-align-center vx-justify-between vx-pl-3 vx-pr-2\"\r\n >\r\n <div\r\n class=\"value-chip vx-fs-11 vx-pl-2 vx-pr-2 vx-lh-6\"\r\n [appTooltip]=\"'Samantha Jones'\"\r\n placement=\"bottom-left\"\r\n delay=\"0\"\r\n type=\"black\"\r\n [tooltipMandatory]=\"false\"\r\n >\r\n Samantha Jones\r\n </div>\r\n <button\r\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\"\r\n >\r\n <i class=\"icons vx-fs-12 vx-txt-blue vx-mr-1\"></i\r\n >EDIT\r\n </button>\r\n </div>\r\n </div>\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-2 vx-d-flex vx-align-center deadline\"\r\n >\r\n <div\r\n class=\"case-calendar vx-d-flex vx-justify-between vx-pt-3 vx-pb-3\"\r\n [class.disabled]=\"true\"\r\n >\r\n <div class=\"case-calendar-inner vx-d-flex vx-align-center\">\r\n <input\r\n type=\"text\"\r\n readonly\r\n value=\"30 Dec 2024\"\r\n (click)=\"openDatePicker()\"\r\n id=\"effective-date\"\r\n />\r\n <i class=\"icons\"></i>\r\n <dp-date-picker\r\n #datePicker\r\n (onSelect)=\"\r\n datePickerOverlay = false; closeDatePicker($event)\r\n \"\r\n [config]=\"dateConfig\"\r\n >\r\n </dp-date-picker>\r\n <div\r\n class=\"vx-overlay\"\r\n (click)=\"closeDatePicker($event)\"\r\n *ngIf=\"datePickerOverlay\"\r\n ></div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div\r\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\r\n >\r\n EMAIL REMINDER CONFIGURATION\r\n <span class=\"required vx-fs-16 vx-fw-400\">*</span>\r\n </div>\r\n <div class=\"divider vx-mb-2\"></div>\r\n <div\r\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\r\n >\r\n REMINDER EMAIL\r\n </div>\r\n <div\r\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\"\r\n >\r\n <div class=\"vx-fs-13 vx-mr-1\">\r\n Send regular email reminders to the assignee\r\n </div>\r\n <input type=\"number\" value=\"5\" />\r\n <div class=\"vx-fs-13 vx-ml-1\">\r\n <span class=\"black-text\">days</span> before the stage deadline.\r\n </div>\r\n </div>\r\n <div\r\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\r\n >\r\n ESCALATION EMAIL\r\n </div>\r\n <div\r\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\"\r\n >\r\n <div class=\"vx-fs-13 vx-mr-1\">\r\n Send email escalation to the Case Owner\r\n </div>\r\n <input type=\"number\" value=\"2\" />\r\n <div class=\"vx-fs-13 vx-ml-1\">\r\n <span class=\"black-text\">days</span> before the overall case\r\n deadline, if the case is still open.\r\n </div>\r\n </div>\r\n </ng-container>\r\n </div>\r\n <app-floating-bar (closeList)=\"closeDueDate()\"></app-floating-bar>\r\n </div>\r\n</div>\r\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 .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;height:2.5rem}::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:.125rem;color:#747576;font-size:12px;pointer-events:none}::ng-deep .configure-resolution-body .case-calendar.disabled{background:#f2f2f5;pointer-events:none;opacity:1}::ng-deep .configure-resolution-body .case-calendar.disabled .case-calendar-inner input,::ng-deep .configure-resolution-body .case-calendar.disabled .case-calendar-inner 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{border-radius:.25rem;border:1px solid #f2f2f5;margin-bottom:1.5rem}::ng-deep .configure-resolution-table .table-header{background:#fff;border-radius:.25rem .25rem 0 0}::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-row{display:flex;justify-content:space-between;position:relative}::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"] }]
|
|
77
|
-
}], propDecorators: {
|
|
78
|
-
type: Output
|
|
79
|
-
}], datePicker: [{
|
|
239
|
+
args: [{ selector: 'app-due-date', template: "<div class=\"configure-resolution\" [class.animate]=\"animation\">\r\n <div\r\n class=\"configure-resolution-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\"\r\n >\r\n <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">\r\n Configure Resolution Deadline & Stage Details\r\n </div>\r\n </div>\r\n <div class=\"configure-resolution-body\">\r\n <div class=\"configure-resolution-body-inner\">\r\n <app-loader-inline *ngIf=\"false\"></app-loader-inline>\r\n <app-no-data\r\n *ngIf=\"false\"\r\n [noDataImage]=\"\r\n 'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/search-data.svg'\r\n \"\r\n [noDataText]=\"'No data to display'\"\r\n ></app-no-data>\r\n\r\n <ng-container>\r\n <div\r\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\r\n >\r\n SPECIFY THE DEADLINE TO CLOSE THIS CASE\r\n <span class=\"required vx-fs-16 vx-fw-400\">*</span>\r\n </div>\r\n <div\r\n class=\"case-calendar vx-d-flex vx-justify-between vx-pt-3 vx-pb-3 vx-mb-3\"\r\n >\r\n <div class=\"case-calendar-inner vx-d-flex vx-align-center\">\r\n <input\r\n type=\"text\"\r\n readonly\r\n placeholder=\"{{\r\n dueDateTexts.case_details.due_date.deadline_placeholder\r\n }}\"\r\n (click)=\"openDatePicker()\"\r\n [value]=\"dueDate | date : 'dd MMM yyyy'\"\r\n id=\"effective-date\"\r\n />\r\n <i class=\"icons\"></i>\r\n <dp-date-picker\r\n #datePicker\r\n (onSelect)=\"datePickerOverlay = false; closeDatePicker($event)\"\r\n [config]=\"dateConfig\"\r\n [(ngModel)]=\"dueDate\"\r\n >\r\n </dp-date-picker>\r\n <div\r\n class=\"vx-overlay\"\r\n (click)=\"closeDatePicker($event)\"\r\n *ngIf=\"datePickerOverlay\"\r\n ></div>\r\n </div>\r\n </div>\r\n <div *ngIf=\"showError\" class=\"errorMsg vx-fs-11 vx-lh-4 vx-mt-1\">\r\n {{ dueDateTexts.errorMessage.dueDate }}\r\n </div>\r\n <div class=\"vx-d-flex vx-align-center vx-justify-between vx-mb-1\">\r\n <div\r\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-tt-uppercase\"\r\n >\r\n CONFIGURE DEADLINE & ASSIGNEE FOR EACH STAGE IN THE WORKFLOW\r\n <span class=\"required vx-fs-16 vx-fw-400\">*</span>\r\n </div>\r\n <!-- <div class=\"toggle-area vx-d-flex vx-align-center\">\r\n <app-cs-switch>Allow Reopening of Previous Stage</app-cs-switch>\r\n <i\r\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-2\"\r\n [appTooltip]=\"\r\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.'\r\n \"\r\n placement=\"bottom-right\"\r\n delay=\"0\"\r\n type=\"white\"\r\n [tooltipMandatory]=\"true\"\r\n ></i\r\n >\r\n </div> -->\r\n </div>\r\n <div class=\"configure-resolution-table\">\r\n <div class=\"table-header\">\r\n <div class=\"table-row\">\r\n <div\r\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\"\r\n >\r\n #\r\n </div>\r\n <div\r\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\"\r\n >\r\n STAGE NAME\r\n </div>\r\n <div\r\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\"\r\n >\r\n TRANSITION STATUS\r\n <i\r\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\r\n [appTooltip]=\"helperText.transition_status\"\r\n placement=\"bottom\"\r\n delay=\"0\"\r\n type=\"white\"\r\n [tooltipMandatory]=\"true\"\r\n ></i\r\n >\r\n </div>\r\n <div\r\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\"\r\n >\r\n ASSIGNEE\r\n <i\r\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\r\n [appTooltip]=\"helperText.assignee\"\r\n placement=\"bottom\"\r\n delay=\"0\"\r\n type=\"white\"\r\n [tooltipMandatory]=\"true\"\r\n ></i\r\n >\r\n </div>\r\n <div\r\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\"\r\n >\r\n DEADLINE\r\n <i\r\n class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\r\n [appTooltip]=\"helperText.deadline\"\r\n placement=\"bottom\"\r\n delay=\"0\"\r\n type=\"white\"\r\n [tooltipMandatory]=\"true\"\r\n ></i\r\n >\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"table-body\">\r\n <div\r\n class=\"table-row\"\r\n *ngFor=\"\r\n let data of workflowDetails?.stages_assignees;\r\n let i = index\r\n \"\r\n >\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\"\r\n >\r\n <div\r\n class=\"sr-no vx-fs-13 vx-d-flex vx-align-center vx-justify-center\"\r\n [appTooltip]=\"i + 1\"\r\n placement=\"bottom\"\r\n delay=\"0\"\r\n type=\"black\"\r\n [tooltipMandatory]=\"true\"\r\n >\r\n {{ i + 1 }}\r\n </div>\r\n </div>\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center stage-name\"\r\n >\r\n <div\r\n class=\"value vx-fs-13 vx-pr-2\"\r\n [appTooltip]=\"data?.name\"\r\n placement=\"bottom-left\"\r\n delay=\"0\"\r\n type=\"black\"\r\n [tooltipMandatory]=\"false\"\r\n >\r\n {{ data?.name }}\r\n </div>\r\n </div>\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center status\"\r\n >\r\n <div class=\"value vx-fs-12\">\r\n {{ data?.status_transition?.fromName }}<br /><span\r\n class=\"vx-mr-1\"\r\n >To</span\r\n >{{ data?.status_transition?.toName }}\r\n </div>\r\n </div>\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center assignee\"\r\n (click)=\"activateSelector(true, i)\"\r\n >\r\n <div\r\n *ngIf=\"!assigneeData[i]?.length\"\r\n class=\"select-box vx-d-flex vx-align-center vx-justify-between vx-pl-3 vx-pr-3\"\r\n >\r\n <div class=\"value vx-fs-13\">Select a User</div>\r\n <i class=\"icons arrow vx-fs-12\"></i>\r\n </div>\r\n <div\r\n *ngIf=\"assigneeData[i]?.length > 0\"\r\n class=\"after-select-box vx-d-flex vx-align-center vx-justify-between vx-pl-3 vx-pr-2\"\r\n >\r\n <div\r\n class=\"value-chip vx-fs-11 vx-pl-2 vx-pr-2 vx-lh-6\"\r\n [appTooltip]=\"assigneeData[i][0]?.member_name\"\r\n placement=\"bottom-left\"\r\n delay=\"0\"\r\n type=\"black\"\r\n [tooltipMandatory]=\"false\"\r\n >\r\n {{ assigneeData[i][0]?.member_name }}\r\n </div>\r\n <button\r\n (click)=\"activateSelector(true, i)\"\r\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\"\r\n >\r\n <i class=\"icons vx-fs-12 vx-txt-blue vx-mr-1\"></i\r\n >EDIT\r\n </button>\r\n </div>\r\n </div>\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-2 vx-d-flex vx-align-center deadline\"\r\n >\r\n <div\r\n class=\"case-calendar vx-d-flex vx-justify-between vx-pt-3 vx-pb-3\"\r\n [class.disabled]=\"true\"\r\n >\r\n <div class=\"case-calendar-inner vx-d-flex vx-align-center\">\r\n <input\r\n type=\"text\"\r\n readonly\r\n value=\"{{ data?.due_date | date : 'dd MMM yyyy' }}\"\r\n (click)=\"openDatePicker()\"\r\n id=\"effective-date\"\r\n />\r\n <i class=\"icons\"></i>\r\n <dp-date-picker\r\n #datePicker\r\n (onSelect)=\"\r\n datePickerOverlay = false; closeDatePicker($event)\r\n \"\r\n [config]=\"dateConfig\"\r\n >\r\n </dp-date-picker>\r\n <div\r\n class=\"vx-overlay\"\r\n (click)=\"closeDatePicker($event)\"\r\n *ngIf=\"datePickerOverlay\"\r\n ></div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div\r\n *ngIf=\"showAssigneeError\"\r\n class=\"errorMsg vx-fs-11 vx-lh-4 vx-mt-1\"\r\n >\r\n {{ dueDateTexts.errorMessage.stageAssignee }}\r\n </div>\r\n <div\r\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\r\n >\r\n EMAIL REMINDER CONFIGURATION\r\n <span class=\"required vx-fs-16 vx-fw-400\">*</span>\r\n </div>\r\n <div class=\"divider vx-mb-2\"></div>\r\n <div\r\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\r\n >\r\n REMINDER EMAIL\r\n </div>\r\n <div\r\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\"\r\n >\r\n <div class=\"vx-fs-13 vx-mr-1\">\r\n Send regular email reminders to the assignee\r\n </div>\r\n <input\r\n type=\"number\"\r\n [(ngModel)]=\"emailReminder\"\r\n onkeydown=\"return event.key !== '.'\"\r\n oninput=\"this.value = Math.abs(this.value)\"\r\n (change)=\"onInputChange()\"\r\n />\r\n <div class=\"vx-fs-13 vx-ml-1\">\r\n <span class=\"black-text\">days</span> before the stage deadline.\r\n </div>\r\n </div>\r\n <div\r\n class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\r\n >\r\n ESCALATION EMAIL\r\n </div>\r\n <div\r\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\"\r\n >\r\n <div class=\"vx-fs-13 vx-mr-1\">\r\n Send email escalation to the Case Owner\r\n </div>\r\n <input\r\n type=\"number\"\r\n [(ngModel)]=\"escalationEmail\"\r\n onkeydown=\"return event.key !== '.'\"\r\n oninput=\"this.value = Math.abs(this.value)\"\r\n (change)=\"onInputChange()\"\r\n />\r\n <div class=\"vx-fs-13 vx-ml-1\">\r\n <span class=\"black-text\">days</span> before the overall case\r\n deadline, if the case is still open.\r\n </div>\r\n </div>\r\n </ng-container>\r\n </div>\r\n <app-floating-bar\r\n (closeList)=\"closeDueDate()\"\r\n (closeEvent)=\"saveCaseResolutionDeadline()\"\r\n ></app-floating-bar>\r\n </div>\r\n</div>\r\n<app-assignee\r\n *ngIf=\"assigneeClicked\"\r\n [payload]=\"payload\"\r\n [assigneeList]=\"assigneeList\"\r\n [activeAssignee]=\"activeAssignee\"\r\n (selectedAssigneeEvent)=\"selectedAssignee($event)\"\r\n (closeEvent)=\"activateSelector(false)\"\r\n></app-assignee>\r\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;height:2.5rem}::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:.125rem;color:#747576;font-size:12px;pointer-events:none}::ng-deep .configure-resolution-body .case-calendar.disabled{background:#f2f2f5;pointer-events:none;opacity:1}::ng-deep .configure-resolution-body .case-calendar.disabled .case-calendar-inner input,::ng-deep .configure-resolution-body .case-calendar.disabled .case-calendar-inner 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{border-radius:.25rem;border:1px solid #f2f2f5;margin-bottom:1.5rem}::ng-deep .configure-resolution-table .table-header{background:#fff;border-radius:.25rem .25rem 0 0}::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-row{display:flex;justify-content:space-between;position:relative}::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"] }]
|
|
240
|
+
}], ctorParameters: function () { return [{ type: i1.CommonService }, { type: i2.FrequencyService }]; }, propDecorators: { datePicker: [{
|
|
80
241
|
type: ViewChild,
|
|
81
242
|
args: ['datePicker']
|
|
82
|
-
}],
|
|
243
|
+
}], animation: [{
|
|
83
244
|
type: ViewChild,
|
|
84
245
|
args: ['datePicker', { read: ElementRef, static: false }]
|
|
85
246
|
}], payload: [{
|
|
86
247
|
type: Input
|
|
87
248
|
}], dueDate: [{
|
|
88
249
|
type: Input
|
|
250
|
+
}], workflowDetails: [{
|
|
251
|
+
type: Input
|
|
252
|
+
}], userList: [{
|
|
253
|
+
type: Input
|
|
254
|
+
}], groupList: [{
|
|
255
|
+
type: Input
|
|
256
|
+
}], initialSelection: [{
|
|
257
|
+
type: Input
|
|
258
|
+
}], closeDueDateResolution: [{
|
|
259
|
+
type: Output
|
|
260
|
+
}], closeDueDateEvent: [{
|
|
261
|
+
type: Output
|
|
262
|
+
}], documentClick: [{
|
|
263
|
+
type: HostListener,
|
|
264
|
+
args: ['document:click', ['$event']]
|
|
89
265
|
}] } });
|
|
90
|
-
//# 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,GACb,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,WAAW,EAAE,MAAM,uCAAuC,CAAC;AACpE,OAAO,EAAE,WAAW,EAAE,MAAM,uCAAuC,CAAC;;;;;;;;AAOpE,MAAM,OAAO,gBAAgB;IAL7B;QAMY,sBAAiB,GAAG,IAAI,YAAY,EAAE,CAAC;QACjD,cAAS,GAAG,IAAI,CAAC;QAIjB,sBAAiB,GAAG,KAAK,CAAC;QAC1B,eAAU,GAAG;YACX,eAAe,EAAE,IAAI;YACrB,MAAM,EAAE,YAAY;YACpB,eAAe,EAAE,IAAI;YACrB,WAAW,EAAE,KAAK;YAClB,WAAW,EAAE,KAAK;SACnB,CAAC;QAEF,iBAAY,GAAG,WAAW,CAAC;QAC3B,eAAU,GAAG,WAAW,CAAC;KAsD1B;IAjDC,QAAQ;QACN,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,EAAE,gBAAgB,CAAC,CAAC;QAC5C,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACzB,CAAC,EAAE,GAAG,CAAC,CAAC;IACV,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,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC;SAC9B;QACD,IAAI,CAAC,UAAU,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC;IAChC,CAAC;IAED,YAAY;QACV,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,CAAC;IAChC,CAAC;+GArEU,gBAAgB;mGAAhB,gBAAgB,kVAIM,UAAU,6BCtB7C,+oXA2RA;;4FDzQa,gBAAgB;kBAL5B,SAAS;+BACE,cAAc;8BAKd,iBAAiB;sBAA1B,MAAM;gBAEkB,UAAU;sBAAlC,SAAS;uBAAC,YAAY;gBAEvB,eAAe;sBADd,SAAS;uBAAC,YAAY,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE;gBAcnD,OAAO;sBAAf,KAAK;gBACG,OAAO;sBAAf,KAAK","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  Input,\r\n  OnInit,\r\n  ViewChild,\r\n  Output,\r\n  EventEmitter,\r\n} from '@angular/core';\r\nimport { DatePickerComponent } from 'ng2-date-picker';\r\nimport { REPORT_CASE } from '../../constants/report-case.constants';\r\nimport { HELPER_TEXT } from '../../constants/report-case.constants';\r\n\r\n@Component({\r\n  selector: 'app-due-date',\r\n  templateUrl: './due-date.component.html',\r\n  styleUrls: ['./due-date.component.less'],\r\n})\r\nexport class DueDateComponent implements OnInit {\r\n  @Output() closeDueDateEvent = new EventEmitter();\r\n  animation = true;\r\n  @ViewChild('datePicker') datePicker!: DatePickerComponent;\r\n  @ViewChild('datePicker', { read: ElementRef, static: false })\r\n  datePickerPopUp!: ElementRef;\r\n  datePickerOverlay = false;\r\n  dateConfig = {\r\n    disableKeypress: true,\r\n    format: 'DD MM YYYY',\r\n    unSelectOnClick: true,\r\n    openOnClick: false,\r\n    openOnFocus: false,\r\n  };\r\n  commonService: any;\r\n  dueDateTexts = REPORT_CASE;\r\n  helperText = HELPER_TEXT;\r\n\r\n  @Input() payload: any;\r\n  @Input() dueDate: any;\r\n\r\n  ngOnInit(): void {\r\n    console.log(this.payload, 'payloadduedate');\r\n    setTimeout(() => {\r\n      this.animation = false;\r\n    }, 300);\r\n  }\r\n\r\n  openDatePicker() {\r\n    this.datePicker?.api?.open();\r\n    this.datePickerOverlay = true;\r\n  }\r\n\r\n  /**\r\n   * closes the date picker from policy form\r\n   */\r\n  closeDatePicker(evt: any) {\r\n    this.datePickerOverlay = false;\r\n\r\n    if (!evt) {\r\n      return;\r\n    }\r\n    if (evt?.date?.$d) {\r\n      let monthArray = [\r\n        'Jan',\r\n        'Feb',\r\n        'Mar',\r\n        'Apr',\r\n        'Jun',\r\n        'Jul',\r\n        'Aug',\r\n        'Sep',\r\n        'Oct',\r\n        'Nov',\r\n        'Dec',\r\n      ];\r\n      const dateValue = new Date(evt?.date?.$d).getDate();\r\n      const monthValue = monthArray[new Date(evt?.date?.$d).getMonth()];\r\n      const yearValue = new Date(evt?.date?.$d).getFullYear();\r\n      const dateStr = `${dateValue} ${monthValue} ${yearValue}`;\r\n    }\r\n    if (evt?.date?.$d) {\r\n      this.dueDate = evt?.date?.$d;\r\n    }\r\n    this.datePicker?.api?.close();\r\n  }\r\n\r\n  closeDueDate() {\r\n    this.closeDueDateEvent.emit();\r\n  }\r\n}\r\n","<div class=\"configure-resolution\" [class.animate]=\"animation\">\r\n  <div\r\n    class=\"configure-resolution-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\"\r\n  >\r\n    <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">\r\n      Configure Resolution Deadline & Stage Details\r\n    </div>\r\n  </div>\r\n  <div class=\"configure-resolution-body\">\r\n    <div class=\"configure-resolution-body-inner\">\r\n      <app-loader-inline *ngIf=\"false\"></app-loader-inline>\r\n      <app-no-data\r\n        *ngIf=\"false\"\r\n        [noDataImage]=\"\r\n          'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/search-data.svg'\r\n        \"\r\n        [noDataText]=\"'No data to display'\"\r\n      ></app-no-data>\r\n\r\n      <ng-container>\r\n        <div\r\n          class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\r\n        >\r\n          SPECIFY THE DEADLINE TO CLOSE THIS CASE\r\n          <span class=\"required vx-fs-16 vx-fw-400\">*</span>\r\n        </div>\r\n        <div\r\n          class=\"case-calendar vx-d-flex vx-justify-between vx-pt-3 vx-pb-3 vx-mb-3\"\r\n        >\r\n          <div class=\"case-calendar-inner vx-d-flex vx-align-center\">\r\n            <input\r\n              type=\"text\"\r\n              readonly\r\n              placeholder=\"{{\r\n                dueDateTexts.case_details.due_date.deadline_placeholder\r\n              }}\"\r\n              (click)=\"openDatePicker()\"\r\n              [value]=\"dueDate | date : 'dd MMM yyyy'\"\r\n              id=\"effective-date\"\r\n            />\r\n            <i class=\"icons\">&#xe92d;</i>\r\n            <dp-date-picker\r\n              #datePicker\r\n              (onSelect)=\"datePickerOverlay = false; closeDatePicker($event)\"\r\n              [config]=\"dateConfig\"\r\n              [(ngModel)]=\"dueDate\"\r\n            >\r\n            </dp-date-picker>\r\n            <div\r\n              class=\"vx-overlay\"\r\n              (click)=\"closeDatePicker($event)\"\r\n              *ngIf=\"datePickerOverlay\"\r\n            ></div>\r\n          </div>\r\n        </div>\r\n        <div class=\"vx-d-flex vx-align-center vx-justify-between vx-mb-1\">\r\n          <div\r\n            class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-tt-uppercase\"\r\n          >\r\n            CONFIGURE DEADLINE & ASSIGNEE FOR EACH STAGE IN THE WORKFLOW\r\n            <span class=\"required vx-fs-16 vx-fw-400\">*</span>\r\n          </div>\r\n          <!-- <div class=\"toggle-area vx-d-flex vx-align-center\">\r\n            <app-cs-switch>Allow Reopening of Previous Stage</app-cs-switch>\r\n            <i\r\n              class=\"icons info vx-fs-12 vx-txt-blue vx-ml-2\"\r\n              [appTooltip]=\"\r\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.'\r\n              \"\r\n              placement=\"bottom-right\"\r\n              delay=\"0\"\r\n              type=\"white\"\r\n              [tooltipMandatory]=\"true\"\r\n              >&#xe91f;</i\r\n            >\r\n          </div> -->\r\n        </div>\r\n        <div class=\"configure-resolution-table\">\r\n          <div class=\"table-header\">\r\n            <div class=\"table-row\">\r\n              <div\r\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\"\r\n              >\r\n                #\r\n              </div>\r\n              <div\r\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\"\r\n              >\r\n                STAGE NAME\r\n              </div>\r\n              <div\r\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\"\r\n              >\r\n                TRANSITION STATUS\r\n                <i\r\n                  class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\r\n                  [appTooltip]=\"helperText.transition_status\"\r\n                  placement=\"bottom\"\r\n                  delay=\"0\"\r\n                  type=\"white\"\r\n                  [tooltipMandatory]=\"true\"\r\n                  >&#xe91f;</i\r\n                >\r\n              </div>\r\n              <div\r\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\"\r\n              >\r\n                ASSIGNEE\r\n                <i\r\n                  class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\r\n                  [appTooltip]=\"helperText.assignee\"\r\n                  placement=\"bottom\"\r\n                  delay=\"0\"\r\n                  type=\"white\"\r\n                  [tooltipMandatory]=\"true\"\r\n                  >&#xe91f;</i\r\n                >\r\n              </div>\r\n              <div\r\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\"\r\n              >\r\n                DEADLINE\r\n                <i\r\n                  class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\r\n                  [appTooltip]=\"helperText.deadline\"\r\n                  placement=\"bottom\"\r\n                  delay=\"0\"\r\n                  type=\"white\"\r\n                  [tooltipMandatory]=\"true\"\r\n                  >&#xe91f;</i\r\n                >\r\n              </div>\r\n            </div>\r\n          </div>\r\n          <div class=\"table-body\">\r\n            <div class=\"table-row\" *ngFor=\"let data of [1, 1, 1, 1, 1, 1, 1]\">\r\n              <div\r\n                class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\"\r\n              >\r\n                <div\r\n                  class=\"sr-no vx-fs-13 vx-d-flex vx-align-center vx-justify-center\"\r\n                  [appTooltip]=\"'1'\"\r\n                  placement=\"bottom\"\r\n                  delay=\"0\"\r\n                  type=\"black\"\r\n                  [tooltipMandatory]=\"true\"\r\n                >\r\n                  1\r\n                </div>\r\n              </div>\r\n              <div\r\n                class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center stage-name\"\r\n              >\r\n                <div\r\n                  class=\"value vx-fs-13 vx-pr-2\"\r\n                  [appTooltip]=\"'Communication and Reporting'\"\r\n                  placement=\"bottom-left\"\r\n                  delay=\"0\"\r\n                  type=\"black\"\r\n                  [tooltipMandatory]=\"false\"\r\n                >\r\n                  Communication and Reporting\r\n                </div>\r\n              </div>\r\n              <div\r\n                class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center status\"\r\n              >\r\n                <div class=\"value vx-fs-12\">\r\n                  In Progress<br /><span class=\"vx-mr-1\">To</span>Closed\r\n                </div>\r\n              </div>\r\n              <div\r\n                class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center assignee\"\r\n              >\r\n                <div\r\n                  *ngIf=\"true\"\r\n                  class=\"select-box vx-d-flex vx-align-center vx-justify-between vx-pl-3 vx-pr-3\"\r\n                >\r\n                  <div class=\"value vx-fs-13\">Select a User</div>\r\n                  <i class=\"icons arrow vx-fs-12\">&#xe9e8;</i>\r\n                </div>\r\n                <div\r\n                  *ngIf=\"false\"\r\n                  class=\"after-select-box vx-d-flex vx-align-center vx-justify-between vx-pl-3 vx-pr-2\"\r\n                >\r\n                  <div\r\n                    class=\"value-chip vx-fs-11 vx-pl-2 vx-pr-2 vx-lh-6\"\r\n                    [appTooltip]=\"'Samantha Jones'\"\r\n                    placement=\"bottom-left\"\r\n                    delay=\"0\"\r\n                    type=\"black\"\r\n                    [tooltipMandatory]=\"false\"\r\n                  >\r\n                    Samantha Jones\r\n                  </div>\r\n                  <button\r\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\"\r\n                  >\r\n                    <i class=\"icons vx-fs-12 vx-txt-blue vx-mr-1\">&#xe9ba;</i\r\n                    >EDIT\r\n                  </button>\r\n                </div>\r\n              </div>\r\n              <div\r\n                class=\"table-column vx-pl-1 vx-pr-2 vx-d-flex vx-align-center deadline\"\r\n              >\r\n                <div\r\n                  class=\"case-calendar vx-d-flex vx-justify-between vx-pt-3 vx-pb-3\"\r\n                  [class.disabled]=\"true\"\r\n                >\r\n                  <div class=\"case-calendar-inner vx-d-flex vx-align-center\">\r\n                    <input\r\n                      type=\"text\"\r\n                      readonly\r\n                      value=\"30 Dec 2024\"\r\n                      (click)=\"openDatePicker()\"\r\n                      id=\"effective-date\"\r\n                    />\r\n                    <i class=\"icons\">&#xe92d;</i>\r\n                    <dp-date-picker\r\n                      #datePicker\r\n                      (onSelect)=\"\r\n                        datePickerOverlay = false; closeDatePicker($event)\r\n                      \"\r\n                      [config]=\"dateConfig\"\r\n                    >\r\n                    </dp-date-picker>\r\n                    <div\r\n                      class=\"vx-overlay\"\r\n                      (click)=\"closeDatePicker($event)\"\r\n                      *ngIf=\"datePickerOverlay\"\r\n                    ></div>\r\n                  </div>\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n        <div\r\n          class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\r\n        >\r\n          EMAIL REMINDER CONFIGURATION\r\n          <span class=\"required vx-fs-16 vx-fw-400\">*</span>\r\n        </div>\r\n        <div class=\"divider vx-mb-2\"></div>\r\n        <div\r\n          class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\r\n        >\r\n          REMINDER EMAIL\r\n        </div>\r\n        <div\r\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\"\r\n        >\r\n          <div class=\"vx-fs-13 vx-mr-1\">\r\n            Send regular email reminders to the assignee\r\n          </div>\r\n          <input type=\"number\" value=\"5\" />\r\n          <div class=\"vx-fs-13 vx-ml-1\">\r\n            <span class=\"black-text\">days</span> before the stage deadline.\r\n          </div>\r\n        </div>\r\n        <div\r\n          class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\r\n        >\r\n          ESCALATION EMAIL\r\n        </div>\r\n        <div\r\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\"\r\n        >\r\n          <div class=\"vx-fs-13 vx-mr-1\">\r\n            Send email escalation to the Case Owner\r\n          </div>\r\n          <input type=\"number\" value=\"2\" />\r\n          <div class=\"vx-fs-13 vx-ml-1\">\r\n            <span class=\"black-text\">days</span> before the overall case\r\n            deadline, if the case is still open.\r\n          </div>\r\n        </div>\r\n      </ng-container>\r\n    </div>\r\n    <app-floating-bar (closeList)=\"closeDueDate()\"></app-floating-bar>\r\n  </div>\r\n</div>\r\n"]}
|
|
266
|
+
//# 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 {\r\n  Component,\r\n  ElementRef,\r\n  Input,\r\n  OnInit,\r\n  ViewChild,\r\n  Output,\r\n  EventEmitter,\r\n  HostListener,\r\n} from '@angular/core';\r\nimport { DatePickerComponent, IDatePickerConfig } from 'ng2-date-picker';\r\n\r\nimport {\r\n  REPORT_CASE,\r\n  HELPER_TEXT,\r\n  EMAIL_REMINDERS,\r\n} from '../../constants/report-case.constants';\r\n\r\nimport { CommonService } from '../../../services/common.service';\r\nimport { FrequencyService } from '../../../sharedComponents/frequency/frequency.service';\r\n\r\n@Component({\r\n  selector: 'app-due-date',\r\n  templateUrl: './due-date.component.html',\r\n  styleUrls: ['./due-date.component.less'],\r\n})\r\nexport class DueDateComponent implements OnInit {\r\n  @ViewChild('datePicker') datePicker!: DatePickerComponent;\r\n  @ViewChild('datePicker', { read: ElementRef, static: false })\r\n  animation = true;\r\n  datePickerPopUp!: ElementRef;\r\n  datePickerOverlay = false;\r\n  dateConfig: IDatePickerConfig = {\r\n    disableKeypress: true,\r\n    format: 'DD MM YYYY',\r\n    unSelectOnClick: true,\r\n    openOnClick: false,\r\n    openOnFocus: false,\r\n    min: '',\r\n  };\r\n  commonService: any;\r\n  dueDateTexts = REPORT_CASE;\r\n  helperText = HELPER_TEXT;\r\n  assigneeClicked: boolean = false;\r\n  assigneeList: any[] = [];\r\n  assigneeData: { [key: number]: any[] } = {};\r\n  currentStageIndex: number = -1;\r\n  activeAssignee: any[] = [];\r\n  emailReminder: number = EMAIL_REMINDERS.email_reminder;\r\n  escalationEmail: number = EMAIL_REMINDERS.escalation_email_reminder;\r\n  showError: boolean = false;\r\n  showAssigneeError: boolean = false;\r\n\r\n  @Input() payload: any;\r\n  @Input() dueDate: any;\r\n  @Input() workflowDetails: any;\r\n  @Input() userList: any[] = [];\r\n  @Input() groupList: any[] = [];\r\n  @Input() set initialSelection(value: any) {\r\n    this.dueDate = value?.resolution_deadline?.due_date;\r\n    this.emailReminder = value?.resolution_deadline?.assignee_remind_before;\r\n    this.escalationEmail = value?.resolution_deadline?.owner_remind_before;\r\n  }\r\n\r\n  @Output() closeDueDateResolution = new EventEmitter();\r\n  @Output() closeDueDateEvent = new EventEmitter();\r\n\r\n  constructor(\r\n    private commonDateService: CommonService,\r\n    private frequencyService: FrequencyService\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    this.dateConfig.min = this.frequencyService.formatDate();\r\n    setTimeout(() => {\r\n      this.animation = false;\r\n    }, 300);\r\n    this.setAssigneeList();\r\n    this.initializeEditMode();\r\n  }\r\n\r\n  private initializeEditMode() {\r\n    if (!this.payload?.caseToWorkflow?.resolution_deadline) return;\r\n\r\n    const deadline = this.payload.caseToWorkflow.resolution_deadline;\r\n    this.initializeDeadlineValues(deadline);\r\n    this.initializeStageAssignees(deadline);\r\n  }\r\n\r\n  private initializeDeadlineValues(deadline: any) {\r\n    this.dueDate = deadline.due_date ? new Date(deadline.due_date) : null;\r\n    this.emailReminder =\r\n      deadline.assignee_remind_before || EMAIL_REMINDERS.email_reminder;\r\n    this.escalationEmail =\r\n      deadline.owner_remind_before || EMAIL_REMINDERS.escalation_email_reminder;\r\n  }\r\n\r\n  private initializeStageAssignees(deadline: any) {\r\n    if (!deadline?.stages_assignees?.length) return;\r\n\r\n    const stageAssigneeMap = this.createStageAssigneeMap(\r\n      deadline.stages_assignees\r\n    );\r\n    this.mapWorkflowStages(stageAssigneeMap);\r\n  }\r\n\r\n  private createStageAssigneeMap(stagesAssignees: any[]): Map<string, string> {\r\n    return new Map(\r\n      stagesAssignees.map((stage: any) => [stage?.stage_id, stage?.assignee_id])\r\n    );\r\n  }\r\n\r\n  private mapWorkflowStages(stageAssigneeMap: Map<string, string>) {\r\n    this.workflowDetails?.stages_assignees?.forEach(\r\n      (workflowStage: any, index: number) => {\r\n        const assigneeId = stageAssigneeMap?.get(workflowStage?.stage_id);\r\n        if (!assigneeId) return;\r\n\r\n        const assignee = this.assigneeList?.find(\r\n          (assignee: any) => assignee?._id === assigneeId\r\n        );\r\n        if (assignee) {\r\n          this.assigneeData[index] = [assignee];\r\n        }\r\n      }\r\n    );\r\n  }\r\n\r\n  openDatePicker() {\r\n    this.datePicker?.api?.open();\r\n    this.datePickerOverlay = true;\r\n  }\r\n\r\n  /**\r\n   * closes the date picker from policy form\r\n   */\r\n  closeDatePicker(evt: any) {\r\n    this.datePickerOverlay = false;\r\n\r\n    if (!evt) {\r\n      return;\r\n    }\r\n    if (evt?.date?.$d) {\r\n      let monthArray = [\r\n        'Jan',\r\n        'Feb',\r\n        'Mar',\r\n        'Apr',\r\n        'Jun',\r\n        'Jul',\r\n        'Aug',\r\n        'Sep',\r\n        'Oct',\r\n        'Nov',\r\n        'Dec',\r\n      ];\r\n      const dateValue = new Date(evt?.date?.$d).getDate();\r\n      const monthValue = monthArray[new Date(evt?.date?.$d).getMonth()];\r\n      const yearValue = new Date(evt?.date?.$d).getFullYear();\r\n      const dateStr = `${dateValue} ${monthValue} ${yearValue}`;\r\n    }\r\n    if (evt?.date?.$d) {\r\n      this.dueDate = evt?.date?.$d;\r\n      this.showError = false;\r\n    }\r\n    this.datePicker?.api?.close();\r\n  }\r\n\r\n  closeDueDate() {\r\n    this.closeDueDateEvent.emit();\r\n  }\r\n\r\n  activateSelector(active: boolean, stageIndex?: number) {\r\n    this.assigneeClicked = active;\r\n    if (active) {\r\n      this.currentStageIndex = stageIndex ?? -1;\r\n      this.activeAssignee =\r\n        this.currentStageIndex !== -1\r\n          ? this.assigneeData[this.currentStageIndex]\r\n          : [];\r\n    }\r\n  }\r\n\r\n  setAssigneeList() {\r\n    const assigneeIds = this.payload.caseToWorkflow?.assignees;\r\n    this.assigneeList = this.userList\r\n      ?.filter((user: any) => assigneeIds?.includes(user?._id))\r\n      ?.map((user: any) => {\r\n        const userGroups = this.groupList?.filter((group: any) =>\r\n          user?.usergroup_id?.includes(group?.group_id)\r\n        );\r\n\r\n        return {\r\n          ...user,\r\n          associatedGroups: userGroups,\r\n        };\r\n      });\r\n  }\r\n\r\n  selectedAssignee(event: any[]) {\r\n    if (this.currentStageIndex !== -1) {\r\n      this.assigneeData[this.currentStageIndex] = event;\r\n    }\r\n    this.assigneeClicked = false;\r\n    if (event?.length > 0) {\r\n      this.showAssigneeError = false;\r\n    }\r\n  }\r\n\r\n  saveCaseResolutionDeadline() {\r\n    if (!this.isDueDateValid()) {\r\n      this.showError = true;\r\n      return;\r\n    } else if (!this.areAssigneesValid()) {\r\n      this.showAssigneeError = true;\r\n      return;\r\n    }\r\n    this.showError = false;\r\n    this.showAssigneeError = false;\r\n    this.setPayload();\r\n    this.closeDueDateResolution.emit();\r\n  }\r\n\r\n  isDueDateValid(): boolean {\r\n    return !!this.dueDate;\r\n  }\r\n\r\n  areAssigneesValid(): boolean {\r\n    return this.workflowDetails?.stages_assignees?.every(\r\n      (stage: any, index: number) =>\r\n        this.assigneeData[index] && this.assigneeData[index]?.length > 0\r\n    );\r\n  }\r\n\r\n  formatDueDate(date: any): string {\r\n    return new Date(date).toISOString();\r\n  }\r\n\r\n  setDeadlineReminders(): void {\r\n    this.payload.caseToWorkflow.resolution_deadline.assignee_remind_before =\r\n      this.emailReminder;\r\n    this.payload.caseToWorkflow.resolution_deadline.owner_remind_before =\r\n      this.escalationEmail;\r\n  }\r\n\r\n  setStagesAssignees(): any[] {\r\n    return this.workflowDetails?.stages_assignees\r\n      .map((stage: any, index: number) => {\r\n        const assigneeData = this.assigneeData[index];\r\n        return assigneeData\r\n          ? this.createStageAssignee(stage, assigneeData)\r\n          : null;\r\n      })\r\n      .filter(Boolean);\r\n  }\r\n\r\n  createStageAssignee(stage: any, assigneeData: any[]): any {\r\n    return {\r\n      stage_id: stage?.stage_id || '',\r\n      assignee_id: assigneeData[0]?._id || '',\r\n      due_date: stage?.due_date || '',\r\n    };\r\n  }\r\n\r\n  setPayload() {\r\n    const formattedDate = this.formatDueDate(this.dueDate);\r\n    this.payload.caseToWorkflow.resolution_deadline.due_date = formattedDate;\r\n    this.setDeadlineReminders();\r\n    const stagesAssignees = this.setStagesAssignees();\r\n    this.payload.caseToWorkflow.resolution_deadline.stages_assignees =\r\n      stagesAssignees;\r\n    this.payload.caseToWorkflow.workflow_id = this.workflowDetails?._id;\r\n  }\r\n\r\n  @HostListener('document:click', ['$event'])\r\n  documentClick(event: any): void {\r\n    const datePickerObject = {\r\n      event: event,\r\n      class: 'effective-date',\r\n      popup: this.datePickerPopUp,\r\n      component: this.datePicker,\r\n      overlay: this.datePickerOverlay,\r\n    };\r\n    this.commonDateService.handleDocumentClick(datePickerObject);\r\n  }\r\n\r\n  onInputChange() {\r\n    if (this.emailReminder === 0) {\r\n      this.emailReminder = EMAIL_REMINDERS.email_reminder;\r\n    }\r\n    if (this.escalationEmail === 0) {\r\n      this.escalationEmail = EMAIL_REMINDERS.escalation_email_reminder;\r\n    }\r\n  }\r\n}\r\n","<div class=\"configure-resolution\" [class.animate]=\"animation\">\r\n  <div\r\n    class=\"configure-resolution-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\"\r\n  >\r\n    <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">\r\n      Configure Resolution Deadline & Stage Details\r\n    </div>\r\n  </div>\r\n  <div class=\"configure-resolution-body\">\r\n    <div class=\"configure-resolution-body-inner\">\r\n      <app-loader-inline *ngIf=\"false\"></app-loader-inline>\r\n      <app-no-data\r\n        *ngIf=\"false\"\r\n        [noDataImage]=\"\r\n          'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/search-data.svg'\r\n        \"\r\n        [noDataText]=\"'No data to display'\"\r\n      ></app-no-data>\r\n\r\n      <ng-container>\r\n        <div\r\n          class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\r\n        >\r\n          SPECIFY THE DEADLINE TO CLOSE THIS CASE\r\n          <span class=\"required vx-fs-16 vx-fw-400\">*</span>\r\n        </div>\r\n        <div\r\n          class=\"case-calendar vx-d-flex vx-justify-between vx-pt-3 vx-pb-3 vx-mb-3\"\r\n        >\r\n          <div class=\"case-calendar-inner vx-d-flex vx-align-center\">\r\n            <input\r\n              type=\"text\"\r\n              readonly\r\n              placeholder=\"{{\r\n                dueDateTexts.case_details.due_date.deadline_placeholder\r\n              }}\"\r\n              (click)=\"openDatePicker()\"\r\n              [value]=\"dueDate | date : 'dd MMM yyyy'\"\r\n              id=\"effective-date\"\r\n            />\r\n            <i class=\"icons\">&#xe92d;</i>\r\n            <dp-date-picker\r\n              #datePicker\r\n              (onSelect)=\"datePickerOverlay = false; closeDatePicker($event)\"\r\n              [config]=\"dateConfig\"\r\n              [(ngModel)]=\"dueDate\"\r\n            >\r\n            </dp-date-picker>\r\n            <div\r\n              class=\"vx-overlay\"\r\n              (click)=\"closeDatePicker($event)\"\r\n              *ngIf=\"datePickerOverlay\"\r\n            ></div>\r\n          </div>\r\n        </div>\r\n        <div *ngIf=\"showError\" class=\"errorMsg vx-fs-11 vx-lh-4 vx-mt-1\">\r\n          {{ dueDateTexts.errorMessage.dueDate }}\r\n        </div>\r\n        <div class=\"vx-d-flex vx-align-center vx-justify-between vx-mb-1\">\r\n          <div\r\n            class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-tt-uppercase\"\r\n          >\r\n            CONFIGURE DEADLINE & ASSIGNEE FOR EACH STAGE IN THE WORKFLOW\r\n            <span class=\"required vx-fs-16 vx-fw-400\">*</span>\r\n          </div>\r\n          <!-- <div class=\"toggle-area vx-d-flex vx-align-center\">\r\n            <app-cs-switch>Allow Reopening of Previous Stage</app-cs-switch>\r\n            <i\r\n              class=\"icons info vx-fs-12 vx-txt-blue vx-ml-2\"\r\n              [appTooltip]=\"\r\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.'\r\n              \"\r\n              placement=\"bottom-right\"\r\n              delay=\"0\"\r\n              type=\"white\"\r\n              [tooltipMandatory]=\"true\"\r\n              >&#xe91f;</i\r\n            >\r\n          </div> -->\r\n        </div>\r\n        <div class=\"configure-resolution-table\">\r\n          <div class=\"table-header\">\r\n            <div class=\"table-row\">\r\n              <div\r\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\"\r\n              >\r\n                #\r\n              </div>\r\n              <div\r\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\"\r\n              >\r\n                STAGE NAME\r\n              </div>\r\n              <div\r\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\"\r\n              >\r\n                TRANSITION STATUS\r\n                <i\r\n                  class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\r\n                  [appTooltip]=\"helperText.transition_status\"\r\n                  placement=\"bottom\"\r\n                  delay=\"0\"\r\n                  type=\"white\"\r\n                  [tooltipMandatory]=\"true\"\r\n                  >&#xe91f;</i\r\n                >\r\n              </div>\r\n              <div\r\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\"\r\n              >\r\n                ASSIGNEE\r\n                <i\r\n                  class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\r\n                  [appTooltip]=\"helperText.assignee\"\r\n                  placement=\"bottom\"\r\n                  delay=\"0\"\r\n                  type=\"white\"\r\n                  [tooltipMandatory]=\"true\"\r\n                  >&#xe91f;</i\r\n                >\r\n              </div>\r\n              <div\r\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\"\r\n              >\r\n                DEADLINE\r\n                <i\r\n                  class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1\"\r\n                  [appTooltip]=\"helperText.deadline\"\r\n                  placement=\"bottom\"\r\n                  delay=\"0\"\r\n                  type=\"white\"\r\n                  [tooltipMandatory]=\"true\"\r\n                  >&#xe91f;</i\r\n                >\r\n              </div>\r\n            </div>\r\n          </div>\r\n          <div class=\"table-body\">\r\n            <div\r\n              class=\"table-row\"\r\n              *ngFor=\"\r\n                let data of workflowDetails?.stages_assignees;\r\n                let i = index\r\n              \"\r\n            >\r\n              <div\r\n                class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\"\r\n              >\r\n                <div\r\n                  class=\"sr-no vx-fs-13 vx-d-flex vx-align-center vx-justify-center\"\r\n                  [appTooltip]=\"i + 1\"\r\n                  placement=\"bottom\"\r\n                  delay=\"0\"\r\n                  type=\"black\"\r\n                  [tooltipMandatory]=\"true\"\r\n                >\r\n                  {{ i + 1 }}\r\n                </div>\r\n              </div>\r\n              <div\r\n                class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center stage-name\"\r\n              >\r\n                <div\r\n                  class=\"value vx-fs-13 vx-pr-2\"\r\n                  [appTooltip]=\"data?.name\"\r\n                  placement=\"bottom-left\"\r\n                  delay=\"0\"\r\n                  type=\"black\"\r\n                  [tooltipMandatory]=\"false\"\r\n                >\r\n                  {{ data?.name }}\r\n                </div>\r\n              </div>\r\n              <div\r\n                class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center status\"\r\n              >\r\n                <div class=\"value vx-fs-12\">\r\n                  {{ data?.status_transition?.fromName }}<br /><span\r\n                    class=\"vx-mr-1\"\r\n                    >To</span\r\n                  >{{ data?.status_transition?.toName }}\r\n                </div>\r\n              </div>\r\n              <div\r\n                class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center assignee\"\r\n                (click)=\"activateSelector(true, i)\"\r\n              >\r\n                <div\r\n                  *ngIf=\"!assigneeData[i]?.length\"\r\n                  class=\"select-box vx-d-flex vx-align-center vx-justify-between vx-pl-3 vx-pr-3\"\r\n                >\r\n                  <div class=\"value vx-fs-13\">Select a User</div>\r\n                  <i class=\"icons arrow vx-fs-12\">&#xe9e8;</i>\r\n                </div>\r\n                <div\r\n                  *ngIf=\"assigneeData[i]?.length > 0\"\r\n                  class=\"after-select-box vx-d-flex vx-align-center vx-justify-between vx-pl-3 vx-pr-2\"\r\n                >\r\n                  <div\r\n                    class=\"value-chip vx-fs-11 vx-pl-2 vx-pr-2 vx-lh-6\"\r\n                    [appTooltip]=\"assigneeData[i][0]?.member_name\"\r\n                    placement=\"bottom-left\"\r\n                    delay=\"0\"\r\n                    type=\"black\"\r\n                    [tooltipMandatory]=\"false\"\r\n                  >\r\n                    {{ assigneeData[i][0]?.member_name }}\r\n                  </div>\r\n                  <button\r\n                    (click)=\"activateSelector(true, i)\"\r\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\"\r\n                  >\r\n                    <i class=\"icons vx-fs-12 vx-txt-blue vx-mr-1\">&#xe9ba;</i\r\n                    >EDIT\r\n                  </button>\r\n                </div>\r\n              </div>\r\n              <div\r\n                class=\"table-column vx-pl-1 vx-pr-2 vx-d-flex vx-align-center deadline\"\r\n              >\r\n                <div\r\n                  class=\"case-calendar vx-d-flex vx-justify-between vx-pt-3 vx-pb-3\"\r\n                  [class.disabled]=\"true\"\r\n                >\r\n                  <div class=\"case-calendar-inner vx-d-flex vx-align-center\">\r\n                    <input\r\n                      type=\"text\"\r\n                      readonly\r\n                      value=\"{{ data?.due_date | date : 'dd MMM yyyy' }}\"\r\n                      (click)=\"openDatePicker()\"\r\n                      id=\"effective-date\"\r\n                    />\r\n                    <i class=\"icons\">&#xe92d;</i>\r\n                    <dp-date-picker\r\n                      #datePicker\r\n                      (onSelect)=\"\r\n                        datePickerOverlay = false; closeDatePicker($event)\r\n                      \"\r\n                      [config]=\"dateConfig\"\r\n                    >\r\n                    </dp-date-picker>\r\n                    <div\r\n                      class=\"vx-overlay\"\r\n                      (click)=\"closeDatePicker($event)\"\r\n                      *ngIf=\"datePickerOverlay\"\r\n                    ></div>\r\n                  </div>\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n        <div\r\n          *ngIf=\"showAssigneeError\"\r\n          class=\"errorMsg vx-fs-11 vx-lh-4 vx-mt-1\"\r\n        >\r\n          {{ dueDateTexts.errorMessage.stageAssignee }}\r\n        </div>\r\n        <div\r\n          class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\r\n        >\r\n          EMAIL REMINDER CONFIGURATION\r\n          <span class=\"required vx-fs-16 vx-fw-400\">*</span>\r\n        </div>\r\n        <div class=\"divider vx-mb-2\"></div>\r\n        <div\r\n          class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\r\n        >\r\n          REMINDER EMAIL\r\n        </div>\r\n        <div\r\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\"\r\n        >\r\n          <div class=\"vx-fs-13 vx-mr-1\">\r\n            Send regular email reminders to the assignee\r\n          </div>\r\n          <input\r\n            type=\"number\"\r\n            [(ngModel)]=\"emailReminder\"\r\n            onkeydown=\"return event.key !== '.'\"\r\n            oninput=\"this.value = Math.abs(this.value)\"\r\n            (change)=\"onInputChange()\"\r\n          />\r\n          <div class=\"vx-fs-13 vx-ml-1\">\r\n            <span class=\"black-text\">days</span> before the stage deadline.\r\n          </div>\r\n        </div>\r\n        <div\r\n          class=\"label-top vx-fs-11 vx-fw-500 vx-label-txt vx-lh-4 vx-mb-1 vx-tt-uppercase\"\r\n        >\r\n          ESCALATION EMAIL\r\n        </div>\r\n        <div\r\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\"\r\n        >\r\n          <div class=\"vx-fs-13 vx-mr-1\">\r\n            Send email escalation to the Case Owner\r\n          </div>\r\n          <input\r\n            type=\"number\"\r\n            [(ngModel)]=\"escalationEmail\"\r\n            onkeydown=\"return event.key !== '.'\"\r\n            oninput=\"this.value = Math.abs(this.value)\"\r\n            (change)=\"onInputChange()\"\r\n          />\r\n          <div class=\"vx-fs-13 vx-ml-1\">\r\n            <span class=\"black-text\">days</span> before the overall case\r\n            deadline, if the case is still open.\r\n          </div>\r\n        </div>\r\n      </ng-container>\r\n    </div>\r\n    <app-floating-bar\r\n      (closeList)=\"closeDueDate()\"\r\n      (closeEvent)=\"saveCaseResolutionDeadline()\"\r\n    ></app-floating-bar>\r\n  </div>\r\n</div>\r\n<app-assignee\r\n  *ngIf=\"assigneeClicked\"\r\n  [payload]=\"payload\"\r\n  [assigneeList]=\"assigneeList\"\r\n  [activeAssignee]=\"activeAssignee\"\r\n  (selectedAssigneeEvent)=\"selectedAssignee($event)\"\r\n  (closeEvent)=\"activateSelector(false)\"\r\n></app-assignee>\r\n"]}
|