@radix-ng/primitives 1.0.0-beta.3 → 1.0.0-beta.5

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 (118) hide show
  1. package/README.md +1 -1
  2. package/fesm2022/radix-ng-primitives-accordion.mjs +5 -3
  3. package/fesm2022/radix-ng-primitives-accordion.mjs.map +1 -1
  4. package/fesm2022/radix-ng-primitives-alert-dialog.mjs +3 -2
  5. package/fesm2022/radix-ng-primitives-alert-dialog.mjs.map +1 -1
  6. package/fesm2022/radix-ng-primitives-autocomplete.mjs +617 -659
  7. package/fesm2022/radix-ng-primitives-autocomplete.mjs.map +1 -1
  8. package/fesm2022/radix-ng-primitives-calendar.mjs +5 -3
  9. package/fesm2022/radix-ng-primitives-calendar.mjs.map +1 -1
  10. package/fesm2022/radix-ng-primitives-checkbox.mjs +33 -18
  11. package/fesm2022/radix-ng-primitives-checkbox.mjs.map +1 -1
  12. package/fesm2022/radix-ng-primitives-combobox.mjs +1305 -572
  13. package/fesm2022/radix-ng-primitives-combobox.mjs.map +1 -1
  14. package/fesm2022/radix-ng-primitives-config.mjs +13 -4
  15. package/fesm2022/radix-ng-primitives-config.mjs.map +1 -1
  16. package/fesm2022/radix-ng-primitives-context-menu.mjs +51 -10
  17. package/fesm2022/radix-ng-primitives-context-menu.mjs.map +1 -1
  18. package/fesm2022/radix-ng-primitives-core.mjs +1352 -64
  19. package/fesm2022/radix-ng-primitives-core.mjs.map +1 -1
  20. package/fesm2022/radix-ng-primitives-date-field.mjs +5 -3
  21. package/fesm2022/radix-ng-primitives-date-field.mjs.map +1 -1
  22. package/fesm2022/radix-ng-primitives-dialog.mjs +290 -120
  23. package/fesm2022/radix-ng-primitives-dialog.mjs.map +1 -1
  24. package/fesm2022/radix-ng-primitives-direction-provider.mjs +70 -0
  25. package/fesm2022/radix-ng-primitives-direction-provider.mjs.map +1 -0
  26. package/fesm2022/radix-ng-primitives-dismissable-layer.mjs +519 -184
  27. package/fesm2022/radix-ng-primitives-dismissable-layer.mjs.map +1 -1
  28. package/fesm2022/radix-ng-primitives-drawer.mjs +3 -3
  29. package/fesm2022/radix-ng-primitives-drawer.mjs.map +1 -1
  30. package/fesm2022/radix-ng-primitives-editable.mjs +12 -7
  31. package/fesm2022/radix-ng-primitives-editable.mjs.map +1 -1
  32. package/fesm2022/radix-ng-primitives-field.mjs +3 -2
  33. package/fesm2022/radix-ng-primitives-field.mjs.map +1 -1
  34. package/fesm2022/radix-ng-primitives-floating-focus-manager.mjs +803 -0
  35. package/fesm2022/radix-ng-primitives-floating-focus-manager.mjs.map +1 -0
  36. package/fesm2022/radix-ng-primitives-focus-scope.mjs +305 -70
  37. package/fesm2022/radix-ng-primitives-focus-scope.mjs.map +1 -1
  38. package/fesm2022/radix-ng-primitives-menu.mjs +893 -289
  39. package/fesm2022/radix-ng-primitives-menu.mjs.map +1 -1
  40. package/fesm2022/radix-ng-primitives-menubar.mjs +32 -4
  41. package/fesm2022/radix-ng-primitives-menubar.mjs.map +1 -1
  42. package/fesm2022/radix-ng-primitives-navigation-menu.mjs +144 -159
  43. package/fesm2022/radix-ng-primitives-navigation-menu.mjs.map +1 -1
  44. package/fesm2022/radix-ng-primitives-number-field.mjs +7 -2
  45. package/fesm2022/radix-ng-primitives-number-field.mjs.map +1 -1
  46. package/fesm2022/radix-ng-primitives-popover.mjs +284 -212
  47. package/fesm2022/radix-ng-primitives-popover.mjs.map +1 -1
  48. package/fesm2022/radix-ng-primitives-popper.mjs +94 -51
  49. package/fesm2022/radix-ng-primitives-popper.mjs.map +1 -1
  50. package/fesm2022/radix-ng-primitives-presence.mjs +1 -1
  51. package/fesm2022/radix-ng-primitives-presence.mjs.map +1 -1
  52. package/fesm2022/radix-ng-primitives-preview-card.mjs +141 -173
  53. package/fesm2022/radix-ng-primitives-preview-card.mjs.map +1 -1
  54. package/fesm2022/radix-ng-primitives-radio.mjs +19 -14
  55. package/fesm2022/radix-ng-primitives-radio.mjs.map +1 -1
  56. package/fesm2022/radix-ng-primitives-roving-focus.mjs +4 -2
  57. package/fesm2022/radix-ng-primitives-roving-focus.mjs.map +1 -1
  58. package/fesm2022/radix-ng-primitives-scroll-area.mjs +5 -4
  59. package/fesm2022/radix-ng-primitives-scroll-area.mjs.map +1 -1
  60. package/fesm2022/radix-ng-primitives-select.mjs +241 -164
  61. package/fesm2022/radix-ng-primitives-select.mjs.map +1 -1
  62. package/fesm2022/radix-ng-primitives-slider.mjs +262 -29
  63. package/fesm2022/radix-ng-primitives-slider.mjs.map +1 -1
  64. package/fesm2022/radix-ng-primitives-stepper.mjs +16 -10
  65. package/fesm2022/radix-ng-primitives-stepper.mjs.map +1 -1
  66. package/fesm2022/radix-ng-primitives-switch.mjs +10 -5
  67. package/fesm2022/radix-ng-primitives-switch.mjs.map +1 -1
  68. package/fesm2022/radix-ng-primitives-tabs.mjs +15 -10
  69. package/fesm2022/radix-ng-primitives-tabs.mjs.map +1 -1
  70. package/fesm2022/radix-ng-primitives-time-field.mjs +5 -3
  71. package/fesm2022/radix-ng-primitives-time-field.mjs.map +1 -1
  72. package/fesm2022/radix-ng-primitives-toast.mjs +15 -36
  73. package/fesm2022/radix-ng-primitives-toast.mjs.map +1 -1
  74. package/fesm2022/radix-ng-primitives-toggle-group.mjs +14 -7
  75. package/fesm2022/radix-ng-primitives-toggle-group.mjs.map +1 -1
  76. package/fesm2022/radix-ng-primitives-toggle.mjs +12 -6
  77. package/fesm2022/radix-ng-primitives-toggle.mjs.map +1 -1
  78. package/fesm2022/radix-ng-primitives-toolbar.mjs +5 -3
  79. package/fesm2022/radix-ng-primitives-toolbar.mjs.map +1 -1
  80. package/fesm2022/radix-ng-primitives-tooltip.mjs +251 -143
  81. package/fesm2022/radix-ng-primitives-tooltip.mjs.map +1 -1
  82. package/package.json +10 -1
  83. package/types/radix-ng-primitives-accordion.d.ts +4 -3
  84. package/types/radix-ng-primitives-autocomplete.d.ts +217 -152
  85. package/types/radix-ng-primitives-calendar.d.ts +5 -3
  86. package/types/radix-ng-primitives-checkbox.d.ts +27 -15
  87. package/types/radix-ng-primitives-combobox.d.ts +672 -283
  88. package/types/radix-ng-primitives-config.d.ts +1 -1
  89. package/types/radix-ng-primitives-context-menu.d.ts +15 -5
  90. package/types/radix-ng-primitives-core.d.ts +764 -14
  91. package/types/radix-ng-primitives-date-field.d.ts +3 -2
  92. package/types/radix-ng-primitives-dialog.d.ts +88 -32
  93. package/types/radix-ng-primitives-direction-provider.d.ts +41 -0
  94. package/types/radix-ng-primitives-dismissable-layer.d.ts +147 -99
  95. package/types/radix-ng-primitives-editable.d.ts +11 -5
  96. package/types/radix-ng-primitives-field.d.ts +1 -0
  97. package/types/radix-ng-primitives-floating-focus-manager.d.ts +272 -0
  98. package/types/radix-ng-primitives-focus-scope.d.ts +132 -1
  99. package/types/radix-ng-primitives-menu.d.ts +192 -103
  100. package/types/radix-ng-primitives-navigation-menu.d.ts +37 -75
  101. package/types/radix-ng-primitives-number-field.d.ts +8 -3
  102. package/types/radix-ng-primitives-popover.d.ts +71 -92
  103. package/types/radix-ng-primitives-popper.d.ts +39 -9
  104. package/types/radix-ng-primitives-preview-card.d.ts +39 -72
  105. package/types/radix-ng-primitives-radio.d.ts +13 -6
  106. package/types/radix-ng-primitives-roving-focus.d.ts +7 -6
  107. package/types/radix-ng-primitives-scroll-area.d.ts +2 -2
  108. package/types/radix-ng-primitives-select.d.ts +142 -109
  109. package/types/radix-ng-primitives-slider.d.ts +64 -12
  110. package/types/radix-ng-primitives-stepper.d.ts +15 -7
  111. package/types/radix-ng-primitives-switch.d.ts +10 -4
  112. package/types/radix-ng-primitives-tabs.d.ts +12 -6
  113. package/types/radix-ng-primitives-time-field.d.ts +3 -2
  114. package/types/radix-ng-primitives-toast.d.ts +7 -7
  115. package/types/radix-ng-primitives-toggle-group.d.ts +15 -8
  116. package/types/radix-ng-primitives-toggle.d.ts +10 -3
  117. package/types/radix-ng-primitives-toolbar.d.ts +3 -2
  118. package/types/radix-ng-primitives-tooltip.d.ts +61 -80
