vcomply-workflow-engine 3.6.7 → 3.6.9

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.
@@ -11,13 +11,27 @@ export class CommonService {
11
11
  };
12
12
  }
13
13
  handleDocumentClick(datePickerObject) {
14
- const dateInputElement = document.getElementById(datePickerObject?.class) || null;
15
- const datePickerCalendarContainer = document.getElementsByClassName('dp-day-calendar-container')[0];
16
- const isOutsideFromDateInput = !datePickerObject?.popup?.nativeElement?.contains(datePickerObject?.event?.target);
17
- const isNotFromDateElement = datePickerObject?.event?.target !== dateInputElement;
18
- const isNotInsideCalendar = !datePickerCalendarContainer?.contains(datePickerObject?.event?.target);
19
- if (isOutsideFromDateInput && isNotFromDateElement && isNotInsideCalendar) {
20
- this.closeDatePickerIfOpen(datePickerObject?.event?.target, datePickerObject?.popup, datePickerObject?.overlay, datePickerObject?.component);
14
+ const { event, popup, class: className } = datePickerObject || {};
15
+ const targetElement = event?.target;
16
+ if (!targetElement)
17
+ return false;
18
+ const dateInputElement = document.getElementById(className);
19
+ const datePickerCalendarContainer = document.querySelector(".dp-day-calendar-container");
20
+ const monthYearElement = document.querySelector(".dp-month-calendar-container");
21
+ const isNotMonthYearElement = !monthYearElement?.contains(targetElement);
22
+ const isOutsidePopup = !popup?.nativeElement?.contains(targetElement);
23
+ const isOutsidePopup2 = !popup?.nativeElement?.className.includes("dp-calendar-month");
24
+ const isNotDateInputElement = targetElement !== dateInputElement;
25
+ const isNotInsideCalendar = !datePickerCalendarContainer?.contains(targetElement);
26
+ const isNotCalendarMonth = !targetElement.className.includes("dp-calendar-month");
27
+ if (datePickerCalendarContainer &&
28
+ isNotMonthYearElement &&
29
+ isOutsidePopup &&
30
+ isNotDateInputElement &&
31
+ isNotInsideCalendar &&
32
+ isNotCalendarMonth &&
33
+ isOutsidePopup2) {
34
+ this.closeDatePickerIfOpen(targetElement, popup, datePickerObject?.overlay, datePickerObject?.component);
21
35
  return true;
22
36
  }
23
37
  return false;
@@ -38,4 +52,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
38
52
  providedIn: 'root',
39
53
  }]
40
54
  }] });
