@odx/angular 8.1.0 → 9.1.0

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.
Files changed (44) hide show
  1. package/CHANGELOG.md +14 -0
  2. package/animations/index.d.ts +1 -0
  3. package/cdk/connected-overlay/lib/connected-overlay.component.d.ts +4 -7
  4. package/cdk/connected-overlay/lib/models/connected-overlay-options.d.ts +1 -0
  5. package/cdk/connected-overlay/lib/models/connected-overlay-ref.d.ts +1 -0
  6. package/components/modal/lib/modal.component.d.ts +2 -8
  7. package/components/toast/lib/components/toast-container/toast-container.component.d.ts +2 -0
  8. package/components/tooltip/lib/tooltip.directive.d.ts +1 -0
  9. package/esm2022/animations/index.mjs +2 -1
  10. package/esm2022/cdk/connected-overlay/lib/connected-overlay.component.mjs +18 -56
  11. package/esm2022/cdk/connected-overlay/lib/helpers/compute-overlay-position.mjs +9 -14
  12. package/esm2022/cdk/connected-overlay/lib/models/connected-overlay-options.mjs +1 -1
  13. package/esm2022/cdk/connected-overlay/lib/models/connected-overlay-ref.mjs +2 -1
  14. package/esm2022/components/badge/lib/badge.directive.mjs +6 -2
  15. package/esm2022/components/dropdown/lib/dropdown.directive.mjs +2 -2
  16. package/esm2022/components/modal/lib/modal.component.mjs +17 -42
  17. package/esm2022/components/modal/lib/modal.service.mjs +5 -4
  18. package/esm2022/components/toast/lib/components/toast-container/toast-container.component.mjs +13 -3
  19. package/esm2022/components/tooltip/lib/tooltip.directive.mjs +6 -2
  20. package/esm2022/internal/lib/helpers/deepmerge.mjs +1 -1
  21. package/esm2022/sdk/lib/application-environment.mjs +4 -4
  22. package/esm2022/utils/lib/helpers/queue.mjs +2 -2
  23. package/fesm2022/odx-angular-animations.mjs +1 -1
  24. package/fesm2022/odx-angular-animations.mjs.map +1 -1
  25. package/fesm2022/odx-angular-cdk-connected-overlay.mjs +25 -67
  26. package/fesm2022/odx-angular-cdk-connected-overlay.mjs.map +1 -1
  27. package/fesm2022/odx-angular-components-badge.mjs +5 -1
  28. package/fesm2022/odx-angular-components-badge.mjs.map +1 -1
  29. package/fesm2022/odx-angular-components-dropdown.mjs +1 -1
  30. package/fesm2022/odx-angular-components-dropdown.mjs.map +1 -1
  31. package/fesm2022/odx-angular-components-modal.mjs +20 -44
  32. package/fesm2022/odx-angular-components-modal.mjs.map +1 -1
  33. package/fesm2022/odx-angular-components-toast.mjs +12 -2
  34. package/fesm2022/odx-angular-components-toast.mjs.map +1 -1
  35. package/fesm2022/odx-angular-components-tooltip.mjs +4 -0
  36. package/fesm2022/odx-angular-components-tooltip.mjs.map +1 -1
  37. package/fesm2022/odx-angular-internal.mjs.map +1 -1
  38. package/fesm2022/odx-angular-sdk.mjs +3 -3
  39. package/fesm2022/odx-angular-sdk.mjs.map +1 -1
  40. package/fesm2022/odx-angular-utils.mjs +1 -1
  41. package/fesm2022/odx-angular-utils.mjs.map +1 -1
  42. package/internal/lib/helpers/deepmerge.d.ts +2 -1
  43. package/package.json +6 -6
  44. package/sdk/lib/application-environment.d.ts +1 -2
package/CHANGELOG.md CHANGED
@@ -1,5 +1,19 @@
1
1
  # @odx/angular
2
2
 
3
+ ## 9.1.0
4
+
5
+ ### Minor Changes
6
+
7
+ - 388a92e: Badges, Dropdowns, Tooltips rework (connected overlay now uses popover api)
8
+
9
+ ## 9.0.0
10
+
11
+ ### Major Changes
12
+
13
+ - 65fe0c6: BREAKING CHANGE: All uses of the browsers cache API was removed due to too many race with caches on application level. Please handle request/response caching on application level.
14
+
15
+ BREAKING CHANGE: The "AuthHttpCache" service was removed due to too many race conditions with caches on application level. Please remove all usages of the "AuthHttpCache" (@odx/auth) from your application.
16
+
3
17
  ## 8.1.0
4
18
 
5
19
  ### Minor Changes
@@ -1,3 +1,4 @@
1
+ export * from './lib/config';
1
2
  export * from './lib/expand';
2
3
  export * from './lib/fade';
3
4
  export * from './lib/slide';
@@ -1,12 +1,10 @@
1
- import { AnimationEvent } from '@angular/animations';
2
- import { ElementRef, Injector, OnChanges, OnDestroy } from '@angular/core';
1
+ import { ElementRef, Injector, OnChanges, OnDestroy, OnInit } from '@angular/core';
3
2
  import { VirtualElement } from '@floating-ui/dom';
4
3
  import { NgChanges, Side } from '@odx/angular/utils';
5
4
  import { Subject } from 'rxjs';
6
5
  import { ConnectedOverlayOptions } from './models';
7
6
  import * as i0 from "@angular/core";
