@datarailsshared/datarailsshared 1.5.528 → 1.5.533
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/datarailsshared-datarailsshared-1.5.533.tgz +0 -0
- package/esm2022/lib/date-tags/forecast-tag/forecast-tag.service.mjs +18 -14
- package/esm2022/lib/dr-popover/dr-popover.directive.mjs +28 -1
- package/fesm2022/datarailsshared-datarailsshared.mjs +44 -13
- package/fesm2022/datarailsshared-datarailsshared.mjs.map +1 -1
- package/lib/date-tags/forecast-tag/forecast-tag.service.d.ts +2 -1
- package/lib/dr-popover/dr-popover.directive.d.ts +2 -0
- package/package.json +1 -1
- package/datarailsshared-datarailsshared-1.5.528.tgz +0 -0
|
Binary file
|
|
@@ -4,19 +4,22 @@ import * as i0 from "@angular/core";
|
|
|
4
4
|
export class ForecastTagService {
|
|
5
5
|
static { this.MONTH_DIFF = 1; }
|
|
6
6
|
static { this.forecastByMonth = {
|
|
7
|
-
0: '0+12',
|
|
8
|
-
1: '1+11',
|
|
9
|
-
2: '2+10',
|
|
10
|
-
3: '3+9',
|
|
11
|
-
4: '4+8',
|
|
12
|
-
5: '5+7',
|
|
13
|
-
6: '6+6',
|
|
14
|
-
7: '7+5',
|
|
15
|
-
8: '8+4',
|
|
16
|
-
9: '9+3',
|
|
17
|
-
10: '10+2',
|
|
18
|
-
11: '11+1',
|
|
7
|
+
'0': '0+12',
|
|
8
|
+
'1': '1+11',
|
|
9
|
+
'2': '2+10',
|
|
10
|
+
'3': '3+9',
|
|
11
|
+
'4': '4+8',
|
|
12
|
+
'5': '5+7',
|
|
13
|
+
'6': '6+6',
|
|
14
|
+
'7': '7+5',
|
|
15
|
+
'8': '8+4',
|
|
16
|
+
'9': '9+3',
|
|
17
|
+
'10': '10+2',
|
|
18
|
+
'11': '11+1',
|
|
19
19
|
}; }
|
|
20
|
+
static getForecastMonthTemplates() {
|
|
21
|
+
return Array.from(Object.values(ForecastTagService.forecastByMonth));
|
|
22
|
+
}
|
|
20
23
|
static getFiscalMonthFromDate(date, fiscalYearStartsFrom) {
|
|
21
24
|
const all_months = [];
|
|
22
25
|
for (let i = fiscalYearStartsFrom; i < 13; i++) {
|
|
@@ -43,7 +46,8 @@ export class ForecastTagService {
|
|
|
43
46
|
return fiscal_year;
|
|
44
47
|
}
|
|
45
48
|
static getForecastLabel(month) {
|
|
46
|
-
|
|
49
|
+
const index = month - ForecastTagService.MONTH_DIFF;
|
|
50
|
+
return ForecastTagService.forecastByMonth[index];
|
|
47
51
|
}
|
|
48
52
|
static getCalendarDateFromMonthAndFiscalYear(chosenMoment, monthLabel, fiscalYearStartsFrom, fiscalYearBack) {
|
|
49
53
|
const yearWithMonth = ForecastTagService.addMonthsWithoutYearChange(chosenMoment, monthLabel, fiscalYearStartsFrom);
|
|
@@ -80,4 +84,4 @@ export class ForecastTagService {
|
|
|
80
84
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ForecastTagService, [{
|
|
81
85
|
type: Injectable
|
|
82
86
|
}], null, null); })();
|
|
83
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
87
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"forecast-tag.service.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/date-tags/forecast-tag/forecast-tag.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport * as moment from 'moment';\nimport { indexOf as _indexOf } from 'lodash';\n\ninterface IForecastByMonth {\n    [monthIndex: string]: string;\n}\n\n@Injectable()\nexport class ForecastTagService {\n    private static readonly MONTH_DIFF = 1;\n    private static readonly forecastByMonth: IForecastByMonth = {\n        '0': '0+12',\n        '1': '1+11',\n        '2': '2+10',\n        '3': '3+9',\n        '4': '4+8',\n        '5': '5+7',\n        '6': '6+6',\n        '7': '7+5',\n        '8': '8+4',\n        '9': '9+3',\n        '10': '10+2',\n        '11': '11+1',\n    };\n\n    public static getForecastMonthTemplates(): string[] {\n        return Array.from(Object.values(ForecastTagService.forecastByMonth));\n    }\n\n    public static getFiscalMonthFromDate(date: moment.Moment, fiscalYearStartsFrom: number): number {\n        const all_months = [];\n\n        for (let i = fiscalYearStartsFrom; i < 13; i++) {\n            all_months.push(i);\n        }\n\n        for (let i = 1; i < fiscalYearStartsFrom; i++) {\n            all_months.push(i);\n        }\n\n        return _indexOf(all_months, date.month() + ForecastTagService.MONTH_DIFF) + ForecastTagService.MONTH_DIFF;\n    }\n\n    public static getFiscalYearFromDate(date: moment.Moment, fiscalYearStartsFrom: number, fiscalYearBack: boolean): number {\n        const month = date.month();\n        let fiscal_year = date.year();\n\n        if (!fiscalYearBack) {\n            if (month + 1 >= fiscalYearStartsFrom && fiscalYearStartsFrom !== 1) {\n                fiscal_year += 1;\n            }\n        } else {\n            if (month + 1 < fiscalYearStartsFrom && fiscalYearStartsFrom !== 1) {\n                fiscal_year -= 1;\n            }\n        }\n\n        return fiscal_year;\n    }\n\n    public static getForecastLabel(month: number): string {\n        const index = month - ForecastTagService.MONTH_DIFF;\n        return ForecastTagService.forecastByMonth[index];\n    }\n\n    public static getCalendarDateFromMonthAndFiscalYear(\n        chosenMoment: moment.Moment,\n        monthLabel: string,\n        fiscalYearStartsFrom: number,\n        fiscalYearBack: boolean,\n    ): number {\n        const yearWithMonth = ForecastTagService.addMonthsWithoutYearChange(chosenMoment, monthLabel, fiscalYearStartsFrom);\n        return ForecastTagService.transformYearFromFiscal(yearWithMonth, fiscalYearStartsFrom, fiscalYearBack);\n    }\n\n    public static addMonthsWithoutYearChange(\n        date: moment.Moment,\n        monthLabel: string,\n        fiscalYearStartsFrom: number,\n    ): moment.Moment {\n        if (!monthLabel || !date) return;\n\n        const dateToTransform = date.clone();\n\n        const labelsIndex: number = +Object.keys(ForecastTagService.forecastByMonth).find(\n            (key: string) => ForecastTagService.forecastByMonth[key] === monthLabel,\n        );\n        const monthsWithFiscalDifference = labelsIndex + fiscalYearStartsFrom - 1;\n        const monthsToAdd = monthsWithFiscalDifference >= 12 ? monthsWithFiscalDifference - 12 : monthsWithFiscalDifference;\n\n        return dateToTransform.utc().startOf('year').add(monthsToAdd, 'M');\n    }\n\n    public static transformYearFromFiscal(\n        fiscalYearWithMonth: moment.Moment,\n        fiscalYearStartsFrom: number,\n        fiscalYearBack: boolean,\n    ): number {\n        if (!fiscalYearWithMonth) return;\n\n        let fiscalYearStartMoment = fiscalYearWithMonth.clone();\n        if (fiscalYearBack) {\n            if (fiscalYearStartMoment.month() + 1 < fiscalYearStartsFrom && fiscalYearStartsFrom !== 1) {\n                fiscalYearStartMoment.add(1, 'year');\n            }\n        } else {\n            if (fiscalYearStartMoment.month() + 1 >= fiscalYearStartsFrom && fiscalYearStartsFrom !== 1) {\n                fiscalYearStartMoment.subtract(1, 'year');\n            }\n        }\n        return fiscalYearStartMoment.unix();\n    }\n}\n"]}
|
|
@@ -15,6 +15,15 @@ export class DrPopoverDirective {
|
|
|
15
15
|
this.popoverClose = new EventEmitter();
|
|
16
16
|
this.popoverOpened = new EventEmitter();
|
|
17
17
|
this.showStateChange = new EventEmitter();
|
|
18
|
+
this.scrollHandler = (event) => {
|
|
19
|
+
// Find the nearest scrollable parent for which scrolling is possible
|
|
20
|
+
const isVerticalScroll = !event.shiftKey;
|
|
21
|
+
const scrollableElement = this.getScrollableElement(event.target, isVerticalScroll);
|
|
22
|
+
// Check if scroll possible and host element places inside scrollable element
|
|
23
|
+
if (scrollableElement && scrollableElement.contains(this.elementRef.nativeElement)) {
|
|
24
|
+
this.closePopover();
|
|
25
|
+
}
|
|
26
|
+
};
|
|
18
27
|
}
|
|
19
28
|
togglePopover() {
|
|
20
29
|
if (this.disabled)
|
|
@@ -31,6 +40,7 @@ export class DrPopoverDirective {
|
|
|
31
40
|
if (this.popoverRef) {
|
|
32
41
|
this.popoverRef.close(res);
|
|
33
42
|
this.popoverRef = null;
|
|
43
|
+
window.removeEventListener('wheel', this.scrollHandler);
|
|
34
44
|
}
|
|
35
45
|
}
|
|
36
46
|
renderPopover() {
|
|
@@ -52,10 +62,27 @@ export class DrPopoverDirective {
|
|
|
52
62
|
popoverRef.componentRef.instance.popoverOpened.pipe(first()).subscribe(() => {
|
|
53
63
|
this.popoverOpened.emit();
|
|
54
64
|
});
|
|
65
|
+
if (!this.manualClosing?.enabled && !this.freezeToContainerSelector) {
|
|
66
|
+
window.addEventListener('wheel', this.scrollHandler);
|
|
67
|
+
}
|
|
55
68
|
}
|
|
56
69
|
ngOnDestroy() {
|
|
57
70
|
this.closePopover();
|
|
58
71
|
}
|
|
72
|
+
getScrollableElement(element, isVerticalScroll) {
|
|
73
|
+
while (element) {
|
|
74
|
+
const overflow = isVerticalScroll
|
|
75
|
+
? window.getComputedStyle(element).overflowY
|
|
76
|
+
: window.getComputedStyle(element).overflowX;
|
|
77
|
+
const isScrollable = ['auto', 'scroll'].includes(overflow) &&
|
|
78
|
+
(isVerticalScroll ? element.scrollHeight > element.clientHeight : element.scrollWidth > element.clientWidth);
|
|
79
|
+
if (isScrollable) {
|
|
80
|
+
return element;
|
|
81
|
+
}
|
|
82
|
+
element = element.parentElement;
|
|
83
|
+
}
|
|
84
|
+
return null;
|
|
85
|
+
}
|
|
59
86
|
/** @nocollapse */ static { this.ɵfac = function DrPopoverDirective_Factory(t) { return new (t || DrPopoverDirective)(i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i1.DrPopoverService)); }; }
|
|
60
87
|
/** @nocollapse */ static { this.ɵdir = /** @pureOrBreakMyCode */ i0.ɵɵdefineDirective({ type: DrPopoverDirective, selectors: [["", "drPopover", ""]], hostBindings: function DrPopoverDirective_HostBindings(rf, ctx) { if (rf & 1) {
|
|
61
88
|
i0.ɵɵlistener("click", function DrPopoverDirective_click_HostBindingHandler() { return ctx.togglePopover(); });
|
|
@@ -107,4 +134,4 @@ export class DrPopoverDirective {
|
|
|
107
134
|
type: HostListener,
|
|
108
135
|
args: ['click']
|
|
109
136
|
}] }); })();
|
|
110
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItcG9wb3Zlci5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9kci1wb3BvdmVyL2RyLXBvcG92ZXIuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLFlBQVksRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFhLE1BQU0sRUFBcUIsTUFBTSxlQUFlLENBQUM7QUFDL0gsT0FBTyxFQUFFLEtBQUssRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBR3ZDLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDOzs7QUFPeEQsTUFBTSxPQUFPLGtCQUFrQjtJQTJCM0IsWUFDWSxVQUFzQixFQUN0QixnQkFBa0M7UUFEbEMsZUFBVSxHQUFWLFVBQVUsQ0FBWTtRQUN0QixxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQWtCO1FBMUJuQixtQkFBYyxHQUFlLEVBQWdCLENBQUM7UUFFN0MsYUFBUSxHQUFlLFFBQVEsQ0FBQztRQUVuQyxVQUFLLEdBQUcsRUFBRSxDQUFDO1FBRUgsa0JBQWEsR0FBb0IsRUFBRSxDQUFDO1FBRXBDLGtCQUFhLEdBQTBCLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxDQUFDO1FBUWpFLGlCQUFZLEdBQUcsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUV0QyxrQkFBYSxHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7UUFFaEMsb0JBQWUsR0FBRyxJQUFJLFlBQVksRUFBd0IsQ0FBQztJQU81RixDQUFDO0lBR0osYUFBYTtRQUNULElBQUksSUFBSSxDQUFDLFFBQVE7WUFBRSxPQUFPO1FBRTFCLElBQUksSUFBSSxDQUFDLFVBQVUsRUFBRTtZQUNqQixJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7U0FDdkI7YUFBTTtZQUNILElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUNyQixJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxFQUFFLE9BQU8sRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDLENBQUM7U0FDN0Q7SUFDTCxDQUFDO0lBRUQsWUFBWSxDQUFDLEdBQVM7UUFDbEIsSUFBSSxJQUFJLENBQUMsVUFBVSxFQUFFO1lBQ2pCLElBQUksQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQzNCLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDO1NBQzFCO0lBQ0wsQ0FBQztJQUVPLGFBQWE7UUFDakIsTUFBTSxVQUFVLEdBQUcsQ0FBQyxJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUMzRSxPQUFPLEVBQUUsSUFBSSxDQUFDLFVBQVU7WUFDeEIsYUFBYSxFQUFFLElBQUksQ0FBQyxhQUFhO1lBQ2pDLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSztZQUNqQixhQUFhLEVBQUUsSUFBSSxDQUFDLGFBQWE7WUFDakMsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRO1lBQ3ZCLGNBQWMsRUFBRSxJQUFJLENBQUMsY0FBYztZQUNuQyxTQUFTLEVBQUUsSUFBSSxDQUFDLFNBQVM7WUFDekIseUJBQXlCLEVBQUUsSUFBSSxDQUFDLHlCQUF5QjtTQUM1RCxDQUFDLENBQUMsQ0FBQztRQUVKLFVBQVUsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUU7WUFDL0MsSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO1lBQ3BCLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQzVCLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUMsQ0FBQztRQUM5RCxDQUFDLENBQUMsQ0FBQztRQUVILFVBQVUsQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ3hFLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDOUIsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRUQsV0FBVztRQUNQLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUN4QixDQUFDO3NHQTVFUSxrQkFBa0I7bUdBQWxCLGtCQUFrQjttR0FBbEIsbUJBQWU7Ozt1RkFBZixrQkFBa0I7Y0FKOUIsU0FBUztlQUFDO2dCQUNQLFFBQVEsRUFBRSxhQUFhO2dCQUN2QixRQUFRLEVBQUUsbUJBQW1CO2FBQ2hDOzRGQUV1QixPQUFPO2tCQUExQixLQUFLO21CQUFDLFdBQVc7WUFFUyxjQUFjO2tCQUF4QyxLQUFLO21CQUFDLGtCQUFrQjtZQUVHLFFBQVE7a0JBQW5DLEtBQUs7bUJBQUMsbUJBQW1CO1lBRUQsS0FBSztrQkFBN0IsS0FBSzttQkFBQyxnQkFBZ0I7WUFFVSxhQUFhO2tCQUE3QyxLQUFLO21CQUFDLHdCQUF3QjtZQUVFLGFBQWE7a0JBQTdDLEtBQUs7bUJBQUMsd0JBQXdCO1lBRUYsU0FBUztrQkFBckMsS0FBSzttQkFBQyxvQkFBb0I7WUFFQyxRQUFRO2tCQUFuQyxLQUFLO21CQUFDLG1CQUFtQjtZQUVtQix5QkFBeUI7a0JBQXJFLEtBQUs7bUJBQUMsb0NBQW9DO1lBRWpCLFlBQVk7a0JBQXJDLE1BQU07bUJBQUMsZ0JBQWdCO1lBRUcsYUFBYTtrQkFBdkMsTUFBTTttQkFBQyxpQkFBaUI7WUFFVyxlQUFlO2tCQUFsRCxNQUFNO21CQUFDLDBCQUEwQjtZQVVsQyxhQUFhO2tCQURaLFlBQVk7bUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgRXZlbnRFbWl0dGVyLCBIb3N0TGlzdGVuZXIsIElucHV0LCBPbkRlc3Ryb3ksIE91dHB1dCwgVGVtcGxhdGVSZWYsIFR5cGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGZpcnN0IH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuaW1wb3J0IHsgRWxQb3NpdGlvbiB9IGZyb20gJy4vLi4vbW9kZWxzL2Ryb3Bkb3duJztcbmltcG9ydCB7IERyUG9wb3ZlclJlZiB9IGZyb20gJy4vZHItcG9wb3Zlci1yZWYnO1xuaW1wb3J0IHsgRHJQb3BvdmVyU2VydmljZSB9IGZyb20gJy4vZHItcG9wb3Zlci5zZXJ2aWNlJztcbmltcG9ydCB7IERyUG9wb3ZlckFsaWdubWVudCwgRHJQb3BvdmVyQ29uZmlnLCBJUG9wb3Zlck1hbnVhbENsb3NpbmcgfSBmcm9tICcuLi9tb2RlbHMvcG9wb3Zlcic7XG5cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnW2RyUG9wb3Zlcl0nLFxuICAgIGV4cG9ydEFzOiAnZHJQb3BvdmVySW5zdGFuY2UnLFxufSlcbmV4cG9ydCBjbGFzcyBEclBvcG92ZXJEaXJlY3RpdmU8VD4gaW1wbGVtZW50cyBPbkRlc3Ryb3kge1xuICAgIEBJbnB1dCgnZHJQb3BvdmVyJykgY29udGVudDogVGVtcGxhdGVSZWY8VD4gfCBUeXBlPFQ+O1xuXG4gICAgQElucHV0KCdkclBvcG92ZXJDb250ZXh0JykgY29udGVudENvbnRleHQ6IFBhcnRpYWw8VD4gPSB7fSBhcyBQYXJ0aWFsPFQ+O1xuXG4gICAgQElucHV0KCdkclBvcG92ZXJQb3NpdGlvbicpIHBvc2l0aW9uOiBFbFBvc2l0aW9uID0gJ2JvdHRvbSc7XG5cbiAgICBASW5wdXQoJ2RyUG9wb3ZlckNsYXNzJykgY2xhc3MgPSAnJztcblxuICAgIEBJbnB1dCgnZHJQb3BvdmVyT3ZlcmxheUNvbmZpZycpIG92ZXJsYXlDb25maWc6IERyUG9wb3ZlckNvbmZpZyA9IHt9O1xuXG4gICAgQElucHV0KCdkclBvcG92ZXJNYW51YWxDbG9zaW5nJykgbWFudWFsQ2xvc2luZzogSVBvcG92ZXJNYW51YWxDbG9zaW5nID0geyBlbmFibGVkOiBmYWxzZSB9O1xuXG4gICAgQElucHV0KCdkclBvcG92ZXJBbGlnbm1lbnQnKSBhbGlnbm1lbnQ6IERyUG9wb3ZlckFsaWdubWVudDtcblxuICAgIEBJbnB1dCgnZHJQb3BvdmVyRGlzYWJsZWQnKSBkaXNhYmxlZDogYm9vbGVhbjtcblxuICAgIEBJbnB1dCgnZHJQb3BvdmVyRnJlZXplVG9Db250YWluZXJTZWxlY3RvcicpIGZyZWV6ZVRvQ29udGFpbmVyU2VsZWN0b3I6IHN0cmluZztcblxuICAgIEBPdXRwdXQoJ2RyUG9wb3ZlckNsb3NlJykgcG9wb3ZlckNsb3NlID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgICBAT3V0cHV0KCdkclBvcG92ZXJPcGVuZWQnKSBwb3BvdmVyT3BlbmVkID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuXG4gICAgQE91dHB1dCgnZHJQb3BvdmVyU2hvd1N0YXRlQ2hhbmdlJykgc2hvd1N0YXRlQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjx7IGlzU2hvd246IGJvb2xlYW4gfT4oKTtcblxuICAgIHByaXZhdGUgcG9wb3ZlclJlZjogRHJQb3BvdmVyUmVmPFQ+O1xuXG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIHByaXZhdGUgZWxlbWVudFJlZjogRWxlbWVudFJlZixcbiAgICAgICAgcHJpdmF0ZSBkclBvcG92ZXJTZXJ2aWNlOiBEclBvcG92ZXJTZXJ2aWNlLFxuICAgICkge31cblxuICAgIEBIb3N0TGlzdGVuZXIoJ2NsaWNrJylcbiAgICB0b2dnbGVQb3BvdmVyKCk6IHZvaWQge1xuICAgICAgICBpZiAodGhpcy5kaXNhYmxlZCkgcmV0dXJuO1xuXG4gICAgICAgIGlmICh0aGlzLnBvcG92ZXJSZWYpIHtcbiAgICAgICAgICAgIHRoaXMuY2xvc2VQb3BvdmVyKCk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0aGlzLnJlbmRlclBvcG92ZXIoKTtcbiAgICAgICAgICAgIHRoaXMuc2hvd1N0YXRlQ2hhbmdlLmVtaXQoeyBpc1Nob3duOiAhIXRoaXMucG9wb3ZlclJlZiB9KTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIGNsb3NlUG9wb3ZlcihyZXM/OiBhbnkpOiB2b2lkIHtcbiAgICAgICAgaWYgKHRoaXMucG9wb3ZlclJlZikge1xuICAgICAgICAgICAgdGhpcy5wb3BvdmVyUmVmLmNsb3NlKHJlcyk7XG4gICAgICAgICAgICB0aGlzLnBvcG92ZXJSZWYgPSBudWxsO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHJpdmF0ZSByZW5kZXJQb3BvdmVyKCk6IHZvaWQge1xuICAgICAgICBjb25zdCBwb3BvdmVyUmVmID0gKHRoaXMucG9wb3ZlclJlZiA9IHRoaXMuZHJQb3BvdmVyU2VydmljZS5vcGVuKHRoaXMuY29udGVudCwge1xuICAgICAgICAgICAgaG9zdFJlZjogdGhpcy5lbGVtZW50UmVmLFxuICAgICAgICAgICAgb3ZlcmxheUNvbmZpZzogdGhpcy5vdmVybGF5Q29uZmlnLFxuICAgICAgICAgICAgY2xhc3M6IHRoaXMuY2xhc3MsXG4gICAgICAgICAgICBtYW51YWxDbG9zaW5nOiB0aGlzLm1hbnVhbENsb3NpbmcsXG4gICAgICAgICAgICBwb3NpdGlvbjogdGhpcy5wb3NpdGlvbixcbiAgICAgICAgICAgIGNvbnRlbnRDb250ZXh0OiB0aGlzLmNvbnRlbnRDb250ZXh0LFxuICAgICAgICAgICAgYWxpZ25tZW50OiB0aGlzLmFsaWdubWVudCxcbiAgICAgICAgICAgIGZyZWV6ZVRvQ29udGFpbmVyU2VsZWN0b3I6IHRoaXMuZnJlZXplVG9Db250YWluZXJTZWxlY3RvcixcbiAgICAgICAgfSkpO1xuXG4gICAgICAgIHBvcG92ZXJSZWYub25DbG9zZS5waXBlKGZpcnN0KCkpLnN1YnNjcmliZSgocmVzKSA9PiB7XG4gICAgICAgICAgICB0aGlzLmNsb3NlUG9wb3ZlcigpO1xuICAgICAgICAgICAgdGhpcy5wb3BvdmVyQ2xvc2UuZW1pdChyZXMpO1xuICAgICAgICAgICAgdGhpcy5zaG93U3RhdGVDaGFuZ2UuZW1pdCh7IGlzU2hvd246ICEhdGhpcy5wb3BvdmVyUmVmIH0pO1xuICAgICAgICB9KTtcblxuICAgICAgICBwb3BvdmVyUmVmLmNvbXBvbmVudFJlZi5pbnN0YW5jZS5wb3BvdmVyT3BlbmVkLnBpcGUoZmlyc3QoKSkuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgICAgICAgIHRoaXMucG9wb3Zlck9wZW5lZC5lbWl0KCk7XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgICAgICB0aGlzLmNsb3NlUG9wb3ZlcigpO1xuICAgIH1cbn1cbiJdfQ==
|
|
137
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-popover.directive.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-popover/dr-popover.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, EventEmitter, HostListener, Input, OnDestroy, Output, TemplateRef, Type } from '@angular/core';\nimport { first } from 'rxjs/operators';\nimport { ElPosition } from './../models/dropdown';\nimport { DrPopoverRef } from './dr-popover-ref';\nimport { DrPopoverService } from './dr-popover.service';\nimport { DrPopoverAlignment, DrPopoverConfig, IPopoverManualClosing } from '../models/popover';\n\n@Directive({\n    selector: '[drPopover]',\n    exportAs: 'drPopoverInstance',\n})\nexport class DrPopoverDirective<T> implements OnDestroy {\n    @Input('drPopover') content: TemplateRef<T> | Type<T>;\n\n    @Input('drPopoverContext') contentContext: Partial<T> = {} as Partial<T>;\n\n    @Input('drPopoverPosition') position: ElPosition = 'bottom';\n\n    @Input('drPopoverClass') class = '';\n\n    @Input('drPopoverOverlayConfig') overlayConfig: DrPopoverConfig = {};\n\n    @Input('drPopoverManualClosing') manualClosing: IPopoverManualClosing = { enabled: false };\n\n    @Input('drPopoverAlignment') alignment: DrPopoverAlignment;\n\n    @Input('drPopoverDisabled') disabled: boolean;\n\n    @Input('drPopoverFreezeToContainerSelector') freezeToContainerSelector: string;\n\n    @Output('drPopoverClose') popoverClose = new EventEmitter<any>();\n\n    @Output('drPopoverOpened') popoverOpened = new EventEmitter<void>();\n\n    @Output('drPopoverShowStateChange') showStateChange = new EventEmitter<{ isShown: boolean }>();\n\n    private popoverRef: DrPopoverRef<T>;\n\n    constructor(\n        private elementRef: ElementRef,\n        private drPopoverService: DrPopoverService,\n    ) {}\n\n    @HostListener('click')\n    togglePopover(): void {\n        if (this.disabled) return;\n\n        if (this.popoverRef) {\n            this.closePopover();\n        } else {\n            this.renderPopover();\n            this.showStateChange.emit({ isShown: !!this.popoverRef });\n        }\n    }\n\n    closePopover(res?: any): void {\n        if (this.popoverRef) {\n            this.popoverRef.close(res);\n            this.popoverRef = null;\n            window.removeEventListener('wheel', this.scrollHandler);\n        }\n    }\n\n    private renderPopover(): void {\n        const popoverRef = (this.popoverRef = this.drPopoverService.open(this.content, {\n            hostRef: this.elementRef,\n            overlayConfig: this.overlayConfig,\n            class: this.class,\n            manualClosing: this.manualClosing,\n            position: this.position,\n            contentContext: this.contentContext,\n            alignment: this.alignment,\n            freezeToContainerSelector: this.freezeToContainerSelector,\n        }));\n\n        popoverRef.onClose.pipe(first()).subscribe((res) => {\n            this.closePopover();\n            this.popoverClose.emit(res);\n            this.showStateChange.emit({ isShown: !!this.popoverRef });\n        });\n\n        popoverRef.componentRef.instance.popoverOpened.pipe(first()).subscribe(() => {\n            this.popoverOpened.emit();\n        });\n\n        if (!this.manualClosing?.enabled && !this.freezeToContainerSelector) {\n            window.addEventListener('wheel', this.scrollHandler);\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.closePopover();\n    }\n\n    private scrollHandler = (event) => {\n        // Find the nearest scrollable parent for which scrolling is possible\n        const isVerticalScroll = !event.shiftKey;\n        const scrollableElement = this.getScrollableElement(event.target as HTMLElement, isVerticalScroll);\n\n        // Check if scroll possible and host element places inside scrollable element\n        if (scrollableElement && scrollableElement.contains(this.elementRef.nativeElement)) {\n            this.closePopover();\n        }\n    };\n\n    getScrollableElement(element: HTMLElement | null, isVerticalScroll): HTMLElement | null {\n        while (element) {\n            const overflow = isVerticalScroll\n                ? window.getComputedStyle(element).overflowY\n                : window.getComputedStyle(element).overflowX;\n            const isScrollable =\n                ['auto', 'scroll'].includes(overflow) &&\n                (isVerticalScroll ? element.scrollHeight > element.clientHeight : element.scrollWidth > element.clientWidth);\n\n            if (isScrollable) {\n                return element;\n            }\n\n            element = element.parentElement;\n        }\n\n        return null;\n    }\n}\n"]}
|
|
@@ -2751,19 +2751,22 @@ class DateTagComponent {
|
|
|
2751
2751
|
class ForecastTagService {
|
|
2752
2752
|
static { this.MONTH_DIFF = 1; }
|
|
2753
2753
|
static { this.forecastByMonth = {
|
|
2754
|
-
0: '0+12',
|
|
2755
|
-
1: '1+11',
|
|
2756
|
-
2: '2+10',
|
|
2757
|
-
3: '3+9',
|
|
2758
|
-
4: '4+8',
|
|
2759
|
-
5: '5+7',
|
|
2760
|
-
6: '6+6',
|
|
2761
|
-
7: '7+5',
|
|
2762
|
-
8: '8+4',
|
|
2763
|
-
9: '9+3',
|
|
2764
|
-
10: '10+2',
|
|
2765
|
-
11: '11+1',
|
|
2754
|
+
'0': '0+12',
|
|
2755
|
+
'1': '1+11',
|
|
2756
|
+
'2': '2+10',
|
|
2757
|
+
'3': '3+9',
|
|
2758
|
+
'4': '4+8',
|
|
2759
|
+
'5': '5+7',
|
|
2760
|
+
'6': '6+6',
|
|
2761
|
+
'7': '7+5',
|
|
2762
|
+
'8': '8+4',
|
|
2763
|
+
'9': '9+3',
|
|
2764
|
+
'10': '10+2',
|
|
2765
|
+
'11': '11+1',
|
|
2766
2766
|
}; }
|
|
2767
|
+
static getForecastMonthTemplates() {
|
|
2768
|
+
return Array.from(Object.values(ForecastTagService.forecastByMonth));
|
|
2769
|
+
}
|
|
2767
2770
|
static getFiscalMonthFromDate(date, fiscalYearStartsFrom) {
|
|
2768
2771
|
const all_months = [];
|
|
2769
2772
|
for (let i = fiscalYearStartsFrom; i < 13; i++) {
|
|
@@ -2790,7 +2793,8 @@ class ForecastTagService {
|
|
|
2790
2793
|
return fiscal_year;
|
|
2791
2794
|
}
|
|
2792
2795
|
static getForecastLabel(month) {
|
|
2793
|
-
|
|
2796
|
+
const index = month - ForecastTagService.MONTH_DIFF;
|
|
2797
|
+
return ForecastTagService.forecastByMonth[index];
|
|
2794
2798
|
}
|
|
2795
2799
|
static getCalendarDateFromMonthAndFiscalYear(chosenMoment, monthLabel, fiscalYearStartsFrom, fiscalYearBack) {
|
|
2796
2800
|
const yearWithMonth = ForecastTagService.addMonthsWithoutYearChange(chosenMoment, monthLabel, fiscalYearStartsFrom);
|
|
@@ -8244,6 +8248,15 @@ class DrPopoverDirective {
|
|
|
8244
8248
|
this.popoverClose = new EventEmitter();
|
|
8245
8249
|
this.popoverOpened = new EventEmitter();
|
|
8246
8250
|
this.showStateChange = new EventEmitter();
|
|
8251
|
+
this.scrollHandler = (event) => {
|
|
8252
|
+
// Find the nearest scrollable parent for which scrolling is possible
|
|
8253
|
+
const isVerticalScroll = !event.shiftKey;
|
|
8254
|
+
const scrollableElement = this.getScrollableElement(event.target, isVerticalScroll);
|
|
8255
|
+
// Check if scroll possible and host element places inside scrollable element
|
|
8256
|
+
if (scrollableElement && scrollableElement.contains(this.elementRef.nativeElement)) {
|
|
8257
|
+
this.closePopover();
|
|
8258
|
+
}
|
|
8259
|
+
};
|
|
8247
8260
|
}
|
|
8248
8261
|
togglePopover() {
|
|
8249
8262
|
if (this.disabled)
|
|
@@ -8260,6 +8273,7 @@ class DrPopoverDirective {
|
|
|
8260
8273
|
if (this.popoverRef) {
|
|
8261
8274
|
this.popoverRef.close(res);
|
|
8262
8275
|
this.popoverRef = null;
|
|
8276
|
+
window.removeEventListener('wheel', this.scrollHandler);
|
|
8263
8277
|
}
|
|
8264
8278
|
}
|
|
8265
8279
|
renderPopover() {
|
|
@@ -8281,10 +8295,27 @@ class DrPopoverDirective {
|
|
|
8281
8295
|
popoverRef.componentRef.instance.popoverOpened.pipe(first()).subscribe(() => {
|
|
8282
8296
|
this.popoverOpened.emit();
|
|
8283
8297
|
});
|
|
8298
|
+
if (!this.manualClosing?.enabled && !this.freezeToContainerSelector) {
|
|
8299
|
+
window.addEventListener('wheel', this.scrollHandler);
|
|
8300
|
+
}
|
|
8284
8301
|
}
|
|
8285
8302
|
ngOnDestroy() {
|
|
8286
8303
|
this.closePopover();
|
|
8287
8304
|
}
|
|
8305
|
+
getScrollableElement(element, isVerticalScroll) {
|
|
8306
|
+
while (element) {
|
|
8307
|
+
const overflow = isVerticalScroll
|
|
8308
|
+
? window.getComputedStyle(element).overflowY
|
|
8309
|
+
: window.getComputedStyle(element).overflowX;
|
|
8310
|
+
const isScrollable = ['auto', 'scroll'].includes(overflow) &&
|
|
8311
|
+
(isVerticalScroll ? element.scrollHeight > element.clientHeight : element.scrollWidth > element.clientWidth);
|
|
8312
|
+
if (isScrollable) {
|
|
8313
|
+
return element;
|
|
8314
|
+
}
|
|
8315
|
+
element = element.parentElement;
|
|
8316
|
+
}
|
|
8317
|
+
return null;
|
|
8318
|
+
}
|
|
8288
8319
|
/** @nocollapse */ static { this.ɵfac = function DrPopoverDirective_Factory(t) { return new (t || DrPopoverDirective)(i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(DrPopoverService)); }; }
|
|
8289
8320
|
/** @nocollapse */ static { this.ɵdir = /** @pureOrBreakMyCode */ i0.ɵɵdefineDirective({ type: DrPopoverDirective, selectors: [["", "drPopover", ""]], hostBindings: function DrPopoverDirective_HostBindings(rf, ctx) { if (rf & 1) {
|
|
8290
8321
|
i0.ɵɵlistener("click", function DrPopoverDirective_click_HostBindingHandler() { return ctx.togglePopover(); });
|