41
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92eC13b3JrZmxvdy1lbmdpbmUvc3JjL2xpYi9zZXJ2aWNlcy9jb21tb24uc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWMsVUFBVSxFQUFZLE1BQU0sZUFBZSxDQUFDOztBQUtqRSxNQUFNLE9BQU8sYUFBYTtJQUgxQjtRQUlJLHFCQUFnQixHQUFHO1lBQ2YsS0FBSyxFQUFFLElBQUk7WUFDWCxLQUFLLEVBQUUsRUFBRTtZQUNULEtBQUssRUFBRSxJQUFJO1lBQ1gsU0FBUyxFQUFFLElBQUk7WUFDZixPQUFPLEVBQUUsS0FBSztTQUNqQixDQUFBO0tBMkNKO0lBMUNDLG1CQUFtQixDQUNqQixnQkFBcUI7UUFFckIsTUFBTSxnQkFBZ0IsR0FBRyxRQUFRLENBQUMsY0FBYyxDQUFDLGdCQUFnQixFQUFFLEtBQUssQ0FBQyxJQUFJLElBQUksQ0FBQztRQUNsRixNQUFNLDJCQUEyQixHQUFHLFFBQVEsQ0FBQyxzQkFBc0IsQ0FDakUsMkJBQTJCLENBQzVCLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDTCxNQUFNLHNCQUFzQixHQUFHLENBQUMsZ0JBQWdCLEVBQUUsS0FBSyxFQUFFLGFBQWEsRUFBRSxRQUFRLENBQzlFLGdCQUFnQixFQUFFLEtBQUssRUFBRSxNQUFpQixDQUMzQyxDQUFDO1FBQ0YsTUFBTSxvQkFBb0IsR0FBRyxnQkFBZ0IsRUFBRSxLQUFLLEVBQUUsTUFBTSxLQUFLLGdCQUFnQixDQUFDO1FBQ2xGLE1BQU0sbUJBQW1CLEdBQUcsQ0FBQywyQkFBMkIsRUFBRSxRQUFRLENBQzlELGdCQUFnQixFQUFFLEtBQUssRUFBRSxNQUFpQixDQUM3QyxDQUFDO1FBRUYsSUFBSSxzQkFBc0IsSUFBSSxvQkFBb0IsSUFBSSxtQkFBbUIsRUFBRTtZQUN6RSxJQUFJLENBQUMscUJBQXFCLENBQ3hCLGdCQUFnQixFQUFFLEtBQUssRUFBRSxNQUFNLEVBQy9CLGdCQUFnQixFQUFFLEtBQUssRUFDdkIsZ0JBQWdCLEVBQUUsT0FBTyxFQUN6QixnQkFBZ0IsRUFBRSxTQUFTLENBQzVCLENBQUM7WUFDRixPQUFPLElBQUksQ0FBQztTQUNiO1FBRUQsT0FBTyxLQUFLLENBQUM7SUFDZixDQUFDO0lBRU8scUJBQXFCLENBQzNCLE1BQVcsRUFDWCxhQUF5QixFQUN6QixpQkFBMEIsRUFDMUIsVUFBZTtRQUVmLElBQ0UsQ0FBQyxhQUFhLEVBQUUsYUFBYSxFQUFFLFFBQVEsQ0FBQyxNQUFNLENBQUM7WUFDL0MsVUFBVSxFQUFFLGlCQUFpQixFQUM3QjtZQUNBLFVBQVUsRUFBRSxHQUFHLEVBQUUsS0FBSyxFQUFFLENBQUM7WUFDekIsaUJBQWlCLEdBQUcsS0FBSyxDQUFDO1NBQzNCO0lBQ0gsQ0FBQzsrR0FqRFUsYUFBYTttSEFBYixhQUFhLGNBRlosTUFBTTs7NEZBRVAsYUFBYTtrQkFIekIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFbGVtZW50UmVmLCBJbmplY3RhYmxlLCBPcHRpb25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290JyxcclxufSlcclxuZXhwb3J0IGNsYXNzIENvbW1vblNlcnZpY2Uge1xyXG4gICAgZGF0ZVBpY2tlck9iamVjdCA9IHtcclxuICAgICAgICBldmVudDogbnVsbCxcclxuICAgICAgICBjbGFzczogJycsXHJcbiAgICAgICAgcG9wdXA6IG51bGwsXHJcbiAgICAgICAgY29tcG9uZW50OiBudWxsLFxyXG4gICAgICAgIG92ZXJsYXk6IGZhbHNlLFxyXG4gICAgfVxyXG4gIGhhbmRsZURvY3VtZW50Q2xpY2soXHJcbiAgICBkYXRlUGlja2VyT2JqZWN0OiBhbnlcclxuICApOiBib29sZWFuIHtcclxuICAgIGNvbnN0IGRhdGVJbnB1dEVsZW1lbnQgPSBkb2N1bWVudC5nZXRFbGVtZW50QnlJZChkYXRlUGlja2VyT2JqZWN0Py5jbGFzcykgfHwgbnVsbDtcclxuICAgIGNvbnN0IGRhdGVQaWNrZXJDYWxlbmRhckNvbnRhaW5lciA9IGRvY3VtZW50LmdldEVsZW1lbnRzQnlDbGFzc05hbWUoXHJcbiAgICAgICdkcC1kYXktY2FsZW5kYXItY29udGFpbmVyJ1xyXG4gICAgKVswXTtcclxuICAgIGNvbnN0IGlzT3V0c2lkZUZyb21EYXRlSW5wdXQgPSAhZGF0ZVBpY2tlck9iamVjdD8ucG9wdXA/Lm5hdGl2ZUVsZW1lbnQ/LmNvbnRhaW5zKFxyXG4gICAgICBkYXRlUGlja2VyT2JqZWN0Py5ldmVudD8udGFyZ2V0IGFzIEVsZW1lbnRcclxuICAgICk7XHJcbiAgICBjb25zdCBpc05vdEZyb21EYXRlRWxlbWVudCA9IGRhdGVQaWNrZXJPYmplY3Q/LmV2ZW50Py50YXJnZXQgIT09IGRhdGVJbnB1dEVsZW1lbnQ7XHJcbiAgICBjb25zdCBpc05vdEluc2lkZUNhbGVuZGFyID0gIWRhdGVQaWNrZXJDYWxlbmRhckNvbnRhaW5lcj8uY29udGFpbnMoXHJcbiAgICAgICAgZGF0ZVBpY2tlck9iamVjdD8uZXZlbnQ/LnRhcmdldCBhcyBFbGVtZW50XHJcbiAgICApO1xyXG5cclxuICAgIGlmIChpc091dHNpZGVGcm9tRGF0ZUlucHV0ICYmIGlzTm90RnJvbURhdGVFbGVtZW50ICYmIGlzTm90SW5zaWRlQ2FsZW5kYXIpIHtcclxuICAgICAgdGhpcy5jbG9zZURhdGVQaWNrZXJJZk9wZW4oXHJcbiAgICAgICAgZGF0ZVBpY2tlck9iamVjdD8uZXZlbnQ/LnRhcmdldCxcclxuICAgICAgICBkYXRlUGlja2VyT2JqZWN0Py5wb3B1cCxcclxuICAgICAgICBkYXRlUGlja2VyT2JqZWN0Py5vdmVybGF5LFxyXG4gICAgICAgIGRhdGVQaWNrZXJPYmplY3Q/LmNvbXBvbmVudFxyXG4gICAgICApO1xyXG4gICAgICByZXR1cm4gdHJ1ZTtcclxuICAgIH1cclxuXHJcbiAgICByZXR1cm4gZmFsc2U7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIGNsb3NlRGF0ZVBpY2tlcklmT3BlbihcclxuICAgIHRhcmdldDogYW55LFxyXG4gICAgb3BlbmVkRWxlbWVudDogRWxlbWVudFJlZixcclxuICAgIGRhdGVQaWNrZXJPdmVybGF5OiBib29sZWFuLFxyXG4gICAgRGF0ZVBpY2tlcjogYW55XHJcbiAgKTogdm9pZCB7XHJcbiAgICBpZiAoXHJcbiAgICAgICFvcGVuZWRFbGVtZW50Py5uYXRpdmVFbGVtZW50Py5jb250YWlucyh0YXJnZXQpICYmXHJcbiAgICAgIERhdGVQaWNrZXI/LmFyZUNhbGVuZGFyc1Nob3duXHJcbiAgICApIHtcclxuICAgICAgRGF0ZVBpY2tlcj8uYXBpPy5jbG9zZSgpO1xyXG4gICAgICBkYXRlUGlja2VyT3ZlcmxheSA9IGZhbHNlO1xyXG4gICAgfVxyXG4gIH1cclxufVxyXG4iXX0=
55
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92eC13b3JrZmxvdy1lbmdpbmUvc3JjL2xpYi9zZXJ2aWNlcy9jb21tb24uc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWMsVUFBVSxFQUFZLE1BQU0sZUFBZSxDQUFDOztBQUtqRSxNQUFNLE9BQU8sYUFBYTtJQUgxQjtRQUlJLHFCQUFnQixHQUFHO1lBQ2YsS0FBSyxFQUFFLElBQUk7WUFDWCxLQUFLLEVBQUUsRUFBRTtZQUNULEtBQUssRUFBRSxJQUFJO1lBQ1gsU0FBUyxFQUFFLElBQUk7WUFDZixPQUFPLEVBQUUsS0FBSztTQUNqQixDQUFBO0tBNERKO0lBM0RHLG1CQUFtQixDQUFDLGdCQUFxQjtRQUN2QyxNQUFNLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsU0FBUyxFQUFFLEdBQUcsZ0JBQWdCLElBQUksRUFBRSxDQUFDO1FBQ2xFLE1BQU0sYUFBYSxHQUFHLEtBQUssRUFBRSxNQUFpQixDQUFDO1FBRS9DLElBQUksQ0FBQyxhQUFhO1lBQUUsT0FBTyxLQUFLLENBQUM7UUFFakMsTUFBTSxnQkFBZ0IsR0FBRyxRQUFRLENBQUMsY0FBYyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQzVELE1BQU0sMkJBQTJCLEdBQUcsUUFBUSxDQUFDLGFBQWEsQ0FDeEQsNEJBQTRCLENBQzdCLENBQUM7UUFDRixNQUFNLGdCQUFnQixHQUFHLFFBQVEsQ0FBQyxhQUFhLENBQzdDLDhCQUE4QixDQUMvQixDQUFDO1FBRUYsTUFBTSxxQkFBcUIsR0FBRyxDQUFDLGdCQUFnQixFQUFFLFFBQVEsQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUN6RSxNQUFNLGNBQWMsR0FBRyxDQUFDLEtBQUssRUFBRSxhQUFhLEVBQUUsUUFBUSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQ3RFLE1BQU0sZUFBZSxHQUFHLENBQUMsS0FBSyxFQUFFLGFBQWEsRUFBRSxTQUFTLENBQUMsUUFBUSxDQUFDLG1CQUFtQixDQUFDLENBQUM7UUFFdkYsTUFBTSxxQkFBcUIsR0FBRyxhQUFhLEtBQUssZ0JBQWdCLENBQUM7UUFDakUsTUFBTSxtQkFBbUIsR0FDdkIsQ0FBQywyQkFBMkIsRUFBRSxRQUFRLENBQUMsYUFBYSxDQUFDLENBQUM7UUFDeEQsTUFBTSxrQkFBa0IsR0FDdEIsQ0FBQyxhQUFhLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO1FBRXpELElBQ0UsMkJBQTJCO1lBQzNCLHFCQUFxQjtZQUNyQixjQUFjO1lBQ2QscUJBQXFCO1lBQ3JCLG1CQUFtQjtZQUNuQixrQkFBa0I7WUFDbEIsZUFBZSxFQUNmO1lBQ0EsSUFBSSxDQUFDLHFCQUFxQixDQUN4QixhQUFhLEVBQ2IsS0FBSyxFQUNMLGdCQUFnQixFQUFFLE9BQU8sRUFDekIsZ0JBQWdCLEVBQUUsU0FBUyxDQUM1QixDQUFDO1lBQ0YsT0FBTyxJQUFJLENBQUM7U0FDYjtRQUVELE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUVLLHFCQUFxQixDQUMzQixNQUFXLEVBQ1gsYUFBeUIsRUFDekIsaUJBQTBCLEVBQzFCLFVBQWU7UUFFZixJQUNFLENBQUMsYUFBYSxFQUFFLGFBQWEsRUFBRSxRQUFRLENBQUMsTUFBTSxDQUFDO1lBQy9DLFVBQVUsRUFBRSxpQkFBaUIsRUFDN0I7WUFDQSxVQUFVLEVBQUUsR0FBRyxFQUFFLEtBQUssRUFBRSxDQUFDO1lBQ3pCLGlCQUFpQixHQUFHLEtBQUssQ0FBQztTQUMzQjtJQUNILENBQUM7K0dBbEVVLGFBQWE7bUhBQWIsYUFBYSxjQUZaLE1BQU07OzRGQUVQLGFBQWE7a0JBSHpCLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRWxlbWVudFJlZiwgSW5qZWN0YWJsZSwgT3B0aW9uYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCcsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDb21tb25TZXJ2aWNlIHtcclxuICAgIGRhdGVQaWNrZXJPYmplY3QgPSB7XHJcbiAgICAgICAgZXZlbnQ6IG51bGwsXHJcbiAgICAgICAgY2xhc3M6ICcnLFxyXG4gICAgICAgIHBvcHVwOiBudWxsLFxyXG4gICAgICAgIGNvbXBvbmVudDogbnVsbCxcclxuICAgICAgICBvdmVybGF5OiBmYWxzZSxcclxuICAgIH1cclxuICAgIGhhbmRsZURvY3VtZW50Q2xpY2soZGF0ZVBpY2tlck9iamVjdDogYW55KTogYm9vbGVhbiB7XHJcbiAgICAgIGNvbnN0IHsgZXZlbnQsIHBvcHVwLCBjbGFzczogY2xhc3NOYW1lIH0gPSBkYXRlUGlja2VyT2JqZWN0IHx8IHt9O1xyXG4gICAgICBjb25zdCB0YXJnZXRFbGVtZW50ID0gZXZlbnQ/LnRhcmdldCBhcyBFbGVtZW50O1xyXG4gIFxyXG4gICAgICBpZiAoIXRhcmdldEVsZW1lbnQpIHJldHVybiBmYWxzZTtcclxuICBcclxuICAgICAgY29uc3QgZGF0ZUlucHV0RWxlbWVudCA9IGRvY3VtZW50LmdldEVsZW1lbnRCeUlkKGNsYXNzTmFtZSk7XHJcbiAgICAgIGNvbnN0IGRhdGVQaWNrZXJDYWxlbmRhckNvbnRhaW5lciA9IGRvY3VtZW50LnF1ZXJ5U2VsZWN0b3IoXHJcbiAgICAgICAgXCIuZHAtZGF5LWNhbGVuZGFyLWNvbnRhaW5lclwiXHJcbiAgICAgICk7XHJcbiAgICAgIGNvbnN0IG1vbnRoWWVhckVsZW1lbnQgPSBkb2N1bWVudC5xdWVyeVNlbGVjdG9yKFxyXG4gICAgICAgIFwiLmRwLW1vbnRoLWNhbGVuZGFyLWNvbnRhaW5lclwiXHJcbiAgICAgICk7XHJcbiAgXHJcbiAgICAgIGNvbnN0IGlzTm90TW9udGhZZWFyRWxlbWVudCA9ICFtb250aFllYXJFbGVtZW50Py5jb250YWlucyh0YXJnZXRFbGVtZW50KTtcclxuICAgICAgY29uc3QgaXNPdXRzaWRlUG9wdXAgPSAhcG9wdXA/Lm5hdGl2ZUVsZW1lbnQ/LmNvbnRhaW5zKHRhcmdldEVsZW1lbnQpO1xyXG4gICAgICBjb25zdCBpc091dHNpZGVQb3B1cDIgPSAhcG9wdXA/Lm5hdGl2ZUVsZW1lbnQ/LmNsYXNzTmFtZS5pbmNsdWRlcyhcImRwLWNhbGVuZGFyLW1vbnRoXCIpO1xyXG4gIFxyXG4gICAgICBjb25zdCBpc05vdERhdGVJbnB1dEVsZW1lbnQgPSB0YXJnZXRFbGVtZW50ICE9PSBkYXRlSW5wdXRFbGVtZW50O1xyXG4gICAgICBjb25zdCBpc05vdEluc2lkZUNhbGVuZGFyID1cclxuICAgICAgICAhZGF0ZVBpY2tlckNhbGVuZGFyQ29udGFpbmVyPy5jb250YWlucyh0YXJnZXRFbGVtZW50KTtcclxuICAgICAgY29uc3QgaXNOb3RDYWxlbmRhck1vbnRoID1cclxuICAgICAgICAhdGFyZ2V0RWxlbWVudC5jbGFzc05hbWUuaW5jbHVkZXMoXCJkcC1jYWxlbmRhci1tb250aFwiKTtcclxuICBcclxuICAgICAgaWYgKFxyXG4gICAgICAgIGRhdGVQaWNrZXJDYWxlbmRhckNvbnRhaW5lciAmJlxyXG4gICAgICAgIGlzTm90TW9udGhZZWFyRWxlbWVudCAmJlxyXG4gICAgICAgIGlzT3V0c2lkZVBvcHVwICYmXHJcbiAgICAgICAgaXNOb3REYXRlSW5wdXRFbGVtZW50ICYmXHJcbiAgICAgICAgaXNOb3RJbnNpZGVDYWxlbmRhciAmJlxyXG4gICAgICAgIGlzTm90Q2FsZW5kYXJNb250aCAmJlxyXG4gICAgICAgIGlzT3V0c2lkZVBvcHVwMlxyXG4gICAgICApIHtcclxuICAgICAgICB0aGlzLmNsb3NlRGF0ZVBpY2tlcklmT3BlbihcclxuICAgICAgICAgIHRhcmdldEVsZW1lbnQsXHJcbiAgICAgICAgICBwb3B1cCxcclxuICAgICAgICAgIGRhdGVQaWNrZXJPYmplY3Q/Lm92ZXJsYXksXHJcbiAgICAgICAgICBkYXRlUGlja2VyT2JqZWN0Py5jb21wb25lbnRcclxuICAgICAgICApO1xyXG4gICAgICAgIHJldHVybiB0cnVlO1xyXG4gICAgICB9XHJcbiAgXHJcbiAgICAgIHJldHVybiBmYWxzZTtcclxuICAgIH1cclxuXHJcbiAgcHJpdmF0ZSBjbG9zZURhdGVQaWNrZXJJZk9wZW4oXHJcbiAgICB0YXJnZXQ6IGFueSxcclxuICAgIG9wZW5lZEVsZW1lbnQ6IEVsZW1lbnRSZWYsXHJcbiAgICBkYXRlUGlja2VyT3ZlcmxheTogYm9vbGVhbixcclxuICAgIERhdGVQaWNrZXI6IGFueVxyXG4gICk6IHZvaWQge1xyXG4gICAgaWYgKFxyXG4gICAgICAhb3BlbmVkRWxlbWVudD8ubmF0aXZlRWxlbWVudD8uY29udGFpbnModGFyZ2V0KSAmJlxyXG4gICAgICBEYXRlUGlja2VyPy5hcmVDYWxlbmRhcnNTaG93blxyXG4gICAgKSB7XHJcbiAgICAgIERhdGVQaWNrZXI/LmFwaT8uY2xvc2UoKTtcclxuICAgICAgZGF0ZVBpY2tlck92ZXJsYXkgPSBmYWxzZTtcclxuICAgIH1cclxuICB9XHJcbn1cclxuIl19
@@ -1,6 +1,7 @@
1
1
  import { Component, ViewChild, Input, Output, EventEmitter, HostListener, ElementRef, } from '@angular/core';
