@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.
@@ -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(); });