@radix-ng/primitives 0.19.0 → 0.20.1

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 (40) hide show
  1. package/compodoc/documentation.json +2751 -957
  2. package/esm2022/popover/index.mjs +41 -0
  3. package/esm2022/popover/radix-ng-primitives-popover.mjs +5 -0
  4. package/esm2022/popover/src/popover-arrow.directive.mjs +112 -0
  5. package/esm2022/popover/src/popover-arrow.token.mjs +3 -0
  6. package/esm2022/popover/src/popover-close.directive.mjs +37 -0
  7. package/esm2022/popover/src/popover-content.directive.mjs +227 -0
  8. package/esm2022/popover/src/popover-root.directive.mjs +142 -0
  9. package/esm2022/popover/src/popover-root.inject.mjs +7 -0
  10. package/esm2022/popover/src/popover-root.token.mjs +3 -0
  11. package/esm2022/popover/src/popover-trigger.directive.mjs +42 -0
  12. package/esm2022/popover/src/popover.constants.mjs +90 -0
  13. package/esm2022/popover/src/popover.types.mjs +14 -0
  14. package/esm2022/popover/src/popover.utils.mjs +115 -0
  15. package/esm2022/radio/src/radio-indicator.directive.mjs +3 -3
  16. package/esm2022/radio/src/radio-item-input.directive.mjs +2 -2
  17. package/esm2022/radio/src/radio-item.directive.mjs +10 -13
  18. package/esm2022/radio/src/radio-root.directive.mjs +16 -20
  19. package/esm2022/radio/src/radio-tokens.mjs +1 -1
  20. package/fesm2022/radix-ng-primitives-popover.mjs +796 -0
  21. package/fesm2022/radix-ng-primitives-popover.mjs.map +1 -0
  22. package/fesm2022/radix-ng-primitives-radio.mjs +26 -33
  23. package/fesm2022/radix-ng-primitives-radio.mjs.map +1 -1
  24. package/package.json +7 -1
  25. package/popover/README.md +3 -0
  26. package/popover/index.d.ts +17 -0
  27. package/popover/src/popover-arrow.directive.d.ts +37 -0
  28. package/popover/src/popover-arrow.token.d.ts +3 -0
  29. package/popover/src/popover-close.directive.d.ts +15 -0
  30. package/popover/src/popover-content.directive.d.ts +84 -0
  31. package/popover/src/popover-root.directive.d.ts +58 -0
  32. package/popover/src/popover-root.inject.d.ts +2 -0
  33. package/popover/src/popover-root.token.d.ts +3 -0
  34. package/popover/src/popover-trigger.directive.d.ts +18 -0
  35. package/popover/src/popover.constants.d.ts +8 -0
  36. package/popover/src/popover.types.d.ts +34 -0
  37. package/popover/src/popover.utils.d.ts +12 -0
  38. package/radio/src/radio-item.directive.d.ts +2 -2
  39. package/radio/src/radio-root.directive.d.ts +9 -8
  40. package/radio/src/radio-tokens.d.ts +6 -4