8
- export declare class ConnectedOverlayComponent implements OnChanges, OnDestroy {
9
- private readonly renderer;
7
+ export declare class ConnectedOverlayComponent implements OnInit, OnChanges, OnDestroy {
10
8
  private readonly zone;
11
9
  private positionUpdater;
12
10
  protected readonly injector: Injector;
@@ -17,13 +15,12 @@ export declare class ConnectedOverlayComponent implements OnChanges, OnDestroy {
17
15
  referenceElement: VirtualElement;
18
16
  options: ConnectedOverlayOptions;
19
17
  closed: Subject<void>;
18
+ ngOnInit(): void;
20
19
  ngOnChanges(changes: NgChanges<ConnectedOverlayComponent>): void;
21
20
  ngOnDestroy(): void;
22
- protected onAnimationStart({ fromState, toState }: AnimationEvent): void;
23
- protected onAnimationDone({ fromState, toState }: AnimationEvent): void;
24
21
  private startPositionUpdater;
25
22
  private stopPositionUpdater;
26
23
  private updatePosition;
27
24
  static ɵfac: i0.ɵɵFactoryDeclaration<ConnectedOverlayComponent, never>;
28
- static ɵcmp: i0.ɵɵComponentDeclaration<ConnectedOverlayComponent, "odx-connected-overlay", never, { "referenceElement": { "alias": "referenceElement"; "required": false; }; "options": { "alias": "options"; "required": false; }; }, { "closed": "closed"; }, never, never, true, never>;
25
+ static ɵcmp: i0.ɵɵComponentDeclaration<ConnectedOverlayComponent, "odx-connected-overlay[popover=\"manual\"]", never, { "referenceElement": { "alias": "referenceElement"; "required": false; }; "options": { "alias": "options"; "required": false; }; }, { "closed": "closed"; }, never, never, true, never>;
29
26
  }
@@ -15,6 +15,7 @@ export interface ConnectedOverlayOptions {
15
15
  position: Position;
16
16
  strategy: Strategy;
17
17
  showArrow?: boolean;
18
+ updateOnAnimationFrame?: boolean;
18
19
  hooks?: {
19
20
  beforeOpen?: () => void;
20
21
  afterOpen?: () => void;
@@ -43,6 +43,7 @@ export declare class ConnectedOverlayRef {
43
43
  * An Observable that emits when the overlay is closed.
44
44
  *
45
45
  * @emits {void} - Emits when the overlay is closed.
46
+ *
46
47
  */
47
48
  readonly onClose$: Observable<void>;
48
49
  constructor(dynamicViewRef: DynamicViewRef<typeof ConnectedOverlayComponent>);
@@ -1,4 +1,3 @@
1
- import { AnimationEvent } from '@angular/animations';
2
1
  import { Injector, OnChanges } from '@angular/core';
3
2
  import { DynamicContent, DynamicTextContent } from '@odx/angular/cdk/dynamic-view';
4
3
  import { NgChanges } from '@odx/angular/utils';
@@ -42,13 +41,8 @@ export declare class ModalComponent implements OnChanges {
42
41
  content: Exclude<DynamicContent, DynamicTextContent>;
43
42
  constructor();
44
43
  ngOnChanges(changes: NgChanges<ModalComponent>): void;
45
- protected animationStart(event: AnimationEvent): void;
46
- protected animationDone(event: AnimationEvent): void;
47
- /**
48
- * Prevents the default behavior of the specified event and dismisses the modal if it is dismissable.
49
- * 'Cancel' event is called by HTML Dialog on ESC key press.
50
- */
51
- protected cancelPrevent(event: Event): void;
44
+ protected preventNativeDismiss(event: KeyboardEvent): void;
45
+ protected handleDialogClose(): void;
52
46
  static ɵfac: i0.ɵɵFactoryDeclaration<ModalComponent, never>;
53
47
  static ɵcmp: i0.ɵɵComponentDeclaration<ModalComponent, "dialog[odx-dialog-modal]", never, { "content": { "alias": "content"; "required": false; }; }, {}, never, never, true, never>;
54
48
  }
@@ -13,6 +13,7 @@ import * as i0 from "@angular/core";
13
13
  */
14
14
  export declare class ToastContainerComponent implements AfterViewInit, OnDestroy {
15
15
  private static INITIALIZED;
16
+ private readonly destroyRef;
16
17
  private readonly windowRef;
17
18
  private readonly renderer;
18
19
  private readonly toastService;
@@ -36,6 +37,7 @@ export declare class ToastContainerComponent implements AfterViewInit, OnDestroy
36
37
  ngAfterViewInit(): void;
37
38
  ngOnDestroy(): void;
38
39
  protected onDismiss(itemRef: ToastRef): void;
40
+ private updatePopverPosition;
39
41
  static ɵfac: i0.ɵɵFactoryDeclaration<ToastContainerComponent, never>;
40
42
  static ɵcmp: i0.ɵɵComponentDeclaration<ToastContainerComponent, "odx-toast-container", never, { "maxItems": { "alias": "maxItems"; "required": false; }; }, { "dismiss": "dismiss"; }, never, never, true, never>;
41
43
  static ngAcceptInputType_maxItems: unknown;
@@ -15,6 +15,7 @@ export declare class TooltipDirective implements OnInit, OnChanges {
15
15
  private readonly hideTrigger$$;
16
16
  private connectedOverlayRef;
17
17
  private tooltipOptions;
18
+ private readonly injector;
18
19
  protected tooltipId: string | null;
19
20
  readonly element: import("@angular/core").ElementRef<HTMLElement>;
20
21
  /**
@@ -1,5 +1,6 @@
1
+ export * from './lib/config';
1
2
  export * from './lib/expand';
2
3
  export * from './lib/fade';
3
4
  export * from './lib/slide';
4
5
  export * from './lib/wait-for-child-animations';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvYW5pbWF0aW9ucy9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxpQ0FBaUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2V4cGFuZCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9mYWRlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NsaWRlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3dhaXQtZm9yLWNoaWxkLWFuaW1hdGlvbnMnO1xuIl19
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvYW5pbWF0aW9ucy9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxpQ0FBaUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2NvbmZpZyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9leHBhbmQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZmFkZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zbGlkZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi93YWl0LWZvci1jaGlsZC1hbmltYXRpb25zJztcbiJdfQ==
@@ -1,19 +1,16 @@
1
1
  import { __decorate } from "tslib";
2
- import { group, transition, trigger, useAnimation } from '@angular/animations';
3
- import { ChangeDetectionStrategy, Component, ElementRef, Injector, Input, NgZone, Output, Renderer2, RendererStyleFlags2, ViewChild, ViewEncapsulation, inject, } from '@angular/core';
2
+ import { ChangeDetectionStrategy, Component, ElementRef, Injector, Input, NgZone, Output, ViewChild, ViewEncapsulation, inject, } from '@angular/core';
4
3
  import { autoUpdate } from '@floating-ui/dom';
5
4
  import { CoreModule } from '@odx/angular';
6
- import { fadeIn, fadeOut, slideInLeft, slideInRight, slideInUp, slideOutDown, slideOutLeft, slideOutRight, slideOutUp, waitForChildAnimations, } from '@odx/angular/animations';
7
5
  import { DynamicViewDirective } from '@odx/angular/cdk/dynamic-view';
8
6
  import { CSSComponent } from '@odx/angular/internal';
9
- import { getSide, hasChanged, injectElement, isPresent } from '@odx/angular/utils';
7
+ import { deferFn, getSide, hasChanged, injectElement, isPresent } from '@odx/angular/utils';
10
8
  import { Subject } from 'rxjs';
11
9
  import { computeOverlayPosition } from './helpers';
12
10
  import { DefaultConnectedOverlayOptions } from './models';
13
11
  import * as i0 from "@angular/core";
14
12
  export let ConnectedOverlayComponent = class ConnectedOverlayComponent {
15
13
  constructor() {
16
- this.renderer = inject(Renderer2);
17
14
  this.zone = inject(NgZone);
18
15
  this.positionUpdater = null;
19
16
  this.injector = inject(Injector);
@@ -21,6 +18,14 @@ export let ConnectedOverlayComponent = class ConnectedOverlayComponent {
21
18
  this.options = DefaultConnectedOverlayOptions;
22
19
  this.closed = new Subject();
23
20
  }
21
+ ngOnInit() {
22
+ this.options.hooks?.beforeOpen?.();
23
+ deferFn(() => {
24
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
25
+ this.element.nativeElement?.showPopover?.();
26
+ this.options.hooks?.afterOpen?.();
27
+ });
28
+ }
24
29
  ngOnChanges(changes) {
25
30
  if (hasChanged(changes, ['options'], false)) {
26
31
  this.overlaySide = getSide(this.options.position);
@@ -31,33 +36,16 @@ export let ConnectedOverlayComponent = class ConnectedOverlayComponent {
31
36
  }
32
37
  }
33
38
  ngOnDestroy() {
39
+ this.options.hooks?.beforeClose?.();
34
40
  this.stopPositionUpdater();
35
- }
36
- onAnimationStart({ fromState, toState }) {
37
- if (!fromState)
38
- return;
39
- if (fromState === 'void') {
40
- this.renderer.setStyle(this.element.nativeElement, 'pointer-events', 'none', RendererStyleFlags2.Important);
41
- this.options.hooks?.beforeOpen?.();
42
- }
43
- else if (toState === 'void') {
44
- this.options.hooks?.beforeClose?.();
45
- }
46
- }
47
- onAnimationDone({ fromState, toState }) {
48
- if (!fromState)
49
- return;
50
- if (fromState === 'void') {
51
- this.options.hooks?.afterOpen?.();
52
- this.renderer.removeStyle(this.element.nativeElement, 'pointer-events');
53
- }
54
- else if (toState === 'void') {
55
- this.options.hooks?.afterClose?.();
56
- }
41
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
42
+ this.element.nativeElement?.hidePopover?.();
43
+ this.options.hooks?.afterClose?.();
57
44
  }
58
45
  startPositionUpdater() {
59
46
  this.positionUpdater = this.zone.runOutsideAngular(() => autoUpdate(this.referenceElement, this.element.nativeElement, () => this.updatePosition(), {
60
47
  elementResize: isPresent(window.ResizeObserver),
48
+ animationFrame: this.options.updateOnAnimationFrame,
61
49
  }));
62
50
  }
63
51
  stopPositionUpdater() {
@@ -70,40 +58,14 @@ export let ConnectedOverlayComponent = class ConnectedOverlayComponent {
70
58
  });
71
59
  }
72
60
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ConnectedOverlayComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
73
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ConnectedOverlayComponent, isStandalone: true, selector: "odx-connected-overlay", inputs: { referenceElement: "referenceElement", options: "options" }, outputs: { closed: "closed" }, host: { properties: { "@hostAnimation": "true" } }, viewQueries: [{ propertyName: "contentElement", first: true, predicate: ["content"], descendants: true, static: true }, { propertyName: "arrowElement", first: true, predicate: ["arrow"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "<div\n [@contentAnimation]=\"overlaySide\"\n (@contentAnimation.start)=\"onAnimationStart($event)\"\n (@contentAnimation.done)=\"onAnimationDone($event)\"\n class=\"odx-cdk-connected-overlay__content {{ options.containerClass }}\"\n #content\n>\n <ng-template [odxDynamicView]=\"options.content\" [odxDynamicViewContext]=\"options.context\" [odxDynamicViewInjector]=\"injector\"></ng-template>\n <div class=\"odx-cdk-connected-overlay-arrow\" #arrow></div>\n</div>\n", dependencies: [{ kind: "ngmodule", type: CoreModule }, { kind: "directive", type: DynamicViewDirective, selector: "ng-template[odxDynamicView]", inputs: ["odxDynamicView", "odxDynamicViewInjector", "odxDynamicViewContext"] }], animations: [
74
- trigger('hostAnimation', [waitForChildAnimations]),
75
- trigger('contentAnimation', [
76
- transition('void => top', group([useAnimation(slideInUp, { params: { from: '-8px' } }), useAnimation(fadeIn())])),
77
- transition('top => void', group([useAnimation(slideOutUp, { params: { to: '-8px' } }), useAnimation(fadeOut())])),
78
- transition('void => right', group([useAnimation(slideInLeft, { params: { from: '8px' } }), useAnimation(fadeIn())])),
79
- transition('right => void', group([useAnimation(slideOutRight, { params: { to: '8px' } }), useAnimation(fadeOut())])),
80
- transition('void => bottom', group([useAnimation(slideInUp, { params: { from: '8px' } }), useAnimation(fadeIn())])),
81
- transition('bottom => void', group([useAnimation(slideOutDown, { params: { to: '8px' } }), useAnimation(fadeOut())])),
82
- transition('void => left', group([useAnimation(slideInRight, { params: { from: '-8px' } }), useAnimation(fadeIn())])),
83
- transition('left => void', group([useAnimation(slideOutLeft, { params: { to: '-8px' } }), useAnimation(fadeOut())])),
84
- ]),
85
- ], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
61
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ConnectedOverlayComponent, isStandalone: true, selector: "odx-connected-overlay[popover=\"manual\"]", inputs: { referenceElement: "referenceElement", options: "options" }, outputs: { closed: "closed" }, viewQueries: [{ propertyName: "contentElement", first: true, predicate: ["content"], descendants: true, static: true }, { propertyName: "arrowElement", first: true, predicate: ["arrow"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"odx-cdk-connected-overlay__content {{ options.containerClass }}\" #content>\n <ng-template [odxDynamicView]=\"options.content\" [odxDynamicViewContext]=\"options.context\" [odxDynamicViewInjector]=\"injector\"></ng-template>\n <div class=\"odx-cdk-connected-overlay-arrow\" #arrow></div>\n</div>\n", dependencies: [{ kind: "ngmodule", type: CoreModule }, { kind: "directive", type: DynamicViewDirective, selector: "ng-template[odxDynamicView]", inputs: ["odxDynamicView", "odxDynamicViewInjector", "odxDynamicViewContext"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
86
62
  };
87
63
  ConnectedOverlayComponent = __decorate([
88
64
  CSSComponent('cdk-connected-overlay')
89
65
  ], ConnectedOverlayComponent);
90
66
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ConnectedOverlayComponent, decorators: [{
91
67
  type: Component,
92
- args: [{ standalone: true, selector: 'odx-connected-overlay', imports: [CoreModule, DynamicViewDirective], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: {
93
- '[@hostAnimation]': 'true',
94
- }, animations: [
95
- trigger('hostAnimation', [waitForChildAnimations]),
96
- trigger('contentAnimation', [
97
- transition('void => top', group([useAnimation(slideInUp, { params: { from: '-8px' } }), useAnimation(fadeIn())])),
98
- transition('top => void', group([useAnimation(slideOutUp, { params: { to: '-8px' } }), useAnimation(fadeOut())])),
99
- transition('void => right', group([useAnimation(slideInLeft, { params: { from: '8px' } }), useAnimation(fadeIn())])),
100
- transition('right => void', group([useAnimation(slideOutRight, { params: { to: '8px' } }), useAnimation(fadeOut())])),
101
- transition('void => bottom', group([useAnimation(slideInUp, { params: { from: '8px' } }), useAnimation(fadeIn())])),
102
- transition('bottom => void', group([useAnimation(slideOutDown, { params: { to: '8px' } }), useAnimation(fadeOut())])),
103
- transition('void => left', group([useAnimation(slideInRight, { params: { from: '-8px' } }), useAnimation(fadeIn())])),
104
- transition('left => void', group([useAnimation(slideOutLeft, { params: { to: '-8px' } }), useAnimation(fadeOut())])),
105
- ]),
106
- ], template: "<div\n [@contentAnimation]=\"overlaySide\"\n (@contentAnimation.start)=\"onAnimationStart($event)\"\n (@contentAnimation.done)=\"onAnimationDone($event)\"\n class=\"odx-cdk-connected-overlay__content {{ options.containerClass }}\"\n #content\n>\n <ng-template [odxDynamicView]=\"options.content\" [odxDynamicViewContext]=\"options.context\" [odxDynamicViewInjector]=\"injector\"></ng-template>\n <div class=\"odx-cdk-connected-overlay-arrow\" #arrow></div>\n</div>\n" }]
68
+ args: [{ standalone: true, selector: 'odx-connected-overlay[popover="manual"]', imports: [CoreModule, DynamicViewDirective], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<div class=\"odx-cdk-connected-overlay__content {{ options.containerClass }}\" #content>\n <ng-template [odxDynamicView]=\"options.content\" [odxDynamicViewContext]=\"options.context\" [odxDynamicViewInjector]=\"injector\"></ng-template>\n <div class=\"odx-cdk-connected-overlay-arrow\" #arrow></div>\n</div>\n" }]
107
69
  }], propDecorators: { contentElement: [{
108
70
  type: ViewChild,
109
71
  args: ['content', { static: true }]
@@ -117,4 +79,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
117
79
  }], closed: [{
118
80
  type: Output
119
81
  }] } });
120
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"connected-overlay.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular/cdk/connected-overlay/src/lib/connected-overlay.component.ts","../../../../../../../libs/angular/cdk/connected-overlay/src/lib/connected-overlay.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AnimationEvent, group, transition, trigger, useAnimation } from '@angular/animations';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Injector,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  Output,\n  Renderer2,\n  RendererStyleFlags2,\n  ViewChild,\n  ViewEncapsulation,\n  inject,\n} from '@angular/core';\nimport { VirtualElement, autoUpdate } from '@floating-ui/dom';\nimport { CoreModule } from '@odx/angular';\nimport {\n  fadeIn,\n  fadeOut,\n  slideInLeft,\n  slideInRight,\n  slideInUp,\n  slideOutDown,\n  slideOutLeft,\n  slideOutRight,\n  slideOutUp,\n  waitForChildAnimations,\n} from '@odx/angular/animations';\nimport { DynamicViewDirective } from '@odx/angular/cdk/dynamic-view';\nimport { CSSComponent } from '@odx/angular/internal';\nimport { NgChanges, Side, getSide, hasChanged, injectElement, isPresent } from '@odx/angular/utils';\nimport { Subject } from 'rxjs';\nimport { computeOverlayPosition } from './helpers';\nimport { ConnectedOverlayOptions, DefaultConnectedOverlayOptions } from './models';\n\n@CSSComponent('cdk-connected-overlay')\n@Component({\n  standalone: true,\n  selector: 'odx-connected-overlay',\n  imports: [CoreModule, DynamicViewDirective],\n  templateUrl: 'connected-overlay.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  host: {\n    '[@hostAnimation]': 'true',\n  },\n  animations: [\n    trigger('hostAnimation', [waitForChildAnimations]),\n    trigger('contentAnimation', [\n      transition('void => top', group([useAnimation(slideInUp, { params: { from: '-8px' } }), useAnimation(fadeIn())])),\n      transition('top => void', group([useAnimation(slideOutUp, { params: { to: '-8px' } }), useAnimation(fadeOut())])),\n      transition('void => right', group([useAnimation(slideInLeft, { params: { from: '8px' } }), useAnimation(fadeIn())])),\n      transition('right => void', group([useAnimation(slideOutRight, { params: { to: '8px' } }), useAnimation(fadeOut())])),\n      transition('void => bottom', group([useAnimation(slideInUp, { params: { from: '8px' } }), useAnimation(fadeIn())])),\n      transition('bottom => void', group([useAnimation(slideOutDown, { params: { to: '8px' } }), useAnimation(fadeOut())])),\n      transition('void => left', group([useAnimation(slideInRight, { params: { from: '-8px' } }), useAnimation(fadeIn())])),\n      transition('left => void', group([useAnimation(slideOutLeft, { params: { to: '-8px' } }), useAnimation(fadeOut())])),\n    ]),\n  ],\n})\nexport class ConnectedOverlayComponent implements OnChanges, OnDestroy {\n  private readonly renderer = inject(Renderer2);\n  private readonly zone = inject(NgZone);\n  private positionUpdater: (() => void) | null = null;\n\n  protected readonly injector = inject(Injector);\n  protected overlaySide?: Side;\n\n  @ViewChild('content', { static: true })\n  protected contentElement!: ElementRef<HTMLElement>;\n\n  @ViewChild('arrow', { static: true })\n  protected arrowElement!: ElementRef<HTMLElement>;\n\n  public readonly element = injectElement();\n\n  @Input()\n  public referenceElement!: VirtualElement;\n\n  @Input()\n  public options: ConnectedOverlayOptions = DefaultConnectedOverlayOptions;\n\n  @Output()\n  public closed = new Subject<void>();\n\n  public ngOnChanges(changes: NgChanges<ConnectedOverlayComponent>): void {\n    if (hasChanged(changes, ['options'], false)) {\n      this.overlaySide = getSide(this.options.position);\n    }\n    if (hasChanged(changes, ['referenceElement', 'options'], false)) {\n      this.stopPositionUpdater();\n      this.startPositionUpdater();\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.stopPositionUpdater();\n  }\n\n  protected onAnimationStart({ fromState, toState }: AnimationEvent): void {\n    if (!fromState) return;\n    if (fromState === 'void') {\n      this.renderer.setStyle(this.element.nativeElement, 'pointer-events', 'none', RendererStyleFlags2.Important);\n      this.options.hooks?.beforeOpen?.();\n    } else if (toState === 'void') {\n      this.options.hooks?.beforeClose?.();\n    }\n  }\n\n  protected onAnimationDone({ fromState, toState }: AnimationEvent): void {\n    if (!fromState) return;\n    if (fromState === 'void') {\n      this.options.hooks?.afterOpen?.();\n      this.renderer.removeStyle(this.element.nativeElement, 'pointer-events');\n    } else if (toState === 'void') {\n      this.options.hooks?.afterClose?.();\n    }\n  }\n\n  private startPositionUpdater(): void {\n    this.positionUpdater = this.zone.runOutsideAngular(() =>\n      autoUpdate(this.referenceElement, this.element.nativeElement, () => this.updatePosition(), {\n        elementResize: isPresent(window.ResizeObserver),\n      }),\n    );\n  }\n\n  private stopPositionUpdater(): void {\n    this.positionUpdater?.();\n    this.positionUpdater = null;\n  }\n\n  private async updatePosition(): Promise<void> {\n    return computeOverlayPosition(\n      this.referenceElement,\n      this.element.nativeElement,\n      this.contentElement.nativeElement,\n      this.arrowElement.nativeElement,\n      this.options,\n    ).then(({ placement }) => {\n      this.overlaySide = getSide(placement);\n    });\n  }\n}\n","<div\n  [@contentAnimation]=\"overlaySide\"\n  (@contentAnimation.start)=\"onAnimationStart($event)\"\n  (@contentAnimation.done)=\"onAnimationDone($event)\"\n  class=\"odx-cdk-connected-overlay__content {{ options.containerClass }}\"\n  #content\n>\n  <ng-template [odxDynamicView]=\"options.content\" [odxDynamicViewContext]=\"options.context\" [odxDynamicViewInjector]=\"injector\"></ng-template>\n  <div class=\"odx-cdk-connected-overlay-arrow\" #arrow></div>\n</div>\n"]}
82
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"connected-overlay.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular/cdk/connected-overlay/src/lib/connected-overlay.component.ts","../../../../../../../libs/angular/cdk/connected-overlay/src/lib/connected-overlay.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Injector,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild,\n  ViewEncapsulation,\n  inject,\n} from '@angular/core';\nimport { VirtualElement, autoUpdate } from '@floating-ui/dom';\nimport { CoreModule } from '@odx/angular';\nimport { DynamicViewDirective } from '@odx/angular/cdk/dynamic-view';\nimport { CSSComponent } from '@odx/angular/internal';\nimport { NgChanges, Side, deferFn, getSide, hasChanged, injectElement, isPresent } from '@odx/angular/utils';\nimport { Subject } from 'rxjs';\nimport { computeOverlayPosition } from './helpers';\nimport { ConnectedOverlayOptions, DefaultConnectedOverlayOptions } from './models';\n\n@CSSComponent('cdk-connected-overlay')\n@Component({\n  standalone: true,\n  selector: 'odx-connected-overlay[popover=\"manual\"]',\n  imports: [CoreModule, DynamicViewDirective],\n  templateUrl: 'connected-overlay.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class ConnectedOverlayComponent implements OnInit, OnChanges, OnDestroy {\n  private readonly zone = inject(NgZone);\n  private positionUpdater: (() => void) | null = null;\n\n  protected readonly injector = inject(Injector);\n  protected overlaySide?: Side;\n\n  @ViewChild('content', { static: true })\n  protected contentElement!: ElementRef<HTMLElement>;\n\n  @ViewChild('arrow', { static: true })\n  protected arrowElement!: ElementRef<HTMLElement>;\n\n  public readonly element = injectElement();\n\n  @Input()\n  public referenceElement!: VirtualElement;\n\n  @Input()\n  public options: ConnectedOverlayOptions = DefaultConnectedOverlayOptions;\n\n  @Output()\n  public closed = new Subject<void>();\n\n  public ngOnInit(): void {\n    this.options.hooks?.beforeOpen?.();\n    deferFn(() => {\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      (this.element.nativeElement as any)?.showPopover?.();\n      this.options.hooks?.afterOpen?.();\n    });\n  }\n\n  public ngOnChanges(changes: NgChanges<ConnectedOverlayComponent>): void {\n    if (hasChanged(changes, ['options'], false)) {\n      this.overlaySide = getSide(this.options.position);\n    }\n    if (hasChanged(changes, ['referenceElement', 'options'], false)) {\n      this.stopPositionUpdater();\n      this.startPositionUpdater();\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.options.hooks?.beforeClose?.();\n    this.stopPositionUpdater();\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    (this.element.nativeElement as any)?.hidePopover?.();\n    this.options.hooks?.afterClose?.();\n  }\n\n  private startPositionUpdater(): void {\n    this.positionUpdater = this.zone.runOutsideAngular(() =>\n      autoUpdate(this.referenceElement, this.element.nativeElement, () => this.updatePosition(), {\n        elementResize: isPresent(window.ResizeObserver),\n        animationFrame: this.options.updateOnAnimationFrame,\n      }),\n    );\n  }\n\n  private stopPositionUpdater(): void {\n    this.positionUpdater?.();\n    this.positionUpdater = null;\n  }\n\n  private async updatePosition(): Promise<void> {\n    return computeOverlayPosition(\n      this.referenceElement,\n      this.element.nativeElement,\n      this.contentElement.nativeElement,\n      this.arrowElement.nativeElement,\n      this.options,\n    ).then(({ placement }) => {\n      this.overlaySide = getSide(placement);\n    });\n  }\n}\n","<div class=\"odx-cdk-connected-overlay__content {{ options.containerClass }}\" #content>\n  <ng-template [odxDynamicView]=\"options.content\" [odxDynamicViewContext]=\"options.context\" [odxDynamicViewInjector]=\"injector\"></ng-template>\n  <div class=\"odx-cdk-connected-overlay-arrow\" #arrow></div>\n</div>\n"]}
@@ -1,5 +1,5 @@
1
1
  import { arrow, computePosition, flip, hide, shift, size, offset as withOffset } from '@floating-ui/dom';
2
- import { applyStyles, cssTranslate, getOppositeSide, getSide, px } from '@odx/angular/utils';
2
+ import { applyStyles, getOppositeSide, getSide, px } from '@odx/angular/utils';
3
3
  /**
4
4
  * Computes the position of an overlay element relative to a reference element.
5
5
  *
@@ -11,6 +11,7 @@ import { applyStyles, cssTranslate, getOppositeSide, getSide, px } from '@odx/an
11
11
  * @returns A promise that resolves to the computed position of the overlay.
12
12
  */
13
13
  export async function computeOverlayPosition(referenceElement, overlayElement, contentElement, arrowElement, options) {
14
+ const variablePrefix = '--odx-cdk-connected-overlay';
14
15
  const { position, offset, outerPadding, matchReferenceWidth, enableFallback, fallbackAxisSideDirection, strategy, minHeight } = options;
15
16
  const arrowSize = options.showArrow ? arrowElement.offsetWidth : 0;
16
17
  const arrowMiddleware = options.showArrow ? [arrow({ element: arrowElement, padding: 8 })] : [];
@@ -24,23 +25,17 @@ export async function computeOverlayPosition(referenceElement, overlayElement, c
24
25
  ...flipMiddleWare,
25
26
  size({
26
27
  padding: outerPadding,
27
- apply: ({ availableHeight, availableWidth, rects }) => {
28
- const variablePrefix = '--odx-cdk-connected-overlay';
29
- contentElement.style.setProperty(`${variablePrefix}-max-height`, px(availableHeight));
30
- contentElement.style.setProperty(`${variablePrefix}-max-width`, px(availableWidth));
31
- contentElement.style.setProperty(`${variablePrefix}-min-height`, minHeight ? px(Math.min(availableHeight, minHeight)) : null);
32
- contentElement.style.setProperty(`${variablePrefix}-min-width`, matchReferenceWidth ? px(rects.reference.width) : null);
28
+ apply: ({ availableHeight, rects }) => {
29
+ contentElement.style.setProperty?.(`${variablePrefix}-min-height`, minHeight ? px(Math.min(availableHeight, minHeight)) : null);
30
+ contentElement.style.setProperty?.(`${variablePrefix}-min-width`, matchReferenceWidth ? px(rects.reference.width) : null);
33
31
  },
34
32
  }),
35
33
  ...arrowMiddleware,
36
- hide(),
34
+ hide({ rootBoundary: 'viewport' }),
37
35
  ],
38
36
  }).then((result) => {
39
- applyStyles(overlayElement, {
40
- top: '0',
41
- left: '0',
42
- transform: cssTranslate(px(result.x), px(result.y)),
43
- });
37
+ overlayElement.style.setProperty?.(`${variablePrefix}-position-x`, px(result.x));
38
+ overlayElement.style.setProperty?.(`${variablePrefix}-position-y`, px(result.y));
44
39
  if (options.hiddenClass) {
45
40
  overlayElement.classList.toggle(options.hiddenClass, !!result.middlewareData.hide?.referenceHidden);
46
41
  }
@@ -61,4 +56,4 @@ export async function computeOverlayPosition(referenceElement, overlayElement, c
61
56
  return result;
62
57
  });
63
58
  }
64
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"compute-overlay-position.js","sourceRoot":"","sources":["../../../../../../../../libs/angular/cdk/connected-overlay/src/lib/helpers/compute-overlay-position.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComputePositionReturn, VirtualElement, arrow, computePosition, flip, hide, shift, size, offset as withOffset } from '@floating-ui/dom';\nimport { applyStyles, cssTranslate, getOppositeSide, getSide, px } from '@odx/angular/utils';\nimport { ConnectedOverlayOptions } from '../models';\n\n/**\n * Computes the position of an overlay element relative to a reference element.\n *\n * @param referenceElement - The reference element to position the overlay relative to.\n * @param overlayElement - The overlay element to be positioned.\n * @param contentElement - The content element within the overlay.\n * @param arrowElement - The arrow element within the overlay.\n * @param options - The options for positioning the overlay.\n * @returns A promise that resolves to the computed position of the overlay.\n */\nexport async function computeOverlayPosition(\n  referenceElement: VirtualElement,\n  overlayElement: HTMLElement,\n  contentElement: HTMLElement,\n  arrowElement: HTMLElement,\n  options: ConnectedOverlayOptions,\n): Promise<ComputePositionReturn> {\n  const { position, offset, outerPadding, matchReferenceWidth, enableFallback, fallbackAxisSideDirection, strategy, minHeight } = options;\n  const arrowSize = options.showArrow ? arrowElement.offsetWidth : 0;\n  const arrowMiddleware = options.showArrow ? [arrow({ element: arrowElement, padding: 8 })] : [];\n  const flipMiddleWare = enableFallback ? [flip({ fallbackAxisSideDirection })] : [];\n\n  return computePosition(referenceElement, overlayElement, {\n    strategy,\n    placement: position,\n    middleware: [\n      withOffset(Math.max(offset, arrowSize + offset)),\n      shift({ padding: outerPadding }),\n      ...flipMiddleWare,\n      size({\n        padding: outerPadding,\n        apply: ({ availableHeight, availableWidth, rects }) => {\n          const variablePrefix = '--odx-cdk-connected-overlay';\n          contentElement.style.setProperty(`${variablePrefix}-max-height`, px(availableHeight));\n          contentElement.style.setProperty(`${variablePrefix}-max-width`, px(availableWidth));\n          contentElement.style.setProperty(`${variablePrefix}-min-height`, minHeight ? px(Math.min(availableHeight, minHeight)) : null);\n          contentElement.style.setProperty(`${variablePrefix}-min-width`, matchReferenceWidth ? px(rects.reference.width) : null);\n        },\n      }),\n      ...arrowMiddleware,\n      hide(),\n    ],\n  }).then((result) => {\n    applyStyles(overlayElement, {\n      top: '0',\n      left: '0',\n      transform: cssTranslate(px(result.x), px(result.y)),\n    });\n    if (options.hiddenClass) {\n      overlayElement.classList.toggle(options.hiddenClass, !!result.middlewareData.hide?.referenceHidden);\n    }\n    if (options.showArrow) {\n      const overlaySide = getSide(result.placement);\n      const arrowSide = getOppositeSide(result.placement);\n      applyStyles(arrowElement, {\n        display: null,\n        top: px(result.middlewareData.arrow?.y),\n        left: px(result.middlewareData.arrow?.x),\n        [arrowSide]: px(-arrowSize / 2),\n        [overlaySide]: null,\n      });\n    } else {\n      applyStyles(arrowElement, { display: 'none' });\n    }\n\n    return result;\n  });\n}\n"]}
59
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcHV0ZS1vdmVybGF5LXBvc2l0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL2Nkay9jb25uZWN0ZWQtb3ZlcmxheS9zcmMvbGliL2hlbHBlcnMvY29tcHV0ZS1vdmVybGF5LXBvc2l0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBeUMsS0FBSyxFQUFFLGVBQWUsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUUsTUFBTSxJQUFJLFVBQVUsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ2hKLE9BQU8sRUFBRSxXQUFXLEVBQUUsZUFBZSxFQUFFLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUcvRTs7Ozs7Ozs7O0dBU0c7QUFDSCxNQUFNLENBQUMsS0FBSyxVQUFVLHNCQUFzQixDQUMxQyxnQkFBZ0MsRUFDaEMsY0FBMkIsRUFDM0IsY0FBMkIsRUFDM0IsWUFBeUIsRUFDekIsT0FBZ0M7SUFFaEMsTUFBTSxjQUFjLEdBQUcsNkJBQTZCLENBQUM7SUFDckQsTUFBTSxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsWUFBWSxFQUFFLG1CQUFtQixFQUFFLGNBQWMsRUFBRSx5QkFBeUIsRUFBRSxRQUFRLEVBQUUsU0FBUyxFQUFFLEdBQUcsT0FBTyxDQUFDO0lBQ3hJLE1BQU0sU0FBUyxHQUFHLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLFlBQVksQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNuRSxNQUFNLGVBQWUsR0FBRyxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxFQUFFLE9BQU8sRUFBRSxZQUFZLEVBQUUsT0FBTyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO0lBQ2hHLE1BQU0s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cG9ydCB7IENvbXB1dGVQb3NpdGlvblJldHVybiwgVmlydHVhbEVsZW1lbnQsIGFycm93LCBjb21wdXRlUG9zaXRpb24sIGZsaXAsIGhpZGUsIHNoaWZ0LCBzaXplLCBvZmZzZXQgYXMgd2l0aE9mZnNldCB9IGZyb20gJ0BmbG9hdGluZy11aS9kb20nO1xuaW1wb3J0IHsgYXBwbHlTdHlsZXMsIGdldE9wcG9zaXRlU2lkZSwgZ2V0U2lkZSwgcHggfSBmcm9tICdAb2R4L2FuZ3VsYXIvdXRpbHMnO1xuaW1wb3J0IHsgQ29ubmVjdGVkT3ZlcmxheU9wdGlvbnMgfSBmcm9tICcuLi9tb2RlbHMnO1xuXG4vKipcbiAqIENvbXB1dGVzIHRoZSBwb3NpdGlvbiBvZiBhbiBvdmVybGF5IGVsZW1lbnQgcmVsYXRpdmUgdG8gYSByZWZlcmVuY2UgZWxlbWVudC5cbiAqXG4gKiBAcGFyYW0gcmVmZXJlbmNlRWxlbWVudCAtIFRoZSByZWZlcmVuY2UgZWxlbWVudCB0byBwb3NpdGlvbiB0aGUgb3ZlcmxheSByZWxhdGl2ZSB0by5cbiAqIEBwYXJhbSBvdmVybGF5RWxlbWVudCAtIFRoZSBvdmVybGF5IGVsZW1lbnQgdG8gYmUgcG9zaXRpb25lZC5cbiAqIEBwYXJhbSBjb250ZW50RWxlbWVudCAtIFRoZSBjb250ZW50IGVsZW1lbnQgd2l0aGluIHRoZSBvdmVybGF5LlxuICogQHBhcmFtIGFycm93RWxlbWVudCAtIFRoZSBhcnJvdyBlbGVtZW50IHdpdGhpbiB0aGUgb3ZlcmxheS5cbiAqIEBwYXJhbSBvcHRpb25zIC0gVGhlIG9wdGlvbnMgZm9yIHBvc2l0aW9uaW5nIHRoZSBvdmVybGF5LlxuICogQHJldHVybnMgQSBwcm9taXNlIHRoYXQgcmVzb2x2ZXMgdG8gdGhlIGNvbXB1dGVkIHBvc2l0aW9uIG9mIHRoZSBvdmVybGF5LlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gY29tcHV0ZU92ZXJsYXlQb3NpdGlvbihcbiAgcmVmZXJlbmNlRWxlbWVudDogVmlydHVhbEVsZW1lbnQsXG4gIG92ZXJsYXlFbGVtZW50OiBIVE1MRWxlbWVudCxcbiAgY29udGVudEVsZW1lbnQ6IEhUTUxFbGVtZW50LFxuICBhcnJvd0VsZW1lbnQ6IEhUTUxFbGVtZW50LFxuICBvcHRpb25zOiBDb25uZWN0ZWRPdmVybGF5T3B0aW9ucyxcbik6IFByb21pc2U8Q29tcHV0ZVBvc2l0aW9uUmV0dXJuPiB7XG4gIGNvbnN0IHZhcmlhYmxlUHJlZml4ID0gJy0tb2R4LWNkay1jb25uZWN0ZWQtb3ZlcmxheSc7XG4gIGNvbnN0IHsgcG9zaXRpb24sIG9mZnNldCwgb3V0ZXJQYWRkaW5nLCBtYXRjaFJlZmVyZW5jZVdpZHRoLCBlbmFibGVGYWxsYmFjaywgZmFsbGJhY2tBeGlzU2lkZURpcmVjdGlvbiwgc3RyYXRlZ3ksIG1pbkhlaWdodCB9ID0gb3B0aW9ucztcbiAgY29uc3QgYXJyb3dTaXplID0gb3B0aW9ucy5zaG93QXJyb3cgPyBhcnJvd0VsZW1lbnQub2Zmc2V0V2lkdGggOiAwO1xuICBjb25zdCBhcnJvd01pZGRsZXdhcmUgPSBvcHRpb25zLnNob3dBcnJvdyA/IFthcnJvdyh7IGVsZW1lbnQ6IGFycm93RWxlbWVudCwgcGFkZGluZzogOCB9KV0gOiBbXTtcbiAgY29uc3QgZmxpcE1pZGRsZVdhcmUgPSBlbmFibGVGYWxsYmFjayA/IFtmbGlwKHsgZmFsbGJhY2tBeGlzU2lkZURpcmVjdGlvbiB9KV0gOiBbXTtcbiAgcmV0dXJuIGNvbXB1dGVQb3NpdGlvbihyZWZlcmVuY2VFbGVtZW50LCBvdmVybGF5RWxlbWVudCwge1xuICAgIHN0cmF0ZWd5LFxuICAgIHBsYWNlbWVudDogcG9zaXRpb24sXG4gICAgbWlkZGxld2FyZTogW1xuICAgICAgd2l0aE9mZnNldChNYXRoLm1heChvZmZzZXQsIGFycm93U2l6ZSArIG9mZnNldCkpLFxuICAgICAgc2hpZnQoeyBwYWRkaW5nOiBvdXRlclBhZGRpbmcgfSksXG4gICAgICAuLi5mbGlwTWlkZGxlV2FyZSxcbiAgICAgIHNpemUoe1xuICAgICAgICBwYWRkaW5nOiBvdXRlclBhZGRpbmcsXG4gICAgICAgIGFwcGx5OiAoeyBhdmFpbGFibGVIZWlnaHQsIHJlY3RzIH0pID0+IHtcbiAgICAgICAgICBjb250ZW50RWxlbWVudC5zdHlsZS5zZXRQcm9wZXJ0eT8uKGAke3ZhcmlhYmxlUHJlZml4fS1taW4taGVpZ2h0YCwgbWluSGVpZ2h0ID8gcHgoTWF0aC5taW4oYXZhaWxhYmxlSGVpZ2h0LCBtaW5IZWlnaHQpKSA6IG51bGwpO1xuICAgICAgICAgIGNvbnRlbnRFbGVtZW50LnN0eWxlLnNldFByb3BlcnR5Py4oYCR7dmFyaWFibGVQcmVmaXh9LW1pbi13aWR0aGAsIG1hdGNoUmVmZXJlbmNlV2lkdGggPyBweChyZWN0cy5yZWZlcmVuY2Uud2lkdGgpIDogbnVsbCk7XG4gICAgICAgIH0sXG4gICAgICB9KSxcbiAgICAgIC4uLmFycm93TWlkZGxld2FyZSxcbiAgICAgIGhpZGUoeyByb290Qm91bmRhcnk6ICd2aWV3cG9ydCcgfSksXG4gICAgXSxcbiAgfSkudGhlbigocmVzdWx0KSA9PiB7XG4gICAgb3ZlcmxheUVsZW1lbnQuc3R5bGUuc2V0UHJvcGVydHk/LihgJHt2YXJpYWJsZVByZWZpeH0tcG9zaXRpb24teGAsIHB4KHJlc3VsdC54KSk7XG4gICAgb3ZlcmxheUVsZW1lbnQuc3R5bGUuc2V0UHJvcGVydHk/LihgJHt2YXJpYWJsZVByZWZpeH0tcG9zaXRpb24teWAsIHB4KHJlc3VsdC55KSk7XG4gICAgaWYgKG9wdGlvbnMuaGlkZGVuQ2xhc3MpIHtcbiAgICAgIG92ZXJsYXlFbGVtZW50LmNsYXNzTGlzdC50b2dnbGUob3B0aW9ucy5oaWRkZW5DbGFzcywgISFyZXN1bHQubWlkZGxld2FyZURhdGEuaGlkZT8ucmVmZXJlbmNlSGlkZGVuKTtcbiAgICB9XG4gICAgaWYgKG9wdGlvbnMuc2hvd0Fycm93KSB7XG4gICAgICBjb25zdCBvdmVybGF5U2lkZSA9IGdldFNpZGUocmVzdWx0LnBsYWNlbWVudCk7XG4gICAgICBjb25zdCBhcnJvd1NpZGUgPSBnZXRPcHBvc2l0ZVNpZGUocmVzdWx0LnBsYWNlbWVudCk7XG4gICAgICBhcHBseVN0eWxlcyhhcnJvd0VsZW1lbnQsIHtcbiAgICAgICAgZGlzcGxheTogbnVsbCxcbiAgICAgICAgdG9wOiBweChyZXN1bHQubWlkZGxld2FyZURhdGEuYXJyb3c/LnkpLFxuICAgICAgICBsZWZ0OiBweChyZXN1bHQubWlkZGxld2FyZURhdGEuYXJyb3c/LngpLFxuICAgICAgICBbYXJyb3dTaWRlXTogcHgoLWFycm93U2l6ZSAvIDIpLFxuICAgICAgICBbb3ZlcmxheVNpZGVdOiBudWxsLFxuICAgICAgfSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIGFwcGx5U3R5bGVzKGFycm93RWxlbWVudCwgeyBkaXNwbGF5OiAnbm9uZScgfSk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHJlc3VsdDtcbiAgfSk7XG59XG4iXX0=
@@ -9,4 +9,4 @@ export const DefaultConnectedOverlayOptions = {
9
9
  position: Position.BOTTOM,
10
10
  strategy: 'fixed',
11
11
  };
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29ubmVjdGVkLW92ZXJsYXktb3B0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci9jZGsvY29ubmVjdGVkLW92ZXJsYXkvc3JjL2xpYi9tb2RlbHMvY29ubmVjdGVkLW92ZXJsYXktb3B0aW9ucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUF3QjlDLE1BQU0sQ0FBQyxNQUFNLDhCQUE4QixHQUE0QjtJQUNyRSxXQUFXLEVBQUUsV0FBVztJQUN4QixjQUFjLEVBQUUsS0FBSztJQUNyQix5QkFBeUIsRUFBRSxPQUFPO0lBQ2xDLG1CQUFtQixFQUFFLEtBQUs7SUFDMUIsTUFBTSxFQUFFLENBQUM7SUFDVCxZQUFZLEVBQUUsRUFBRTtJQUNoQixRQUFRLEVBQUUsUUFBUSxDQUFDLE1BQU07SUFDekIsUUFBUSxFQUFFLE9BQU87Q0FDbEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFN0cmF0ZWd5IH0gZnJvbSAnQGZsb2F0aW5nLXVpL2RvbSc7XG5pbXBvcnQgeyBEeW5hbWljQ29udGVudCB9IGZyb20gJ0BvZHgvYW5ndWxhci9jZGsvZHluYW1pYy12aWV3JztcbmltcG9ydCB7IFBvc2l0aW9uIH0gZnJvbSAnQG9keC9hbmd1bGFyL3V0aWxzJztcblxuZXhwb3J0IGludGVyZmFjZSBDb25uZWN0ZWRPdmVybGF5T3B0aW9ucyB7XG4gIGNvbnRlbnQ/OiBEeW5hbWljQ29udGVudCB8IG51bGw7XG4gIGNvbnRleHQ/OiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPjtcbiAgY29udGFpbmVyQ2xhc3M/OiBzdHJpbmcgfCBudWxsO1xuICBoaWRkZW5DbGFzczogc3RyaW5nIHwgbnVsbDtcbiAgZW5hYmxlRmFsbGJhY2s6IGJvb2xlYW47XG4gIGZhbGxiYWNrQXhpc1NpZGVEaXJlY3Rpb246ICdzdGFydCcgfCAnZW5kJztcbiAgbWF0Y2hSZWZlcmVuY2VXaWR0aDogYm9vbGVhbjtcbiAgbWluSGVpZ2h0PzogbnVtYmVyIHwgbnVsbDtcbiAgb2Zmc2V0OiBudW1iZXI7XG4gIG91dGVyUGFkZGluZzogbnVtYmVyO1xuICBwb3NpdGlvbjogUG9zaXRpb247XG4gIHN0cmF0ZWd5OiBTdHJhdGVneTtcbiAgc2hvd0Fycm93PzogYm9vbGVhbjtcbiAgaG9va3M/OiB7XG4gICAgYmVmb3JlT3Blbj86ICgpID0+IHZvaWQ7XG4gICAgYWZ0ZXJPcGVuPzogKCkgPT4gdm9pZDtcbiAgICBiZWZvcmVDbG9zZT86ICgpID0+IHZvaWQ7XG4gICAgYWZ0ZXJDbG9zZT86ICgpID0+IHZvaWQ7XG4gIH07XG59XG5cbmV4cG9ydCBjb25zdCBEZWZhdWx0Q29ubmVjdGVkT3ZlcmxheU9wdGlvbnM6IENvbm5lY3RlZE92ZXJsYXlPcHRpb25zID0ge1xuICBoaWRkZW5DbGFzczogJ2lzLWhpZGRlbicsXG4gIGVuYWJsZUZhbGxiYWNrOiBmYWxzZSxcbiAgZmFsbGJhY2tBeGlzU2lkZURpcmVjdGlvbjogJ3N0YXJ0JyxcbiAgbWF0Y2hSZWZlcmVuY2VXaWR0aDogZmFsc2UsXG4gIG9mZnNldDogOCxcbiAgb3V0ZXJQYWRkaW5nOiAxMixcbiAgcG9zaXRpb246IFBvc2l0aW9uLkJPVFRPTSxcbiAgc3RyYXRlZ3k6ICdmaXhlZCcsXG59O1xuIl19
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29ubmVjdGVkLW92ZXJsYXktb3B0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci9jZGsvY29ubmVjdGVkLW92ZXJsYXkvc3JjL2xpYi9tb2RlbHMvY29ubmVjdGVkLW92ZXJsYXktb3B0aW9ucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUF5QjlDLE1BQU0sQ0FBQyxNQUFNLDhCQUE4QixHQUE0QjtJQUNyRSxXQUFXLEVBQUUsV0FBVztJQUN4QixjQUFjLEVBQUUsS0FBSztJQUNyQix5QkFBeUIsRUFBRSxPQUFPO0lBQ2xDLG1CQUFtQixFQUFFLEtBQUs7SUFDMUIsTUFBTSxFQUFFLENBQUM7SUFDVCxZQUFZLEVBQUUsRUFBRTtJQUNoQixRQUFRLEVBQUUsUUFBUSxDQUFDLE1BQU07SUFDekIsUUFBUSxFQUFFLE9BQU87Q0FDbEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFN0cmF0ZWd5IH0gZnJvbSAnQGZsb2F0aW5nLXVpL2RvbSc7XG5pbXBvcnQgeyBEeW5hbWljQ29udGVudCB9IGZyb20gJ0BvZHgvYW5ndWxhci9jZGsvZHluYW1pYy12aWV3JztcbmltcG9ydCB7IFBvc2l0aW9uIH0gZnJvbSAnQG9keC9hbmd1bGFyL3V0aWxzJztcblxuZXhwb3J0IGludGVyZmFjZSBDb25uZWN0ZWRPdmVybGF5T3B0aW9ucyB7XG4gIGNvbnRlbnQ/OiBEeW5hbWljQ29udGVudCB8IG51bGw7XG4gIGNvbnRleHQ/OiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPjtcbiAgY29udGFpbmVyQ2xhc3M/OiBzdHJpbmcgfCBudWxsO1xuICBoaWRkZW5DbGFzczogc3RyaW5nIHwgbnVsbDtcbiAgZW5hYmxlRmFsbGJhY2s6IGJvb2xlYW47XG4gIGZhbGxiYWNrQXhpc1NpZGVEaXJlY3Rpb246ICdzdGFydCcgfCAnZW5kJztcbiAgbWF0Y2hSZWZlcmVuY2VXaWR0aDogYm9vbGVhbjtcbiAgbWluSGVpZ2h0PzogbnVtYmVyIHwgbnVsbDtcbiAgb2Zmc2V0OiBudW1iZXI7XG4gIG91dGVyUGFkZGluZzogbnVtYmVyO1xuICBwb3NpdGlvbjogUG9zaXRpb247XG4gIHN0cmF0ZWd5OiBTdHJhdGVneTtcbiAgc2hvd0Fycm93PzogYm9vbGVhbjtcbiAgdXBkYXRlT25BbmltYXRpb25GcmFtZT86IGJvb2xlYW47XG4gIGhvb2tzPzoge1xuICAgIGJlZm9yZU9wZW4/OiAoKSA9PiB2b2lkO1xuICAgIGFmdGVyT3Blbj86ICgpID0+IHZvaWQ7XG4gICAgYmVmb3JlQ2xvc2U/OiAoKSA9PiB2b2lkO1xuICAgIGFmdGVyQ2xvc2U/OiAoKSA9PiB2b2lkO1xuICB9O1xufVxuXG5leHBvcnQgY29uc3QgRGVmYXVsdENvbm5lY3RlZE92ZXJsYXlPcHRpb25zOiBDb25uZWN0ZWRPdmVybGF5T3B0aW9ucyA9IHtcbiAgaGlkZGVuQ2xhc3M6ICdpcy1oaWRkZW4nLFxuICBlbmFibGVGYWxsYmFjazogZmFsc2UsXG4gIGZhbGxiYWNrQXhpc1NpZGVEaXJlY3Rpb246ICdzdGFydCcsXG4gIG1hdGNoUmVmZXJlbmNlV2lkdGg6IGZhbHNlLFxuICBvZmZzZXQ6IDgsXG4gIG91dGVyUGFkZGluZzogMTIsXG4gIHBvc2l0aW9uOiBQb3NpdGlvbi5CT1RUT00sXG4gIHN0cmF0ZWd5OiAnZml4ZWQnLFxufTtcbiJdfQ==
@@ -41,6 +41,7 @@ export class ConnectedOverlayRef {
41
41
  * An Observable that emits when the overlay is closed.
42
42
  *
43
43
  * @emits {void} - Emits when the overlay is closed.
44
+ *
44
45
  */
45
46
  this.onClose$ = this.dynamicViewRef.getContext().closed ?? EMPTY;
46
47
  }
@@ -61,4 +62,4 @@ export class ConnectedOverlayRef {
61
62
  this.dynamicViewRef.destroy();
62
63
  }
63
64
  }
64
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29ubmVjdGVkLW92ZXJsYXktcmVmLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL2Nkay9jb25uZWN0ZWQtb3ZlcmxheS9zcmMvbGliL21vZGVscy9jb25uZWN0ZWQtb3ZlcmxheS1yZWYudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLEtBQUssRUFBYyxNQUFNLE1BQU0sQ0FBQztBQUl6Qzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBaUNHO0FBQ0gsTUFBTSxPQUFPLG1CQUFtQjtJQVU5QixZQUE2QixjQUFnRTtRQUFoRSxtQkFBYyxHQUFkLGNBQWMsQ0FBa0Q7UUFUN0UsWUFBTyxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsVUFBVSxFQUFFLENBQUM7UUFFM0Q7Ozs7V0FJRztRQUNhLGFBQVEsR0FBcUIsSUFBSSxDQUFDLGNBQWMsQ0FBQyxVQUFVLEVBQUUsQ0FBQyxNQUFNLElBQUksS0FBSyxDQUFDO0lBRUUsQ0FBQztJQUVqRzs7OztPQUlHO0lBQ0ksTUFBTSxDQUFDLE9BQXlDO1FBQ3JELElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLEVBQUUsT0FBTyxFQUFFLE9BQWtDLEVBQUUsQ0FBQyxDQUFDO0lBQzlFLENBQUM7SUFFRDs7OztPQUlHO0lBQ0ksS0FBSztRQUNWLElBQUksQ0FBQyxjQUFjLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDaEMsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRHluYW1pY1ZpZXdSZWYgfSBmcm9tICdAb2R4L2FuZ3VsYXIvY2RrL2R5bmFtaWMtdmlldyc7XG5pbXBvcnQgeyBFTVBUWSwgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgQ29ubmVjdGVkT3ZlcmxheUNvbXBvbmVudCB9IGZyb20gJy4uL2Nvbm5lY3RlZC1vdmVybGF5LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDb25uZWN0ZWRPdmVybGF5T3B0aW9ucyB9IGZyb20gJy4vY29ubmVjdGVkLW92ZXJsYXktb3B0aW9ucyc7XG5cbi8qKlxuICogQSByZWZlcmVuY2UgdG8gYSBjb25uZWN0ZWQgb3ZlcmxheSBjcmVhdGVkIGJ5IHRoZSBgQ29ubmVjdGVkT3ZlcmxheVNlcnZpY2VgLiBUaGlzIGNsYXNzIHByb3ZpZGVzIG1ldGhvZHMgdG8gaW50ZXJhY3RcbiAqIHdpdGggdGhlIG92ZXJsYXksIHN1Y2ggYXMgdXBkYXRpbmcgaXRzIG9wdGlvbnMgb3IgY2xvc2luZyBpdC4gSXQgZW5jYXBzdWxhdGVzIHRoZSBgRHluYW1pY1ZpZXdSZWZgIGZvciB0aGUgb3ZlcmxheSdzIGluc3RhbmNlLFxuICogYWxsb3dpbmcgZm9yIGRpcmVjdCBtYW5pcHVsYXRpb24gb2YgdGhlIG92ZXJsYXkncyBzdGF0ZSBhbmQgYmVoYXZpb3IuXG4gKlxuICogVGhpcyBleGFtcGxlIGRlbW9uc3RyYXRlcyBob3cgdG8gdXNlIGEgYENvbm5lY3RlZE92ZXJsYXlSZWZgIHRvIHVwZGF0ZSBhbmQgY2xvc2UgYSBjb25uZWN0ZWQgb3ZlcmxheSBpbiByZXNwb25zZVxuICogdG8gdXNlciBpbnRlcmFjdGlvbnMuXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYHRzXG4gKiBjbGFzcyBNeUNvbXBvbmVudCB7XG4gKiAgIHByaXZhdGUgb3ZlcmxheVJlZj86IENvbm5lY3RlZE92ZXJsYXlSZWY7XG4gKlxuICogICBjb25zdHJ1Y3Rvcihwcml2YXRlIG92ZXJsYXlTZXJ2aWNlOiBDb25uZWN0ZWRPdmVybGF5U2VydmljZSkge31cbiAqXG4gKiAgIG9wZW5PdmVybGF5KCkge1xuICogICAgIHRoaXMub3ZlcmxheVJlZiA9IHRoaXMub3ZlcmxheVNlcnZpY2UuY3JlYXRlT3ZlcmxheSh0aGlzLnNvbWVFbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQsIHsgcG9zaXRpb246ICdib3R0b20nIH0pO1xuICogICB9XG4gKlxuICogICB1cGRhdGVPdmVybGF5UG9zaXRpb24oKSB7XG4gKiAgICAgaWYgKHRoaXMub3ZlcmxheVJlZikge1xuICogICAgICAgdGhpcy5vdmVybGF5UmVmLnVwZGF0ZSh7IHBvc2l0aW9uOiAndG9wJyB9KTtcbiAqICAgICB9XG4gKiAgIH1cbiAqXG4gKiAgIGNsb3NlT3ZlcmxheSgpIHtcbiAqICAgICB0aGlzLm92ZXJsYXlSZWY/LmNsb3NlKCk7XG4gKiAgIH1cbiAqIH1cbiAqIGBgYFxuICpcbiAqIEluIHRoaXMgZXhhbXBsZSwgYE15Q29tcG9uZW50YCB1c2VzIHRoZSBgQ29ubmVjdGVkT3ZlcmxheVNlcnZpY2VgIHRvIGNyZWF0ZSBhbiBvdmVybGF5LiBJdCBzdG9yZXMgYSByZWZlcmVuY2UgdG9cbiAqIHRoZSBjcmVhdGVkIG92ZXJsYXkgaW4gYG92ZXJsYXlSZWZgLCBhbGxvd2luZyBpdCB0byB1cGRhdGUgdGhlIG92ZXJsYXkncyBwb3NpdGlvbiBvciBjbG9zZSBpdCB3aGVuIG5lY2Vzc2FyeS5cbiAqL1xuZXhwb3J0IGNsYXNzIENvbm5lY3RlZE92ZXJsYXlSZWYge1xuICBwdWJsaWMgcmVhZG9ubHkgZWxlbWVudCA9IHRoaXMuZHluYW1pY1ZpZXdSZWYuZ2V0RWxlbWVudCgpO1xuXG4gIC8qKlxuICAgKiBBbiBPYnNlcnZhYmxlIHRoYXQgZW1pdHMgd2hlbiB0aGUgb3ZlcmxheSBpcyBjbG9zZWQuXG4gICAqXG4gICAqIEBlbWl0cyB7dm9pZH0gLSBFbWl0cyB3aGVuIHRoZSBvdmVybGF5IGlzIGNsb3NlZC5cbiAgICovXG4gIHB1YmxpYyByZWFkb25seSBvbkNsb3NlJDogT2JzZXJ2YWJsZTx2b2lkPiA9IHRoaXMuZHluYW1pY1ZpZXdSZWYuZ2V0Q29udGV4dCgpLmNsb3NlZCA/PyBFTVBUWTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IGR5bmFtaWNWaWV3UmVmOiBEeW5hbWljVmlld1JlZjx0eXBlb2YgQ29ubmVjdGVkT3ZlcmxheUNvbXBvbmVudD4pIHt9XG5cbiAgLyoqXG4gICAqIFVwZGF0ZXMgdGhlIGNvbm5lY3RlZCBvdmVybGF5IHdpdGggbmV3IG9wdGlvbnMuXG4gICAqXG4gICAqIEBwYXJhbSBvcHRpb25zIHtQYXJ0aWFsPENvbm5lY3RlZE92ZXJsYXlPcHRpb25zPn0gLSBUaGUgbmV3IG9wdGlvbnMgdG8gYmUgYXBwbGllZCB0byB0aGUgY29ubmVjdGVkIG92ZXJsYXkuXG4gICAqL1xuICBwdWJsaWMgdXBkYXRlKG9wdGlvbnM6IFBhcnRpYWw8Q29ubmVjdGVkT3ZlcmxheU9wdGlvbnM+KTogdm9pZCB7XG4gICAgdGhpcy5keW5hbWljVmlld1JlZi51cGRhdGUoeyBvcHRpb25zOiBvcHRpb25zIGFzIENvbm5lY3RlZE92ZXJsYXlPcHRpb25zIH0pO1xuICB9XG5cbiAgLyoqXG4gICAqIENsb3NlcyB0aGUgY29ubmVjdGVkIG92ZXJsYXkuXG4gICAqXG4gICAqIEByZXR1cm5zIHt2b2lkfVxuICAgKi9cbiAgcHVibGljIGNsb3NlKCk6IHZvaWQge1xuICAgIHRoaXMuZHluYW1pY1ZpZXdSZWYuZGVzdHJveSgpO1xuICB9XG59XG4iXX0=
65
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29ubmVjdGVkLW92ZXJsYXktcmVmLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL2Nkay9jb25uZWN0ZWQtb3ZlcmxheS9zcmMvbGliL21vZGVscy9jb25uZWN0ZWQtb3ZlcmxheS1yZWYudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLEtBQUssRUFBYyxNQUFNLE1BQU0sQ0FBQztBQUl6Qzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBaUNHO0FBQ0gsTUFBTSxPQUFPLG1CQUFtQjtJQVc5QixZQUE2QixjQUFnRTtRQUFoRSxtQkFBYyxHQUFkLGNBQWMsQ0FBa0Q7UUFWN0UsWUFBTyxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsVUFBVSxFQUFFLENBQUM7UUFFM0Q7Ozs7O1dBS0c7UUFDYSxhQUFRLEdBQXFCLElBQUksQ0FBQyxjQUFjLENBQUMsVUFBVSxFQUFFLENBQUMsTUFBTSxJQUFJLEtBQUssQ0FBQztJQUVFLENBQUM7SUFFakc7Ozs7T0FJRztJQUNJLE1BQU0sQ0FBQyxPQUF5QztRQUNyRCxJQUFJLENBQUMsY0FBYyxDQUFDLE1BQU0sQ0FBQyxFQUFFLE9BQU8sRUFBRSxPQUFrQyxFQUFFLENBQUMsQ0FBQztJQUM5RSxDQUFDO0lBRUQ7Ozs7T0FJRztJQUNJLEtBQUs7UUFDVixJQUFJLENBQUMsY0FBYyxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQ2hDLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IER5bmFtaWNWaWV3UmVmIH0gZnJvbSAnQG9keC9hbmd1bGFyL2Nkay9keW5hbWljLXZpZXcnO1xuaW1wb3J0IHsgRU1QVFksIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IENvbm5lY3RlZE92ZXJsYXlDb21wb25lbnQgfSBmcm9tICcuLi9jb25uZWN0ZWQtb3ZlcmxheS5jb21wb25lbnQnO1xuaW1wb3J0IHsgQ29ubmVjdGVkT3ZlcmxheU9wdGlvbnMgfSBmcm9tICcuL2Nvbm5lY3RlZC1vdmVybGF5LW9wdGlvbnMnO1xuXG4vKipcbiAqIEEgcmVmZXJlbmNlIHRvIGEgY29ubmVjdGVkIG92ZXJsYXkgY3JlYXRlZCBieSB0aGUgYENvbm5lY3RlZE92ZXJsYXlTZXJ2aWNlYC4gVGhpcyBjbGFzcyBwcm92aWRlcyBtZXRob2RzIHRvIGludGVyYWN0XG4gKiB3aXRoIHRoZSBvdmVybGF5LCBzdWNoIGFzIHVwZGF0aW5nIGl0cyBvcHRpb25zIG9yIGNsb3NpbmcgaXQuIEl0IGVuY2Fwc3VsYXRlcyB0aGUgYER5bmFtaWNWaWV3UmVmYCBmb3IgdGhlIG92ZXJsYXkncyBpbnN0YW5jZSxcbiAqIGFsbG93aW5nIGZvciBkaXJlY3QgbWFuaXB1bGF0aW9uIG9mIHRoZSBvdmVybGF5J3Mgc3RhdGUgYW5kIGJlaGF2aW9yLlxuICpcbiAqIFRoaXMgZXhhbXBsZSBkZW1vbnN0cmF0ZXMgaG93IHRvIHVzZSBhIGBDb25uZWN0ZWRPdmVybGF5UmVmYCB0byB1cGRhdGUgYW5kIGNsb3NlIGEgY29ubmVjdGVkIG92ZXJsYXkgaW4gcmVzcG9uc2VcbiAqIHRvIHVzZXIgaW50ZXJhY3Rpb25zLlxuICpcbiAqIEBleGFtcGxlXG4gKiBgYGB0c1xuICogY2xhc3MgTXlDb21wb25lbnQge1xuICogICBwcml2YXRlIG92ZXJsYXlSZWY/OiBDb25uZWN0ZWRPdmVybGF5UmVmO1xuICpcbiAqICAgY29uc3RydWN0b3IocHJpdmF0ZSBvdmVybGF5U2VydmljZTogQ29ubmVjdGVkT3ZlcmxheVNlcnZpY2UpIHt9XG4gKlxuICogICBvcGVuT3ZlcmxheSgpIHtcbiAqICAgICB0aGlzLm92ZXJsYXlSZWYgPSB0aGlzLm92ZXJsYXlTZXJ2aWNlLmNyZWF0ZU92ZXJsYXkodGhpcy5zb21lRWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LCB7IHBvc2l0aW9uOiAnYm90dG9tJyB9KTtcbiAqICAgfVxuICpcbiAqICAgdXBkYXRlT3ZlcmxheVBvc2l0aW9uKCkge1xuICogICAgIGlmICh0aGlzLm92ZXJsYXlSZWYpIHtcbiAqICAgICAgIHRoaXMub3ZlcmxheVJlZi51cGRhdGUoeyBwb3NpdGlvbjogJ3RvcCcgfSk7XG4gKiAgICAgfVxuICogICB9XG4gKlxuICogICBjbG9zZU92ZXJsYXkoKSB7XG4gKiAgICAgdGhpcy5vdmVybGF5UmVmPy5jbG9zZSgpO1xuICogICB9XG4gKiB9XG4gKiBgYGBcbiAqXG4gKiBJbiB0aGlzIGV4YW1wbGUsIGBNeUNvbXBvbmVudGAgdXNlcyB0aGUgYENvbm5lY3RlZE92ZXJsYXlTZXJ2aWNlYCB0byBjcmVhdGUgYW4gb3ZlcmxheS4gSXQgc3RvcmVzIGEgcmVmZXJlbmNlIHRvXG4gKiB0aGUgY3JlYXRlZCBvdmVybGF5IGluIGBvdmVybGF5UmVmYCwgYWxsb3dpbmcgaXQgdG8gdXBkYXRlIHRoZSBvdmVybGF5J3MgcG9zaXRpb24gb3IgY2xvc2UgaXQgd2hlbiBuZWNlc3NhcnkuXG4gKi9cbmV4cG9ydCBjbGFzcyBDb25uZWN0ZWRPdmVybGF5UmVmIHtcbiAgcHVibGljIHJlYWRvbmx5IGVsZW1lbnQgPSB0aGlzLmR5bmFtaWNWaWV3UmVmLmdldEVsZW1lbnQoKTtcblxuICAvKipcbiAgICogQW4gT2JzZXJ2YWJsZSB0aGF0IGVtaXRzIHdoZW4gdGhlIG92ZXJsYXkgaXMgY2xvc2VkLlxuICAgKlxuICAgKiBAZW1pdHMge3ZvaWR9IC0gRW1pdHMgd2hlbiB0aGUgb3ZlcmxheSBpcyBjbG9zZWQuXG4gICAqXG4gICAqL1xuICBwdWJsaWMgcmVhZG9ubHkgb25DbG9zZSQ6IE9ic2VydmFibGU8dm9pZD4gPSB0aGlzLmR5bmFtaWNWaWV3UmVmLmdldENvbnRleHQoKS5jbG9zZWQgPz8gRU1QVFk7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBkeW5hbWljVmlld1JlZjogRHluYW1pY1ZpZXdSZWY8dHlwZW9mIENvbm5lY3RlZE92ZXJsYXlDb21wb25lbnQ+KSB7fVxuXG4gIC8qKlxuICAgKiBVcGRhdGVzIHRoZSBjb25uZWN0ZWQgb3ZlcmxheSB3aXRoIG5ldyBvcHRpb25zLlxuICAgKlxuICAgKiBAcGFyYW0gb3B0aW9ucyB7UGFydGlhbDxDb25uZWN0ZWRPdmVybGF5T3B0aW9ucz59IC0gVGhlIG5ldyBvcHRpb25zIHRvIGJlIGFwcGxpZWQgdG8gdGhlIGNvbm5lY3RlZCBvdmVybGF5LlxuICAgKi9cbiAgcHVibGljIHVwZGF0ZShvcHRpb25zOiBQYXJ0aWFsPENvbm5lY3RlZE92ZXJsYXlPcHRpb25zPik6IHZvaWQge1xuICAgIHRoaXMuZHluYW1pY1ZpZXdSZWYudXBkYXRlKHsgb3B0aW9uczogb3B0aW9ucyBhcyBDb25uZWN0ZWRPdmVybGF5T3B0aW9ucyB9KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDbG9zZXMgdGhlIGNvbm5lY3RlZCBvdmVybGF5LlxuICAgKlxuICAgKiBAcmV0dXJucyB7dm9pZH1cbiAgICovXG4gIHB1YmxpYyBjbG9zZSgpOiB2b2lkIHtcbiAgICB0aGlzLmR5bmFtaWNWaWV3UmVmLmRlc3Ryb3koKTtcbiAgfVxufVxuIl19
@@ -11,6 +11,7 @@ const DEFAULT_BADGE_OVERLAY_OPTIONS = {
11
11
  enableFallback: false,
12
12
  offset: 0,
13
13
  containerClass: 'odx-badge-overlay',
14
+ updateOnAnimationFrame: true,
14
15
  };
15
16
  export let BadgeDirective = class BadgeDirective {
16
17
  constructor() {
@@ -67,7 +68,10 @@ export let BadgeDirective = class BadgeDirective {
67
68
  this.hideBadge();
68
69
  }
69
70
  showBadge() {
70
- this.badgeRef ??= this.connectedOverlayService.createOverlay(this.element.nativeElement, DEFAULT_BADGE_OVERLAY_OPTIONS, { injector: this.injector });
71
+ this.badgeRef ??= this.connectedOverlayService.createOverlay(this.element.nativeElement, DEFAULT_BADGE_OVERLAY_OPTIONS, {
72
+ host: this.element.nativeElement.parentElement,
73
+ injector: this.injector,
74
+ });
71
75
  }
72
76
  hideBadge() {
73
77
  this.badgeRef?.close();
@@ -108,4 +112,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
108
112
  type: Input,
109
113
  args: [{ alias: 'odxBadgeVariant' }]
110
114
  }] } });
111
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFkZ2UuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL2NvbXBvbmVudHMvYmFkZ2Uvc3JjL2xpYi9iYWRnZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLFFBQVEsRUFBRSxLQUFLLEVBQUUsZUFBZSxFQUF3QixNQUFNLGVBQWUsQ0FBQztBQUM1SCxPQUFPLEVBQWdELHVCQUF1QixFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFFM0gsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3JELE9BQU8sRUFBRSxhQUFhLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3hFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNuRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sVUFBVSxDQUFDOztBQUV4QyxNQUFNLDZCQUE2QixHQUFxQztJQUN0RSxPQUFPLEVBQUUsY0FBYztJQUN2QixjQUFjLEVBQUUsS0FBSztJQUNyQixNQUFNLEVBQUUsQ0FBQztJQUNULGNBQWMsRUFBRSxtQkFBbUI7Q0FDcEMsQ0FBQztBQU9LLFdBQU0sY0FBYyxHQUFwQixNQUFNLGNBQWM7SUFBcEI7UUFDWSw0QkFBdUIsR0FBRyxNQUFNLENBQUMsdUJBQXVCLENBQUMsQ0FBQztRQUMxRCxhQUFRLEdBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQ3JDLGFBQVEsR0FBK0IsSUFBSSxDQUFDO1FBRXBDLFlBQU8sR0FBRyxhQUFhLEVBQUUsQ0FBQztRQUUxQzs7Ozs7V0FLRztRQUVJLFVBQUssR0FBK0IsSUFBSSxDQUFDO1FBRWhEOzs7OztXQUtHO1FBRUksYUFBUSxHQUFHLEtBQUssQ0FBQztRQUV4Qjs7Ozs7V0FLRztRQUVJLGFBQVEsR0FBYSxRQUFRLENBQUMsVUFBVSxDQUFDO1FBRWhEOzs7OztXQUtHO1FBRUksV0FBTSxHQUFHLENBQUMsQ0FBQztRQUVsQjs7Ozs7V0FLRztRQUVJLFlBQU8sR0FBaUIsWUFBWSxDQUFDLFNBQVMsQ0FBQztLQStCdkQ7SUE3QlEsV0FBVztRQUNoQixJQUFJLFNBQVMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUU7WUFDekIsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1NBQ2xCO2FBQU07WUFDTCxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7U0FDbEI7UUFDRCxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDckIsQ0FBQztJQUVNLFdBQVc7UUFDaEIsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO0lBQ25CLENBQUM7SUFFTyxTQUFTO1FBQ2YsSUFBSSxDQUFDLFFBQVEsS0FBSyxJQUFJLENBQUMsdUJBQXVCLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxFQUFFLDZCQUE2QixFQUFFLEVBQUUsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO0lBQ3ZKLENBQUM7SUFFTyxTQUFTO1FBQ2YsSUFBSSxDQUFDLFFBQVEsRUFBRSxLQUFLLEVBQUUsQ0FBQztRQUN2QixJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQztJQUN2QixDQUFDO0lBRU8sV0FBVztRQUNqQixJQUFJLENBQUMsUUFBUSxFQUFFLE1BQU0sQ0FBQztZQUNwQixPQUFPLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVEsRUFBRSxLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUssRUFBRSxPQUFPLEVBQUUsSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUM5RSxRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVE7WUFDdkIsTUFBTSxFQUFFLElBQUksQ0FBQyxNQUFNO1NBQ3BCLENBQUMsQ0FBQztJQUNMLENBQUM7K0dBaEZVLGNBQWM7bUdBQWQsY0FBYyxpSUFzQnNCLGdCQUFnQixvRkFrQmxCLGVBQWU7O0FBeENqRCxjQUFjO0lBTDFCLFlBQVksQ0FBQyxZQUFZLENBQUM7R0FLZCxjQUFjLENBaUYxQjs0RkFqRlksY0FBYztrQkFKMUIsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsWUFBWTtvQkFDdEIsVUFBVSxFQUFFLElBQUk7aUJBQ2pCOzhCQWVRLEtBQUs7c0JBRFgsS0FBSzt1QkFBQyxVQUFVO2dCQVVWLFFBQVE7c0JBRGQsS0FBSzt1QkFBQyxFQUFFLEtBQUssRUFBRSxrQkFBa0IsRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUU7Z0JBVTFELFFBQVE7c0JBRGQsS0FBSzt1QkFBQyxFQUFFLEtBQUssRUFBRSxrQkFBa0IsRUFBRTtnQkFVN0IsTUFBTTtzQkFEWixLQUFLO3VCQUFDLEVBQUUsS0FBSyxFQUFFLGdCQUFnQixFQUFFLFNBQVMsRUFBRSxlQUFlLEVBQUU7Z0JBVXZELE9BQU87c0JBRGIsS0FBSzt1QkFBQyxFQUFFLEtBQUssRUFBRSxpQkFBaUIsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGJvb2xlYW5BdHRyaWJ1dGUsIERpcmVjdGl2ZSwgaW5qZWN0LCBJbmplY3RvciwgSW5wdXQsIG51bWJlckF0dHJpYnV0ZSwgT25DaGFuZ2VzLCBPbkRlc3Ryb3kgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbm5lY3RlZE92ZXJsYXlPcHRpb25zLCBDb25uZWN0ZWRPdmVybGF5UmVmLCBDb25uZWN0ZWRPdmVybGF5U2VydmljZSB9IGZyb20gJ0BvZHgvYW5ndWxhci9jZGsvY29ubmVjdGVkLW92ZXJsYXknO1xuaW1wb3J0IHsgRHluYW1pY1RleHRDb250ZW50IH0gZnJvbSAnQG9keC9hbmd1bGFyL2Nkay9keW5hbWljLXZpZXcnO1xuaW1wb3J0IHsgQ1NTQ29tcG9uZW50IH0gZnJvbSAnQG9keC9hbmd1bGFyL2ludGVybmFsJztcbmltcG9ydCB7IGluamVjdEVsZW1lbnQsIGlzUHJlc2VudCwgUG9zaXRpb24gfSBmcm9tICdAb2R4L2FuZ3VsYXIvdXRpbHMnO1xuaW1wb3J0IHsgQmFkZ2VDb21wb25lbnQgfSBmcm9tICcuL2JhZGdlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBCYWRnZVZhcmlhbnQgfSBmcm9tICcuL21vZGVscyc7XG5cbmNvbnN0IERFRkFVTFRfQkFER0VfT1ZFUkxBWV9PUFRJT05TOiBQYXJ0aWFsPENvbm5lY3RlZE92ZXJsYXlPcHRpb25zPiA9IHtcbiAgY29udGVudDogQmFkZ2VDb21wb25lbnQsXG4gIGVuYWJsZUZhbGxiYWNrOiBmYWxzZSxcbiAgb2Zmc2V0OiAwLFxuICBjb250YWluZXJDbGFzczogJ29keC1iYWRnZS1vdmVybGF5Jyxcbn07XG5cbkBDU1NDb21wb25lbnQoJ2JhZGdlLWhvc3QnKVxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW29keEJhZGdlXScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIEJhZGdlRGlyZWN0aXZlIGltcGxlbWVudHMgQmFkZ2VDb21wb25lbnQsIE9uQ2hhbmdlcywgT25EZXN0cm95IHtcbiAgcHJpdmF0ZSByZWFkb25seSBjb25uZWN0ZWRPdmVybGF5U2VydmljZSA9IGluamVjdChDb25uZWN0ZWRPdmVybGF5U2VydmljZSk7XG4gIHByaXZhdGUgcmVhZG9ubHkgaW5qZWN0b3IgPSBpbmplY3QoSW5qZWN0b3IpO1xuICBwcml2YXRlIGJhZGdlUmVmOiBDb25uZWN0ZWRPdmVybGF5UmVmIHwgbnVsbCA9IG51bGw7XG5cbiAgcHVibGljIHJlYWRvbmx5IGVsZW1lbnQgPSBpbmplY3RFbGVtZW50KCk7XG5cbiAgLyoqXG4gICAqIFRoZSB2YWx1ZSBvZiB0aGUgYmFkZ2UgZGlyZWN0aXZlLlxuICAgKlxuICAgKiBAdHlwZSB7RHluYW1pY1RleHRDb250ZW50fVxuICAgKiBAZGVmYXVsdCBudWxsXG4gICAqL1xuICBASW5wdXQoJ29keEJhZGdlJylcbiAgcHVibGljIHZhbHVlPzogRHluYW1pY1RleHRDb250ZW50IHwgbnVsbCA9IG51bGw7XG5cbiAgLyoqXG4gICAqIEluZGljYXRlcyB3aGV0aGVyIHRoZSBiYWRnZSBzaG91bGQgaGF2ZSBhIGNvbnRyYXN0IGVmZmVjdC5cbiAgICpcbiAgICogQHR5cGUge2Jvb2xlYW59XG4gICAqIEBkZWZhdWx0IGZhbHNlXG4gICAqL1xuICBASW5wdXQoeyBhbGlhczogJ29keEJhZGdlQ29udHJhc3QnLCB0cmFuc2Zvcm06IGJvb2xlYW5BdHRyaWJ1dGUgfSlcbiAgcHVibGljIGNvbnRyYXN0ID0gZmFsc2U7XG5cbiAgLyoqXG4gICAqIFRoZSBwb3NpdGlvbiBvZiB0aGUgYmFkZ2UuXG4gICAqXG4gICAqIEB0eXBlIHtQb3NpdGlvbn1cbiAgICogQGRlZmF1bHQgUG9zaXRpb24uQk9UVE9NX0VORFxuICAgKi9cbiAgQElucHV0KHsgYWxpYXM6ICdvZHhCYWRnZVBvc2l0aW9uJyB9KVxuICBwdWJsaWMgcG9zaXRpb246IFBvc2l0aW9uID0gUG9zaXRpb24uQk9UVE9NX0VORDtcblxuICAvKipcbiAgICogVGhlIG9mZnNldCBvZiB0aGUgYmFkZ2UuXG4gICAqXG4gICAqIEB0eXBlIHtudW1iZXJ9XG4gICAqIEBkZWZhdWx0IDBcbiAgICovXG4gIEBJbnB1dCh7IGFsaWFzOiAnb2R4QmFkZ2VPZmZzZXQnLCB0cmFuc2Zvcm06IG51bWJlckF0dHJpYnV0ZSB9KVxuICBwdWJsaWMgb2Zmc2V0ID0gMDtcblxuICAvKipcbiAgICogVGhlIHZhcmlhbnQgb2YgdGhlIGJhZGdlLlxuICAgKlxuICAgKiBAdHlwZSB7QmFkZ2VWYXJpYW50fVxuICAgKiBAZGVmYXVsdCBCYWRnZVZhcmlhbnQuSElHSExJR0hUXG4gICAqL1xuICBASW5wdXQoeyBhbGlhczogJ29keEJhZGdlVmFyaWFudCcgfSlcbiAgcHVibGljIHZhcmlhbnQ6IEJhZGdlVmFyaWFudCA9IEJhZGdlVmFyaWFudC5ISUdITElHSFQ7XG5cbiAgcHVibGljIG5nT25DaGFuZ2VzKCk6IHZvaWQge1xuICAgIGlmIChpc1ByZXNlbnQodGhpcy52YWx1ZSkpIHtcbiAgICAgIHRoaXMuc2hvd0JhZGdlKCk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuaGlkZUJhZGdlKCk7XG4gICAgfVxuICAgIHRoaXMudXBkYXRlQmFkZ2UoKTtcbiAgfVxuXG4gIHB1YmxpYyBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLmhpZGVCYWRnZSgpO1xuICB9XG5cbiAgcHJpdmF0ZSBzaG93QmFkZ2UoKTogdm9pZCB7XG4gICAgdGhpcy5iYWRnZVJlZiA/Pz0gdGhpcy5jb25uZWN0ZWRPdmVybGF5U2VydmljZS5jcmVhdGVPdmVybGF5KHRoaXMuZWxlbWVudC5uYXRpdmVFbGVtZW50LCBERUZBVUxUX0JBREdFX09WRVJMQVlfT1BUSU9OUywgeyBpbmplY3RvcjogdGhpcy5pbmplY3RvciB9KTtcbiAgfVxuXG4gIHByaXZhdGUgaGlkZUJhZGdlKCk6IHZvaWQge1xuICAgIHRoaXMuYmFkZ2VSZWY/LmNsb3NlKCk7XG4gICAgdGhpcy5iYWRnZVJlZiA9IG51bGw7XG4gIH1cblxuICBwcml2YXRlIHVwZGF0ZUJhZGdlKCk6IHZvaWQge1xuICAgIHRoaXMuYmFkZ2VSZWY/LnVwZGF0ZSh7XG4gICAgICBjb250ZXh0OiB7IGNvbnRyYXN0OiB0aGlzLmNvbnRyYXN0LCB2YWx1ZTogdGhpcy52YWx1ZSwgdmFyaWFudDogdGhpcy52YXJpYW50IH0sXG4gICAgICBwb3NpdGlvbjogdGhpcy5wb3NpdGlvbixcbiAgICAgIG9mZnNldDogdGhpcy5vZmZzZXQsXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
115
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFkZ2UuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL2NvbXBvbmVudHMvYmFkZ2Uvc3JjL2xpYi9iYWRnZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLFFBQVEsRUFBRSxLQUFLLEVBQUUsZUFBZSxFQUF3QixNQUFNLGVBQWUsQ0FBQztBQUM1SCxPQUFPLEVBQWdELHVCQUF1QixFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFFM0gsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3JELE9BQU8sRUFBRSxhQUFhLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3hFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNuRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sVUFBVSxDQUFDOztBQUV4QyxNQUFNLDZCQUE2QixHQUFxQztJQUN0RSxPQUFPLEVBQUUsY0FBYztJQUN2QixjQUFjLEVBQUUsS0FBSztJQUNyQixNQUFNLEVBQUUsQ0FBQztJQUNULGNBQWMsRUFBRSxtQkFBbUI7SUFDbkMsc0JBQXNCLEVBQUUsSUFBSTtDQUM3QixDQUFDO0FBT0ssV0FBTSxjQUFjLEdBQXBCLE1BQU0sY0FBYztJQUFwQjtRQUNZLDRCQUF1QixHQUFHLE1BQU0sQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDO1FBQzFELGFBQVEsR0FBRyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDckMsYUFBUSxHQUErQixJQUFJLENBQUM7UUFFcEMsWUFBTyxHQUFHLGFBQWEsRUFBRSxDQUFDO1FBRTFDOzs7OztXQUtHO1FBRUksVUFBSyxHQUErQixJQUFJLENBQUM7UUFFaEQ7Ozs7O1dBS0c7UUFFSSxhQUFRLEdBQUcsS0FBSyxDQUFDO1FBRXhCOzs7OztXQUtHO1FBRUksYUFBUSxHQUFhLFFBQVEsQ0FBQyxVQUFVLENBQUM7UUFFaEQ7Ozs7O1dBS0c7UUFFSSxXQUFNLEdBQUcsQ0FBQyxDQUFDO1FBRWxCOzs7OztXQUtHO1FBRUksWUFBTyxHQUFpQixZQUFZLENBQUMsU0FBUyxDQUFDO0tBa0N2RDtJQWhDUSxXQUFXO1FBQ2hCLElBQUksU0FBUyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUN6QixJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7U0FDbEI7YUFBTTtZQUNMLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztTQUNsQjtRQUNELElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUNyQixDQUFDO0lBRU0sV0FBVztRQUNoQixJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7SUFDbkIsQ0FBQztJQUVPLFNBQVM7UUFDZixJQUFJLENBQUMsUUFBUSxLQUFLLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLEVBQUUsNkJBQTZCLEVBQUU7WUFDdEgsSUFBSSxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLGFBQWE7WUFDOUMsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRO1NBQ3hCLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFTyxTQUFTO1FBQ2YsSUFBSSxDQUFDLFFBQVEsRUFBRSxLQUFLLEVBQUUsQ0FBQztRQUN2QixJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQztJQUN2QixDQUFDO0lBRU8sV0FBVztRQUNqQixJQUFJLENBQUMsUUFBUSxFQUFFLE1BQU0sQ0FBQztZQUNwQixPQUFPLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVEsRUFBRSxLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUssRUFBRSxPQUFPLEVBQUUsSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUM5RSxRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVE7WUFDdkIsTUFBTSxFQUFFLElBQUksQ0FBQyxNQUFNO1NBQ3BCLENBQUMsQ0FBQztJQUNMLENBQUM7K0dBbkZVLGNBQWM7bUdBQWQsY0FBYyxpSUFzQnNCLGdCQUFnQixvRkFrQmxCLGVBQWU7O0FBeENqRCxjQUFjO0lBTDFCLFlBQVksQ0FBQyxZQUFZLENBQUM7R0FLZCxjQUFjLENBb0YxQjs0RkFwRlksY0FBYztrQkFKMUIsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsWUFBWTtvQkFDdEIsVUFBVSxFQUFFLElBQUk7aUJBQ2pCOzhCQWVRLEtBQUs7c0JBRFgsS0FBSzt1QkFBQyxVQUFVO2dCQVVWLFFBQVE7c0JBRGQsS0FBSzt1QkFBQyxFQUFFLEtBQUssRUFBRSxrQkFBa0IsRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUU7Z0JBVTFELFFBQVE7c0JBRGQsS0FBSzt1QkFBQyxFQUFFLEtBQUssRUFBRSxrQkFBa0IsRUFBRTtnQkFVN0IsTUFBTTtzQkFEWixLQUFLO3VCQUFDLEVBQUUsS0FBSyxFQUFFLGdCQUFnQixFQUFFLFNBQVMsRUFBRSxlQUFlLEVBQUU7Z0JBVXZELE9BQU87c0JBRGIsS0FBSzt1QkFBQyxFQUFFLEtBQUssRUFBRSxpQkFBaUIsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGJvb2xlYW5BdHRyaWJ1dGUsIERpcmVjdGl2ZSwgaW5qZWN0LCBJbmplY3RvciwgSW5wdXQsIG51bWJlckF0dHJpYnV0ZSwgT25DaGFuZ2VzLCBPbkRlc3Ryb3kgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbm5lY3RlZE92ZXJsYXlPcHRpb25zLCBDb25uZWN0ZWRPdmVybGF5UmVmLCBDb25uZWN0ZWRPdmVybGF5U2VydmljZSB9IGZyb20gJ0BvZHgvYW5ndWxhci9jZGsvY29ubmVjdGVkLW92ZXJsYXknO1xuaW1wb3J0IHsgRHluYW1pY1RleHRDb250ZW50IH0gZnJvbSAnQG9keC9hbmd1bGFyL2Nkay9keW5hbWljLXZpZXcnO1xuaW1wb3J0IHsgQ1NTQ29tcG9uZW50IH0gZnJvbSAnQG9keC9hbmd1bGFyL2ludGVybmFsJztcbmltcG9ydCB7IGluamVjdEVsZW1lbnQsIGlzUHJlc2VudCwgUG9zaXRpb24gfSBmcm9tICdAb2R4L2FuZ3VsYXIvdXRpbHMnO1xuaW1wb3J0IHsgQmFkZ2VDb21wb25lbnQgfSBmcm9tICcuL2JhZGdlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBCYWRnZVZhcmlhbnQgfSBmcm9tICcuL21vZGVscyc7XG5cbmNvbnN0IERFRkFVTFRfQkFER0VfT1ZFUkxBWV9PUFRJT05TOiBQYXJ0aWFsPENvbm5lY3RlZE92ZXJsYXlPcHRpb25zPiA9IHtcbiAgY29udGVudDogQmFkZ2VDb21wb25lbnQsXG4gIGVuYWJsZUZhbGxiYWNrOiBmYWxzZSxcbiAgb2Zmc2V0OiAwLFxuICBjb250YWluZXJDbGFzczogJ29keC1iYWRnZS1vdmVybGF5JyxcbiAgdXBkYXRlT25BbmltYXRpb25GcmFtZTogdHJ1ZSxcbn07XG5cbkBDU1NDb21wb25lbnQoJ2JhZGdlLWhvc3QnKVxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW29keEJhZGdlXScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIEJhZGdlRGlyZWN0aXZlIGltcGxlbWVudHMgQmFkZ2VDb21wb25lbnQsIE9uQ2hhbmdlcywgT25EZXN0cm95IHtcbiAgcHJpdmF0ZSByZWFkb25seSBjb25uZWN0ZWRPdmVybGF5U2VydmljZSA9IGluamVjdChDb25uZWN0ZWRPdmVybGF5U2VydmljZSk7XG4gIHByaXZhdGUgcmVhZG9ubHkgaW5qZWN0b3IgPSBpbmplY3QoSW5qZWN0b3IpO1xuICBwcml2YXRlIGJhZGdlUmVmOiBDb25uZWN0ZWRPdmVybGF5UmVmIHwgbnVsbCA9IG51bGw7XG5cbiAgcHVibGljIHJlYWRvbmx5IGVsZW1lbnQgPSBpbmplY3RFbGVtZW50KCk7XG5cbiAgLyoqXG4gICAqIFRoZSB2YWx1ZSBvZiB0aGUgYmFkZ2UgZGlyZWN0aXZlLlxuICAgKlxuICAgKiBAdHlwZSB7RHluYW1pY1RleHRDb250ZW50fVxuICAgKiBAZGVmYXVsdCBudWxsXG4gICAqL1xuICBASW5wdXQoJ29keEJhZGdlJylcbiAgcHVibGljIHZhbHVlPzogRHluYW1pY1RleHRDb250ZW50IHwgbnVsbCA9IG51bGw7XG5cbiAgLyoqXG4gICAqIEluZGljYXRlcyB3aGV0aGVyIHRoZSBiYWRnZSBzaG91bGQgaGF2ZSBhIGNvbnRyYXN0IGVmZmVjdC5cbiAgICpcbiAgICogQHR5cGUge2Jvb2xlYW59XG4gICAqIEBkZWZhdWx0IGZhbHNlXG4gICAqL1xuICBASW5wdXQoeyBhbGlhczogJ29keEJhZGdlQ29udHJhc3QnLCB0cmFuc2Zvcm06IGJvb2xlYW5BdHRyaWJ1dGUgfSlcbiAgcHVibGljIGNvbnRyYXN0ID0gZmFsc2U7XG5cbiAgLyoqXG4gICAqIFRoZSBwb3NpdGlvbiBvZiB0aGUgYmFkZ2UuXG4gICAqXG4gICAqIEB0eXBlIHtQb3NpdGlvbn1cbiAgICogQGRlZmF1bHQgUG9zaXRpb24uQk9UVE9NX0VORFxuICAgKi9cbiAgQElucHV0KHsgYWxpYXM6ICdvZHhCYWRnZVBvc2l0aW9uJyB9KVxuICBwdWJsaWMgcG9zaXRpb246IFBvc2l0aW9uID0gUG9zaXRpb24uQk9UVE9NX0VORDtcblxuICAvKipcbiAgICogVGhlIG9mZnNldCBvZiB0aGUgYmFkZ2UuXG4gICAqXG4gICAqIEB0eXBlIHtudW1iZXJ9XG4gICAqIEBkZWZhdWx0IDBcbiAgICovXG4gIEBJbnB1dCh7IGFsaWFzOiAnb2R4QmFkZ2VPZmZzZXQnLCB0cmFuc2Zvcm06IG51bWJlckF0dHJpYnV0ZSB9KVxuICBwdWJsaWMgb2Zmc2V0ID0gMDtcblxuICAvKipcbiAgICogVGhlIHZhcmlhbnQgb2YgdGhlIGJhZGdlLlxuICAgKlxuICAgKiBAdHlwZSB7QmFkZ2VWYXJpYW50fVxuICAgKiBAZGVmYXVsdCBCYWRnZVZhcmlhbnQuSElHSExJR0hUXG4gICAqL1xuICBASW5wdXQoeyBhbGlhczogJ29keEJhZGdlVmFyaWFudCcgfSlcbiAgcHVibGljIHZhcmlhbnQ6IEJhZGdlVmFyaWFudCA9IEJhZGdlVmFyaWFudC5ISUdITElHSFQ7XG5cbiAgcHVibGljIG5nT25DaGFuZ2VzKCk6IHZvaWQge1xuICAgIGlmIChpc1ByZXNlbnQodGhpcy52YWx1ZSkpIHtcbiAgICAgIHRoaXMuc2hvd0JhZGdlKCk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuaGlkZUJhZGdlKCk7XG4gICAgfVxuICAgIHRoaXMudXBkYXRlQmFkZ2UoKTtcbiAgfVxuXG4gIHB1YmxpYyBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLmhpZGVCYWRnZSgpO1xuICB9XG5cbiAgcHJpdmF0ZSBzaG93QmFkZ2UoKTogdm9pZCB7XG4gICAgdGhpcy5iYWRnZVJlZiA/Pz0gdGhpcy5jb25uZWN0ZWRPdmVybGF5U2VydmljZS5jcmVhdGVPdmVybGF5KHRoaXMuZWxlbWVudC5uYXRpdmVFbGVtZW50LCBERUZBVUxUX0JBREdFX09WRVJMQVlfT1BUSU9OUywge1xuICAgICAgaG9zdDogdGhpcy5lbGVtZW50Lm5hdGl2ZUVsZW1lbnQucGFyZW50RWxlbWVudCxcbiAgICAgIGluamVjdG9yOiB0aGlzLmluamVjdG9yLFxuICAgIH0pO1xuICB9XG5cbiAgcHJpdmF0ZSBoaWRlQmFkZ2UoKTogdm9pZCB7XG4gICAgdGhpcy5iYWRnZVJlZj8uY2xvc2UoKTtcbiAgICB0aGlzLmJhZGdlUmVmID0gbnVsbDtcbiAgfVxuXG4gIHByaXZhdGUgdXBkYXRlQmFkZ2UoKTogdm9pZCB7XG4gICAgdGhpcy5iYWRnZVJlZj8udXBkYXRlKHtcbiAgICAgIGNvbnRleHQ6IHsgY29udHJhc3Q6IHRoaXMuY29udHJhc3QsIHZhbHVlOiB0aGlzLnZhbHVlLCB2YXJpYW50OiB0aGlzLnZhcmlhbnQgfSxcbiAgICAgIHBvc2l0aW9uOiB0aGlzLnBvc2l0aW9uLFxuICAgICAgb2Zmc2V0OiB0aGlzLm9mZnNldCxcbiAgICB9KTtcbiAgfVxufVxuIl19
@@ -135,7 +135,7 @@ export let DropdownDirective = class DropdownDirective {
135
135
  if (this.isOpen || !this.content || this.disabled)
136
136
  return;
137
137
  this.overlayRef = this.connectedOverlayService.createOverlay(this.referenceElement ?? this.element.nativeElement, this.createOverlayOptions(), {
138
- host: this.referenceElement || this.host,
138
+ host: this.referenceElement?.parentElement ?? this.host,
139
139
  injector: this.injector,
140
140
  });
141
141
  this.changeDetector.markForCheck();
@@ -234,4 +234,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
234
234
  type: Output,
235
235
  args: ['odxDropdownAfterClose']
236
236
  }] } });