@@ -2,11 +2,12 @@ import * as _angular_core from '@angular/core';
2
2
  import { InjectionToken, Provider, Signal, ElementRef } from '@angular/core';
3
3
  import * as i1 from '@radix-ng/primitives/portal';
4
4
  import * as _radix_ng_primitives_core from '@radix-ng/primitives/core';
5
- import { BooleanInput, NumberInput } from '@radix-ng/primitives/core';
5
+ import { RdxFloatingRootContext, BooleanInput, NumberInput, RdxCancelableChangeEventDetails } from '@radix-ng/primitives/core';
6
6
  import * as i1$1 from '@radix-ng/primitives/popper';
7
- import { RdxPopperContentWrapper, RdxPopperAnchorElement } from '@radix-ng/primitives/popper';
7
+ import { RdxPopperContentWrapper } from '@radix-ng/primitives/popper';
8
8
  import * as _radix_ng_primitives_tooltip from '@radix-ng/primitives/tooltip';
9
- import * as i1$2 from '@radix-ng/primitives/dismissable-layer';
9
+ import { RdxOutsidePressDomEvent } from '@radix-ng/primitives/dismissable-layer';
10
+ import * as _radix_ng_primitives_floating_focus_manager from '@radix-ng/primitives/floating-focus-manager';
10
11
 