2
2
  import moment from 'moment/moment';
3
3
  import { lifecycleText } from './lifecycl.constant';
4
+ import dayjs from 'dayjs';
4
5
  import * as i0 from "@angular/core";
5
6
  import * as i1 from "../frequency.service";
6
7
  import * as i2 from "@angular/forms";
@@ -48,6 +49,7 @@ export class FrequencyLifecycleComponent {
48
49
  }
49
50
  changeEndDateObj(date) {
50
51
  this.endDateObject = new Date(moment(date).unix() * 1000);
52
+ this.selectedEndDate = moment(this.endDate).unix();
51
53
  }
52
54
  ngOnChanges(change) {
53
55
  this.endBy = moment(this.endDate)
@@ -55,16 +57,16 @@ export class FrequencyLifecycleComponent {
55
57
  .split('T')[0];
56
58
  }
57
59
  openDatePicker() {
58
- const newDate = moment(this.startDate);
59
- this.startDatePicker?.api?.moveCalendarTo(newDate);
60
+ const newDate = dayjs(this.startDate);
60
61
  this.startDatePicker?.api?.open();
62
+ this.startDatePicker?.api?.moveCalendarTo(newDate);
61
63
  this.datePickerOverlay = true;
62
64
  this.openedDatePicker = 'START_DATE';
63
65
  }
64
66
  openDatePicker1() {
65
67
  const newDate = moment(this.endDate);
66
- this.endDatePicker?.api?.moveCalendarTo(newDate);
67
68
  this.endDatePicker?.api?.open();
69
+ this.endDatePicker?.api?.moveCalendarTo(this.endDate);
68
70
  this.openedDatePicker = 'END_DATE';
69
71
  this.datePickerOverlay = true;
70
72
  }
@@ -136,18 +138,27 @@ export class FrequencyLifecycleComponent {
136
138
  });
137
139
  }
138
140
  documentClick(event) {
141
+ const targetElement = event?.target;
139
142
  const fromDateInputElement = document.getElementById(this.openedDatePicker.toLowerCase()) || null;
140
143
  const datePickerCalendarContainer = document.getElementsByClassName('dp-day-calendar-container')[0];
144
+ const monthYearElement = document.querySelector('.dp-month-calendar-container');
145
+ const isNotMonthYearElement = !monthYearElement?.contains(targetElement);
141
146
  const openedElement = this.openedDatePicker === 'START_DATE'
142
147
  ? this.startDatePickerPopup
143
148
  : this.endDatePickerPopup;
144
- const isOutsideFromDateInput = !openedElement?.nativeElement?.contains(event?.target);
149
+ const isOutsideFromDateInput = !openedElement?.nativeElement?.contains(targetElement);
145
150
  const isNotFromDateElement = event?.target !== fromDateInputElement;
146
- const isNotInsideCalendar = !datePickerCalendarContainer?.contains(event?.target);
151
+ const isNotInsideCalendar = !datePickerCalendarContainer?.contains(targetElement);
147
152
  const selectedDatePicker = this.openedDatePicker === 'START_DATE'
148
153
  ? this.startDatePicker
149
154
  : this.endDatePicker;
150
- if (isOutsideFromDateInput && isNotFromDateElement && isNotInsideCalendar) {
155
+ const isNotCalendarMonth = !targetElement.className.includes('dp-calendar-month');
156
+ if (isOutsideFromDateInput &&
157
+ isNotFromDateElement &&
158
+ isNotInsideCalendar &&
159
+ isNotCalendarMonth &&
160
+ isNotMonthYearElement &&
161
+ datePickerCalendarContainer) {
151
162
  this.documentClickListener(event?.target, openedElement, selectedDatePicker);
152
163
  }
153
164
  }
@@ -196,4 +207,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
196
207
  type: HostListener,
197
208
  args: ['document:click', ['$event']]
198
209
  }] } });
