@radix-ng/primitives 0.20.2 → 0.21.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 (63) hide show
  1. package/avatar/src/avatar-fallback.directive.d.ts +1 -1
  2. package/avatar/src/avatar-image.directive.d.ts +3 -3
  3. package/compodoc/documentation.json +5818 -1682
  4. package/core/index.d.ts +1 -0
  5. package/core/src/id-generator.d.ts +12 -0
  6. package/esm2022/avatar/src/avatar-fallback.directive.mjs +6 -8
  7. package/esm2022/avatar/src/avatar-image.directive.mjs +4 -3
  8. package/esm2022/core/index.mjs +2 -1
  9. package/esm2022/core/src/create-inject-context/index.mjs +2 -2
  10. package/esm2022/core/src/id-generator.mjs +43 -0
  11. package/esm2022/popover/index.mjs +14 -4
  12. package/esm2022/popover/src/popover-anchor.directive.mjs +70 -0
  13. package/esm2022/popover/src/popover-anchor.token.mjs +3 -0
  14. package/esm2022/popover/src/popover-arrow.directive.mjs +12 -7
  15. package/esm2022/popover/src/popover-close.directive.mjs +16 -4
  16. package/esm2022/popover/src/popover-close.token.mjs +3 -0
  17. package/esm2022/popover/src/popover-content-attributes.component.mjs +70 -0
  18. package/esm2022/popover/src/popover-content-attributes.token.mjs +3 -0
  19. package/esm2022/popover/src/popover-content.directive.mjs +120 -84
  20. package/esm2022/popover/src/popover-root.directive.mjs +232 -64
  21. package/esm2022/popover/src/popover-root.inject.mjs +4 -4
  22. package/esm2022/popover/src/popover-trigger.directive.mjs +5 -7
  23. package/esm2022/popover/src/popover.types.mjs +18 -1
  24. package/esm2022/popover/src/popover.utils.mjs +4 -6
  25. package/esm2022/switch/src/switch-input.directive.mjs +16 -7
  26. package/esm2022/switch/src/switch-root.directive.mjs +59 -14
  27. package/esm2022/switch/src/switch-thumb.directive.mjs +3 -3
  28. package/esm2022/toggle/index.mjs +2 -2
  29. package/esm2022/toggle/src/toggle-visually-hidden-input.directive.mjs +31 -0
  30. package/esm2022/toggle/src/toggle.directive.mjs +37 -8
  31. package/fesm2022/radix-ng-primitives-avatar.mjs +8 -9
  32. package/fesm2022/radix-ng-primitives-avatar.mjs.map +1 -1
  33. package/fesm2022/radix-ng-primitives-core.mjs +44 -3
  34. package/fesm2022/radix-ng-primitives-core.mjs.map +1 -1
  35. package/fesm2022/radix-ng-primitives-popover.mjs +672 -303
  36. package/fesm2022/radix-ng-primitives-popover.mjs.map +1 -1
  37. package/fesm2022/radix-ng-primitives-switch.mjs +76 -22
  38. package/fesm2022/radix-ng-primitives-switch.mjs.map +1 -1
  39. package/fesm2022/radix-ng-primitives-toggle.mjs +45 -15
  40. package/fesm2022/radix-ng-primitives-toggle.mjs.map +1 -1
  41. package/package.json +1 -1
  42. package/popover/index.d.ts +5 -1
  43. package/popover/src/popover-anchor.directive.d.ts +28 -0
  44. package/popover/src/popover-anchor.token.d.ts +3 -0
  45. package/popover/src/popover-arrow.directive.d.ts +8 -5
  46. package/popover/src/popover-close.directive.d.ts +1 -1
  47. package/popover/src/popover-close.token.d.ts +3 -0
  48. package/popover/src/popover-content-attributes.component.d.ts +17 -0
  49. package/popover/src/popover-content-attributes.token.d.ts +3 -0
  50. package/popover/src/popover-content.directive.d.ts +36 -23
  51. package/popover/src/popover-root.directive.d.ts +89 -18
  52. package/popover/src/popover-root.inject.d.ts +2 -1
  53. package/popover/src/popover-trigger.directive.d.ts +3 -5
  54. package/popover/src/popover.types.d.ts +14 -3
  55. package/switch/src/switch-input.directive.d.ts +2 -0
  56. package/switch/src/switch-root.directive.d.ts +33 -5
  57. package/toggle/index.d.ts +2 -2
  58. package/toggle/src/toggle-visually-hidden-input.directive.d.ts +6 -0
  59. package/toggle/src/toggle.directive.d.ts +19 -2
  60. package/esm2022/popover/src/popover-root.token.mjs +0 -3
  61. package/esm2022/toggle/src/toggle-input.directive.mjs +0 -30
  62. package/popover/src/popover-root.token.d.ts +0 -3
  63. package/toggle/src/toggle-input.directive.d.ts +0 -6