11
12
  /**
12
13
  * Structural directive that teleports the tooltip content into a container (default `document.body`)
@@ -77,6 +78,7 @@ declare function injectRdxTooltipConfig(): Required<RdxTooltipConfig>;
77
78
  interface RdxTooltipContext {
78
79
  contentId: string;
79
80
  isOpen: Signal<boolean>;
81
+ present: Signal<boolean>;
80
82
  /** Whether the tooltip opened/closed without waiting for the delay. */
81
83
  instant: Signal<boolean>;
82
84
  disabled: Signal<boolean>;
@@ -86,13 +88,16 @@ interface RdxTooltipContext {
86
88
  trigger: Signal<HTMLElement | undefined>;
87
89
  triggers: Signal<HTMLElement[]>;
88
90
  payload: Signal<unknown>;
89
- open: (trigger?: HTMLElement, payload?: unknown) => void;
90
- close: () => void;
91
+ open: (trigger?: HTMLElement, payload?: unknown, event?: Event) => void;
92
+ close: (reason?: RdxTooltipOpenChangeReason, event?: Event) => void;
93
+ openChangeReason: Signal<RdxTooltipOpenChangeReason>;
94
+ cancelPendingOpen: () => void;
95
+ closeHoverOpen: (event?: Event) => void;
91
96
  /** Closes after the resolved close delay (used when hover/focus is lost). */
92
- closeDelayed: () => void;
97
+ closeDelayed: (event?: Event) => void;
93
98
  registerTrigger: (trigger: HTMLElement) => () => void;
94
99
  /** Hover entered a trigger — opens after the resolved delay (or instantly). */
95
- onTriggerEnter: (trigger?: HTMLElement, payload?: unknown) => void;
100
+ onTriggerEnter: (trigger?: HTMLElement, payload?: unknown, event?: Event) => void;
96
101
  /** Hover left a trigger — cancels a pending open and closes when appropriate. */
97
102
  onTriggerLeave: () => void;
98
103
  setCursorPosition: (position: {
@@ -101,6 +106,12 @@ interface RdxTooltipContext {
101
106
  } | undefined) => void;
102
107
  setDelays: (delay: number | undefined, closeDelay: number | undefined) => void;
103
108
  }
109
+ type RdxTooltipOpenChangeReason = 'trigger-hover' | 'trigger-focus' | 'trigger-press' | 'outside-press' | 'escape-key' | 'disabled' | 'imperative-action' | 'none';
110
+ type RdxTooltipOpenChangeEventDetails = RdxCancelableChangeEventDetails<RdxTooltipOpenChangeReason>;
111
+ interface RdxTooltipOpenChangeEvent {
112
+ open: boolean;
113
+ eventDetails: RdxTooltipOpenChangeEventDetails;
114
+ }
104
115
  declare const injectRdxTooltipContext: _radix_ng_primitives_core.InjectContext<RdxTooltipContext>;
105
116
  declare const provideRdxTooltipContext: (useFactory: () => RdxTooltipContext) => _angular_core.Provider;
106
117
  declare class RdxTooltip {
@@ -109,6 +120,12 @@ declare class RdxTooltip {
109
120
  private readonly popper;
110
121
  private readonly destroyRef;
111
122
  private hasAppliedDefaultOpen;
123
+ /**
124
+ * Per-popup floating root context (ADR 0015) — the shared store the positioner's dismissal
125
+ * capability reads (`open`, `triggers`, the reference/floating elements). The tree node is
126
+ * registered by the positioner; this context exists independently so dismissal can read `open()`.
127
+ */
128
+ readonly floatingContext: RdxFloatingRootContext;
112
129
  /**
113
130
  * Whether the tooltip is currently open.
114
131
  */
@@ -146,7 +163,7 @@ declare class RdxTooltip {
146
163
  /**
147
164
  * Event handler called when the open state changes.
148
165
  */
149
- readonly onOpenChange: _angular_core.OutputEmitterRef<boolean>;
166
+ readonly onOpenChange: _angular_core.OutputEmitterRef<RdxTooltipOpenChangeEvent>;
150
167
  readonly contentId: string;
151
168
  readonly trigger: _angular_core.WritableSignal<HTMLElement | undefined>;
152
169
  readonly triggers: _angular_core.WritableSignal<HTMLElement[]>;
@@ -155,7 +172,10 @@ declare class RdxTooltip {
155
172
  x: number;
156
173
  y: number;
157
174
  } | undefined>;
175
+ readonly openChangeReason: _angular_core.WritableSignal<RdxTooltipOpenChangeReason>;
176
+ private readonly preventUnmountOnClose;
158
177
  private readonly openedInstant;
178
+ private suppressNextOpenChangeEmit;
159
179
  /** Local instant window used when this tooltip is not inside a provider. */
160
180
  private readonly localInstant;
161
181
  private readonly instantGroup;
@@ -166,17 +186,20 @@ declare class RdxTooltip {
166
186
  private readonly resolvedCloseDelay;
167
187
  /** Whether the most recent open happened without the delay. */
168
188
  readonly instant: Signal<boolean>;
189
+ readonly present: Signal<boolean>;
169
190
  private readonly virtualAnchor;
170
191
  private readonly openTimer;
171
192
  private readonly closeTimer;
172
193
  constructor();
173
194
  /** Opens immediately, optionally switching the active trigger/payload. */
174
- show(trigger?: HTMLElement | undefined, payload?: unknown): void;
175
- close(): void;
195
+ show(trigger?: HTMLElement | undefined, payload?: unknown, event?: Event): void;
196
+ close(reason?: RdxTooltipOpenChangeReason, event?: Event): void;
197
+ cancelPendingOpen(): void;
198
+ closeHoverOpen(event?: Event): void;
176
199
  /** Closes after the resolved close delay, e.g. when the pointer or focus leaves. */
177
- scheduleClose(): void;
200
+ scheduleClose(event?: Event): void;
178
201
  /** Hover/focus entered — open after the delay, or instantly within the instant window. */
179
- onTriggerEnter(trigger?: HTMLElement | undefined, payload?: unknown): void;
202
+ onTriggerEnter(trigger?: HTMLElement | undefined, payload?: unknown, event?: Event): void;
180
203
  onTriggerLeave(): void;
181
204
  registerTrigger(trigger: HTMLElement): () => void;
182
205
  setCursorPosition(position: {
@@ -216,84 +239,35 @@ declare class RdxTooltipPopup {
216
239
 
217
240
  /**
218
241
  * Positions the tooltip popup against its trigger (or a custom anchor).
242
+ *
243
+ * A "thin" positioner (ADR 0012): it inherits the popper positioning surface (inputs, `placed`
244
+ * output, unified vars + placement attrs) from {@link RdxPopperContentWrapper} and adds tooltip's own
245
+ * concerns — Base UI-aligned defaults (`side: 'top'`) via the config provider, dismiss handling
246
+ * (ADR 0015 — inline {@link RdxDismiss} on the shared floating tree, dismissal-only with
247
+ * no focus manager), the cursor-follow pointer-through behavior (via the inherited `nonInteractive`
248
+ * signal), the open/closed state attributes, and the hover grace area.
219
249
  */
220
- declare class RdxTooltipPositioner {
250
+ declare class RdxTooltipPositioner extends RdxPopperContentWrapper {
221
251
  protected readonly rootContext: _radix_ng_primitives_tooltip.RdxTooltipContext;
222
- protected readonly wrapper: RdxPopperContentWrapper;
223
252
  private readonly destroyRef;
224
- private readonly dismissableLayer;
225
- private readonly elementRef;
226
- /**
227
- * An element to position the popup against. Defaults to the trigger.
228
- */
229
- readonly anchor: _angular_core.InputSignal<RdxPopperAnchorElement>;
230
- /**
231
- * The preferred side of the anchor to render against when open.
232
- */
233
- readonly side: _angular_core.InputSignal<"top" | "right" | "bottom" | "left">;
234
- /**
235
- * The distance in pixels from the anchor.
236
- */
237
- readonly sideOffset: _angular_core.InputSignalWithTransform<number, NumberInput>;
238
- /**
239
- * The preferred alignment against the anchor.
240
- */
241
- readonly align: _angular_core.InputSignal<"start" | "center" | "end">;
242
- /**
243
- * An offset in pixels from the `start` or `end` alignment options.
244
- */
245
- readonly alignOffset: _angular_core.InputSignalWithTransform<number, NumberInput>;
246
- /**
247
- * The padding between the arrow and the edges of the content.
248
- */
249
- readonly arrowPadding: _angular_core.InputSignalWithTransform<number, NumberInput>;
250
- /**
251
- * When `true`, overrides the `side` and `align` preferences to prevent collisions with boundary edges.
252
- */
253
- readonly avoidCollisions: _angular_core.InputSignalWithTransform<boolean, BooleanInput>;
254
- /**
255
- * The element used as the collision boundary.
256
- */
257
- readonly collisionBoundary: _angular_core.InputSignal<ElementRef<HTMLElement> | ElementRef<HTMLElement>[] | undefined>;
258
- /**
259
- * The distance in pixels from the boundary edges where collision detection should occur.
260
- */
261
- readonly collisionPadding: _angular_core.InputSignal<number | Partial<Record<"top" | "right" | "bottom" | "left", number>>>;
262
- /**
263
- * The sticky behavior on the `align` axis.
264
- */
265
- readonly sticky: _angular_core.InputSignal<"partial" | "always">;
266
- /**
267
- * Whether to hide the content when the trigger becomes fully occluded.
268
- */
269
- readonly hideWhenDetached: _angular_core.InputSignalWithTransform<boolean, BooleanInput>;
270
- /**
271
- * The CSS position strategy used by Floating UI.
272
- */
273
- readonly positionStrategy: _angular_core.InputSignal<"fixed" | "absolute">;
274
- /**
275
- * Whether to update the position of the floating element on every animation frame if required.
276
- */
277
- readonly updatePositionStrategy: _angular_core.InputSignal<"always" | "optimized">;
278
- /**
279
- * Emits when the element is placed.
280
- */
281
- readonly placed: _angular_core.OutputRef<void>;
253
+ private readonly floatingContext;
254
+ private readonly registration;
255
+ private readonly containerRef;
282
256
  /**
283
257
  * Event handler called when the escape key is down. Can be prevented.
284
258
  */
285
- readonly escapeKeyDown: _angular_core.OutputRef<KeyboardEvent>;
259
+ readonly escapeKeyDown: _angular_core.OutputEmitterRef<KeyboardEvent>;
286
260
  /**
287
- * Event handler called when a `pointerdown` event happens outside of the `DismissableLayer`. Can be prevented.
261
+ * Event handler called when a `pointerdown` event happens outside of the popup. Can be prevented.
288
262
  */
289
- readonly pointerDownOutside: _angular_core.OutputRef<PointerEvent>;
263
+ readonly pointerDownOutside: _angular_core.OutputEmitterRef<RdxOutsidePressDomEvent>;
290
264
  private readonly triggerEl;
291
265
  private readonly containerEl;
292
266
  private readonly graceArea;
293
267
  private readonly afterNextRender;
294
268
  constructor();
295
269
  static ɵfac: _angular_core.ɵɵFactoryDeclaration<RdxTooltipPositioner, never>;
296
- static ɵdir: _angular_core.ɵɵDirectiveDeclaration<RdxTooltipPositioner, "[rdxTooltipPositioner]", never, { "anchor": { "alias": "anchor"; "required": false; "isSignal": true; }; "side": { "alias": "side"; "required": false; "isSignal": true; }; "sideOffset": { "alias": "sideOffset"; "required": false; "isSignal": true; }; "align": { "alias": "align"; "required": false; "isSignal": true; }; "alignOffset": { "alias": "alignOffset"; "required": false; "isSignal": true; }; "arrowPadding": { "alias": "arrowPadding"; "required": false; "isSignal": true; }; "avoidCollisions": { "alias": "avoidCollisions"; "required": false; "isSignal": true; }; "collisionBoundary": { "alias": "collisionBoundary"; "required": false; "isSignal": true; }; "collisionPadding": { "alias": "collisionPadding"; "required": false; "isSignal": true; }; "sticky": { "alias": "sticky"; "required": false; "isSignal": true; }; "hideWhenDetached": { "alias": "hideWhenDetached"; "required": false; "isSignal": true; }; "positionStrategy": { "alias": "positionStrategy"; "required": false; "isSignal": true; }; "updatePositionStrategy": { "alias": "updatePositionStrategy"; "required": false; "isSignal": true; }; }, { "placed": "placed"; "escapeKeyDown": "escapeKeyDown"; "pointerDownOutside": "pointerDownOutside"; }, never, never, true, [{ directive: typeof i1$2.RdxDismissableLayer; inputs: {}; outputs: {}; }, { directive: typeof i1$1.RdxPopperContentWrapper; inputs: { "anchor": "anchor"; "side": "side"; "sideOffset": "sideOffset"; "align": "align"; "alignOffset": "alignOffset"; "arrowPadding": "arrowPadding"; "avoidCollisions": "avoidCollisions"; "collisionBoundary": "collisionBoundary"; "collisionPadding": "collisionPadding"; "sticky": "sticky"; "hideWhenDetached": "hideWhenDetached"; "positionStrategy": "positionStrategy"; "updatePositionStrategy": "updatePositionStrategy"; }; outputs: {}; }]>;
270
+ static ɵdir: _angular_core.ɵɵDirectiveDeclaration<RdxTooltipPositioner, "[rdxTooltipPositioner]", never, {}, { "escapeKeyDown": "escapeKeyDown"; "pointerDownOutside": "pointerDownOutside"; }, never, never, true, [{ directive: typeof _radix_ng_primitives_core.RdxFloatingNodeRegistration; inputs: {}; outputs: {}; }]>;
297
271
  }
298
272
 
299
273
  type TooltipInstantController = {
@@ -384,15 +358,22 @@ declare class RdxTooltipTrigger {
384
358
  protected readonly isDisabled: _angular_core.Signal<boolean>;
385
359
  /** Whether this specific trigger is the active anchor of an open tooltip. */
386
360
  protected readonly isOpen: _angular_core.Signal<boolean>;
361
+ protected readonly triggerInteraction: _radix_ng_primitives_floating_focus_manager.RdxTriggerInteraction;
387
362
  private readonly isPointerDown;
388
363
  private readonly hasPointerMoveOpened;
364
+ private readonly isNestedTriggerHovered;
365
+ private pointerType;
389
366
  constructor();
390
- protected handleFocus(): void;
391
- protected handleBlur(): void;
392
- protected handleClick(): void;
367
+ protected handleFocus(event: FocusEvent): void;
368
+ protected handleBlur(event: FocusEvent): void;
369
+ protected handleClick(event: MouseEvent): void;
370
+ protected handlePointerEnter(event: PointerEvent): void;
393
371
  protected handlePointerMove(event: PointerEvent): void;
394
372
  protected handlePointerLeave(): void;
373
+ protected handleMouseOver(event: MouseEvent): void;
374
+ protected handleMouseLeave(): void;
395
375
  protected handlePointerDown(event: PointerEvent): Promise<void>;
376
+ private detectNestedTriggerHover;
396
377
  static ɵfac: _angular_core.ɵɵFactoryDeclaration<RdxTooltipTrigger, never>;
397
378
  static ɵdir: _angular_core.ɵɵDirectiveDeclaration<RdxTooltipTrigger, "[rdxTooltipTrigger]", never, { "handle": { "alias": "handle"; "required": false; "isSignal": true; }; "payload": { "alias": "payload"; "required": false; "isSignal": true; }; "id": { "alias": "id"; "required": false; "isSignal": true; }; "closeOnClick": { "alias": "closeOnClick"; "required": false; "isSignal": true; }; "disabled": { "alias": "disabled"; "required": false; "isSignal": true; }; "delay": { "alias": "delay"; "required": false; "isSignal": true; }; "closeDelay": { "alias": "closeDelay"; "required": false; "isSignal": true; }; "userOnPointerDown": { "alias": "rdxOnPointerDown"; "required": false; "isSignal": true; }; }, {}, never, never, true, [{ directive: typeof i1$1.RdxPopperAnchor; inputs: {}; outputs: {}; }]>;
398
379
  }
@@ -400,4 +381,4 @@ declare class RdxTooltipTrigger {
400
381
  declare const tooltipImports: (typeof RdxTooltipPortal)[];
401
382
 
402
383
  export { RdxTooltip, RdxTooltipArrow, RdxTooltipDefaultsToken, RdxTooltipHandle, RdxTooltipPopup, RdxTooltipPortal, RdxTooltipPortalMisuseGuard, RdxTooltipPositioner, RdxTooltipProvider, RdxTooltipTrigger, createRdxTooltipHandle, defaultTooltipConfig, injectRdxTooltipConfig, injectRdxTooltipContext, injectRdxTooltipProviderContext, provideRdxTooltipConfig, provideRdxTooltipContext, provideRdxTooltipProviderContext, tooltipImports };
403
- export type { RdxTooltipConfig, RdxTooltipContext, RdxTooltipProviderContext, RdxTrackCursorAxis };
384
+ export type { RdxTooltipConfig, RdxTooltipContext, RdxTooltipOpenChangeEvent, RdxTooltipOpenChangeEventDetails, RdxTooltipOpenChangeReason, RdxTooltipProviderContext, RdxTrackCursorAxis };