@@ -0,0 +1,41 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { RdxPopoverArrowDirective } from './src/popover-arrow.directive';
3
+ import { RdxPopoverCloseDirective } from './src/popover-close.directive';
4
+ import { RdxPopoverContentDirective } from './src/popover-content.directive';
5
+ import { RdxPopoverRootDirective } from './src/popover-root.directive';
6
+ import { RdxPopoverTriggerDirective } from './src/popover-trigger.directive';
7
+ import * as i0 from "@angular/core";
8
+ export * from './src/popover-arrow.directive';
9
+ export * from './src/popover-close.directive';
10
+ export * from './src/popover-content.directive';
11
+ export * from './src/popover-root.directive';
12
+ export * from './src/popover-trigger.directive';
13
+ export * from './src/popover.types';
14
+ const _imports = [
15
+ RdxPopoverArrowDirective,
16
+ RdxPopoverCloseDirective,
17
+ RdxPopoverContentDirective,
18
+ RdxPopoverTriggerDirective,
19
+ RdxPopoverRootDirective
20
+ ];
21
+ export class RdxPopoverModule {
22
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxPopoverModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
23
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.11", ngImport: i0, type: RdxPopoverModule, imports: [RdxPopoverArrowDirective,
24
+ RdxPopoverCloseDirective,
25
+ RdxPopoverContentDirective,
26
+ RdxPopoverTriggerDirective,
27
+ RdxPopoverRootDirective], exports: [RdxPopoverArrowDirective,
28
+ RdxPopoverCloseDirective,
29
+ RdxPopoverContentDirective,
30
+ RdxPopoverTriggerDirective,
31
+ RdxPopoverRootDirective] }); }
32
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxPopoverModule }); }
33
+ }
34
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxPopoverModule, decorators: [{
35
+ type: NgModule,
36
+ args: [{
37
+ imports: [..._imports],
38
+ exports: [..._imports]
39
+ }]
40
+ }] });
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9wcmltaXRpdmVzL3BvcG92ZXIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUN6RSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUN6RSxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUM3RSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUN2RSxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQzs7QUFFN0UsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMscUJBQXFCLENBQUM7QUFFcEMsTUFBTSxRQUFRLEdBQUc7SUFDYix3QkFBd0I7SUFDeEIsd0JBQXdCO0lBQ3hCLDBCQUEwQjtJQUMxQiwwQkFBMEI7SUFDMUIsdUJBQXVCO0NBQzFCLENBQUM7QUFNRixNQUFNLE9BQU8sZ0JBQWdCOytHQUFoQixnQkFBZ0I7Z0hBQWhCLGdCQUFnQixZQVh6Qix3QkFBd0I7WUFDeEIsd0JBQXdCO1lBQ3hCLDBCQUEwQjtZQUMxQiwwQkFBMEI7WUFDMUIsdUJBQXVCLGFBSnZCLHdCQUF3QjtZQUN4Qix3QkFBd0I7WUFDeEIsMEJBQTBCO1lBQzFCLDBCQUEwQjtZQUMxQix1QkFBdUI7Z0hBT2QsZ0JBQWdCOzs0RkFBaEIsZ0JBQWdCO2tCQUo1QixRQUFRO21CQUFDO29CQUNOLE9BQU8sRUFBRSxDQUFDLEdBQUcsUUFBUSxDQUFDO29CQUN0QixPQUFPLEVBQUUsQ0FBQyxHQUFHLFFBQVEsQ0FBQztpQkFDekIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUmR4UG9wb3ZlckFycm93RGlyZWN0aXZlIH0gZnJvbSAnLi9zcmMvcG9wb3Zlci1hcnJvdy5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgUmR4UG9wb3ZlckNsb3NlRGlyZWN0aXZlIH0gZnJvbSAnLi9zcmMvcG9wb3Zlci1jbG9zZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgUmR4UG9wb3ZlckNvbnRlbnREaXJlY3RpdmUgfSBmcm9tICcuL3NyYy9wb3BvdmVyLWNvbnRlbnQuZGlyZWN0aXZlJztcbmltcG9ydCB7IFJkeFBvcG92ZXJSb290RGlyZWN0aXZlIH0gZnJvbSAnLi9zcmMvcG9wb3Zlci1yb290LmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBSZHhQb3BvdmVyVHJpZ2dlckRpcmVjdGl2ZSB9IGZyb20gJy4vc3JjL3BvcG92ZXItdHJpZ2dlci5kaXJlY3RpdmUnO1xuXG5leHBvcnQgKiBmcm9tICcuL3NyYy9wb3BvdmVyLWFycm93LmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL3NyYy9wb3BvdmVyLWNsb3NlLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL3NyYy9wb3BvdmVyLWNvbnRlbnQuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vc3JjL3BvcG92ZXItcm9vdC5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9zcmMvcG9wb3Zlci10cmlnZ2VyLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL3NyYy9wb3BvdmVyLnR5cGVzJztcblxuY29uc3QgX2ltcG9ydHMgPSBbXG4gICAgUmR4UG9wb3ZlckFycm93RGlyZWN0aXZlLFxuICAgIFJkeFBvcG92ZXJDbG9zZURpcmVjdGl2ZSxcbiAgICBSZHhQb3BvdmVyQ29udGVudERpcmVjdGl2ZSxcbiAgICBSZHhQb3BvdmVyVHJpZ2dlckRpcmVjdGl2ZSxcbiAgICBSZHhQb3BvdmVyUm9vdERpcmVjdGl2ZVxuXTtcblxuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbLi4uX2ltcG9ydHNdLFxuICAgIGV4cG9ydHM6IFsuLi5faW1wb3J0c11cbn0pXG5leHBvcnQgY2xhc3MgUmR4UG9wb3Zlck1vZHVsZSB7fVxuIl19
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './index';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFkaXgtbmctcHJpbWl0aXZlcy1wb3BvdmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvcHJpbWl0aXZlcy9wb3BvdmVyL3JhZGl4LW5nLXByaW1pdGl2ZXMtcG9wb3Zlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
@@ -0,0 +1,112 @@
1
+ import { computed, Directive, effect, ElementRef, forwardRef, inject, input, Renderer2, signal, untracked } from '@angular/core';
2
+ import { toSignal } from '@angular/core/rxjs-interop';
3
+ import { RdxPopoverArrowToken } from './popover-arrow.token';
4
+ import { injectPopoverRoot } from './popover-root.inject';
5
+ import { getArrowPositionParams, getSideAndAlignFromAllPossibleConnectedPositions } from './popover.utils';
6
+ import * as i0 from "@angular/core";
7
+ export class RdxPopoverArrowDirective {
8
+ constructor() {
9
+ /** @ignore */
10
+ this.renderer = inject(Renderer2);
11
+ /** @ignore */
12
+ this.popoverRoot = injectPopoverRoot();
13
+ /** @ignore */
14
+ this.elementRef = inject(ElementRef);
15
+ /**
16
+ * The width of the arrow in pixels.
17
+ */
18
+ this.width = input(10);
19
+ /**
20
+ * The height of the arrow in pixels.
21
+ */
22
+ this.height = input(5);
23
+ /** @ignore */
24
+ this.arrowSvgElement = computed(() => {
25
+ const width = this.width();
26
+ const height = this.height();
27
+ const svgElement = this.renderer.createElement('svg', 'svg');
28
+ this.renderer.setAttribute(svgElement, 'viewBox', '0 0 30 10');
29
+ this.renderer.setAttribute(svgElement, 'width', String(width));
30
+ this.renderer.setAttribute(svgElement, 'height', String(height));
31
+ const polygonElement = this.renderer.createElement('polygon', 'svg');
32
+ this.renderer.setAttribute(polygonElement, 'points', '0,0 30,0 15,10');
33
+ this.renderer.setAttribute(svgElement, 'preserveAspectRatio', 'none');
34
+ this.renderer.appendChild(svgElement, polygonElement);
35
+ return svgElement;
36
+ });
37
+ /** @ignore */
38
+ this.currentArrowSvgElement = signal(void 0);
39
+ /** @ignore */
40
+ this.position = toSignal(this.popoverRoot.popoverContentDirective().positionChange());
41
+ this.onArrowSvgElementChangeEffect();
42
+ this.onContentPositionChangeEffect();
43
+ }
44
+ /** @ignore */
45
+ ngAfterViewInit() {
46
+ if (this.elementRef.nativeElement.parentElement) {
47
+ this.renderer.setStyle(this.elementRef.nativeElement.parentElement, 'position', 'relative');
48
+ }
49
+ this.renderer.setStyle(this.elementRef.nativeElement, 'position', 'absolute');
50
+ this.renderer.setStyle(this.elementRef.nativeElement, 'boxSizing', '');
51
+ this.renderer.setStyle(this.elementRef.nativeElement, 'fontSize', '0px');
52
+ this.triggerRect = this.popoverRoot.popoverTriggerDirective().elementRef.nativeElement.getBoundingClientRect();
53
+ }
54
+ /** @ignore */
55
+ setPosition(position) {
56
+ const posParams = getArrowPositionParams(getSideAndAlignFromAllPossibleConnectedPositions(position.connectionPair), { width: this.width(), height: this.height() }, { width: this.triggerRect.width, height: this.triggerRect.height });
57
+ this.renderer.setStyle(this.elementRef.nativeElement, 'top', posParams.top);
58
+ this.renderer.setStyle(this.elementRef.nativeElement, 'bottom', posParams.bottom);
59
+ this.renderer.setStyle(this.elementRef.nativeElement, 'left', posParams.left);
60
+ this.renderer.setStyle(this.elementRef.nativeElement, 'right', posParams.right);
61
+ this.renderer.setStyle(this.elementRef.nativeElement, 'transform', posParams.transform);
62
+ }
63
+ /** @ignore */
64
+ onArrowSvgElementChangeEffect() {
65
+ effect(() => {
66
+ const arrowElement = this.arrowSvgElement();
67
+ untracked(() => {
68
+ const currentArrowSvgElement = this.currentArrowSvgElement();
69
+ if (currentArrowSvgElement) {
70
+ this.renderer.removeChild(this.elementRef.nativeElement, currentArrowSvgElement);
71
+ }
72
+ this.currentArrowSvgElement.set(arrowElement);
73
+ this.renderer.setStyle(this.elementRef.nativeElement, 'width', `${this.width()}px`);
74
+ this.renderer.setStyle(this.elementRef.nativeElement, 'height', `${this.height()}px`);
75
+ this.renderer.appendChild(this.elementRef.nativeElement, this.currentArrowSvgElement());
76
+ });
77
+ });
78
+ }
79
+ /** @ignore */
80
+ onContentPositionChangeEffect() {
81
+ effect(() => {
82
+ const position = this.position();
83
+ untracked(() => {
84
+ if (!position) {
85
+ return;
86
+ }
87
+ this.setPosition(position);
88
+ });
89
+ });
90
+ }
91
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxPopoverArrowDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
92
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.11", type: RdxPopoverArrowDirective, isStandalone: true, selector: "[rdxPopoverArrow]", inputs: { width: { classPropertyName: "width", publicName: "width", isSignal: true, isRequired: false, transformFunction: null }, height: { classPropertyName: "height", publicName: "height", isSignal: true, isRequired: false, transformFunction: null } }, providers: [
93
+ {
94
+ provide: RdxPopoverArrowToken,
95
+ useExisting: forwardRef(() => RdxPopoverArrowDirective)
96
+ }
97
+ ], ngImport: i0 }); }
98
+ }
99
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxPopoverArrowDirective, decorators: [{
100
+ type: Directive,
101
+ args: [{
102
+ selector: '[rdxPopoverArrow]',
103
+ standalone: true,
104
+ providers: [
105
+ {
106
+ provide: RdxPopoverArrowToken,
107
+ useExisting: forwardRef(() => RdxPopoverArrowDirective)
108
+ }
109
+ ]
110
+ }]
111
+ }], ctorParameters: () => [] });
112
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover-arrow.directive.js","sourceRoot":"","sources":["../../../../../packages/primitives/popover/src/popover-arrow.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { ConnectedOverlayPositionChange } from '@angular/cdk/overlay';\nimport {\n    AfterViewInit,\n    computed,\n    Directive,\n    effect,\n    ElementRef,\n    forwardRef,\n    inject,\n    input,\n    Renderer2,\n    signal,\n    untracked\n} from '@angular/core';\nimport { toSignal } from '@angular/core/rxjs-interop';\nimport { RdxPopoverArrowToken } from './popover-arrow.token';\nimport { injectPopoverRoot } from './popover-root.inject';\nimport { getArrowPositionParams, getSideAndAlignFromAllPossibleConnectedPositions } from './popover.utils';\n\n@Directive({\n    selector: '[rdxPopoverArrow]',\n    standalone: true,\n    providers: [\n        {\n            provide: RdxPopoverArrowToken,\n            useExisting: forwardRef(() => RdxPopoverArrowDirective)\n        }\n    ]\n})\nexport class RdxPopoverArrowDirective implements AfterViewInit {\n    /** @ignore */\n    private readonly renderer = inject(Renderer2);\n    /** @ignore */\n    private readonly popoverRoot = injectPopoverRoot();\n    /** @ignore */\n    private readonly elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n\n    /**\n     * The width of the arrow in pixels.\n     */\n    readonly width = input<number>(10);\n\n    /**\n     * The height of the arrow in pixels.\n     */\n    readonly height = input<number>(5);\n\n    /** @ignore */\n    readonly arrowSvgElement = computed<HTMLElement>(() => {\n        const width = this.width();\n        const height = this.height();\n\n        const svgElement = this.renderer.createElement('svg', 'svg');\n        this.renderer.setAttribute(svgElement, 'viewBox', '0 0 30 10');\n        this.renderer.setAttribute(svgElement, 'width', String(width));\n        this.renderer.setAttribute(svgElement, 'height', String(height));\n        const polygonElement = this.renderer.createElement('polygon', 'svg');\n        this.renderer.setAttribute(polygonElement, 'points', '0,0 30,0 15,10');\n        this.renderer.setAttribute(svgElement, 'preserveAspectRatio', 'none');\n        this.renderer.appendChild(svgElement, polygonElement);\n\n        return svgElement;\n    });\n\n    /** @ignore */\n    private readonly currentArrowSvgElement = signal<HTMLOrSVGElement | undefined>(void 0);\n    /** @ignore */\n    private readonly position = toSignal(this.popoverRoot.popoverContentDirective().positionChange());\n\n    /** @ignore */\n    private triggerRect: DOMRect;\n\n    constructor() {\n        this.onArrowSvgElementChangeEffect();\n        this.onContentPositionChangeEffect();\n    }\n\n    /** @ignore */\n    ngAfterViewInit() {\n        if (this.elementRef.nativeElement.parentElement) {\n            this.renderer.setStyle(this.elementRef.nativeElement.parentElement, 'position', 'relative');\n        }\n        this.renderer.setStyle(this.elementRef.nativeElement, 'position', 'absolute');\n        this.renderer.setStyle(this.elementRef.nativeElement, 'boxSizing', '');\n        this.renderer.setStyle(this.elementRef.nativeElement, 'fontSize', '0px');\n        this.triggerRect = this.popoverRoot.popoverTriggerDirective().elementRef.nativeElement.getBoundingClientRect();\n    }\n\n    /** @ignore */\n    private setPosition(position: ConnectedOverlayPositionChange) {\n        const posParams = getArrowPositionParams(\n            getSideAndAlignFromAllPossibleConnectedPositions(position.connectionPair),\n            { width: this.width(), height: this.height() },\n            { width: this.triggerRect.width, height: this.triggerRect.height }\n        );\n\n        this.renderer.setStyle(this.elementRef.nativeElement, 'top', posParams.top);\n        this.renderer.setStyle(this.elementRef.nativeElement, 'bottom', posParams.bottom);\n        this.renderer.setStyle(this.elementRef.nativeElement, 'left', posParams.left);\n        this.renderer.setStyle(this.elementRef.nativeElement, 'right', posParams.right);\n        this.renderer.setStyle(this.elementRef.nativeElement, 'transform', posParams.transform);\n    }\n\n    /** @ignore */\n    private onArrowSvgElementChangeEffect() {\n        effect(() => {\n            const arrowElement = this.arrowSvgElement();\n            untracked(() => {\n                const currentArrowSvgElement = this.currentArrowSvgElement();\n                if (currentArrowSvgElement) {\n                    this.renderer.removeChild(this.elementRef.nativeElement, currentArrowSvgElement);\n                }\n                this.currentArrowSvgElement.set(arrowElement);\n                this.renderer.setStyle(this.elementRef.nativeElement, 'width', `${this.width()}px`);\n                this.renderer.setStyle(this.elementRef.nativeElement, 'height', `${this.height()}px`);\n                this.renderer.appendChild(this.elementRef.nativeElement, this.currentArrowSvgElement());\n            });\n        });\n    }\n\n    /** @ignore */\n    private onContentPositionChangeEffect() {\n        effect(() => {\n            const position = this.position();\n            untracked(() => {\n                if (!position) {\n                    return;\n                }\n                this.setPosition(position);\n            });\n        });\n    }\n}\n"]}
@@ -0,0 +1,3 @@
1
+ import { InjectionToken } from '@angular/core';
2
+ export const RdxPopoverArrowToken = new InjectionToken('RdxPopoverArrowToken');
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wb3Zlci1hcnJvdy50b2tlbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvcG9wb3Zlci9zcmMvcG9wb3Zlci1hcnJvdy50b2tlbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRy9DLE1BQU0sQ0FBQyxNQUFNLG9CQUFvQixHQUFHLElBQUksY0FBYyxDQUEyQixzQkFBc0IsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFJkeFBvcG92ZXJBcnJvd0RpcmVjdGl2ZSB9IGZyb20gJy4vcG9wb3Zlci1hcnJvdy5kaXJlY3RpdmUnO1xuXG5leHBvcnQgY29uc3QgUmR4UG9wb3ZlckFycm93VG9rZW4gPSBuZXcgSW5qZWN0aW9uVG9rZW48UmR4UG9wb3ZlckFycm93RGlyZWN0aXZlPignUmR4UG9wb3ZlckFycm93VG9rZW4nKTtcbiJdfQ==
@@ -0,0 +1,37 @@
1
+ import { Directive, effect, ElementRef, inject, Renderer2, untracked } from '@angular/core';
2
+ import { injectPopoverRoot } from './popover-root.inject';
3
+ import * as i0 from "@angular/core";
4
+ export class RdxPopoverCloseDirective {
5
+ constructor() {
6
+ /** @ignore */
7
+ this.popoverRoot = injectPopoverRoot();
8
+ /** @ignore */
9
+ this.elementRef = inject((ElementRef));
10
+ /** @ignore */
11
+ this.renderer = inject(Renderer2);
12
+ this.onIsControlledExternallyEffect();
13
+ }
14
+ /** @ignore */
15
+ onIsControlledExternallyEffect() {
16
+ effect(() => {
17
+ const isControlledExternally = this.popoverRoot.controlledExternally()();
18
+ untracked(() => {
19
+ this.renderer.setStyle(this.elementRef.nativeElement, 'display', isControlledExternally ? 'none' : null);
20
+ });
21
+ });
22
+ }
23
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxPopoverCloseDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
24
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.11", type: RdxPopoverCloseDirective, isStandalone: true, selector: "[rdxPopoverClose]", host: { attributes: { "type": "button" }, listeners: { "click": "popoverRoot.handleClose()" } }, ngImport: i0 }); }
25
+ }
26
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxPopoverCloseDirective, decorators: [{
27
+ type: Directive,
28
+ args: [{
29
+ selector: '[rdxPopoverClose]',
30
+ standalone: true,
31
+ host: {
32
+ type: 'button',
33
+ '(click)': 'popoverRoot.handleClose()'
34
+ }
35
+ }]
36
+ }], ctorParameters: () => [] });
37
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wb3Zlci1jbG9zZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9wcmltaXRpdmVzL3BvcG92ZXIvc3JjL3BvcG92ZXItY2xvc2UuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsU0FBUyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM1RixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQzs7QUFVMUQsTUFBTSxPQUFPLHdCQUF3QjtJQVFqQztRQVBBLGNBQWM7UUFDTCxnQkFBVyxHQUFHLGlCQUFpQixFQUFFLENBQUM7UUFDM0MsY0FBYztRQUNMLGVBQVUsR0FBRyxNQUFNLENBQTBCLENBQUEsVUFBdUIsQ0FBQSxDQUFDLENBQUM7UUFDL0UsY0FBYztRQUNHLGFBQVEsR0FBRyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7UUFHMUMsSUFBSSxDQUFDLDhCQUE4QixFQUFFLENBQUM7SUFDMUMsQ0FBQztJQUVELGNBQWM7SUFDTiw4QkFBOEI7UUFDbEMsTUFBTSxDQUFDLEdBQUcsRUFBRTtZQUNSLE1BQU0sc0JBQXNCLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxvQkFBb0IsRUFBRSxFQUFFLENBQUM7WUFFekUsU0FBUyxDQUFDLEdBQUcsRUFBRTtnQkFDWCxJQUFJLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FDbEIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLEVBQzdCLFNBQVMsRUFDVCxzQkFBc0IsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQ3pDLENBQUM7WUFDTixDQUFDLENBQUMsQ0FBQztRQUNQLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQzsrR0F6QlEsd0JBQXdCO21HQUF4Qix3QkFBd0I7OzRGQUF4Qix3QkFBd0I7a0JBUnBDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLG1CQUFtQjtvQkFDN0IsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLElBQUksRUFBRTt3QkFDRixJQUFJLEVBQUUsUUFBUTt3QkFDZCxTQUFTLEVBQUUsMkJBQTJCO3FCQUN6QztpQkFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgZWZmZWN0LCBFbGVtZW50UmVmLCBpbmplY3QsIFJlbmRlcmVyMiwgdW50cmFja2VkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBpbmplY3RQb3BvdmVyUm9vdCB9IGZyb20gJy4vcG9wb3Zlci1yb290LmluamVjdCc7XG5cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnW3JkeFBvcG92ZXJDbG9zZV0nLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaG9zdDoge1xuICAgICAgICB0eXBlOiAnYnV0dG9uJyxcbiAgICAgICAgJyhjbGljayknOiAncG9wb3ZlclJvb3QuaGFuZGxlQ2xvc2UoKSdcbiAgICB9XG59KVxuZXhwb3J0IGNsYXNzIFJkeFBvcG92ZXJDbG9zZURpcmVjdGl2ZSB7XG4gICAgLyoqIEBpZ25vcmUgKi9cbiAgICByZWFkb25seSBwb3BvdmVyUm9vdCA9IGluamVjdFBvcG92ZXJSb290KCk7XG4gICAgLyoqIEBpZ25vcmUgKi9cbiAgICByZWFkb25seSBlbGVtZW50UmVmID0gaW5qZWN0PEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+PihFbGVtZW50UmVmPEhUTUxFbGVtZW50Pik7XG4gICAgLyoqIEBpZ25vcmUgKi9cbiAgICBwcml2YXRlIHJlYWRvbmx5IHJlbmRlcmVyID0gaW5qZWN0KFJlbmRlcmVyMik7XG5cbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgdGhpcy5vbklzQ29udHJvbGxlZEV4dGVybmFsbHlFZmZlY3QoKTtcbiAgICB9XG5cbiAgICAvKiogQGlnbm9yZSAqL1xuICAgIHByaXZhdGUgb25Jc0NvbnRyb2xsZWRFeHRlcm5hbGx5RWZmZWN0KCkge1xuICAgICAgICBlZmZlY3QoKCkgPT4ge1xuICAgICAgICAgICAgY29uc3QgaXNDb250cm9sbGVkRXh0ZXJuYWxseSA9IHRoaXMucG9wb3ZlclJvb3QuY29udHJvbGxlZEV4dGVybmFsbHkoKSgpO1xuXG4gICAgICAgICAgICB1bnRyYWNrZWQoKCkgPT4ge1xuICAgICAgICAgICAgICAgIHRoaXMucmVuZGVyZXIuc2V0U3R5bGUoXG4gICAgICAgICAgICAgICAgICAgIHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LFxuICAgICAgICAgICAgICAgICAgICAnZGlzcGxheScsXG4gICAgICAgICAgICAgICAgICAgIGlzQ29udHJvbGxlZEV4dGVybmFsbHkgPyAnbm9uZScgOiBudWxsXG4gICAgICAgICAgICAgICAgKTtcbiAgICAgICAgICAgIH0pO1xuICAgICAgICB9KTtcbiAgICB9XG59XG4iXX0=
@@ -0,0 +1,227 @@
1
+ import { CdkConnectedOverlay, Overlay } from '@angular/cdk/overlay';
2
+ import { computed, DestroyRef, Directive, effect, inject, input, output, SimpleChange, TemplateRef, untracked } from '@angular/core';
3
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
4
+ import { filter, tap } from 'rxjs';
5
+ import { injectPopoverRoot } from './popover-root.inject';
6
+ import { DEFAULTS } from './popover.constants';
7
+ import { RdxPopoverAlign, RdxPopoverSide } from './popover.types';
8
+ import { getAllPossibleConnectedPositions, getContentPosition } from './popover.utils';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "@angular/cdk/overlay";
11
+ export class RdxPopoverContentDirective {
12
+ constructor() {
13
+ /** @ignore */
14
+ this.popoverRoot = injectPopoverRoot();
15
+ /** @ignore */
16
+ this.templateRef = inject(TemplateRef);
17
+ /** @ignore */
18
+ this.overlay = inject(Overlay);
19
+ /** @ignore */
20
+ this.destroyRef = inject(DestroyRef);
21
+ /** @ignore */
22
+ this.connectedOverlay = inject(CdkConnectedOverlay);
23
+ /**
24
+ * The preferred side of the trigger to render against when open. Will be reversed when collisions occur and avoidCollisions is enabled.
25
+ */
26
+ this.side = input(RdxPopoverSide.Top);
27
+ /**
28
+ * The distance in pixels from the trigger.
29
+ */
30
+ this.sideOffset = input(void 0);
31
+ /**
32
+ * The preferred alignment against the trigger. May change when collisions occur.
33
+ */
34
+ this.align = input(RdxPopoverAlign.Center);
35
+ /**
36
+ * An offset in pixels from the "start" or "end" alignment options.
37
+ */
38
+ this.alignOffset = input(void 0);
39
+ /**
40
+ * Whether to add some alternate positions of the content.
41
+ */
42
+ this.disableAlternatePositions = input(false);
43
+ /** @ingore */
44
+ this.positions = computed(() => {
45
+ const greatestDimensionFromTheArrow = Math.max(this.popoverRoot.popoverArrowDirective()?.width() ?? 0, this.popoverRoot.popoverArrowDirective()?.height() ?? 0);
46
+ const offsets = {
47
+ sideOffset: this.sideOffset() ?? (greatestDimensionFromTheArrow || DEFAULTS.offsets.side),
48
+ alignOffset: this.alignOffset() ?? (greatestDimensionFromTheArrow || DEFAULTS.offsets.align)
49
+ };
50
+ const basePosition = getContentPosition({
51
+ side: this.side(),
52
+ align: this.align(),
53
+ sideOffset: offsets.sideOffset,
54
+ alignOffset: offsets.alignOffset
55
+ });
56
+ const positions = [basePosition];
57
+ if (!this.disableAlternatePositions()) {
58
+ /**
59
+ * Alternate positions for better user experience along the X/Y axis (e.g. vertical/horizontal scrolling)
60
+ */
61
+ const allPossibleConnectedPositions = getAllPossibleConnectedPositions();
62
+ allPossibleConnectedPositions.forEach((value, key) => {
63
+ const sideAndAlignArray = key.split('|');
64
+ if (sideAndAlignArray[0] !== this.side() ||
65
+ sideAndAlignArray[1] !== this.align()) {
66
+ positions.push(getContentPosition({
67
+ side: sideAndAlignArray[0],
68
+ align: sideAndAlignArray[1],
69
+ sideOffset: offsets.sideOffset,
70
+ alignOffset: offsets.alignOffset
71
+ }));
72
+ }
73
+ });
74
+ }
75
+ return positions;
76
+ });
77
+ /**
78
+ * Event handler called when the escape key is down. It can be prevented by calling event.preventDefault.
79
+ */
80
+ this.onEscapeKeyDown = output();
81
+ /**
82
+ * Event handler called when a pointer event occurs outside the bounds of the component. It can be prevented by calling event.preventDefault.
83
+ */
84
+ this.onPointerDownOutside = output();
85
+ /**
86
+ * Event handler called when the overlay is atached
87
+ */
88
+ this.onShow = output();
89
+ /**
90
+ * Event handler called when the overlay is detached
91
+ */
92
+ this.onHide = output();
93
+ this.onPositionChangeEffect();
94
+ this.onControlledExternallyChangeEffect();
95
+ }
96
+ /** @ignore */
97
+ ngOnInit() {
98
+ this.setOrigin();
99
+ this.setScrollStrategy();
100
+ this.onAttach();
101
+ this.onDetach();
102
+ this.connectKeydownEscape();
103
+ this.connectOutsideClick();
104
+ }
105
+ /** @ignore */
106
+ show() {
107
+ const prevOpen = this.connectedOverlay.open;
108
+ this.connectedOverlay.open = true;
109
+ if (!prevOpen) {
110
+ this.connectedOverlay.ngOnChanges({ open: new SimpleChange(prevOpen, true, false) });
111
+ }
112
+ }
113
+ /** @ignore */
114
+ hide() {
115
+ const prevOpen = this.connectedOverlay.open;
116
+ this.connectedOverlay.open = false;
117
+ if (prevOpen) {
118
+ this.connectedOverlay.ngOnChanges({ open: new SimpleChange(prevOpen, false, false) });
119
+ }
120
+ }
121
+ /** @ignore */
122
+ positionChange() {
123
+ return this.connectedOverlay.positionChange.asObservable();
124
+ }
125
+ /** @ignore */
126
+ connectKeydownEscape() {
127
+ this.connectedOverlay.overlayKeydown
128
+ .asObservable()
129
+ .pipe(filter((event) => event.key === 'Escape'), tap((event) => {
130
+ this.onEscapeKeyDown.emit(event);
131
+ if (!event.defaultPrevented) {
132
+ this.popoverRoot.handleClose();
133
+ }
134
+ }), takeUntilDestroyed(this.destroyRef))
135
+ .subscribe();
136
+ }
137
+ /** @ignore */
138
+ connectOutsideClick() {
139
+ this.connectedOverlay.overlayOutsideClick
140
+ .asObservable()
141
+ .pipe(tap((event) => {
142
+ this.onPointerDownOutside.emit(event);
143
+ }), takeUntilDestroyed(this.destroyRef))
144
+ .subscribe();
145
+ }
146
+ /** @ignore */
147
+ onAttach() {
148
+ this.connectedOverlay.attach
149
+ .asObservable()
150
+ .pipe(tap(() => {
151
+ this.onShow.emit();
152
+ }), takeUntilDestroyed(this.destroyRef))
153
+ .subscribe();
154
+ }
155
+ /** @ignore */
156
+ onDetach() {
157
+ this.connectedOverlay.detach
158
+ .asObservable()
159
+ .pipe(tap(() => {
160
+ this.onHide.emit();
161
+ }), takeUntilDestroyed(this.destroyRef))
162
+ .subscribe();
163
+ }
164
+ /** @ignore */
165
+ setScrollStrategy() {
166
+ const prevScrollStrategy = this.connectedOverlay.scrollStrategy;
167
+ this.connectedOverlay.scrollStrategy = this.overlay.scrollStrategies.reposition();
168
+ this.connectedOverlay.ngOnChanges({
169
+ scrollStrategy: new SimpleChange(prevScrollStrategy, this.connectedOverlay.scrollStrategy, false)
170
+ });
171
+ }
172
+ /** @ignore */
173
+ setDisableClose() {
174
+ const prevDisableClose = this.connectedOverlay.disableClose;
175
+ this.connectedOverlay.disableClose = this.popoverRoot.controlledExternally()();
176
+ this.connectedOverlay.ngOnChanges({
177
+ disableClose: new SimpleChange(prevDisableClose, this.connectedOverlay.disableClose, false)
178
+ });
179
+ }
180
+ /** @ignore */
181
+ setOrigin() {
182
+ const prevOrigin = this.connectedOverlay.origin;
183
+ this.connectedOverlay.origin = this.popoverRoot.popoverTriggerDirective().overlayOrigin;
184
+ this.connectedOverlay.ngOnChanges({
185
+ origin: new SimpleChange(prevOrigin, this.connectedOverlay.origin, false)
186
+ });
187
+ }
188
+ /** @ignore */
189
+ onPositionChangeEffect() {
190
+ effect(() => {
191
+ const positions = this.positions();
192
+ this.disableAlternatePositions();
193
+ untracked(() => {
194
+ const prevPositions = this.connectedOverlay.positions;
195
+ this.connectedOverlay.positions = positions;
196
+ this.connectedOverlay.ngOnChanges({
197
+ positions: new SimpleChange(prevPositions, this.connectedOverlay.positions, false)
198
+ });
199
+ this.connectedOverlay.overlayRef?.updatePosition();
200
+ });
201
+ });
202
+ }
203
+ /** @ignore */
204
+ onControlledExternallyChangeEffect() {
205
+ effect(() => {
206
+ this.popoverRoot.controlledExternally()();
207
+ untracked(() => {
208
+ this.setDisableClose();
209
+ });
210
+ });
211
+ }
212
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxPopoverContentDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
213
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.11", type: RdxPopoverContentDirective, isStandalone: true, selector: "[rdxPopoverContent]", inputs: { side: { classPropertyName: "side", publicName: "side", isSignal: true, isRequired: false, transformFunction: null }, sideOffset: { classPropertyName: "sideOffset", publicName: "sideOffset", isSignal: true, isRequired: false, transformFunction: null }, align: { classPropertyName: "align", publicName: "align", isSignal: true, isRequired: false, transformFunction: null }, alignOffset: { classPropertyName: "alignOffset", publicName: "alignOffset", isSignal: true, isRequired: false, transformFunction: null }, disableAlternatePositions: { classPropertyName: "disableAlternatePositions", publicName: "disableAlternatePositions", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onEscapeKeyDown: "onEscapeKeyDown", onPointerDownOutside: "onPointerDownOutside", onShow: "onShow", onHide: "onHide" }, hostDirectives: [{ directive: i1.CdkConnectedOverlay }], ngImport: i0 }); }
214
+ }
215
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxPopoverContentDirective, decorators: [{
216
+ type: Directive,
217
+ args: [{
218
+ selector: '[rdxPopoverContent]',
219
+ standalone: true,
220
+ hostDirectives: [
221
+ {
222
+ directive: CdkConnectedOverlay
223
+ }
224
+ ]
225
+ }]
226
+ }], ctorParameters: () => [] });
227
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover-content.directive.js","sourceRoot":"","sources":["../../../../../packages/primitives/popover/src/popover-content.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { CdkConnectedOverlay, Overlay } from '@angular/cdk/overlay';\nimport {\n    computed,\n    DestroyRef,\n    Directive,\n    effect,\n    inject,\n    input,\n    OnInit,\n    output,\n    SimpleChange,\n    TemplateRef,\n    untracked\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { filter, tap } from 'rxjs';\nimport { injectPopoverRoot } from './popover-root.inject';\nimport { DEFAULTS } from './popover.constants';\nimport { RdxPopoverAlign, RdxPopoverSide, RdxSideAndAlignOffsets } from './popover.types';\nimport { getAllPossibleConnectedPositions, getContentPosition } from './popover.utils';\n\n@Directive({\n    selector: '[rdxPopoverContent]',\n    standalone: true,\n    hostDirectives: [\n        {\n            directive: CdkConnectedOverlay\n        }\n    ]\n})\nexport class RdxPopoverContentDirective implements OnInit {\n    /** @ignore */\n    readonly popoverRoot = injectPopoverRoot();\n    /** @ignore */\n    readonly templateRef = inject(TemplateRef);\n    /** @ignore */\n    readonly overlay = inject(Overlay);\n    /** @ignore */\n    readonly destroyRef = inject(DestroyRef);\n    /** @ignore */\n    private readonly connectedOverlay = inject(CdkConnectedOverlay);\n\n    /**\n     * The preferred side of the trigger to render against when open. Will be reversed when collisions occur and avoidCollisions is enabled.\n     */\n    readonly side = input<RdxPopoverSide>(RdxPopoverSide.Top);\n    /**\n     * The distance in pixels from the trigger.\n     */\n    readonly sideOffset = input<number | undefined>(void 0);\n\n    /**\n     * The preferred alignment against the trigger. May change when collisions occur.\n     */\n    readonly align = input<RdxPopoverAlign>(RdxPopoverAlign.Center);\n    /**\n     * An offset in pixels from the \"start\" or \"end\" alignment options.\n     */\n    readonly alignOffset = input<number | undefined>(void 0);\n\n    /**\n     * Whether to add some alternate positions of the content.\n     */\n    readonly disableAlternatePositions = input(false);\n\n    /** @ingore */\n    readonly positions = computed(() => {\n        const greatestDimensionFromTheArrow = Math.max(\n            this.popoverRoot.popoverArrowDirective()?.width() ?? 0,\n            this.popoverRoot.popoverArrowDirective()?.height() ?? 0\n        );\n        const offsets: RdxSideAndAlignOffsets = {\n            sideOffset: this.sideOffset() ?? (greatestDimensionFromTheArrow || DEFAULTS.offsets.side),\n            alignOffset: this.alignOffset() ?? (greatestDimensionFromTheArrow || DEFAULTS.offsets.align)\n        };\n        const basePosition = getContentPosition({\n            side: this.side(),\n            align: this.align(),\n            sideOffset: offsets.sideOffset,\n            alignOffset: offsets.alignOffset\n        });\n        const positions = [basePosition];\n        if (!this.disableAlternatePositions()) {\n            /**\n             * Alternate positions for better user experience along the X/Y axis (e.g. vertical/horizontal scrolling)\n             */\n            const allPossibleConnectedPositions = getAllPossibleConnectedPositions();\n            allPossibleConnectedPositions.forEach((value, key) => {\n                const sideAndAlignArray = key.split('|');\n                if (\n                    (sideAndAlignArray[0] as RdxPopoverSide) !== this.side() ||\n                    (sideAndAlignArray[1] as RdxPopoverAlign) !== this.align()\n                ) {\n                    positions.push(\n                        getContentPosition({\n                            side: sideAndAlignArray[0] as RdxPopoverSide,\n                            align: sideAndAlignArray[1] as RdxPopoverAlign,\n                            sideOffset: offsets.sideOffset,\n                            alignOffset: offsets.alignOffset\n                        })\n                    );\n                }\n            });\n        }\n        return positions;\n    });\n\n    /**\n     * Event handler called when the escape key is down. It can be prevented by calling event.preventDefault.\n     */\n    readonly onEscapeKeyDown = output<KeyboardEvent>();\n\n    /**\n     * Event handler called when a pointer event occurs outside the bounds of the component. It can be prevented by calling event.preventDefault.\n     */\n    readonly onPointerDownOutside = output<MouseEvent>();\n\n    /**\n     * Event handler called when the overlay is atached\n     */\n    readonly onShow = output<void>();\n    /**\n     * Event handler called when the overlay is detached\n     */\n    readonly onHide = output<void>();\n\n    constructor() {\n        this.onPositionChangeEffect();\n        this.onControlledExternallyChangeEffect();\n    }\n\n    /** @ignore */\n    ngOnInit() {\n        this.setOrigin();\n        this.setScrollStrategy();\n        this.onAttach();\n        this.onDetach();\n        this.connectKeydownEscape();\n        this.connectOutsideClick();\n    }\n\n    /** @ignore */\n    show() {\n        const prevOpen = this.connectedOverlay.open;\n        this.connectedOverlay.open = true;\n        if (!prevOpen) {\n            this.connectedOverlay.ngOnChanges({ open: new SimpleChange(prevOpen, true, false) });\n        }\n    }\n\n    /** @ignore */\n    hide() {\n        const prevOpen = this.connectedOverlay.open;\n        this.connectedOverlay.open = false;\n        if (prevOpen) {\n            this.connectedOverlay.ngOnChanges({ open: new SimpleChange(prevOpen, false, false) });\n        }\n    }\n\n    /** @ignore */\n    positionChange() {\n        return this.connectedOverlay.positionChange.asObservable();\n    }\n\n    /** @ignore */\n    private connectKeydownEscape() {\n        this.connectedOverlay.overlayKeydown\n            .asObservable()\n            .pipe(\n                filter((event) => event.key === 'Escape'),\n                tap((event) => {\n                    this.onEscapeKeyDown.emit(event);\n                    if (!event.defaultPrevented) {\n                        this.popoverRoot.handleClose();\n                    }\n                }),\n                takeUntilDestroyed(this.destroyRef)\n            )\n            .subscribe();\n    }\n\n    /** @ignore */\n    private connectOutsideClick() {\n        this.connectedOverlay.overlayOutsideClick\n            .asObservable()\n            .pipe(\n                tap((event) => {\n                    this.onPointerDownOutside.emit(event);\n                }),\n                takeUntilDestroyed(this.destroyRef)\n            )\n            .subscribe();\n    }\n\n    /** @ignore */\n    private onAttach() {\n        this.connectedOverlay.attach\n            .asObservable()\n            .pipe(\n                tap(() => {\n                    this.onShow.emit();\n                }),\n                takeUntilDestroyed(this.destroyRef)\n            )\n            .subscribe();\n    }\n\n    /** @ignore */\n    private onDetach() {\n        this.connectedOverlay.detach\n            .asObservable()\n            .pipe(\n                tap(() => {\n                    this.onHide.emit();\n                }),\n                takeUntilDestroyed(this.destroyRef)\n            )\n            .subscribe();\n    }\n\n    /** @ignore */\n    private setScrollStrategy() {\n        const prevScrollStrategy = this.connectedOverlay.scrollStrategy;\n        this.connectedOverlay.scrollStrategy = this.overlay.scrollStrategies.reposition();\n        this.connectedOverlay.ngOnChanges({\n            scrollStrategy: new SimpleChange(prevScrollStrategy, this.connectedOverlay.scrollStrategy, false)\n        });\n    }\n\n    /** @ignore */\n    private setDisableClose() {\n        const prevDisableClose = this.connectedOverlay.disableClose;\n        this.connectedOverlay.disableClose = this.popoverRoot.controlledExternally()();\n        this.connectedOverlay.ngOnChanges({\n            disableClose: new SimpleChange(prevDisableClose, this.connectedOverlay.disableClose, false)\n        });\n    }\n\n    /** @ignore */\n    private setOrigin() {\n        const prevOrigin = this.connectedOverlay.origin;\n        this.connectedOverlay.origin = this.popoverRoot.popoverTriggerDirective().overlayOrigin;\n        this.connectedOverlay.ngOnChanges({\n            origin: new SimpleChange(prevOrigin, this.connectedOverlay.origin, false)\n        });\n    }\n\n    /** @ignore */\n    private onPositionChangeEffect() {\n        effect(() => {\n            const positions = this.positions();\n            this.disableAlternatePositions();\n            untracked(() => {\n                const prevPositions = this.connectedOverlay.positions;\n                this.connectedOverlay.positions = positions;\n                this.connectedOverlay.ngOnChanges({\n                    positions: new SimpleChange(prevPositions, this.connectedOverlay.positions, false)\n                });\n                this.connectedOverlay.overlayRef?.updatePosition();\n            });\n        });\n    }\n\n    /** @ignore */\n    private onControlledExternallyChangeEffect() {\n        effect(() => {\n            this.popoverRoot.controlledExternally()();\n            untracked(() => {\n                this.setDisableClose();\n            });\n        });\n    }\n}\n"]}