@@ -0,0 +1,70 @@
1
+ import { ChangeDetectionStrategy, Component, computed, forwardRef } from '@angular/core';
2
+ import { RdxPopoverContentAttributesToken } from './popover-content-attributes.token';
3
+ import { injectPopoverRoot } from './popover-root.inject';
4
+ import { RdxPopoverAnimationStatus, RdxPopoverState } from './popover.types';
5
+ import * as i0 from "@angular/core";
6
+ export class RdxPopoverContentAttributesComponent {
7
+ constructor() {
8
+ /** @ignore */
9
+ this.popoverRoot = injectPopoverRoot();
10
+ /** @ignore */
11
+ this.name = computed(() => `rdx-popover-content-attributes-${this.popoverRoot.uniqueId()}`);
12
+ /** @ignore */
13
+ this.disableAnimation = computed(() => !this.canAnimate());
14
+ }
15
+ /** @ignore */
16
+ onAnimationStart(_) {
17
+ this.popoverRoot.cssAnimationStatus.set(this.popoverRoot.state() === RdxPopoverState.OPEN
18
+ ? RdxPopoverAnimationStatus.OPEN_STARTED
19
+ : RdxPopoverAnimationStatus.CLOSED_STARTED);
20
+ }
21
+ /** @ignore */
22
+ onAnimationEnd(_) {
23
+ this.popoverRoot.cssAnimationStatus.set(this.popoverRoot.state() === RdxPopoverState.OPEN
24
+ ? RdxPopoverAnimationStatus.OPEN_ENDED
25
+ : RdxPopoverAnimationStatus.CLOSED_ENDED);
26
+ }
27
+ /** @ignore */
28
+ canAnimate() {
29
+ return (this.popoverRoot.cssAnimation() &&
30
+ ((this.popoverRoot.cssOpeningAnimation() && this.popoverRoot.state() === RdxPopoverState.OPEN) ||
31
+ (this.popoverRoot.cssClosingAnimation() && this.popoverRoot.state() === RdxPopoverState.CLOSED)));
32
+ }
33
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxPopoverContentAttributesComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
34
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.11", type: RdxPopoverContentAttributesComponent, isStandalone: true, selector: "[rdxPopoverContentAttributes]", host: { listeners: { "animationstart": "onAnimationStart($event)", "animationend": "onAnimationEnd($event)" }, properties: { "attr.role": "\"dialog\"", "attr.id": "name()", "attr.data-state": "popoverRoot.state()", "attr.data-side": "popoverRoot.popoverContentDirective().side()", "attr.data-align": "popoverRoot.popoverContentDirective().align()", "style": "disableAnimation() ? {animation: \"none !important\"} : null" } }, providers: [
35
+ {
36
+ provide: RdxPopoverContentAttributesToken,
37
+ useExisting: forwardRef(() => RdxPopoverContentAttributesComponent)
38
+ }
39
+ ], ngImport: i0, template: `
40
+ <ng-content />
41
+ `, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
42
+ }
43
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxPopoverContentAttributesComponent, decorators: [{
44
+ type: Component,
45
+ args: [{
46
+ selector: '[rdxPopoverContentAttributes]',
47
+ standalone: true,
48
+ template: `
49
+ <ng-content />
50
+ `,
51
+ host: {
52
+ '[attr.role]': '"dialog"',
53
+ '[attr.id]': 'name()',
54
+ '[attr.data-state]': 'popoverRoot.state()',
55
+ '[attr.data-side]': 'popoverRoot.popoverContentDirective().side()',
56
+ '[attr.data-align]': 'popoverRoot.popoverContentDirective().align()',
57
+ '[style]': 'disableAnimation() ? {animation: "none !important"} : null',
58
+ '(animationstart)': 'onAnimationStart($event)',
59
+ '(animationend)': 'onAnimationEnd($event)'
60
+ },
61
+ providers: [
62
+ {
63
+ provide: RdxPopoverContentAttributesToken,
64
+ useExisting: forwardRef(() => RdxPopoverContentAttributesComponent)
65
+ }
66
+ ],
67
+ changeDetection: ChangeDetectionStrategy.OnPush
68
+ }]
69
+ }] });
70
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wb3Zlci1jb250ZW50LWF0dHJpYnV0ZXMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvcHJpbWl0aXZlcy9wb3BvdmVyL3NyYy9wb3BvdmVyLWNvbnRlbnQtYXR0cmlidXRlcy5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxRQUFRLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pGLE9BQU8sRUFBRSxnQ0FBZ0MsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBQ3RGLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzFELE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxlQUFlLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7QUEwQjdFLE1BQU0sT0FBTyxvQ0FBb0M7SUF4QmpEO1FBeUJJLGNBQWM7UUFDSyxnQkFBVyxHQUFHLGlCQUFpQixFQUFFLENBQUM7UUFFckQsY0FBYztRQUNMLFNBQUksR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsa0NBQWtDLElBQUksQ0FBQyxXQUFXLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRWhHLGNBQWM7UUFDTCxxQkFBZ0IsR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUMsQ0FBQztLQTRCbEU7SUExQkcsY0FBYztJQUNKLGdCQUFnQixDQUFDLENBQWlCO1FBQ3hDLElBQUksQ0FBQyxXQUFXLENBQUMsa0JBQWtCLENBQUMsR0FBRyxDQUNuQyxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssRUFBRSxLQUFLLGVBQWUsQ0FBQyxJQUFJO1lBQzdDLENBQUMsQ0FBQyx5QkFBeUIsQ0FBQyxZQUFZO1lBQ3hDLENBQUMsQ0FBQyx5QkFBeUIsQ0FBQyxjQUFjLENBQ2pELENBQUM7SUFDTixDQUFDO0lBRUQsY0FBYztJQUNKLGNBQWMsQ0FBQyxDQUFpQjtRQUN0QyxJQUFJLENBQUMsV0FBVyxDQUFDLGtCQUFrQixDQUFDLEdBQUcsQ0FDbkMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLEVBQUUsS0FBSyxlQUFlLENBQUMsSUFBSTtZQUM3QyxDQUFDLENBQUMseUJBQXlCLENBQUMsVUFBVTtZQUN0QyxDQUFDLENBQUMseUJBQXlCLENBQUMsWUFBWSxDQUMvQyxDQUFDO0lBQ04sQ0FBQztJQUVELGNBQWM7SUFDTixVQUFVO1FBQ2QsT0FBTyxDQUNILElBQUksQ0FBQyxXQUFXLENBQUMsWUFBWSxFQUFFO1lBQy9CLENBQUMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLG1CQUFtQixFQUFFLElBQUksSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLEVBQUUsS0FBSyxlQUFlLENBQUMsSUFBSSxDQUFDO2dCQUMxRixDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsbUJBQW1CLEVBQUUsSUFBSSxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssRUFBRSxLQUFLLGVBQWUsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUN2RyxDQUFDO0lBQ04sQ0FBQzsrR0FuQ1Esb0NBQW9DO21HQUFwQyxvQ0FBb0Msc2ZBUmxDO1lBQ1A7Z0JBQ0ksT0FBTyxFQUFFLGdDQUFnQztnQkFDekMsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxvQ0FBb0MsQ0FBQzthQUN0RTtTQUNKLDBCQWxCUzs7S0FFVDs7NEZBbUJRLG9DQUFvQztrQkF4QmhELFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLCtCQUErQjtvQkFDekMsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRTs7S0FFVDtvQkFDRCxJQUFJLEVBQUU7d0JBQ0YsYUFBYSxFQUFFLFVBQVU7d0JBQ3pCLFdBQVcsRUFBRSxRQUFRO3dCQUNyQixtQkFBbUIsRUFBRSxxQkFBcUI7d0JBQzFDLGtCQUFrQixFQUFFLDhDQUE4Qzt3QkFDbEUsbUJBQW1CLEVBQUUsK0NBQStDO3dCQUNwRSxTQUFTLEVBQUUsNERBQTREO3dCQUN2RSxrQkFBa0IsRUFBRSwwQkFBMEI7d0JBQzlDLGdCQUFnQixFQUFFLHdCQUF3QjtxQkFDN0M7b0JBQ0QsU0FBUyxFQUFFO3dCQUNQOzRCQUNJLE9BQU8sRUFBRSxnQ0FBZ0M7NEJBQ3pDLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLHFDQUFxQyxDQUFDO3lCQUN0RTtxQkFDSjtvQkFDRCxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDbEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBjb21wdXRlZCwgZm9yd2FyZFJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUmR4UG9wb3ZlckNvbnRlbnRBdHRyaWJ1dGVzVG9rZW4gfSBmcm9tICcuL3BvcG92ZXItY29udGVudC1hdHRyaWJ1dGVzLnRva2VuJztcbmltcG9ydCB7IGluamVjdFBvcG92ZXJSb290IH0gZnJvbSAnLi9wb3BvdmVyLXJvb3QuaW5qZWN0JztcbmltcG9ydCB7IFJkeFBvcG92ZXJBbmltYXRpb25TdGF0dXMsIFJkeFBvcG92ZXJTdGF0ZSB9IGZyb20gJy4vcG9wb3Zlci50eXBlcyc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnW3JkeFBvcG92ZXJDb250ZW50QXR0cmlidXRlc10nLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgdGVtcGxhdGU6IGBcbiAgICAgICAgPG5nLWNvbnRlbnQgLz5cbiAgICBgLFxuICAgIGhvc3Q6IHtcbiAgICAgICAgJ1thdHRyLnJvbGVdJzogJ1wiZGlhbG9nXCInLFxuICAgICAgICAnW2F0dHIuaWRdJzogJ25hbWUoKScsXG4gICAgICAgICdbYXR0ci5kYXRhLXN0YXRlXSc6ICdwb3BvdmVyUm9vdC5zdGF0ZSgpJyxcbiAgICAgICAgJ1thdHRyLmRhdGEtc2lkZV0nOiAncG9wb3ZlclJvb3QucG9wb3ZlckNvbnRlbnREaXJlY3RpdmUoKS5zaWRlKCknLFxuICAgICAgICAnW2F0dHIuZGF0YS1hbGlnbl0nOiAncG9wb3ZlclJvb3QucG9wb3ZlckNvbnRlbnREaXJlY3RpdmUoKS5hbGlnbigpJyxcbiAgICAgICAgJ1tzdHlsZV0nOiAnZGlzYWJsZUFuaW1hdGlvbigpID8ge2FuaW1hdGlvbjogXCJub25lICFpbXBvcnRhbnRcIn0gOiBudWxsJyxcbiAgICAgICAgJyhhbmltYXRpb25zdGFydCknOiAnb25BbmltYXRpb25TdGFydCgkZXZlbnQpJyxcbiAgICAgICAgJyhhbmltYXRpb25lbmQpJzogJ29uQW5pbWF0aW9uRW5kKCRldmVudCknXG4gICAgfSxcbiAgICBwcm92aWRlcnM6IFtcbiAgICAgICAge1xuICAgICAgICAgICAgcHJvdmlkZTogUmR4UG9wb3ZlckNvbnRlbnRBdHRyaWJ1dGVzVG9rZW4sXG4gICAgICAgICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBSZHhQb3BvdmVyQ29udGVudEF0dHJpYnV0ZXNDb21wb25lbnQpXG4gICAgICAgIH1cbiAgICBdLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIFJkeFBvcG92ZXJDb250ZW50QXR0cmlidXRlc0NvbXBvbmVudCB7XG4gICAgLyoqIEBpZ25vcmUgKi9cbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgcG9wb3ZlclJvb3QgPSBpbmplY3RQb3BvdmVyUm9vdCgpO1xuXG4gICAgLyoqIEBpZ25vcmUgKi9cbiAgICByZWFkb25seSBuYW1lID0gY29tcHV0ZWQoKCkgPT4gYHJkeC1wb3BvdmVyLWNvbnRlbnQtYXR0cmlidXRlcy0ke3RoaXMucG9wb3ZlclJvb3QudW5pcXVlSWQoKX1gKTtcblxuICAgIC8qKiBAaWdub3JlICovXG4gICAgcmVhZG9ubHkgZGlzYWJsZUFuaW1hdGlvbiA9IGNvbXB1dGVkKCgpID0+ICF0aGlzLmNhbkFuaW1hdGUoKSk7XG5cbiAgICAvKiogQGlnbm9yZSAqL1xuICAgIHByb3RlY3RlZCBvbkFuaW1hdGlvblN0YXJ0KF86IEFuaW1hdGlvbkV2ZW50KSB7XG4gICAgICAgIHRoaXMucG9wb3ZlclJvb3QuY3NzQW5pbWF0aW9uU3RhdHVzLnNldChcbiAgICAgICAgICAgIHRoaXMucG9wb3ZlclJvb3Quc3RhdGUoKSA9PT0gUmR4UG9wb3ZlclN0YXRlLk9QRU5cbiAgICAgICAgICAgICAgICA/IFJkeFBvcG92ZXJBbmltYXRpb25TdGF0dXMuT1BFTl9TVEFSVEVEXG4gICAgICAgICAgICAgICAgOiBSZHhQb3BvdmVyQW5pbWF0aW9uU3RhdHVzLkNMT1NFRF9TVEFSVEVEXG4gICAgICAgICk7XG4gICAgfVxuXG4gICAgLyoqIEBpZ25vcmUgKi9cbiAgICBwcm90ZWN0ZWQgb25BbmltYXRpb25FbmQoXzogQW5pbWF0aW9uRXZlbnQpIHtcbiAgICAgICAgdGhpcy5wb3BvdmVyUm9vdC5jc3NBbmltYXRpb25TdGF0dXMuc2V0KFxuICAgICAgICAgICAgdGhpcy5wb3BvdmVyUm9vdC5zdGF0ZSgpID09PSBSZHhQb3BvdmVyU3RhdGUuT1BFTlxuICAgICAgICAgICAgICAgID8gUmR4UG9wb3ZlckFuaW1hdGlvblN0YXR1cy5PUEVOX0VOREVEXG4gICAgICAgICAgICAgICAgOiBSZHhQb3BvdmVyQW5pbWF0aW9uU3RhdHVzLkNMT1NFRF9FTkRFRFxuICAgICAgICApO1xuICAgIH1cblxuICAgIC8qKiBAaWdub3JlICovXG4gICAgcHJpdmF0ZSBjYW5BbmltYXRlKCkge1xuICAgICAgICByZXR1cm4gKFxuICAgICAgICAgICAgdGhpcy5wb3BvdmVyUm9vdC5jc3NBbmltYXRpb24oKSAmJlxuICAgICAgICAgICAgKCh0aGlzLnBvcG92ZXJSb290LmNzc09wZW5pbmdBbmltYXRpb24oKSAmJiB0aGlzLnBvcG92ZXJSb290LnN0YXRlKCkgPT09IFJkeFBvcG92ZXJTdGF0ZS5PUEVOKSB8fFxuICAgICAgICAgICAgICAgICh0aGlzLnBvcG92ZXJSb290LmNzc0Nsb3NpbmdBbmltYXRpb24oKSAmJiB0aGlzLnBvcG92ZXJSb290LnN0YXRlKCkgPT09IFJkeFBvcG92ZXJTdGF0ZS5DTE9TRUQpKVxuICAgICAgICApO1xuICAgIH1cbn1cbiJdfQ==
@@ -0,0 +1,3 @@
1
+ import { InjectionToken } from '@angular/core';
2
+ export const RdxPopoverContentAttributesToken = new InjectionToken('RdxPopoverContentAttributesToken');
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wb3Zlci1jb250ZW50LWF0dHJpYnV0ZXMudG9rZW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9wcmltaXRpdmVzL3BvcG92ZXIvc3JjL3BvcG92ZXItY29udGVudC1hdHRyaWJ1dGVzLnRva2VuLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHL0MsTUFBTSxDQUFDLE1BQU0sZ0NBQWdDLEdBQUcsSUFBSSxjQUFjLENBQzlELGtDQUFrQyxDQUNyQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFJkeFBvcG92ZXJDb250ZW50QXR0cmlidXRlc0NvbXBvbmVudCB9IGZyb20gJy4vcG9wb3Zlci1jb250ZW50LWF0dHJpYnV0ZXMuY29tcG9uZW50JztcblxuZXhwb3J0IGNvbnN0IFJkeFBvcG92ZXJDb250ZW50QXR0cmlidXRlc1Rva2VuID0gbmV3IEluamVjdGlvblRva2VuPFJkeFBvcG92ZXJDb250ZW50QXR0cmlidXRlc0NvbXBvbmVudD4oXG4gICAgJ1JkeFBvcG92ZXJDb250ZW50QXR0cmlidXRlc1Rva2VuJ1xuKTtcbiJdfQ==
@@ -4,7 +4,7 @@ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
4
4
  import { filter, tap } from 'rxjs';
