@datarailsshared/datarailsshared 1.5.531 → 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/dr-popover/dr-popover.directive.mjs +28 -1
- package/fesm2022/datarailsshared-datarailsshared.mjs +27 -0
- package/fesm2022/datarailsshared-datarailsshared.mjs.map +1 -1
- package/lib/dr-popover/dr-popover.directive.d.ts +2 -0
- package/package.json +1 -1
- package/datarailsshared-datarailsshared-1.5.531.tgz +0 -0
|
Binary file
|
|
@@ -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"]}
|
|
@@ -8248,6 +8248,15 @@ class DrPopoverDirective {
|
|
|
8248
8248
|
this.popoverClose = new EventEmitter();
|
|
8249
8249
|
this.popoverOpened = new EventEmitter();
|
|
8250
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
|
+
};
|
|
8251
8260
|
}
|
|
8252
8261
|
togglePopover() {
|
|
8253
8262
|
if (this.disabled)
|
|
@@ -8264,6 +8273,7 @@ class DrPopoverDirective {
|
|
|
8264
8273
|
if (this.popoverRef) {
|
|
8265
8274
|
this.popoverRef.close(res);
|
|
8266
8275
|
this.popoverRef = null;
|
|
8276
|
+
window.removeEventListener('wheel', this.scrollHandler);
|
|
8267
8277
|
}
|
|
8268
8278
|
}
|
|
8269
8279
|
renderPopover() {
|
|
@@ -8285,10 +8295,27 @@ class DrPopoverDirective {
|
|
|
8285
8295
|
popoverRef.componentRef.instance.popoverOpened.pipe(first()).subscribe(() => {
|
|
8286
8296
|
this.popoverOpened.emit();
|
|
8287
8297
|
});
|
|
8298
|
+
if (!this.manualClosing?.enabled && !this.freezeToContainerSelector) {
|
|
8299
|
+
window.addEventListener('wheel', this.scrollHandler);
|
|
8300
|
+
}
|
|
8288
8301
|
}
|
|
8289
8302
|
ngOnDestroy() {
|
|
8290
8303
|
this.closePopover();
|
|
8291
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
|
+
}
|
|
8292
8319
|
/** @nocollapse */ static { this.ɵfac = function DrPopoverDirective_Factory(t) { return new (t || DrPopoverDirective)(i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(DrPopoverService)); }; }
|
|
8293
8320
|
/** @nocollapse */ static { this.ɵdir = /** @pureOrBreakMyCode */ i0.ɵɵdefineDirective({ type: DrPopoverDirective, selectors: [["", "drPopover", ""]], hostBindings: function DrPopoverDirective_HostBindings(rf, ctx) { if (rf & 1) {
|
|
8294
8321
|
i0.ɵɵlistener("click", function DrPopoverDirective_click_HostBindingHandler() { return ctx.togglePopover(); });
|