199
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"frequency-lifecycle.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency/frequency-lifecycle/frequency-lifecycle.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency/frequency-lifecycle/frequency-lifecycle.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EAET,SAAS,EACT,KAAK,EACL,MAAM,EACN,YAAY,EAGZ,YAAY,EACZ,UAAU,GACX,MAAM,eAAe,CAAC;AAEvB,OAAO,MAAM,MAAM,eAAe,CAAC;AAEnC,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;;;;;;;AAQpD,MAAM,OAAO,2BAA2B;IAgCtC,YAAoB,gBAAkC;QAAlC,qBAAgB,GAAhB,gBAAgB,CAAkB;QA5BtD,sBAAiB,GAAG,KAAK,CAAC;QAC1B,kBAAa,GAAG,KAAK,CAAC;QACtB,kBAAa,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAO3B,qBAAqB;QACZ,cAAS,GAAG,IAAI,IAAI,EAAE,CAAC;QACvB,YAAO,GAAG,MAAM,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,GAAG,QAAQ,CAAC,CAAC;QAEhE,eAAU,GAAG,EAAE,CAAC;QAChB,0BAAqB,GAAG,CAAC,CAAC,CAAC,yCAAyC;QACpE,OAAE,GAAG,CAAC,CAAC;QAGhB,oBAAoB;QACV,sBAAiB,GAAG,IAAI,YAAY,EAAO,CAAC;QAOtD,qBAAgB,GAAW,EAAE,CAAC;IAE2B,CAAC;IAE1D,QAAQ;QACN,IAAI,CAAC,WAAW,GAAG,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC5C,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC,MAAM,CAAC;YACnC,GAAG,IAAI,CAAC,gBAAgB,CAAC,UAAU;SACpC,CAAC,CAAC;QACH,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,GAAG,IAAI,CAAC,gBAAgB,CAAC,UAAU,EAAE,CAAC,CAAC;QAC5E,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,gBAAgB,CAAC,UAAU,EAAE,CAAC;QACjE,0DAA0D;QAC1D,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,GAAG,MAAM,CAChC,IAAI,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,GAAG,QAAQ,CAAC,CACxD,CAAC;QACF,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAChC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACtC,CAAC;IAED,UAAU,CAAC,KAAU;QACnB,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,qBAAqB,CAAC,CAAC;QAChE,MAAM,WAAW,GAAG,MAAM,CACxB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,WAAW,EAChC,qBAAqB,CACtB,CAAC,IAAI,EAAE,CAAC;QACT,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,IAAI,EAAE,CAAC;QAC1C,IAAI,IAAI,CAAC,aAAa,IAAI,WAAW,EAAE;YACrC,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,GAAG,QAAQ,CAAC,CAAC;SACtE;aAAM;YACL,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;SACrC;IACH,CAAC;IAED,gBAAgB,CAAC,IAAS;QACxB,IAAI,CAAC,aAAa,GAAG,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,GAAG,IAAI,CAAC,CAAC;IAC5D,CAAC;IAED,WAAW,CAAC,MAAqB;QAC/B,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC;aAC9B,MAAM,CAAC,wBAAwB,CAAC;aAChC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IACnB,CAAC;IAED,cAAc;QACZ,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACvC,IAAI,CAAC,eAAe,EAAE,GAAG,EAAE,cAAc,CAAC,OAA8B,CAAC,CAAC;QAC1E,IAAI,CAAC,eAAe,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC;QAClC,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAC9B,IAAI,CAAC,gBAAgB,GAAG,YAAY,CAAC;IACvC,CAAC;IACD,eAAe;QACb,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACrC,IAAI,CAAC,aAAa,EAAE,GAAG,EAAE,cAAc,CAAC,OAA8B,CAAC,CAAC;QACxE,IAAI,CAAC,aAAa,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC;QAChC,IAAI,CAAC,gBAAgB,GAAG,UAAU,CAAC;QACnC,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;IAChC,CAAC;IACD,eAAe;QACb,IAAI,CAAC,eAAe,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC;QACnC,IAAI,CAAC,aAAa,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC;QACjC,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;IACjC,CAAC;IAED,iBAAiB;IACjB,YAAY,CAAC,KAAU;QACrB,IAAI,CAAC,qBAAqB,GAAG,KAAK,CAAC;QACnC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC;YAC1B,IAAI,EAAE,KAAK;YACX,MAAM,EAAE,IAAI,CAAC,KAAK;YAClB,QAAQ,EAAE,IAAI,CAAC,UAAU;YACzB,SAAS,EAAE,IAAI,CAAC,aAAa;SAC9B,CAAC,CAAC;QACH,OAAO,IAAI,CAAC,qBAAqB,CAAC;IACpC,CAAC;IAED,uBAAuB;IACvB,SAAS,CAAC,KAAU;QAClB,IACE,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACtC,IAAI,CAAC,UAAU,KAAK,CAAC;YACrB,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAC3B;YACA,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC;gBAC1B,IAAI,EAAE,IAAI,CAAC,qBAAqB;gBAChC,MAAM,EAAE,IAAI,CAAC,KAAK;gBAClB,QAAQ,EAAE,IAAI,CAAC,UAAU;gBACzB,SAAS,EAAE,IAAI,CAAC,aAAa;aAC9B,CAAC,CAAC;SACJ;aAAM;YACL,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;SACtB;QACD,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED,gBAAgB;IAChB,WAAW,CAAC,KAAU;QACpB,IAAI,CAAC,aAAa,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC;QAChC,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAC9B,IAAI,CAAC,OAAO,GAAG,KAAK,EAAE,IAAI,EAAE,EAAE,CAAC;QAC/B,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC;QACnD,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACpC,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;QAC5D,MAAM,UAAU,GAAG;YACjB,IAAI,EAAE,IAAI,CAAC,qBAAqB;YAChC,MAAM,EAAE,IAAI,CAAC,KAAK;YAClB,QAAQ,EAAE,IAAI,CAAC,UAAU;YACzB,SAAS,EAAE,IAAI,CAAC,aAAa;SAC9B,CAAC;QACF,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC1C,CAAC;IAED,0BAA0B;IAC1B,eAAe,CAAC,KAAU;QACxB,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC;QACpD,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,eAAe,EAAE;YAC9C,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,aAAa,GAAG,IAAI,GAAG,QAAQ,CAAC,CAAC;YAE5D,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACpC,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC;iBAC9B,MAAM,CAAC,wBAAwB,CAAC;iBAChC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;SAClB;QACD,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,GAAG,MAAM,CAAC,MAAM,CACvC,MAAM,CAAC,IAAI,IAAI,CAAC,IAAI,IAAI,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC,OAAO,EAAE,GAAG,QAAQ,CAAC,CAAC,CACjE,CAAC;QACF,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC;YAC1B,IAAI,EAAE,IAAI,CAAC,qBAAqB;YAChC,MAAM,EAAE,IAAI,CAAC,KAAK;YAClB,QAAQ,EAAE,IAAI,CAAC,UAAU;YACzB,SAAS,EAAE,IAAI,CAAC,aAAa;SAC9B,CAAC,CAAC;IACL,CAAC;IAED,aAAa,CAAC,KAAU;QACtB,MAAM,oBAAoB,GAAG,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,CAAC,IAAI,IAAI,CAAC;QAElG,MAAM,2BAA2B,GAAG,QAAQ,CAAC,sBAAsB,CACjE,2BAA2B,CAC5B,CAAC,CAAC,CAAC,CAAC;QAEL,MAAM,aAAa,GACjB,IAAI,CAAC,gBAAgB,KAAK,YAAY;YACpC,CAAC,CAAC,IAAI,CAAC,oBAAoB;YAC3B,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC;QAC1B,MAAM,sBAAsB,GAAG,CAAC,aAAa,EAAE,aAAa,EAAE,QAAQ,CACpE,KAAK,EAAE,MAAiB,CACzB,CAAC;QACF,MAAM,oBAAoB,GAAG,KAAK,EAAE,MAAM,KAAK,oBAAoB,CAAC;QACpE,MAAM,mBAAmB,GAAG,CAAC,2BAA2B,EAAE,QAAQ,CAChE,KAAK,EAAE,MAAiB,CACzB,CAAC;QACF,MAAM,kBAAkB,GACtB,IAAI,CAAC,gBAAgB,KAAK,YAAY;YACpC,CAAC,CAAC,IAAI,CAAC,eAAe;YACtB,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC;QAGrB,IAAI,sBAAsB,IAAI,oBAAoB,IAAI,mBAAmB,EAAE;YACzE,IAAI,CAAC,qBAAqB,CACxB,KAAK,EAAE,MAAM,EACb,aAAa,EACb,kBAAkB,CACnB,CAAC;SACH;IACX,CAAC;IAED,qBAAqB,CACnB,MAAW,EACX,cAA0B,EAC1B,kBAAuB;QAEvB,IACE,CAAC,cAAc,EAAE,aAAa,EAAE,QAAQ,CAAC,MAAM,CAAC;YAChD,kBAAkB,EAAE,iBAAiB,EACrC;YACA,kBAAkB,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC;YACjC,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;SAChC;IACH,CAAC;+GAhNU,2BAA2B;mGAA3B,2BAA2B,4oBAyBA,UAAU,8GAEZ,UAAU,kDClDhD,qoJAyIA;;4FDlHa,2BAA2B;kBALvC,SAAS;+BACE,yBAAyB;uGAKL,eAAe;sBAA5C,SAAS;uBAAC,iBAAiB;gBACA,aAAa;sBAAxC,SAAS;uBAAC,eAAe;gBAYjB,SAAS;sBAAjB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,qBAAqB;sBAA7B,KAAK;gBACG,EAAE;sBAAV,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBAGI,iBAAiB;sBAA1B,MAAM;gBAGP,oBAAoB;sBADnB,SAAS;uBAAC,iBAAiB,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE;gBAGjE,kBAAkB;sBADjB,SAAS;uBAAC,eAAe,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE;gBAwI/D,aAAa;sBADZ,YAAY;uBAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  ViewChild,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  SimpleChanges,\r\n  OnChanges,\r\n  HostListener,\r\n  ElementRef,\r\n} from '@angular/core';\r\nimport { DatePickerComponent, SingleCalendarValue } from 'ng2-date-picker';\r\nimport moment from 'moment/moment';\r\nimport { FrequencyService } from '../frequency.service';\r\nimport { lifecycleText } from './lifecycl.constant';\r\nimport dayjs from 'dayjs';\r\n\r\n@Component({\r\n  selector: 'app-frequency-lifecycle',\r\n  templateUrl: './frequency-lifecycle.component.html',\r\n  styleUrls: ['./frequency-lifecycle.component.less'],\r\n})\r\nexport class FrequencyLifecycleComponent implements OnInit, OnChanges {\r\n  @ViewChild('startDatePicker') startDatePicker!: DatePickerComponent;\r\n  @ViewChild('endDatePicker') endDatePicker!: DatePickerComponent;\r\n\r\n  datePickerOverlay = false;\r\n  showDateError = false;\r\n  startDateUnix = Date.now();\r\n  endDateObject: any;\r\n  startDateConfig: any;\r\n  endDateConfig: any;\r\n  textDetails: any;\r\n  selectedEndDate: any;\r\n\r\n  // All input variable\r\n  @Input() startDate = new Date();\r\n  @Input() endDate = moment(new Date(this.startDate).getTime() + 86400000);\r\n  @Input() endBy: any;\r\n  @Input() occurrance = 10;\r\n  @Input() selectedLifecycleType = 2; // 0 = End by ,  End After, 2 = perpetual\r\n  @Input() id = 0;\r\n  @Input() mode: any;\r\n\r\n  //  lifecycle output\r\n  @Output() selectedOccurance = new EventEmitter<any>();\r\n\r\n  @ViewChild('startDatePicker', { read: ElementRef, static: false })\r\n  startDatePickerPopup!: ElementRef;\r\n  @ViewChild('endDatePicker', { read: ElementRef, static: false })\r\n  endDatePickerPopup!: ElementRef;\r\n\r\n  openedDatePicker: string = '';\r\n\r\n  constructor(private frequencyService: FrequencyService) {}\r\n\r\n  ngOnInit(): void {\r\n    this.textDetails = lifecycleText[this.mode];\r\n    this.startDateConfig = Object.assign({\r\n      ...this.frequencyService.dateConfig,\r\n    });\r\n    this.endDateConfig = Object.assign({ ...this.frequencyService.dateConfig });\r\n    this.startDateConfig['min'] = this.frequencyService.formatDate();\r\n    //this.startDateUnix = this.startDate.getDate().toString()\r\n    this.endDateConfig['min'] = moment(\r\n      new Date(new Date(this.startDate).getTime() + 86400000)\r\n    );\r\n    this.getEndDate(this.startDate);\r\n    this.changeEndDateObj(this.endDate);\r\n  }\r\n\r\n  getEndDate(event: any) {\r\n    const time = moment(this.endDate).format('DD-MM-YYYY HH:mm:ss');\r\n    const getUnixTime = moment(\r\n      time.split(' ')[0] + ' 00:00:00',\r\n      'DD-MM-YYYY HH:mm:ss'\r\n    ).unix();\r\n    this.startDateUnix = moment(event).unix();\r\n    if (this.startDateUnix >= getUnixTime) {\r\n      this.endDate = moment(new Date(this.startDate).getTime() + 86400000);\r\n    } else {\r\n      this.endDate = moment(this.endDate);\r\n    }\r\n  }\r\n\r\n  changeEndDateObj(date: any) {\r\n    this.endDateObject = new Date(moment(date).unix() * 1000);\r\n  }\r\n\r\n  ngOnChanges(change: SimpleChanges) {\r\n    this.endBy = moment(this.endDate)\r\n      .format('DD-MMMM-YYYYTHH:mm:ssZ')\r\n      .split('T')[0];\r\n  }\r\n\r\n  openDatePicker() {\r\n    const newDate = moment(this.startDate);\r\n    this.startDatePicker?.api?.moveCalendarTo(newDate as SingleCalendarValue);\r\n    this.startDatePicker?.api?.open();\r\n    this.datePickerOverlay = true;\r\n    this.openedDatePicker = 'START_DATE';\r\n  }\r\n  openDatePicker1() {\r\n    const newDate = moment(this.endDate);\r\n    this.endDatePicker?.api?.moveCalendarTo(newDate as SingleCalendarValue);\r\n    this.endDatePicker?.api?.open();\r\n    this.openedDatePicker = 'END_DATE';\r\n    this.datePickerOverlay = true;\r\n  }\r\n  closeDatepicker() {\r\n    this.startDatePicker?.api?.close();\r\n    this.endDatePicker?.api?.close();\r\n    this.datePickerOverlay = false;\r\n  }\r\n\r\n  // lifecycle type\r\n  typeSelected(event: any) {\r\n    this.selectedLifecycleType = event;\r\n    this.selectedOccurance.emit({\r\n      type: event,\r\n      endsBy: this.endBy,\r\n      endafter: this.occurrance,\r\n      startFrom: this.startDateUnix,\r\n    });\r\n    return this.selectedLifecycleType;\r\n  }\r\n\r\n  // ends after selection\r\n  endsAfter(event: any) {\r\n    if (\r\n      !Number.isNaN(Number(this.occurrance)) &&\r\n      this.occurrance !== 0 &&\r\n      Number(this.occurrance) > 0\r\n    ) {\r\n      this.selectedOccurance.emit({\r\n        type: this.selectedLifecycleType,\r\n        endsBy: this.endBy,\r\n        endafter: this.occurrance,\r\n        startFrom: this.startDateUnix,\r\n      });\r\n    } else {\r\n      this.occurrance = 10;\r\n    }\r\n    return this.occurrance;\r\n  }\r\n\r\n  // End by change\r\n  endByChange(event: any) {\r\n    this.endDatePicker?.api?.open();\r\n    this.datePickerOverlay = true;\r\n    this.endDate = event?.date?.$d;\r\n    this.selectedEndDate = moment(this.endDate).unix();\r\n    this.changeEndDateObj(this.endDate);\r\n    this.endBy = moment(event?.date?.$d).format('DD-MMMM-YYYY');\r\n    const dateObject = {\r\n      type: this.selectedLifecycleType,\r\n      endsBy: this.endBy,\r\n      endafter: this.occurrance,\r\n      startFrom: this.startDateUnix,\r\n    };\r\n    this.selectedOccurance.emit(dateObject);\r\n  }\r\n\r\n  // start from change event\r\n  startFromChange(event: any) {\r\n    this.startDateUnix = moment(event?.date?.$d).unix();\r\n    if (this.startDateUnix >= this.selectedEndDate) {\r\n      this.endDate = moment(this.startDateUnix * 1000 + 86400000);\r\n\r\n      this.changeEndDateObj(this.endDate);\r\n      this.endBy = moment(this.endDate)\r\n        .format('DD-MMMM-YYYYTHH:mm:ssZ')\r\n        .split('T')[0];\r\n    }\r\n    this.endDateConfig['min'] = Object.assign(\r\n      moment(new Date(new Date(event?.date?.$d).getTime() + 86400000))\r\n    );\r\n    this.selectedOccurance.emit({\r\n      type: this.selectedLifecycleType,\r\n      endsBy: this.endBy,\r\n      endafter: this.occurrance,\r\n      startFrom: this.startDateUnix,\r\n    });\r\n  }\r\n  @HostListener('document:click', ['$event'])\r\n  documentClick(event: any): void {\r\n    const fromDateInputElement = document.getElementById(this.openedDatePicker.toLowerCase()) || null;\r\n\r\n    const datePickerCalendarContainer = document.getElementsByClassName(\r\n      'dp-day-calendar-container'\r\n    )[0];\r\n\r\n    const openedElement =\r\n      this.openedDatePicker === 'START_DATE'\r\n        ? this.startDatePickerPopup\r\n        : this.endDatePickerPopup;\r\n        const isOutsideFromDateInput = !openedElement?.nativeElement?.contains(\r\n          event?.target as Element\r\n        );\r\n        const isNotFromDateElement = event?.target !== fromDateInputElement;\r\n        const isNotInsideCalendar = !datePickerCalendarContainer?.contains(\r\n          event?.target as Element\r\n        );\r\n        const selectedDatePicker =\r\n          this.openedDatePicker === 'START_DATE'\r\n            ? this.startDatePicker\r\n            : this.endDatePicker;\r\n\r\n\r\n            if (isOutsideFromDateInput && isNotFromDateElement && isNotInsideCalendar) {\r\n              this.documentClickListener(\r\n                event?.target,\r\n                openedElement,\r\n                selectedDatePicker\r\n              );\r\n            }\r\n  }\r\n\r\n  documentClickListener(\r\n    target: any,\r\n    openedElements: ElementRef,\r\n    selectedDatePicker: any\r\n  ): void {\r\n    if (\r\n      !openedElements?.nativeElement?.contains(target) &&\r\n      selectedDatePicker?.areCalendarsShown\r\n    ) {\r\n      selectedDatePicker?.api?.close();\r\n      this.datePickerOverlay = false;\r\n    }\r\n  }\r\n}\r\n","<div class=\"frequency-lifecycle-responsibility vx-mt-5\">\r\n  <div class=\"vx-fs-11 vx-fw-500 vx-label-txt vx-tt-uppercase vx-mb-1\">\r\n    {{ textDetails?.header }}\r\n  </div>\r\n  <div\r\n    class=\"frequency-lifecycle-responsibility-inner vx-p-3 vx-pt-2 vx-d-flex vx-align-center vx-justify-between\"\r\n  >\r\n    <div\r\n      class=\"frequency-lifecycle-responsibility-item\"\r\n      [class.with-policy]=\"mode === 'policy' || mode === 'reviewerFrequency'\"\r\n    >\r\n      <div class=\"vx-d-block\">\r\n        <div\r\n          *ngIf=\"mode === 'responsibility'\"\r\n          class=\"heading vx-fs-12 vx-label-txt vx-mb-1\"\r\n        >\r\n          Starts From\r\n        </div>\r\n        <div class=\"lifecycle-box vx-d-flex vx-align-center vx-p-2\">\r\n          <i class=\"icons vx-fs-16 vx-paragraph-txt vx-mr-3\">&#xe996;</i>\r\n          <input\r\n            class=\"start-date-input\"\r\n            type=\"text\"\r\n            [value]=\"startDate | date : 'dd MMM yyyy'\"\r\n            [placeholder]=\"startDate | date : 'dd MMM yyyy'\"\r\n            readonly\r\n            (click)=\"openDatePicker(); datePickerOverlay = true\"\r\n            id=\"start_date\"\r\n          />\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <div\r\n      *ngIf=\"mode === 'responsibility'\"\r\n      class=\"frequency-lifecycle-responsibility-item\"\r\n    >\r\n      <div class=\"item-inner vx-d-block\">\r\n        <div class=\"heading vx-fs-12 vx-label-txt vx-mb-1\">Ends By</div>\r\n        <app-cs-radio\r\n          [checked]=\"selectedLifecycleType == 0\"\r\n          (checkedEvent)=\"typeSelected(0)\"\r\n        >\r\n          <div class=\"date-field\">\r\n            <i class=\"icons calendar-icon vx-fs-16 vx-paragraph-txt\"\r\n              >&#xe92d;</i\r\n            >\r\n            <input\r\n              type=\"text\"\r\n              [value]=\"endDateObject | date : 'dd MMM yyyy'\"\r\n              [placeholder]=\"endDateObject | date : 'dd MMM yyyy'\"\r\n              readonly\r\n              (click)=\"openDatePicker1(); datePickerOverlay = true\"\r\n              id=\"end_date\"\r\n            />\r\n          </div>\r\n        </app-cs-radio>\r\n      </div>\r\n    </div>\r\n    <div\r\n      *ngIf=\"mode === 'responsibility'\"\r\n      class=\"frequency-lifecycle-responsibility-item\"\r\n    >\r\n      <div class=\"item-inner vx-d-block\">\r\n        <div class=\"heading vx-fs-12 vx-label-txt vx-mb-1\">Ends After</div>\r\n        <app-cs-radio\r\n          [checked]=\"selectedLifecycleType == 1\"\r\n          (checkedEvent)=\"typeSelected(1)\"\r\n        >\r\n          <input\r\n            class=\"input-field\"\r\n            type=\"number\"\r\n            [(ngModel)]=\"occurrance\"\r\n            (focusout)=\"endsAfter($event)\"\r\n            onkeydown=\"return event.keyCode !== 190\"\r\n            min=\"0\"\r\n            oninput=\"this.value = Math.abs(this.value)\"\r\n          />\r\n          <span class=\"vx-fs-11 vx-paragraph-txt vx-ml-2\">Occurrences</span>\r\n        </app-cs-radio>\r\n      </div>\r\n    </div>\r\n    <div\r\n      *ngIf=\"mode === 'responsibility'\"\r\n      class=\"frequency-lifecycle-responsibility-item\"\r\n    >\r\n      <div class=\"item-inner vx-d-block\">\r\n        <div class=\"heading vx-fs-12 vx-label-txt vx-mb-1\">Ongoing</div>\r\n        <app-cs-radio\r\n          [checked]=\"selectedLifecycleType == 2\"\r\n          (checkedEvent)=\"typeSelected(2)\"\r\n        >\r\n          <span class=\"vx-fs-11 vx-paragraph-txt vx-ml-2\"\r\n            >The responsibility will perpetually exist.</span\r\n          >\r\n        </app-cs-radio>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<!-- start date date picker -->\r\n<dp-date-picker\r\n  #startDatePicker\r\n  [id]=\"'start-date-' + id\"\r\n  [placeholder]=\"startDate | date : 'dd MMM yyyy'\"\r\n  [(ngModel)]=\"startDate\"\r\n  [config]=\"startDateConfig\"\r\n  (onSelect)=\"\r\n    openDatePicker();\r\n    startFromChange($event);\r\n    showDateError = false;\r\n    datePickerOverlay = false\r\n  \"\r\n></dp-date-picker>\r\n<div\r\n  class=\"vx-overlay\"\r\n  (click)=\"closeDatepicker()\"\r\n  *ngIf=\"datePickerOverlay\"\r\n></div>\r\n\r\n<!-- end date date picker -->\r\n<dp-date-picker\r\n  #endDatePicker\r\n  [(ngModel)]=\"endDate\"\r\n  [placeholder]=\"endDateObject | date : 'dd MMM yyyy'\"\r\n  [id]=\"'end-by-input-' + id\"\r\n  [config]=\"endDateConfig\"\r\n  [minDate]=\"endDateConfig['min']\"\r\n  (onSelect)=\"\r\n    endByChange($event); showDateError = false; datePickerOverlay = false\r\n  \"\r\n></dp-date-picker>\r\n<div\r\n  class=\"vx-overlay\"\r\n  (click)=\"closeDatepicker()\"\r\n  *ngIf=\"datePickerOverlay\"\r\n></div>\r\n"]}
210
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"frequency-lifecycle.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency/frequency-lifecycle/frequency-lifecycle.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency/frequency-lifecycle/frequency-lifecycle.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EAET,SAAS,EACT,KAAK,EACL,MAAM,EACN,YAAY,EAGZ,YAAY,EACZ,UAAU,GACX,MAAM,eAAe,CAAC;AAEvB,OAAO,MAAM,MAAM,eAAe,CAAC;AAEnC,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,KAAK,MAAM,OAAO,CAAC;;;;;;;AAO1B,MAAM,OAAO,2BAA2B;IAgCtC,YAAoB,gBAAkC;QAAlC,qBAAgB,GAAhB,gBAAgB,CAAkB;QA5BtD,sBAAiB,GAAG,KAAK,CAAC;QAC1B,kBAAa,GAAG,KAAK,CAAC;QACtB,kBAAa,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAO3B,qBAAqB;QACZ,cAAS,GAAG,IAAI,IAAI,EAAE,CAAC;QACvB,YAAO,GAAG,MAAM,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,GAAG,QAAQ,CAAC,CAAC;QAEhE,eAAU,GAAG,EAAE,CAAC;QAChB,0BAAqB,GAAG,CAAC,CAAC,CAAC,yCAAyC;QACpE,OAAE,GAAG,CAAC,CAAC;QAGhB,oBAAoB;QACV,sBAAiB,GAAG,IAAI,YAAY,EAAO,CAAC;QAOtD,qBAAgB,GAAW,EAAE,CAAC;IAE2B,CAAC;IAE1D,QAAQ;QACN,IAAI,CAAC,WAAW,GAAG,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC5C,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC,MAAM,CAAC;YACnC,GAAG,IAAI,CAAC,gBAAgB,CAAC,UAAU;SACpC,CAAC,CAAC;QACH,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,GAAG,IAAI,CAAC,gBAAgB,CAAC,UAAU,EAAE,CAAC,CAAC;QAC5E,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,gBAAgB,CAAC,UAAU,EAAE,CAAC;QACjE,0DAA0D;QAC1D,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,GAAG,MAAM,CAChC,IAAI,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,GAAG,QAAQ,CAAC,CACxD,CAAC;QACF,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAChC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACtC,CAAC;IAED,UAAU,CAAC,KAAU;QACnB,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,qBAAqB,CAAC,CAAC;QAChE,MAAM,WAAW,GAAG,MAAM,CACxB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,WAAW,EAChC,qBAAqB,CACtB,CAAC,IAAI,EAAE,CAAC;QACT,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,IAAI,EAAE,CAAC;QAC1C,IAAI,IAAI,CAAC,aAAa,IAAI,WAAW,EAAE;YACrC,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,GAAG,QAAQ,CAAC,CAAC;SACtE;aAAM;YACL,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;SACrC;IACH,CAAC;IAED,gBAAgB,CAAC,IAAS;QACxB,IAAI,CAAC,aAAa,GAAG,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,GAAG,IAAI,CAAC,CAAC;QAC1D,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC;IACrD,CAAC;IAED,WAAW,CAAC,MAAqB;QAC/B,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC;aAC9B,MAAM,CAAC,wBAAwB,CAAC;aAChC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IACnB,CAAC;IAED,cAAc;QACZ,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACtC,IAAI,CAAC,eAAe,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC;QAClC,IAAI,CAAC,eAAe,EAAE,GAAG,EAAE,cAAc,CAAC,OAAO,CAAC,CAAC;QACnD,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAC9B,IAAI,CAAC,gBAAgB,GAAG,YAAY,CAAC;IACvC,CAAC;IACD,eAAe;QACb,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACrC,IAAI,CAAC,aAAa,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC;QAChC,IAAI,CAAC,aAAa,EAAE,GAAG,EAAE,cAAc,CAAC,IAAI,CAAC,OAA8B,CAAC,CAAC;QAC7E,IAAI,CAAC,gBAAgB,GAAG,UAAU,CAAC;QACnC,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;IAChC,CAAC;IACD,eAAe;QACb,IAAI,CAAC,eAAe,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC;QACnC,IAAI,CAAC,aAAa,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC;QACjC,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;IACjC,CAAC;IAED,iBAAiB;IACjB,YAAY,CAAC,KAAU;QACrB,IAAI,CAAC,qBAAqB,GAAG,KAAK,CAAC;QACnC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC;YAC1B,IAAI,EAAE,KAAK;YACX,MAAM,EAAE,IAAI,CAAC,KAAK;YAClB,QAAQ,EAAE,IAAI,CAAC,UAAU;YACzB,SAAS,EAAE,IAAI,CAAC,aAAa;SAC9B,CAAC,CAAC;QACH,OAAO,IAAI,CAAC,qBAAqB,CAAC;IACpC,CAAC;IAED,uBAAuB;IACvB,SAAS,CAAC,KAAU;QAClB,IACE,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACtC,IAAI,CAAC,UAAU,KAAK,CAAC;YACrB,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAC3B;YACA,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC;gBAC1B,IAAI,EAAE,IAAI,CAAC,qBAAqB;gBAChC,MAAM,EAAE,IAAI,CAAC,KAAK;gBAClB,QAAQ,EAAE,IAAI,CAAC,UAAU;gBACzB,SAAS,EAAE,IAAI,CAAC,aAAa;aAC9B,CAAC,CAAC;SACJ;aAAM;YACL,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;SACtB;QACD,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED,gBAAgB;IAChB,WAAW,CAAC,KAAU;QACpB,IAAI,CAAC,aAAa,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC;QAChC,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAC9B,IAAI,CAAC,OAAO,GAAG,KAAK,EAAE,IAAI,EAAE,EAAE,CAAC;QAC/B,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC;QACnD,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACpC,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;QAC5D,MAAM,UAAU,GAAG;YACjB,IAAI,EAAE,IAAI,CAAC,qBAAqB;YAChC,MAAM,EAAE,IAAI,CAAC,KAAK;YAClB,QAAQ,EAAE,IAAI,CAAC,UAAU;YACzB,SAAS,EAAE,IAAI,CAAC,aAAa;SAC9B,CAAC;QACF,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC1C,CAAC;IAED,0BAA0B;IAC1B,eAAe,CAAC,KAAU;QACxB,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC;QACpD,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,eAAe,EAAE;YAC9C,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,aAAa,GAAG,IAAI,GAAG,QAAQ,CAAC,CAAC;YAE5D,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACpC,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC;iBAC9B,MAAM,CAAC,wBAAwB,CAAC;iBAChC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;SAClB;QACD,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,GAAG,MAAM,CAAC,MAAM,CACvC,MAAM,CAAC,IAAI,IAAI,CAAC,IAAI,IAAI,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC,OAAO,EAAE,GAAG,QAAQ,CAAC,CAAC,CACjE,CAAC;QACF,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC;YAC1B,IAAI,EAAE,IAAI,CAAC,qBAAqB;YAChC,MAAM,EAAE,IAAI,CAAC,KAAK;YAClB,QAAQ,EAAE,IAAI,CAAC,UAAU;YACzB,SAAS,EAAE,IAAI,CAAC,aAAa;SAC9B,CAAC,CAAC;IACL,CAAC;IAED,aAAa,CAAC,KAAU;QACtB,MAAM,aAAa,GAAG,KAAK,EAAE,MAAiB,CAAC;QAC/C,MAAM,oBAAoB,GACxB,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,CAAC,IAAI,IAAI,CAAC;QAEvE,MAAM,2BAA2B,GAAG,QAAQ,CAAC,sBAAsB,CACjE,2BAA2B,CAC5B,CAAC,CAAC,CAAC,CAAC;QACL,MAAM,gBAAgB,GAAG,QAAQ,CAAC,aAAa,CAC7C,8BAA8B,CAC/B,CAAC;QACF,MAAM,qBAAqB,GAAG,CAAC,gBAAgB,EAAE,QAAQ,CAAC,aAAa,CAAC,CAAC;QAEzE,MAAM,aAAa,GACjB,IAAI,CAAC,gBAAgB,KAAK,YAAY;YACpC,CAAC,CAAC,IAAI,CAAC,oBAAoB;YAC3B,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC;QAC9B,MAAM,sBAAsB,GAC1B,CAAC,aAAa,EAAE,aAAa,EAAE,QAAQ,CAAC,aAAa,CAAC,CAAC;QACzD,MAAM,oBAAoB,GAAG,KAAK,EAAE,MAAM,KAAK,oBAAoB,CAAC;QACpE,MAAM,mBAAmB,GACvB,CAAC,2BAA2B,EAAE,QAAQ,CAAC,aAAa,CAAC,CAAC;QACxD,MAAM,kBAAkB,GACtB,IAAI,CAAC,gBAAgB,KAAK,YAAY;YACpC,CAAC,CAAC,IAAI,CAAC,eAAe;YACtB,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC;QAEzB,MAAM,kBAAkB,GACtB,CAAC,aAAa,CAAC,SAAS,CAAC,QAAQ,CAAC,mBAAmB,CAAC,CAAC;QAEzD,IACE,sBAAsB;YACtB,oBAAoB;YACpB,mBAAmB;YACnB,kBAAkB;YAClB,qBAAqB;YACrB,2BAA2B,EAC3B;YACA,IAAI,CAAC,qBAAqB,CACxB,KAAK,EAAE,MAAM,EACb,aAAa,EACb,kBAAkB,CACnB,CAAC;SACH;IACH,CAAC;IAED,qBAAqB,CACnB,MAAW,EACX,cAA0B,EAC1B,kBAAuB;QAEvB,IACE,CAAC,cAAc,EAAE,aAAa,EAAE,QAAQ,CAAC,MAAM,CAAC;YAChD,kBAAkB,EAAE,iBAAiB,EACrC;YACA,kBAAkB,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC;YACjC,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;SAChC;IACH,CAAC;+GA9NU,2BAA2B;mGAA3B,2BAA2B,4oBAyBA,UAAU,8GAEZ,UAAU,kDClDhD,qoJAyIA;;4FDlHa,2BAA2B;kBALvC,SAAS;+BACE,yBAAyB;uGAKL,eAAe;sBAA5C,SAAS;uBAAC,iBAAiB;gBACA,aAAa;sBAAxC,SAAS;uBAAC,eAAe;gBAYjB,SAAS;sBAAjB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,qBAAqB;sBAA7B,KAAK;gBACG,EAAE;sBAAV,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBAGI,iBAAiB;sBAA1B,MAAM;gBAGP,oBAAoB;sBADnB,SAAS;uBAAC,iBAAiB,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE;gBAGjE,kBAAkB;sBADjB,SAAS;uBAAC,eAAe,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE;gBAyI/D,aAAa;sBADZ,YAAY;uBAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  ViewChild,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  SimpleChanges,\r\n  OnChanges,\r\n  HostListener,\r\n  ElementRef,\r\n} from '@angular/core';\r\nimport { DatePickerComponent, SingleCalendarValue } from 'ng2-date-picker';\r\nimport moment from 'moment/moment';\r\nimport { FrequencyService } from '../frequency.service';\r\nimport { lifecycleText } from './lifecycl.constant';\r\nimport dayjs from 'dayjs';\r\n\r\n@Component({\r\n  selector: 'app-frequency-lifecycle',\r\n  templateUrl: './frequency-lifecycle.component.html',\r\n  styleUrls: ['./frequency-lifecycle.component.less'],\r\n})\r\nexport class FrequencyLifecycleComponent implements OnInit, OnChanges {\r\n  @ViewChild('startDatePicker') startDatePicker!: DatePickerComponent;\r\n  @ViewChild('endDatePicker') endDatePicker!: DatePickerComponent;\r\n\r\n  datePickerOverlay = false;\r\n  showDateError = false;\r\n  startDateUnix = Date.now();\r\n  endDateObject: any;\r\n  startDateConfig: any;\r\n  endDateConfig: any;\r\n  textDetails: any;\r\n  selectedEndDate: any;\r\n\r\n  // All input variable\r\n  @Input() startDate = new Date();\r\n  @Input() endDate = moment(new Date(this.startDate).getTime() + 86400000);\r\n  @Input() endBy: any;\r\n  @Input() occurrance = 10;\r\n  @Input() selectedLifecycleType = 2; // 0 = End by ,  End After, 2 = perpetual\r\n  @Input() id = 0;\r\n  @Input() mode: any;\r\n\r\n  //  lifecycle output\r\n  @Output() selectedOccurance = new EventEmitter<any>();\r\n\r\n  @ViewChild('startDatePicker', { read: ElementRef, static: false })\r\n  startDatePickerPopup!: ElementRef;\r\n  @ViewChild('endDatePicker', { read: ElementRef, static: false })\r\n  endDatePickerPopup!: ElementRef;\r\n\r\n  openedDatePicker: string = '';\r\n\r\n  constructor(private frequencyService: FrequencyService) {}\r\n\r\n  ngOnInit(): void {\r\n    this.textDetails = lifecycleText[this.mode];\r\n    this.startDateConfig = Object.assign({\r\n      ...this.frequencyService.dateConfig,\r\n    });\r\n    this.endDateConfig = Object.assign({ ...this.frequencyService.dateConfig });\r\n    this.startDateConfig['min'] = this.frequencyService.formatDate();\r\n    //this.startDateUnix = this.startDate.getDate().toString()\r\n    this.endDateConfig['min'] = moment(\r\n      new Date(new Date(this.startDate).getTime() + 86400000)\r\n    );\r\n    this.getEndDate(this.startDate);\r\n    this.changeEndDateObj(this.endDate);\r\n  }\r\n\r\n  getEndDate(event: any) {\r\n    const time = moment(this.endDate).format('DD-MM-YYYY HH:mm:ss');\r\n    const getUnixTime = moment(\r\n      time.split(' ')[0] + ' 00:00:00',\r\n      'DD-MM-YYYY HH:mm:ss'\r\n    ).unix();\r\n    this.startDateUnix = moment(event).unix();\r\n    if (this.startDateUnix >= getUnixTime) {\r\n      this.endDate = moment(new Date(this.startDate).getTime() + 86400000);\r\n    } else {\r\n      this.endDate = moment(this.endDate);\r\n    }\r\n  }\r\n\r\n  changeEndDateObj(date: any) {\r\n    this.endDateObject = new Date(moment(date).unix() * 1000);\r\n    this.selectedEndDate = moment(this.endDate).unix();\r\n  }\r\n\r\n  ngOnChanges(change: SimpleChanges) {\r\n    this.endBy = moment(this.endDate)\r\n      .format('DD-MMMM-YYYYTHH:mm:ssZ')\r\n      .split('T')[0];\r\n  }\r\n\r\n  openDatePicker() {\r\n    const newDate = dayjs(this.startDate);\r\n    this.startDatePicker?.api?.open();\r\n    this.startDatePicker?.api?.moveCalendarTo(newDate);\r\n    this.datePickerOverlay = true;\r\n    this.openedDatePicker = 'START_DATE';\r\n  }\r\n  openDatePicker1() {\r\n    const newDate = moment(this.endDate);\r\n    this.endDatePicker?.api?.open();\r\n    this.endDatePicker?.api?.moveCalendarTo(this.endDate as SingleCalendarValue);\r\n    this.openedDatePicker = 'END_DATE';\r\n    this.datePickerOverlay = true;\r\n  }\r\n  closeDatepicker() {\r\n    this.startDatePicker?.api?.close();\r\n    this.endDatePicker?.api?.close();\r\n    this.datePickerOverlay = false;\r\n  }\r\n\r\n  // lifecycle type\r\n  typeSelected(event: any) {\r\n    this.selectedLifecycleType = event;\r\n    this.selectedOccurance.emit({\r\n      type: event,\r\n      endsBy: this.endBy,\r\n      endafter: this.occurrance,\r\n      startFrom: this.startDateUnix,\r\n    });\r\n    return this.selectedLifecycleType;\r\n  }\r\n\r\n  // ends after selection\r\n  endsAfter(event: any) {\r\n    if (\r\n      !Number.isNaN(Number(this.occurrance)) &&\r\n      this.occurrance !== 0 &&\r\n      Number(this.occurrance) > 0\r\n    ) {\r\n      this.selectedOccurance.emit({\r\n        type: this.selectedLifecycleType,\r\n        endsBy: this.endBy,\r\n        endafter: this.occurrance,\r\n        startFrom: this.startDateUnix,\r\n      });\r\n    } else {\r\n      this.occurrance = 10;\r\n    }\r\n    return this.occurrance;\r\n  }\r\n\r\n  // End by change\r\n  endByChange(event: any) {\r\n    this.endDatePicker?.api?.open();\r\n    this.datePickerOverlay = true;\r\n    this.endDate = event?.date?.$d;\r\n    this.selectedEndDate = moment(this.endDate).unix();\r\n    this.changeEndDateObj(this.endDate);\r\n    this.endBy = moment(event?.date?.$d).format('DD-MMMM-YYYY');\r\n    const dateObject = {\r\n      type: this.selectedLifecycleType,\r\n      endsBy: this.endBy,\r\n      endafter: this.occurrance,\r\n      startFrom: this.startDateUnix,\r\n    };\r\n    this.selectedOccurance.emit(dateObject);\r\n  }\r\n\r\n  // start from change event\r\n  startFromChange(event: any) {\r\n    this.startDateUnix = moment(event?.date?.$d).unix();\r\n    if (this.startDateUnix >= this.selectedEndDate) {\r\n      this.endDate = moment(this.startDateUnix * 1000 + 86400000);\r\n\r\n      this.changeEndDateObj(this.endDate);\r\n      this.endBy = moment(this.endDate)\r\n        .format('DD-MMMM-YYYYTHH:mm:ssZ')\r\n        .split('T')[0];\r\n    }\r\n    this.endDateConfig['min'] = Object.assign(\r\n      moment(new Date(new Date(event?.date?.$d).getTime() + 86400000))\r\n    );\r\n    this.selectedOccurance.emit({\r\n      type: this.selectedLifecycleType,\r\n      endsBy: this.endBy,\r\n      endafter: this.occurrance,\r\n      startFrom: this.startDateUnix,\r\n    });\r\n  }\r\n  @HostListener('document:click', ['$event'])\r\n  documentClick(event: any): void {\r\n    const targetElement = event?.target as Element;\r\n    const fromDateInputElement =\r\n      document.getElementById(this.openedDatePicker.toLowerCase()) || null;\r\n\r\n    const datePickerCalendarContainer = document.getElementsByClassName(\r\n      'dp-day-calendar-container'\r\n    )[0];\r\n    const monthYearElement = document.querySelector(\r\n      '.dp-month-calendar-container'\r\n    );\r\n    const isNotMonthYearElement = !monthYearElement?.contains(targetElement);\r\n\r\n    const openedElement =\r\n      this.openedDatePicker === 'START_DATE'\r\n        ? this.startDatePickerPopup\r\n        : this.endDatePickerPopup;\r\n    const isOutsideFromDateInput =\r\n      !openedElement?.nativeElement?.contains(targetElement);\r\n    const isNotFromDateElement = event?.target !== fromDateInputElement;\r\n    const isNotInsideCalendar =\r\n      !datePickerCalendarContainer?.contains(targetElement);\r\n    const selectedDatePicker =\r\n      this.openedDatePicker === 'START_DATE'\r\n        ? this.startDatePicker\r\n        : this.endDatePicker;\r\n\r\n    const isNotCalendarMonth =\r\n      !targetElement.className.includes('dp-calendar-month');\r\n\r\n    if (\r\n      isOutsideFromDateInput &&\r\n      isNotFromDateElement &&\r\n      isNotInsideCalendar &&\r\n      isNotCalendarMonth &&\r\n      isNotMonthYearElement &&\r\n      datePickerCalendarContainer\r\n    ) {\r\n      this.documentClickListener(\r\n        event?.target,\r\n        openedElement,\r\n        selectedDatePicker\r\n      );\r\n    }\r\n  }\r\n\r\n  documentClickListener(\r\n    target: any,\r\n    openedElements: ElementRef,\r\n    selectedDatePicker: any\r\n  ): void {\r\n    if (\r\n      !openedElements?.nativeElement?.contains(target) &&\r\n      selectedDatePicker?.areCalendarsShown\r\n    ) {\r\n      selectedDatePicker?.api?.close();\r\n      this.datePickerOverlay = false;\r\n    }\r\n  }\r\n}\r\n","<div class=\"frequency-lifecycle-responsibility vx-mt-5\">\r\n  <div class=\"vx-fs-11 vx-fw-500 vx-label-txt vx-tt-uppercase vx-mb-1\">\r\n    {{ textDetails?.header }}\r\n  </div>\r\n  <div\r\n    class=\"frequency-lifecycle-responsibility-inner vx-p-3 vx-pt-2 vx-d-flex vx-align-center vx-justify-between\"\r\n  >\r\n    <div\r\n      class=\"frequency-lifecycle-responsibility-item\"\r\n      [class.with-policy]=\"mode === 'policy' || mode === 'reviewerFrequency'\"\r\n    >\r\n      <div class=\"vx-d-block\">\r\n        <div\r\n          *ngIf=\"mode === 'responsibility'\"\r\n          class=\"heading vx-fs-12 vx-label-txt vx-mb-1\"\r\n        >\r\n          Starts From\r\n        </div>\r\n        <div class=\"lifecycle-box vx-d-flex vx-align-center vx-p-2\">\r\n          <i class=\"icons vx-fs-16 vx-paragraph-txt vx-mr-3\">&#xe996;</i>\r\n          <input\r\n            class=\"start-date-input\"\r\n            type=\"text\"\r\n            [value]=\"startDate | date : 'dd MMM yyyy'\"\r\n            [placeholder]=\"startDate | date : 'dd MMM yyyy'\"\r\n            readonly\r\n            (click)=\"openDatePicker(); datePickerOverlay = true\"\r\n            id=\"start_date\"\r\n          />\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <div\r\n      *ngIf=\"mode === 'responsibility'\"\r\n      class=\"frequency-lifecycle-responsibility-item\"\r\n    >\r\n      <div class=\"item-inner vx-d-block\">\r\n        <div class=\"heading vx-fs-12 vx-label-txt vx-mb-1\">Ends By</div>\r\n        <app-cs-radio\r\n          [checked]=\"selectedLifecycleType == 0\"\r\n          (checkedEvent)=\"typeSelected(0)\"\r\n        >\r\n          <div class=\"date-field\">\r\n            <i class=\"icons calendar-icon vx-fs-16 vx-paragraph-txt\"\r\n              >&#xe92d;</i\r\n            >\r\n            <input\r\n              type=\"text\"\r\n              [value]=\"endDateObject | date : 'dd MMM yyyy'\"\r\n              [placeholder]=\"endDateObject | date : 'dd MMM yyyy'\"\r\n              readonly\r\n              (click)=\"openDatePicker1(); datePickerOverlay = true\"\r\n              id=\"end_date\"\r\n            />\r\n          </div>\r\n        </app-cs-radio>\r\n      </div>\r\n    </div>\r\n    <div\r\n      *ngIf=\"mode === 'responsibility'\"\r\n      class=\"frequency-lifecycle-responsibility-item\"\r\n    >\r\n      <div class=\"item-inner vx-d-block\">\r\n        <div class=\"heading vx-fs-12 vx-label-txt vx-mb-1\">Ends After</div>\r\n        <app-cs-radio\r\n          [checked]=\"selectedLifecycleType == 1\"\r\n          (checkedEvent)=\"typeSelected(1)\"\r\n        >\r\n          <input\r\n            class=\"input-field\"\r\n            type=\"number\"\r\n            [(ngModel)]=\"occurrance\"\r\n            (focusout)=\"endsAfter($event)\"\r\n            onkeydown=\"return event.keyCode !== 190\"\r\n            min=\"0\"\r\n            oninput=\"this.value = Math.abs(this.value)\"\r\n          />\r\n          <span class=\"vx-fs-11 vx-paragraph-txt vx-ml-2\">Occurrences</span>\r\n        </app-cs-radio>\r\n      </div>\r\n    </div>\r\n    <div\r\n      *ngIf=\"mode === 'responsibility'\"\r\n      class=\"frequency-lifecycle-responsibility-item\"\r\n    >\r\n      <div class=\"item-inner vx-d-block\">\r\n        <div class=\"heading vx-fs-12 vx-label-txt vx-mb-1\">Ongoing</div>\r\n        <app-cs-radio\r\n          [checked]=\"selectedLifecycleType == 2\"\r\n          (checkedEvent)=\"typeSelected(2)\"\r\n        >\r\n          <span class=\"vx-fs-11 vx-paragraph-txt vx-ml-2\"\r\n            >The responsibility will perpetually exist.</span\r\n          >\r\n        </app-cs-radio>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<!-- start date date picker -->\r\n<dp-date-picker\r\n  #startDatePicker\r\n  [id]=\"'start-date-' + id\"\r\n  [placeholder]=\"startDate | date : 'dd MMM yyyy'\"\r\n  [(ngModel)]=\"startDate\"\r\n  [config]=\"startDateConfig\"\r\n  (onSelect)=\"\r\n    openDatePicker();\r\n    startFromChange($event);\r\n    showDateError = false;\r\n    datePickerOverlay = false\r\n  \"\r\n></dp-date-picker>\r\n<div\r\n  class=\"vx-overlay\"\r\n  (click)=\"closeDatepicker()\"\r\n  *ngIf=\"datePickerOverlay\"\r\n></div>\r\n\r\n<!-- end date date picker -->\r\n<dp-date-picker\r\n  #endDatePicker\r\n  [(ngModel)]=\"endDate\"\r\n  [placeholder]=\"endDateObject | date : 'dd MMM yyyy'\"\r\n  [id]=\"'end-by-input-' + id\"\r\n  [config]=\"endDateConfig\"\r\n  [minDate]=\"endDateConfig['min']\"\r\n  (onSelect)=\"\r\n    endByChange($event); showDateError = false; datePickerOverlay = false\r\n  \"\r\n></dp-date-picker>\r\n<div\r\n  class=\"vx-overlay\"\r\n  (click)=\"closeDatepicker()\"\r\n  *ngIf=\"datePickerOverlay\"\r\n></div>\r\n"]}