5
5
  import { injectPopoverRoot } from './popover-root.inject';
6
6
  import { DEFAULTS } from './popover.constants';
7
- import { RdxPopoverAlign, RdxPopoverSide } from './popover.types';
7
+ import { RdxPopoverAlign, RdxPopoverAttachDetachEvent, RdxPopoverSide } from './popover.types';
8
8
  import { getAllPossibleConnectedPositions, getContentPosition } from './popover.utils';
9
9
  import * as i0 from "@angular/core";
10
10
  import * as i1 from "@angular/cdk/overlay";
@@ -20,81 +20,56 @@ export class RdxPopoverContentDirective {
20
20
  this.destroyRef = inject(DestroyRef);
21
21
  /** @ignore */
22
22
  this.connectedOverlay = inject(CdkConnectedOverlay);
23
+ /** @ignore */
24
+ this.name = computed(() => `rdx-popover-trigger-${this.popoverRoot.uniqueId()}`);
23
25
  /**
24
- * The preferred side of the trigger to render against when open. Will be reversed when collisions occur and avoidCollisions is enabled.
26
+ * @description The preferred side of the trigger to render against when open. Will be reversed when collisions occur and avoidCollisions is enabled.
27
+ * @default top
25
28
  */
26
29
  this.side = input(RdxPopoverSide.Top);
27
30
  /**
28
- * The distance in pixels from the trigger.
31
+ * @description The distance in pixels from the trigger.
32
+ * @default undefined
29
33
  */
30
34
  this.sideOffset = input(void 0);
31
35
  /**
32
- * The preferred alignment against the trigger. May change when collisions occur.
36
+ * @description The preferred alignment against the trigger. May change when collisions occur.
37
+ * @default center
33
38
  */
34
39
  this.align = input(RdxPopoverAlign.Center);
35
40
  /**
36
- * An offset in pixels from the "start" or "end" alignment options.
41
+ * @description An offset in pixels from the "start" or "end" alignment options.
42
+ * @default undefined
37
43
  */
38
44
  this.alignOffset = input(void 0);
39
45
  /**
40
- * Whether to add some alternate positions of the content.
46
+ * @description Whether to add some alternate positions of the content.
47
+ * @default false
41
48
  */
42
49
  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() ?? 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((_, 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
50
  /**
78
- * Event handler called when the escape key is down. It can be prevented by calling event.preventDefault.
51
+ * @description Event handler called when the escape key is down. It can be prevented by calling event.preventDefault.
79
52
  */
80
53
  this.onEscapeKeyDown = output();
81
54
  /**
82
- * Event handler called when a pointer event occurs outside the bounds of the component. It can be prevented by calling event.preventDefault.
55
+ * @description Event handler called when a pointer event occurs outside the bounds of the component. It can be prevented by calling event.preventDefault.
83
56
  */
84
- this.onPointerDownOutside = output();
57
+ this.onOutsideClick = output();
85
58
  /**
86
- * Event handler called when the overlay is atached
59
+ * @description Event handler called after the overlay is open
87
60
  */
88
- this.onShow = output();
61
+ this.onOpen = output();
89
62
  /**
90
- * Event handler called when the overlay is detached
63
+ * @description Event handler called after the overlay is closed
91
64
  */
92
- this.onHide = output();
65
+ this.onClosed = output();
66
+ /** @ingore */
67
+ this.positions = computed(() => this.computePositions());
68
+ this.onOriginChangeEffect();
93
69
  this.onPositionChangeEffect();
94
70
  }
95
71
  /** @ignore */
96
72
  ngOnInit() {
97
- this.setOrigin();
98
73
  this.setScrollStrategy();
99
74
  this.setDisableClose();
100
75
  this.onAttach();
@@ -103,20 +78,22 @@ export class RdxPopoverContentDirective {
103
78
  this.connectOutsideClick();
104
79
  }
105
80
  /** @ignore */
106
- show() {
81
+ open() {
82
+ if (this.connectedOverlay.open) {
83
+ return;
84
+ }
107
85
  const prevOpen = this.connectedOverlay.open;
108
86
  this.connectedOverlay.open = true;
109
- if (!prevOpen) {
110
- this.connectedOverlay.ngOnChanges({ open: new SimpleChange(prevOpen, true, false) });
111
- }
87
+ this.fireOverlayNgOnChanges('open', this.connectedOverlay.open, prevOpen);
112
88
  }
113
89
  /** @ignore */
114
- hide() {
90
+ close() {
91
+ if (!this.connectedOverlay.open) {
92
+ return;
93
+ }
115
94
  const prevOpen = this.connectedOverlay.open;
116
95
  this.connectedOverlay.open = false;
117
- if (prevOpen) {
118
- this.connectedOverlay.ngOnChanges({ open: new SimpleChange(prevOpen, false, false) });
119
- }
96
+ this.fireOverlayNgOnChanges('open', this.connectedOverlay.open, prevOpen);
120
97
  }
121
98
  /** @ignore */
122
99
  positionChange() {
@@ -128,9 +105,8 @@ export class RdxPopoverContentDirective {
128
105
  .asObservable()
129
106
  .pipe(filter((event) => event.key === 'Escape'), tap((event) => {
130
107
  this.onEscapeKeyDown.emit(event);
131
- if (!event.defaultPrevented) {
132
- this.popoverRoot.handleClose();
133
- }
108
+ }), filter((event) => !event.defaultPrevented && !this.popoverRoot.firstDefaultOpen()), tap(() => {
109
+ this.popoverRoot.handleClose();
134
110
  }), takeUntilDestroyed(this.destroyRef))
135
111
  .subscribe();
136
112
  }
@@ -138,11 +114,20 @@ export class RdxPopoverContentDirective {
138
114
  connectOutsideClick() {
139
115
  this.connectedOverlay.overlayOutsideClick
140
116
  .asObservable()
141
- .pipe(tap((event) => {
142
- this.onPointerDownOutside.emit(event);
143
- if (!event.defaultPrevented) {
144
- this.popoverRoot.handleClose();
145
- }
117
+ .pipe(
118
+ /**
119
+ * Handle the situation when an anchor is added and the anchor becomes the origin of the overlay
120
+ * hence the trigger will be considered the outside element
121
+ */
122
+ filter((event) => {
123
+ return (!this.popoverRoot.popoverAnchorDirective() ||
124
+ !this.popoverRoot
125
+ .popoverTriggerDirective()
126
+ .elementRef.nativeElement.contains(event.target));
127
+ }), tap((event) => {
128
+ this.onOutsideClick.emit(event);
129
+ }), filter((event) => !event.defaultPrevented && !this.popoverRoot.firstDefaultOpen()), tap(() => {
130
+ this.popoverRoot.handleClose();
146
131
  }), takeUntilDestroyed(this.destroyRef))
147
132
  .subscribe();
148
133
  }
@@ -151,7 +136,10 @@ export class RdxPopoverContentDirective {
151
136
  this.connectedOverlay.attach
152
137
  .asObservable()
153
138
  .pipe(tap(() => {
154
- this.onShow.emit();
139
+ /**
140
+ * `this.onOpen.emit();` is being delegated to the root directive due to the opening animation
141
+ */
142
+ this.popoverRoot.attachDetachEvent.set(RdxPopoverAttachDetachEvent.ATTACH);
155
143
  }), takeUntilDestroyed(this.destroyRef))
156
144
  .subscribe();
157
145
  }
@@ -160,7 +148,10 @@ export class RdxPopoverContentDirective {
160
148
  this.connectedOverlay.detach
161
149
  .asObservable()
162
150
  .pipe(tap(() => {
163
- this.onHide.emit();
151
+ /**
152
+ * `this.onClosed.emit();` is being delegated to the root directive due to the closing animation
153
+ */
154
+ this.popoverRoot.attachDetachEvent.set(RdxPopoverAttachDetachEvent.DETACH);
164
155
  }), takeUntilDestroyed(this.destroyRef))
165
156
  .subscribe();
166
157
  }
@@ -168,24 +159,68 @@ export class RdxPopoverContentDirective {
168
159
  setScrollStrategy() {
169
160
  const prevScrollStrategy = this.connectedOverlay.scrollStrategy;
170
161
  this.connectedOverlay.scrollStrategy = this.overlay.scrollStrategies.reposition();
171
- this.connectedOverlay.ngOnChanges({
172
- scrollStrategy: new SimpleChange(prevScrollStrategy, this.connectedOverlay.scrollStrategy, false)
173
- });
162
+ this.fireOverlayNgOnChanges('scrollStrategy', this.connectedOverlay.scrollStrategy, prevScrollStrategy);
174
163
  }
175
164
  /** @ignore */
176
165
  setDisableClose() {
177
166
  const prevDisableClose = this.connectedOverlay.disableClose;
178
167
  this.connectedOverlay.disableClose = true;
179
- this.connectedOverlay.ngOnChanges({
180
- disableClose: new SimpleChange(prevDisableClose, this.connectedOverlay.disableClose, false)
181
- });
168
+ this.fireOverlayNgOnChanges('disableClose', this.connectedOverlay.disableClose, prevDisableClose);
182
169
  }
183
170
  /** @ignore */
184
- setOrigin() {
171
+ setOrigin(origin) {
185
172
  const prevOrigin = this.connectedOverlay.origin;
186
- this.connectedOverlay.origin = this.popoverRoot.popoverTriggerDirective().overlayOrigin;
187
- this.connectedOverlay.ngOnChanges({
188
- origin: new SimpleChange(prevOrigin, this.connectedOverlay.origin, false)
173
+ this.connectedOverlay.origin = origin;
174
+ this.fireOverlayNgOnChanges('origin', this.connectedOverlay.origin, prevOrigin);
175
+ }
176
+ /** @ignore */
177
+ setPositions(positions) {
178
+ const prevPositions = this.connectedOverlay.positions;
179
+ this.connectedOverlay.positions = positions;
180
+ this.fireOverlayNgOnChanges('positions', this.connectedOverlay.positions, prevPositions);
181
+ this.connectedOverlay.overlayRef?.updatePosition();
182
+ }
183
+ /** @ignore */
184
+ computePositions() {
185
+ const greatestDimensionFromTheArrow = Math.max(this.popoverRoot.popoverArrowDirective()?.width() ?? 0, this.popoverRoot.popoverArrowDirective()?.height() ?? 0);
186
+ const offsets = {
187
+ sideOffset: this.sideOffset() ?? (greatestDimensionFromTheArrow || DEFAULTS.offsets.side),
188
+ alignOffset: this.alignOffset() ?? DEFAULTS.offsets.align
189
+ };
190
+ const basePosition = getContentPosition({
191
+ side: this.side(),
192
+ align: this.align(),
193
+ sideOffset: offsets.sideOffset,
194
+ alignOffset: offsets.alignOffset
195
+ });
196
+ const positions = [basePosition];
197
+ if (!this.disableAlternatePositions()) {
198
+ /**
199
+ * Alternate positions for better user experience along the X/Y axis (e.g. vertical/horizontal scrolling)
200
+ */
201
+ const allPossibleConnectedPositions = getAllPossibleConnectedPositions();
202
+ allPossibleConnectedPositions.forEach((_, key) => {
203
+ const sideAndAlignArray = key.split('|');
204
+ if (sideAndAlignArray[0] !== this.side() ||
205
+ sideAndAlignArray[1] !== this.align()) {
206
+ positions.push(getContentPosition({
207
+ side: sideAndAlignArray[0],
208
+ align: sideAndAlignArray[1],
209
+ sideOffset: offsets.sideOffset,
210
+ alignOffset: offsets.alignOffset
211
+ }));
212
+ }
213
+ });
214
+ }
215
+ return positions;
216
+ }
217
+ onOriginChangeEffect() {
218
+ effect(() => {
219
+ const origin = (this.popoverRoot.popoverAnchorDirective() ?? this.popoverRoot.popoverTriggerDirective())
220
+ .overlayOrigin;
221
+ untracked(() => {
222
+ this.setOrigin(origin);
223
+ });
189
224
  });
190
225
  }
191
226
  /** @ignore */
@@ -194,17 +229,18 @@ export class RdxPopoverContentDirective {
194
229
  const positions = this.positions();
195
230
  this.disableAlternatePositions();
196
231
  untracked(() => {
197
- const prevPositions = this.connectedOverlay.positions;
198
- this.connectedOverlay.positions = positions;
199
- this.connectedOverlay.ngOnChanges({
200
- positions: new SimpleChange(prevPositions, this.connectedOverlay.positions, false)
201
- });
202
- this.connectedOverlay.overlayRef?.updatePosition();
232
+ this.setPositions(positions);
203
233
  });
204
234
  });
205
235
  }
236
+ /** @ignore */
237
+ fireOverlayNgOnChanges(input, currentValue, previousValue, firstChange = false) {
238
+ this.connectedOverlay.ngOnChanges({
239
+ [input]: new SimpleChange(previousValue, currentValue, firstChange)
240
+ });
241
+ }
206
242
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxPopoverContentDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
207
- 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 }); }
243
+ 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", onOutsideClick: "onOutsideClick", onOpen: "onOpen", onClosed: "onClosed" }, hostDirectives: [{ directive: i1.CdkConnectedOverlay }], ngImport: i0 }); }
208
244
  }
209
245
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxPopoverContentDirective, decorators: [{
210
246
  type: Directive,
@@ -216,4 +252,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImpo
216
252
  ]
217
253
  }]
218
254
  }], ctorParameters: () => [] });
219
- //# 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        CdkConnectedOverlay\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() ?? 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((_, 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    }\n\n    /** @ignore */\n    ngOnInit() {\n        this.setOrigin();\n        this.setScrollStrategy();\n        this.setDisableClose();\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                    if (!event.defaultPrevented) {\n                        this.popoverRoot.handleClose();\n                    }\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 = true;\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"]}
255
+ //# 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, RdxPopoverAttachDetachEvent, RdxPopoverSide, RdxSideAndAlignOffsets } from './popover.types';\nimport { getAllPossibleConnectedPositions, getContentPosition } from './popover.utils';\n\n@Directive({\n    selector: '[rdxPopoverContent]',\n    standalone: true,\n    hostDirectives: [\n        CdkConnectedOverlay\n    ]\n})\nexport class RdxPopoverContentDirective implements OnInit {\n    /** @ignore */\n    private readonly popoverRoot = injectPopoverRoot();\n    /** @ignore */\n    private readonly templateRef = inject(TemplateRef);\n    /** @ignore */\n    private readonly overlay = inject(Overlay);\n    /** @ignore */\n    private readonly destroyRef = inject(DestroyRef);\n    /** @ignore */\n    private readonly connectedOverlay = inject(CdkConnectedOverlay);\n\n    /** @ignore */\n    readonly name = computed(() => `rdx-popover-trigger-${this.popoverRoot.uniqueId()}`);\n\n    /**\n     * @description The preferred side of the trigger to render against when open. Will be reversed when collisions occur and avoidCollisions is enabled.\n     * @default top\n     */\n    readonly side = input<RdxPopoverSide>(RdxPopoverSide.Top);\n    /**\n     * @description The distance in pixels from the trigger.\n     * @default undefined\n     */\n    readonly sideOffset = input<number | undefined>(void 0);\n    /**\n     * @description The preferred alignment against the trigger. May change when collisions occur.\n     * @default center\n     */\n    readonly align = input<RdxPopoverAlign>(RdxPopoverAlign.Center);\n    /**\n     * @description An offset in pixels from the \"start\" or \"end\" alignment options.\n     * @default undefined\n     */\n    readonly alignOffset = input<number | undefined>(void 0);\n\n    /**\n     * @description Whether to add some alternate positions of the content.\n     * @default false\n     */\n    readonly disableAlternatePositions = input(false);\n\n    /**\n     * @description 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     * @description 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 onOutsideClick = output<MouseEvent>();\n\n    /**\n     * @description Event handler called after the overlay is open\n     */\n    readonly onOpen = output<void>();\n    /**\n     * @description Event handler called after the overlay is closed\n     */\n    readonly onClosed = output<void>();\n\n    /** @ingore */\n    readonly positions = computed(() => this.computePositions());\n\n    constructor() {\n        this.onOriginChangeEffect();\n        this.onPositionChangeEffect();\n    }\n\n    /** @ignore */\n    ngOnInit() {\n        this.setScrollStrategy();\n        this.setDisableClose();\n        this.onAttach();\n        this.onDetach();\n        this.connectKeydownEscape();\n        this.connectOutsideClick();\n    }\n\n    /** @ignore */\n    open() {\n        if (this.connectedOverlay.open) {\n            return;\n        }\n        const prevOpen = this.connectedOverlay.open;\n        this.connectedOverlay.open = true;\n        this.fireOverlayNgOnChanges('open', this.connectedOverlay.open, prevOpen);\n    }\n\n    /** @ignore */\n    close() {\n        if (!this.connectedOverlay.open) {\n            return;\n        }\n        const prevOpen = this.connectedOverlay.open;\n        this.connectedOverlay.open = false;\n        this.fireOverlayNgOnChanges('open', this.connectedOverlay.open, prevOpen);\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                }),\n                filter((event) => !event.defaultPrevented && !this.popoverRoot.firstDefaultOpen()),\n                tap(() => {\n                    this.popoverRoot.handleClose();\n                }),\n                takeUntilDestroyed(this.destroyRef)\n            )\n            .subscribe();\n    }\n\n    /** @ignore */\n    private connectOutsideClick() {\n        this.connectedOverlay.overlayOutsideClick\n            .asObservable()\n            .pipe(\n                /**\n                 * Handle the situation when an anchor is added and the anchor becomes the origin of the overlay\n                 * hence  the trigger will be considered the outside element\n                 */\n                filter((event) => {\n                    return (\n                        !this.popoverRoot.popoverAnchorDirective() ||\n                        !this.popoverRoot\n                            .popoverTriggerDirective()\n                            .elementRef.nativeElement.contains(event.target as Element)\n                    );\n                }),\n                tap((event) => {\n                    this.onOutsideClick.emit(event);\n                }),\n                filter((event) => !event.defaultPrevented && !this.popoverRoot.firstDefaultOpen()),\n                tap(() => {\n                    this.popoverRoot.handleClose();\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                    /**\n                     * `this.onOpen.emit();` is being delegated to the root directive due to the opening animation\n                     */\n                    this.popoverRoot.attachDetachEvent.set(RdxPopoverAttachDetachEvent.ATTACH);\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                    /**\n                     * `this.onClosed.emit();` is being delegated to the root directive due to the closing animation\n                     */\n                    this.popoverRoot.attachDetachEvent.set(RdxPopoverAttachDetachEvent.DETACH);\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.fireOverlayNgOnChanges('scrollStrategy', this.connectedOverlay.scrollStrategy, prevScrollStrategy);\n    }\n\n    /** @ignore */\n    private setDisableClose() {\n        const prevDisableClose = this.connectedOverlay.disableClose;\n        this.connectedOverlay.disableClose = true;\n        this.fireOverlayNgOnChanges('disableClose', this.connectedOverlay.disableClose, prevDisableClose);\n    }\n\n    /** @ignore */\n    private setOrigin(origin: CdkConnectedOverlay['origin']) {\n        const prevOrigin = this.connectedOverlay.origin;\n        this.connectedOverlay.origin = origin;\n        this.fireOverlayNgOnChanges('origin', this.connectedOverlay.origin, prevOrigin);\n    }\n\n    /** @ignore */\n    private setPositions(positions: CdkConnectedOverlay['positions']) {\n        const prevPositions = this.connectedOverlay.positions;\n        this.connectedOverlay.positions = positions;\n        this.fireOverlayNgOnChanges('positions', this.connectedOverlay.positions, prevPositions);\n        this.connectedOverlay.overlayRef?.updatePosition();\n    }\n\n    /** @ignore */\n    private computePositions() {\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() ?? 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((_, 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    private onOriginChangeEffect() {\n        effect(() => {\n            const origin = (this.popoverRoot.popoverAnchorDirective() ?? this.popoverRoot.popoverTriggerDirective())\n                .overlayOrigin;\n            untracked(() => {\n                this.setOrigin(origin);\n            });\n        });\n    }\n\n    /** @ignore */\n    private onPositionChangeEffect() {\n        effect(() => {\n            const positions = this.positions();\n            this.disableAlternatePositions();\n            untracked(() => {\n                this.setPositions(positions);\n            });\n        });\n    }\n\n    /** @ignore */\n    private fireOverlayNgOnChanges<K extends keyof CdkConnectedOverlay, V extends CdkConnectedOverlay[K]>(\n        input: K,\n        currentValue: V,\n        previousValue: V,\n        firstChange = false\n    ) {\n        this.connectedOverlay.ngOnChanges({\n            [input]: new SimpleChange(previousValue, currentValue, firstChange)\n        });\n    }\n}\n"]}