237
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.directive.js","sourceRoot":"","sources":["../../../../../../../libs/angular/components/dropdown/src/lib/dropdown.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  booleanAttribute,\n  ChangeDetectorRef,\n  Directive,\n  EventEmitter,\n  inject,\n  Injector,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  ViewContainerRef,\n} from '@angular/core';\nimport { ConnectedOverlayOptions, ConnectedOverlayRef, ConnectedOverlayService } from '@odx/angular/cdk/connected-overlay';\nimport { DynamicContent } from '@odx/angular/cdk/dynamic-view';\nimport { CSSComponent } from '@odx/angular/internal';\nimport { EventManager, GetProperties, hasChanged, injectElement, NgChanges } from '@odx/angular/utils';\nimport { DropdownComponent } from './dropdown.component';\nimport { DefaultDropdownOptions, DropdownOptions } from './models';\n\nexport const DEFAULT_DROPDOWN_OPEN_TRIGGERS = ['click', 'keydown.enter'];\nexport const DEFAULT_DROPDOWN_CLOSE_TRIGGERS = ['keyup.esc'];\n\n/**\n * Represents a directive that enables dropdown functionality in Angular.\n * This directive handles the opening and closing of a dropdown menu, as well as\n * managing the associated overlay and event handling.\n */\n@CSSComponent('dropdown-host')\n@Directive({\n  standalone: true,\n  selector: '[odxDropdown]',\n  exportAs: 'odxDropdown',\n  providers: [EventManager],\n  host: {\n    '[attr.aria-haspopup]': 'true',\n    '[attr.aria-expanded]': 'isOpen',\n  },\n})\nexport class DropdownDirective implements AfterViewInit, OnChanges, OnDestroy {\n  private readonly changeDetector = inject(ChangeDetectorRef);\n  private readonly connectedOverlayService = inject(ConnectedOverlayService);\n  private readonly eventManager = inject(EventManager);\n  private readonly viewContainer = inject(ViewContainerRef);\n  private readonly injector = inject(Injector);\n  private overlayRef: ConnectedOverlayRef | null = null;\n\n  public readonly element = injectElement();\n\n  /**\n   * Gets a value indicating whether the dropdown is currently open.\n   *\n   * @returns {boolean}\n   */\n  public get isOpen(): boolean {\n    return this.overlayRef !== null;\n  }\n\n  /**\n   * The content to be displayed in the dropdown.\n   * It can be either a static content or a dynamically loaded content.\n   *\n   * @type {DynamicContent | null}\n   */\n  @Input('odxDropdown')\n  public content?: DynamicContent | null;\n\n  /**\n   * Indicates whether the dropdown is disabled or not.\n   *\n   * @type {boolean}\n   * @default false\n   */\n  @Input({ alias: 'odxDropdownDisabled', transform: booleanAttribute })\n  public disabled = false;\n\n  /**\n   * Indicates whether the loader should be shown.\n   *\n   * @type {boolean}\n   * @default false\n   */\n  @Input({ alias: 'odxDropdownShowLoader', transform: booleanAttribute })\n  public showLoader = false;\n\n  /**\n   * Determines whether the dropdown should close when a click event occurs outside of it.\n   *\n   * @type {boolean}\n   * @default true\n   */\n  @Input({ alias: 'odxDropdownClickOutsideActive', transform: booleanAttribute })\n  public clickOutsideActive = true;\n\n  /**\n   * The options to be used when creating the dropdown overlay.\n   *\n   * @type {Partial<DropdownOptions> | null}\n   */\n  @Input('odxDropdownOptions')\n  public options?: Partial<DropdownOptions> | null;\n\n  /**\n   * The reference element to which the dropdown is anchored.\n   *\n   * @type {HTMLElement | null}\n   */\n  @Input('odxDropdownReferenceElement')\n  public referenceElement?: HTMLElement | null;\n\n  /**\n   * The trigger element that opens the dropdown.\n   *\n   * @type {HTMLElement | null}\n   */\n  @Input('odxDropdownTriggerElement')\n  public triggerElement?: HTMLElement | null;\n\n  /**\n   * The host element to which the dropdown is appended.\n   *\n   * @type {HTMLElement | ViewContainerRef | null}\n   */\n  @Input('odxDropdownHost')\n  public host?: HTMLElement | ViewContainerRef | null = this.viewContainer;\n\n  /**\n   * The event triggers that open the dropdown.\n   *\n   * @type {string[] | null}\n   * @default DEFAULT_DROPDOWN_OPEN_TRIGGERS\n   */\n  @Input('odxDropdownOpenTrigger')\n  public openTrigger?: string[] | null = DEFAULT_DROPDOWN_OPEN_TRIGGERS;\n\n  /**\n   * The event triggers that close the dropdown.\n   *\n   * @type {string[] | null}\n   * @default DEFAULT_DROPDOWN_CLOSE_TRIGGERS\n   */\n  @Input('odxDropdownCloseTrigger')\n  public closeTrigger?: string[] | null = DEFAULT_DROPDOWN_CLOSE_TRIGGERS;\n\n  /**\n   * Event emitter that emits before the dropdown is opened.\n   *\n   * @emits {void}\n   */\n  @Output('odxDropdownBeforeOpen')\n  public beforeOpen = new EventEmitter<void>();\n\n  /**\n   * Event emitter that emits after the dropdown is opened.\n   *\n   * @emits {void}\n   */\n  @Output('odxDropdownAfterOpen')\n  public afterOpen = new EventEmitter<void>();\n\n  /**\n   * Event emitter that emits before the dropdown is closed.\n   *\n   * @emits {void}\n   */\n  @Output('odxDropdownBeforeClose')\n  public beforeClose = new EventEmitter<void>();\n\n  /**\n   * Event emitter that emits after the dropdown is closed.\n   *\n   * @emits {void}\n   */\n  @Output('odxDropdownAfterClose')\n  public afterClose = new EventEmitter<void>();\n\n  public ngAfterViewInit(): void {\n    this.eventManager.register(this.openTrigger ?? [], (event) => this.toggle(event), this.triggerElement ?? this.referenceElement);\n    this.eventManager.register(this.closeTrigger ?? [], () => this.close(), 'document');\n  }\n\n  public ngOnDestroy(): void {\n    this.close();\n  }\n\n  public ngOnChanges(changes: NgChanges<DropdownDirective>) {\n    if (hasChanged(changes, 'disabled') && this.disabled) {\n      this.close();\n    }\n    if (hasChanged(changes, ['options', 'content', 'showLoader', 'clickOutsideActive'])) {\n      this.overlayRef?.update(this.createOverlayOptions());\n    }\n  }\n\n  /**\n   * Toggles the state of the dropdown.\n   * If the dropdown is open, it will be closed. If it is closed, it will be opened.\n   *\n   * @param {Event | undefined} event - The optional event that triggered the toggle.\n   */\n  public toggle(event?: Event): void {\n    if (this.isOpen) {\n      this.close(event);\n    } else {\n      this.open(event);\n    }\n  }\n\n  /**\n   * Opens the dropdown.\n   *\n   * @param {Event | undefined} event - The optional event that triggered the open.\n   */\n  public open(event?: Event) {\n    event?.preventDefault();\n    if (this.isOpen || !this.content || this.disabled) return;\n    this.overlayRef = this.connectedOverlayService.createOverlay(this.referenceElement ?? this.element.nativeElement, this.createOverlayOptions(), {\n      host: this.referenceElement || this.host,\n      injector: this.injector,\n    });\n    this.changeDetector.markForCheck();\n  }\n\n  /**\n   * Closes the dropdown.\n   *\n   * @param {Event | undefined} event - The optional event that triggered the close.\n   */\n  public close(event?: Event) {\n    event?.preventDefault();\n    this.overlayRef?.close();\n    this.overlayRef = null;\n    this.changeDetector.markForCheck();\n  }\n\n  private createOverlayOptions(): Partial<ConnectedOverlayOptions> {\n    const containerClass = ['odx-dropdown-overlay', this.options?.containerClass].filter(Boolean).join(' ');\n    const context = {\n      content: this.content,\n      showLoader: this.showLoader,\n      clickOutsideActive: this.clickOutsideActive,\n    } as Partial<GetProperties<DropdownComponent>>;\n    return {\n      ...DefaultDropdownOptions,\n      ...this.options,\n      fallbackAxisSideDirection: 'end',\n      containerClass,\n      content: DropdownComponent,\n      context,\n      hooks: {\n        beforeOpen: () => this.beforeOpen.emit(),\n        afterOpen: () => this.afterOpen.emit(),\n        beforeClose: () => this.beforeClose.emit(),\n        afterClose: () => this.afterClose.emit(),\n      },\n    };\n  }\n}\n"]}
237
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.directive.js","sourceRoot":"","sources":["../../../../../../../libs/angular/components/dropdown/src/lib/dropdown.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  booleanAttribute,\n  ChangeDetectorRef,\n  Directive,\n  EventEmitter,\n  inject,\n  Injector,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  ViewContainerRef,\n} from '@angular/core';\nimport { ConnectedOverlayOptions, ConnectedOverlayRef, ConnectedOverlayService } from '@odx/angular/cdk/connected-overlay';\nimport { DynamicContent } from '@odx/angular/cdk/dynamic-view';\nimport { CSSComponent } from '@odx/angular/internal';\nimport { EventManager, GetProperties, hasChanged, injectElement, NgChanges } from '@odx/angular/utils';\nimport { DropdownComponent } from './dropdown.component';\nimport { DefaultDropdownOptions, DropdownOptions } from './models';\n\nexport const DEFAULT_DROPDOWN_OPEN_TRIGGERS = ['click', 'keydown.enter'];\nexport const DEFAULT_DROPDOWN_CLOSE_TRIGGERS = ['keyup.esc'];\n\n/**\n * Represents a directive that enables dropdown functionality in Angular.\n * This directive handles the opening and closing of a dropdown menu, as well as\n * managing the associated overlay and event handling.\n */\n@CSSComponent('dropdown-host')\n@Directive({\n  standalone: true,\n  selector: '[odxDropdown]',\n  exportAs: 'odxDropdown',\n  providers: [EventManager],\n  host: {\n    '[attr.aria-haspopup]': 'true',\n    '[attr.aria-expanded]': 'isOpen',\n  },\n})\nexport class DropdownDirective implements AfterViewInit, OnChanges, OnDestroy {\n  private readonly changeDetector = inject(ChangeDetectorRef);\n  private readonly connectedOverlayService = inject(ConnectedOverlayService);\n  private readonly eventManager = inject(EventManager);\n  private readonly viewContainer = inject(ViewContainerRef);\n  private readonly injector = inject(Injector);\n  private overlayRef: ConnectedOverlayRef | null = null;\n\n  public readonly element = injectElement();\n\n  /**\n   * Gets a value indicating whether the dropdown is currently open.\n   *\n   * @returns {boolean}\n   */\n  public get isOpen(): boolean {\n    return this.overlayRef !== null;\n  }\n\n  /**\n   * The content to be displayed in the dropdown.\n   * It can be either a static content or a dynamically loaded content.\n   *\n   * @type {DynamicContent | null}\n   */\n  @Input('odxDropdown')\n  public content?: DynamicContent | null;\n\n  /**\n   * Indicates whether the dropdown is disabled or not.\n   *\n   * @type {boolean}\n   * @default false\n   */\n  @Input({ alias: 'odxDropdownDisabled', transform: booleanAttribute })\n  public disabled = false;\n\n  /**\n   * Indicates whether the loader should be shown.\n   *\n   * @type {boolean}\n   * @default false\n   */\n  @Input({ alias: 'odxDropdownShowLoader', transform: booleanAttribute })\n  public showLoader = false;\n\n  /**\n   * Determines whether the dropdown should close when a click event occurs outside of it.\n   *\n   * @type {boolean}\n   * @default true\n   */\n  @Input({ alias: 'odxDropdownClickOutsideActive', transform: booleanAttribute })\n  public clickOutsideActive = true;\n\n  /**\n   * The options to be used when creating the dropdown overlay.\n   *\n   * @type {Partial<DropdownOptions> | null}\n   */\n  @Input('odxDropdownOptions')\n  public options?: Partial<DropdownOptions> | null;\n\n  /**\n   * The reference element to which the dropdown is anchored.\n   *\n   * @type {HTMLElement | null}\n   */\n  @Input('odxDropdownReferenceElement')\n  public referenceElement?: HTMLElement | null;\n\n  /**\n   * The trigger element that opens the dropdown.\n   *\n   * @type {HTMLElement | null}\n   */\n  @Input('odxDropdownTriggerElement')\n  public triggerElement?: HTMLElement | null;\n\n  /**\n   * The host element to which the dropdown is appended.\n   *\n   * @type {HTMLElement | ViewContainerRef | null}\n   */\n  @Input('odxDropdownHost')\n  public host?: HTMLElement | ViewContainerRef | null = this.viewContainer;\n\n  /**\n   * The event triggers that open the dropdown.\n   *\n   * @type {string[] | null}\n   * @default DEFAULT_DROPDOWN_OPEN_TRIGGERS\n   */\n  @Input('odxDropdownOpenTrigger')\n  public openTrigger?: string[] | null = DEFAULT_DROPDOWN_OPEN_TRIGGERS;\n\n  /**\n   * The event triggers that close the dropdown.\n   *\n   * @type {string[] | null}\n   * @default DEFAULT_DROPDOWN_CLOSE_TRIGGERS\n   */\n  @Input('odxDropdownCloseTrigger')\n  public closeTrigger?: string[] | null = DEFAULT_DROPDOWN_CLOSE_TRIGGERS;\n\n  /**\n   * Event emitter that emits before the dropdown is opened.\n   *\n   * @emits {void}\n   */\n  @Output('odxDropdownBeforeOpen')\n  public beforeOpen = new EventEmitter<void>();\n\n  /**\n   * Event emitter that emits after the dropdown is opened.\n   *\n   * @emits {void}\n   */\n  @Output('odxDropdownAfterOpen')\n  public afterOpen = new EventEmitter<void>();\n\n  /**\n   * Event emitter that emits before the dropdown is closed.\n   *\n   * @emits {void}\n   */\n  @Output('odxDropdownBeforeClose')\n  public beforeClose = new EventEmitter<void>();\n\n  /**\n   * Event emitter that emits after the dropdown is closed.\n   *\n   * @emits {void}\n   */\n  @Output('odxDropdownAfterClose')\n  public afterClose = new EventEmitter<void>();\n\n  public ngAfterViewInit(): void {\n    this.eventManager.register(this.openTrigger ?? [], (event) => this.toggle(event), this.triggerElement ?? this.referenceElement);\n    this.eventManager.register(this.closeTrigger ?? [], () => this.close(), 'document');\n  }\n\n  public ngOnDestroy(): void {\n    this.close();\n  }\n\n  public ngOnChanges(changes: NgChanges<DropdownDirective>) {\n    if (hasChanged(changes, 'disabled') && this.disabled) {\n      this.close();\n    }\n    if (hasChanged(changes, ['options', 'content', 'showLoader', 'clickOutsideActive'])) {\n      this.overlayRef?.update(this.createOverlayOptions());\n    }\n  }\n\n  /**\n   * Toggles the state of the dropdown.\n   * If the dropdown is open, it will be closed. If it is closed, it will be opened.\n   *\n   * @param {Event | undefined} event - The optional event that triggered the toggle.\n   */\n  public toggle(event?: Event): void {\n    if (this.isOpen) {\n      this.close(event);\n    } else {\n      this.open(event);\n    }\n  }\n\n  /**\n   * Opens the dropdown.\n   *\n   * @param {Event | undefined} event - The optional event that triggered the open.\n   */\n  public open(event?: Event) {\n    event?.preventDefault();\n    if (this.isOpen || !this.content || this.disabled) return;\n    this.overlayRef = this.connectedOverlayService.createOverlay(this.referenceElement ?? this.element.nativeElement, this.createOverlayOptions(), {\n      host: this.referenceElement?.parentElement ?? this.host,\n      injector: this.injector,\n    });\n    this.changeDetector.markForCheck();\n  }\n\n  /**\n   * Closes the dropdown.\n   *\n   * @param {Event | undefined} event - The optional event that triggered the close.\n   */\n  public close(event?: Event) {\n    event?.preventDefault();\n    this.overlayRef?.close();\n    this.overlayRef = null;\n    this.changeDetector.markForCheck();\n  }\n\n  private createOverlayOptions(): Partial<ConnectedOverlayOptions> {\n    const containerClass = ['odx-dropdown-overlay', this.options?.containerClass].filter(Boolean).join(' ');\n    const context = {\n      content: this.content,\n      showLoader: this.showLoader,\n      clickOutsideActive: this.clickOutsideActive,\n    } as Partial<GetProperties<DropdownComponent>>;\n    return {\n      ...DefaultDropdownOptions,\n      ...this.options,\n      fallbackAxisSideDirection: 'end',\n      containerClass,\n      content: DropdownComponent,\n      context,\n      hooks: {\n        beforeOpen: () => this.beforeOpen.emit(),\n        afterOpen: () => this.afterOpen.emit(),\n        beforeClose: () => this.beforeClose.emit(),\n        afterClose: () => this.afterClose.emit(),\n      },\n    };\n  }\n}\n"]}