@radix-ui/react-tooltip 0.1.8-rc.5 → 0.1.8-rc.52

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.
@@ -1,2 +1,545 @@
1
- import*as e from"@radix-ui/react-visually-hidden";import{useControllableState as o}from"@radix-ui/react-use-controllable-state";import{Slottable as t}from"@radix-ui/react-slot";import{Primitive as r}from"@radix-ui/react-primitive";import{Presence as n}from"@radix-ui/react-presence";import{Portal as i}from"@radix-ui/react-portal";import*as a from"@radix-ui/react-popper";import{createPopperScope as l}from"@radix-ui/react-popper";import{useId as s}from"@radix-ui/react-id";import{DismissableLayer as c}from"@radix-ui/react-dismissable-layer";import{createContextScope as u}from"@radix-ui/react-context";import{useComposedRefs as p}from"@radix-ui/react-compose-refs";import{composeEventHandlers as d}from"@radix-ui/primitive";import*as m from"react";import f from"@babel/runtime/helpers/esm/extends";const[T,w]=u("Tooltip",[l]);export{w as createTooltipScope};const E=l(),g=700,[C,x]=T("TooltipProvider",{isOpenDelayed:!0,delayDuration:g,onOpen:()=>{},onClose:()=>{}});export const TooltipProvider=e=>{const{__scopeTooltip:o,delayDuration:t=g,skipDelayDuration:r=300,children:n}=e,[i,a]=m.useState(!0),l=m.useRef(0);return m.useEffect((()=>{const e=l.current;return()=>window.clearTimeout(e)}),[]),/*#__PURE__*/m.createElement(C,{scope:o,isOpenDelayed:i,delayDuration:t,onOpen:m.useCallback((()=>{window.clearTimeout(l.current),a(!1)}),[]),onClose:m.useCallback((()=>{window.clearTimeout(l.current),l.current=window.setTimeout((()=>a(!0)),r)}),[r])},n)};/*#__PURE__*/const[v,b]=T("Tooltip");export const Tooltip=e=>{const{__scopeTooltip:t,children:r,open:n,defaultOpen:i=!1,onOpenChange:l,delayDuration:c}=e,u=x("Tooltip",t),p=E(t),[d,f]=m.useState(null),T=s(),w=m.useRef(0),g=null!=c?c:u.delayDuration,C=m.useRef(!1),{onOpen:b,onClose:D}=u,[y=!1,O]=o({prop:n,defaultProp:i,onChange:e=>{e&&(document.dispatchEvent(new CustomEvent("tooltip.open")),b()),null==l||l(e)}}),h=m.useMemo((()=>y?C.current?"delayed-open":"instant-open":"closed"),[y]),_=m.useCallback((()=>{window.clearTimeout(w.current),C.current=!1,O(!0)}),[O]),k=m.useCallback((()=>{window.clearTimeout(w.current),w.current=window.setTimeout((()=>{C.current=!0,O(!0)}),g)}),[g,O]);return m.useEffect((()=>()=>window.clearTimeout(w.current)),[]),/*#__PURE__*/m.createElement(a.Root,p,/*#__PURE__*/m.createElement(v,{scope:t,contentId:T,open:y,stateAttribute:h,trigger:d,onTriggerChange:f,onTriggerEnter:m.useCallback((()=>{u.isOpenDelayed?k():_()}),[u.isOpenDelayed,k,_]),onOpen:m.useCallback(_,[_]),onClose:m.useCallback((()=>{window.clearTimeout(w.current),O(!1),D()}),[O,D])},r))};/*#__PURE__*/export const TooltipTrigger=/*#__PURE__*/m.forwardRef(((e,o)=>{const{__scopeTooltip:t,...n}=e,i=b("TooltipTrigger",t),l=E(t),s=p(o,i.onTriggerChange),c=m.useRef(!1),u=m.useCallback((()=>c.current=!1),[]);return m.useEffect((()=>()=>document.removeEventListener("mouseup",u)),[u]),/*#__PURE__*/m.createElement(a.Anchor,f({asChild:!0},l),/*#__PURE__*/m.createElement(r.button,f({"aria-describedby":i.open?i.contentId:void 0,"data-state":i.stateAttribute},n,{ref:s,onMouseEnter:d(e.onMouseEnter,i.onTriggerEnter),onMouseLeave:d(e.onMouseLeave,i.onClose),onMouseDown:d(e.onMouseDown,(()=>{c.current=!0,document.addEventListener("mouseup",u,{once:!0})})),onFocus:d(e.onFocus,(()=>{c.current||i.onOpen()})),onBlur:d(e.onBlur,i.onClose),onClick:d(e.onClick,(e=>{0===e.detail&&i.onClose()}))})))}));/*#__PURE__*/export const TooltipContent=/*#__PURE__*/m.forwardRef(((e,o)=>{const{forceMount:t,...r}=e,i=b("TooltipContent",e.__scopeTooltip);/*#__PURE__*/return m.createElement(n,{present:t||i.open},/*#__PURE__*/m.createElement(D,f({ref:o},r)))}));const D=/*#__PURE__*/m.forwardRef(((o,r)=>{const{__scopeTooltip:n,children:l,"aria-label":s,portalled:u=!0,onEscapeKeyDown:p,onPointerDownOutside:d,...T}=o,w=b("TooltipContent",n),g=E(n),C=u?i:m.Fragment,{onClose:x}=w;return m.useEffect((()=>(document.addEventListener("tooltip.open",x),()=>document.removeEventListener("tooltip.open",x))),[x]),m.useEffect((()=>{if(w.trigger){const e=e=>{const o=e.target;null!=o&&o.contains(w.trigger)&&x()};return window.addEventListener("scroll",e,{capture:!0}),()=>window.removeEventListener("scroll",e,{capture:!0})}}),[w.trigger,x]),/*#__PURE__*/m.createElement(C,null,/*#__PURE__*/m.createElement(c,{asChild:!0,disableOutsidePointerEvents:!1,onEscapeKeyDown:p,onPointerDownOutside:d,onFocusOutside:e=>e.preventDefault(),onDismiss:x},/*#__PURE__*/m.createElement(a.Content,f({"data-state":w.stateAttribute},g,T,{ref:r,style:{...T.style,"--radix-tooltip-content-transform-origin":"var(--radix-popper-transform-origin)"}}),/*#__PURE__*/m.createElement(t,null,l),/*#__PURE__*/m.createElement(e.Root,{id:w.contentId,role:"tooltip"},s||l))))}));/*#__PURE__*/export const TooltipArrow=/*#__PURE__*/m.forwardRef(((e,o)=>{const{__scopeTooltip:t,...r}=e,n=E(t);/*#__PURE__*/return m.createElement(a.Arrow,f({},n,r,{ref:o}))}));/*#__PURE__*/export const Provider=TooltipProvider;export const Root=Tooltip;export const Trigger=TooltipTrigger;export const Content=TooltipContent;export const Arrow=TooltipArrow;
1
+ import $8wepK$babelruntimehelpersesmextends from "@babel/runtime/helpers/esm/extends";
2
+ import {useState as $8wepK$useState, useRef as $8wepK$useRef, useEffect as $8wepK$useEffect, createElement as $8wepK$createElement, useCallback as $8wepK$useCallback, useMemo as $8wepK$useMemo, forwardRef as $8wepK$forwardRef} from "react";
3
+ import {composeEventHandlers as $8wepK$composeEventHandlers} from "@radix-ui/primitive";
4
+ import {useComposedRefs as $8wepK$useComposedRefs} from "@radix-ui/react-compose-refs";
5
+ import {createContextScope as $8wepK$createContextScope} from "@radix-ui/react-context";
6
+ import {DismissableLayer as $8wepK$DismissableLayer} from "@radix-ui/react-dismissable-layer";
7
+ import {useId as $8wepK$useId} from "@radix-ui/react-id";
8
+ import {createPopperScope as $8wepK$createPopperScope, Root as $8wepK$Root, Anchor as $8wepK$Anchor, Content as $8wepK$Content, Arrow as $8wepK$Arrow} from "@radix-ui/react-popper";
9
+ import {Portal as $8wepK$Portal} from "@radix-ui/react-portal";
10
+ import {Presence as $8wepK$Presence} from "@radix-ui/react-presence";
11
+ import {Primitive as $8wepK$Primitive} from "@radix-ui/react-primitive";
12
+ import {Slottable as $8wepK$Slottable} from "@radix-ui/react-slot";
13
+ import {useControllableState as $8wepK$useControllableState} from "@radix-ui/react-use-controllable-state";
14
+ import {Root as $8wepK$Root1} from "@radix-ui/react-visually-hidden";
15
+
16
+
17
+
18
+
19
+
20
+
21
+
22
+
23
+
24
+
25
+
26
+
27
+
28
+
29
+
30
+
31
+ const [$a093c7e1ec25a057$var$createTooltipContext, $a093c7e1ec25a057$export$1c540a2224f0d865] = $8wepK$createContextScope('Tooltip', [
32
+ $8wepK$createPopperScope
33
+ ]);
34
+ const $a093c7e1ec25a057$var$usePopperScope = $8wepK$createPopperScope();
35
+ /* -------------------------------------------------------------------------------------------------
36
+ * TooltipProvider
37
+ * -----------------------------------------------------------------------------------------------*/ const $a093c7e1ec25a057$var$PROVIDER_NAME = 'TooltipProvider';
38
+ const $a093c7e1ec25a057$var$DEFAULT_DELAY_DURATION = 700;
39
+ const $a093c7e1ec25a057$var$TOOLTIP_OPEN = 'tooltip.open';
40
+ const [$a093c7e1ec25a057$var$TooltipProviderContextProvider, $a093c7e1ec25a057$var$useTooltipProviderContext] = $a093c7e1ec25a057$var$createTooltipContext($a093c7e1ec25a057$var$PROVIDER_NAME);
41
+ const $a093c7e1ec25a057$export$f78649fb9ca566b8 = (props)=>{
42
+ const { __scopeTooltip: __scopeTooltip , delayDuration: delayDuration = $a093c7e1ec25a057$var$DEFAULT_DELAY_DURATION , skipDelayDuration: skipDelayDuration = 300 , disableHoverableContent: disableHoverableContent = false , children: children } = props;
43
+ const [isOpenDelayed, setIsOpenDelayed] = $8wepK$useState(true);
44
+ const isPointerInTransitRef = $8wepK$useRef(false);
45
+ const skipDelayTimerRef = $8wepK$useRef(0);
46
+ $8wepK$useEffect(()=>{
47
+ const skipDelayTimer = skipDelayTimerRef.current;
48
+ return ()=>window.clearTimeout(skipDelayTimer)
49
+ ;
50
+ }, []);
51
+ return /*#__PURE__*/ $8wepK$createElement($a093c7e1ec25a057$var$TooltipProviderContextProvider, {
52
+ scope: __scopeTooltip,
53
+ isOpenDelayed: isOpenDelayed,
54
+ delayDuration: delayDuration,
55
+ onOpen: $8wepK$useCallback(()=>{
56
+ window.clearTimeout(skipDelayTimerRef.current);
57
+ setIsOpenDelayed(false);
58
+ }, []),
59
+ onClose: $8wepK$useCallback(()=>{
60
+ window.clearTimeout(skipDelayTimerRef.current);
61
+ skipDelayTimerRef.current = window.setTimeout(()=>setIsOpenDelayed(true)
62
+ , skipDelayDuration);
63
+ }, [
64
+ skipDelayDuration
65
+ ]),
66
+ isPointerInTransitRef: isPointerInTransitRef,
67
+ onPointerInTransitChange: $8wepK$useCallback((inTransit)=>{
68
+ isPointerInTransitRef.current = inTransit;
69
+ }, []),
70
+ disableHoverableContent: disableHoverableContent
71
+ }, children);
72
+ };
73
+ /*#__PURE__*/ Object.assign($a093c7e1ec25a057$export$f78649fb9ca566b8, {
74
+ displayName: $a093c7e1ec25a057$var$PROVIDER_NAME
75
+ });
76
+ /* -------------------------------------------------------------------------------------------------
77
+ * Tooltip
78
+ * -----------------------------------------------------------------------------------------------*/ const $a093c7e1ec25a057$var$TOOLTIP_NAME = 'Tooltip';
79
+ const [$a093c7e1ec25a057$var$TooltipContextProvider, $a093c7e1ec25a057$var$useTooltipContext] = $a093c7e1ec25a057$var$createTooltipContext($a093c7e1ec25a057$var$TOOLTIP_NAME);
80
+ const $a093c7e1ec25a057$export$28c660c63b792dea = (props)=>{
81
+ const { __scopeTooltip: __scopeTooltip , children: children , open: openProp , defaultOpen: defaultOpen = false , onOpenChange: onOpenChange , disableHoverableContent: disableHoverableContentProp , delayDuration: delayDurationProp } = props;
82
+ const providerContext = $a093c7e1ec25a057$var$useTooltipProviderContext($a093c7e1ec25a057$var$TOOLTIP_NAME, props.__scopeTooltip);
83
+ const popperScope = $a093c7e1ec25a057$var$usePopperScope(__scopeTooltip);
84
+ const [trigger, setTrigger] = $8wepK$useState(null);
85
+ const contentId = $8wepK$useId();
86
+ const openTimerRef = $8wepK$useRef(0);
87
+ const disableHoverableContent = disableHoverableContentProp !== null && disableHoverableContentProp !== void 0 ? disableHoverableContentProp : providerContext.disableHoverableContent;
88
+ const delayDuration = delayDurationProp !== null && delayDurationProp !== void 0 ? delayDurationProp : providerContext.delayDuration;
89
+ const wasOpenDelayedRef = $8wepK$useRef(false);
90
+ const [open1 = false, setOpen] = $8wepK$useControllableState({
91
+ prop: openProp,
92
+ defaultProp: defaultOpen,
93
+ onChange: (open)=>{
94
+ if (open) {
95
+ providerContext.onOpen(); // as `onChange` is called within a lifecycle method we
96
+ // avoid dispatching via `dispatchDiscreteCustomEvent`.
97
+ document.dispatchEvent(new CustomEvent($a093c7e1ec25a057$var$TOOLTIP_OPEN));
98
+ } else providerContext.onClose();
99
+ onOpenChange === null || onOpenChange === void 0 || onOpenChange(open);
100
+ }
101
+ });
102
+ const stateAttribute = $8wepK$useMemo(()=>{
103
+ return open1 ? wasOpenDelayedRef.current ? 'delayed-open' : 'instant-open' : 'closed';
104
+ }, [
105
+ open1
106
+ ]);
107
+ const handleOpen = $8wepK$useCallback(()=>{
108
+ window.clearTimeout(openTimerRef.current);
109
+ wasOpenDelayedRef.current = false;
110
+ setOpen(true);
111
+ }, [
112
+ setOpen
113
+ ]);
114
+ const handleClose = $8wepK$useCallback(()=>{
115
+ window.clearTimeout(openTimerRef.current);
116
+ setOpen(false);
117
+ }, [
118
+ setOpen
119
+ ]);
120
+ const handleDelayedOpen = $8wepK$useCallback(()=>{
121
+ window.clearTimeout(openTimerRef.current);
122
+ openTimerRef.current = window.setTimeout(()=>{
123
+ wasOpenDelayedRef.current = true;
124
+ setOpen(true);
125
+ }, delayDuration);
126
+ }, [
127
+ delayDuration,
128
+ setOpen
129
+ ]);
130
+ $8wepK$useEffect(()=>{
131
+ return ()=>window.clearTimeout(openTimerRef.current)
132
+ ;
133
+ }, []);
134
+ return /*#__PURE__*/ $8wepK$createElement($8wepK$Root, popperScope, /*#__PURE__*/ $8wepK$createElement($a093c7e1ec25a057$var$TooltipContextProvider, {
135
+ scope: __scopeTooltip,
136
+ contentId: contentId,
137
+ open: open1,
138
+ stateAttribute: stateAttribute,
139
+ trigger: trigger,
140
+ onTriggerChange: setTrigger,
141
+ onTriggerEnter: $8wepK$useCallback(()=>{
142
+ if (providerContext.isOpenDelayed) handleDelayedOpen();
143
+ else handleOpen();
144
+ }, [
145
+ providerContext.isOpenDelayed,
146
+ handleDelayedOpen,
147
+ handleOpen
148
+ ]),
149
+ onTriggerLeave: $8wepK$useCallback(()=>{
150
+ if (disableHoverableContent) handleClose();
151
+ else // Clear the timer in case the pointer leaves the trigger before the tooltip is opened.
152
+ window.clearTimeout(openTimerRef.current);
153
+ }, [
154
+ handleClose,
155
+ disableHoverableContent
156
+ ]),
157
+ onOpen: handleOpen,
158
+ onClose: handleClose,
159
+ disableHoverableContent: disableHoverableContent
160
+ }, children));
161
+ };
162
+ /*#__PURE__*/ Object.assign($a093c7e1ec25a057$export$28c660c63b792dea, {
163
+ displayName: $a093c7e1ec25a057$var$TOOLTIP_NAME
164
+ });
165
+ /* -------------------------------------------------------------------------------------------------
166
+ * TooltipTrigger
167
+ * -----------------------------------------------------------------------------------------------*/ const $a093c7e1ec25a057$var$TRIGGER_NAME = 'TooltipTrigger';
168
+ const $a093c7e1ec25a057$export$8c610744efcf8a1d = /*#__PURE__*/ $8wepK$forwardRef((props, forwardedRef)=>{
169
+ const { __scopeTooltip: __scopeTooltip , ...triggerProps } = props;
170
+ const context = $a093c7e1ec25a057$var$useTooltipContext($a093c7e1ec25a057$var$TRIGGER_NAME, __scopeTooltip);
171
+ const providerContext = $a093c7e1ec25a057$var$useTooltipProviderContext($a093c7e1ec25a057$var$TRIGGER_NAME, __scopeTooltip);
172
+ const popperScope = $a093c7e1ec25a057$var$usePopperScope(__scopeTooltip);
173
+ const ref = $8wepK$useRef(null);
174
+ const composedRefs = $8wepK$useComposedRefs(forwardedRef, ref, context.onTriggerChange);
175
+ const isPointerDownRef = $8wepK$useRef(false);
176
+ const hasPointerMoveOpenedRef = $8wepK$useRef(false);
177
+ const handlePointerUp = $8wepK$useCallback(()=>isPointerDownRef.current = false
178
+ , []);
179
+ $8wepK$useEffect(()=>{
180
+ return ()=>document.removeEventListener('pointerup', handlePointerUp)
181
+ ;
182
+ }, [
183
+ handlePointerUp
184
+ ]);
185
+ return /*#__PURE__*/ $8wepK$createElement($8wepK$Anchor, $8wepK$babelruntimehelpersesmextends({
186
+ asChild: true
187
+ }, popperScope), /*#__PURE__*/ $8wepK$createElement($8wepK$Primitive.button, $8wepK$babelruntimehelpersesmextends({
188
+ // We purposefully avoid adding `type=button` here because tooltip triggers are also
189
+ // commonly anchors and the anchor `type` attribute signifies MIME type.
190
+ "aria-describedby": context.open ? context.contentId : undefined,
191
+ "data-state": context.stateAttribute
192
+ }, triggerProps, {
193
+ ref: composedRefs,
194
+ onPointerMove: $8wepK$composeEventHandlers(props.onPointerMove, (event)=>{
195
+ if (event.pointerType === 'touch') return;
196
+ if (!hasPointerMoveOpenedRef.current && !providerContext.isPointerInTransitRef.current) {
197
+ context.onTriggerEnter();
198
+ hasPointerMoveOpenedRef.current = true;
199
+ }
200
+ }),
201
+ onPointerLeave: $8wepK$composeEventHandlers(props.onPointerLeave, ()=>{
202
+ context.onTriggerLeave();
203
+ hasPointerMoveOpenedRef.current = false;
204
+ }),
205
+ onPointerDown: $8wepK$composeEventHandlers(props.onPointerDown, ()=>{
206
+ isPointerDownRef.current = true;
207
+ document.addEventListener('pointerup', handlePointerUp, {
208
+ once: true
209
+ });
210
+ }),
211
+ onFocus: $8wepK$composeEventHandlers(props.onFocus, ()=>{
212
+ if (!isPointerDownRef.current) context.onOpen();
213
+ }),
214
+ onBlur: $8wepK$composeEventHandlers(props.onBlur, context.onClose),
215
+ onClick: $8wepK$composeEventHandlers(props.onClick, (event)=>{
216
+ // keyboard click will occur under different conditions for different node
217
+ // types so we use `onClick` instead of `onKeyDown` to respect that
218
+ const isKeyboardClick = event.detail === 0;
219
+ if (isKeyboardClick) context.onClose();
220
+ })
221
+ })));
222
+ });
223
+ /*#__PURE__*/ Object.assign($a093c7e1ec25a057$export$8c610744efcf8a1d, {
224
+ displayName: $a093c7e1ec25a057$var$TRIGGER_NAME
225
+ });
226
+ /* -------------------------------------------------------------------------------------------------
227
+ * TooltipPortal
228
+ * -----------------------------------------------------------------------------------------------*/ const $a093c7e1ec25a057$var$PORTAL_NAME = 'TooltipPortal';
229
+ const [$a093c7e1ec25a057$var$PortalProvider, $a093c7e1ec25a057$var$usePortalContext] = $a093c7e1ec25a057$var$createTooltipContext($a093c7e1ec25a057$var$PORTAL_NAME, {
230
+ forceMount: undefined
231
+ });
232
+ const $a093c7e1ec25a057$export$7b36b8f925ab7497 = (props)=>{
233
+ const { __scopeTooltip: __scopeTooltip , forceMount: forceMount , children: children , container: container } = props;
234
+ const context = $a093c7e1ec25a057$var$useTooltipContext($a093c7e1ec25a057$var$PORTAL_NAME, __scopeTooltip);
235
+ return /*#__PURE__*/ $8wepK$createElement($a093c7e1ec25a057$var$PortalProvider, {
236
+ scope: __scopeTooltip,
237
+ forceMount: forceMount
238
+ }, /*#__PURE__*/ $8wepK$createElement($8wepK$Presence, {
239
+ present: forceMount || context.open
240
+ }, /*#__PURE__*/ $8wepK$createElement($8wepK$Portal, {
241
+ asChild: true,
242
+ container: container
243
+ }, children)));
244
+ };
245
+ /*#__PURE__*/ Object.assign($a093c7e1ec25a057$export$7b36b8f925ab7497, {
246
+ displayName: $a093c7e1ec25a057$var$PORTAL_NAME
247
+ });
248
+ /* -------------------------------------------------------------------------------------------------
249
+ * TooltipContent
250
+ * -----------------------------------------------------------------------------------------------*/ const $a093c7e1ec25a057$var$CONTENT_NAME = 'TooltipContent';
251
+ const $a093c7e1ec25a057$export$e9003e2be37ec060 = /*#__PURE__*/ $8wepK$forwardRef((props, forwardedRef)=>{
252
+ const portalContext = $a093c7e1ec25a057$var$usePortalContext($a093c7e1ec25a057$var$CONTENT_NAME, props.__scopeTooltip);
253
+ const { forceMount: forceMount = portalContext.forceMount , side: side = 'top' , ...contentProps } = props;
254
+ const context = $a093c7e1ec25a057$var$useTooltipContext($a093c7e1ec25a057$var$CONTENT_NAME, props.__scopeTooltip);
255
+ return /*#__PURE__*/ $8wepK$createElement($8wepK$Presence, {
256
+ present: forceMount || context.open
257
+ }, context.disableHoverableContent ? /*#__PURE__*/ $8wepK$createElement($a093c7e1ec25a057$var$TooltipContentImpl, $8wepK$babelruntimehelpersesmextends({
258
+ side: side
259
+ }, contentProps, {
260
+ ref: forwardedRef
261
+ })) : /*#__PURE__*/ $8wepK$createElement($a093c7e1ec25a057$var$TooltipContentHoverable, $8wepK$babelruntimehelpersesmextends({
262
+ side: side
263
+ }, contentProps, {
264
+ ref: forwardedRef
265
+ })));
266
+ });
267
+ const $a093c7e1ec25a057$var$TooltipContentHoverable = /*#__PURE__*/ $8wepK$forwardRef((props, forwardedRef)=>{
268
+ const context = $a093c7e1ec25a057$var$useTooltipContext($a093c7e1ec25a057$var$CONTENT_NAME, props.__scopeTooltip);
269
+ const providerContext = $a093c7e1ec25a057$var$useTooltipProviderContext($a093c7e1ec25a057$var$CONTENT_NAME, props.__scopeTooltip);
270
+ const ref = $8wepK$useRef(null);
271
+ const composedRefs = $8wepK$useComposedRefs(forwardedRef, ref);
272
+ const [pointerGraceArea, setPointerGraceArea] = $8wepK$useState(null);
273
+ const { trigger: trigger , onClose: onClose } = context;
274
+ const content = ref.current;
275
+ const { onPointerInTransitChange: onPointerInTransitChange } = providerContext;
276
+ const handleRemoveGraceArea = $8wepK$useCallback(()=>{
277
+ setPointerGraceArea(null);
278
+ onPointerInTransitChange(false);
279
+ }, [
280
+ onPointerInTransitChange
281
+ ]);
282
+ const handleCreateGraceArea = $8wepK$useCallback((event, hoverTarget)=>{
283
+ const currentTarget = event.currentTarget;
284
+ const exitPoint = {
285
+ x: event.clientX,
286
+ y: event.clientY
287
+ };
288
+ const exitSide = $a093c7e1ec25a057$var$getExitSideFromRect(exitPoint, currentTarget.getBoundingClientRect());
289
+ const bleed = exitSide === 'right' || exitSide === 'bottom' ? -5 : 5;
290
+ const isXAxis = exitSide === 'right' || exitSide === 'left';
291
+ const startPoint = isXAxis ? {
292
+ x: event.clientX + bleed,
293
+ y: event.clientY
294
+ } : {
295
+ x: event.clientX,
296
+ y: event.clientY + bleed
297
+ };
298
+ const hoverTargetPoints = $a093c7e1ec25a057$var$getPointsFromRect(hoverTarget.getBoundingClientRect());
299
+ const graceArea = $a093c7e1ec25a057$var$getHull([
300
+ startPoint,
301
+ ...hoverTargetPoints
302
+ ]);
303
+ setPointerGraceArea(graceArea);
304
+ onPointerInTransitChange(true);
305
+ }, [
306
+ onPointerInTransitChange
307
+ ]);
308
+ $8wepK$useEffect(()=>{
309
+ return ()=>handleRemoveGraceArea()
310
+ ;
311
+ }, [
312
+ handleRemoveGraceArea
313
+ ]);
314
+ $8wepK$useEffect(()=>{
315
+ if (trigger && content) {
316
+ const handleTriggerLeave = (event)=>handleCreateGraceArea(event, content)
317
+ ;
318
+ const handleContentLeave = (event)=>handleCreateGraceArea(event, trigger)
319
+ ;
320
+ trigger.addEventListener('pointerleave', handleTriggerLeave);
321
+ content.addEventListener('pointerleave', handleContentLeave);
322
+ return ()=>{
323
+ trigger.removeEventListener('pointerleave', handleTriggerLeave);
324
+ content.removeEventListener('pointerleave', handleContentLeave);
325
+ };
326
+ }
327
+ }, [
328
+ trigger,
329
+ content,
330
+ handleCreateGraceArea,
331
+ handleRemoveGraceArea
332
+ ]);
333
+ $8wepK$useEffect(()=>{
334
+ if (pointerGraceArea) {
335
+ const handleTrackPointerGrace = (event)=>{
336
+ const target = event.target;
337
+ const pointerPosition = {
338
+ x: event.clientX,
339
+ y: event.clientY
340
+ };
341
+ const hasEnteredTarget = (trigger === null || trigger === void 0 ? void 0 : trigger.contains(target)) || (content === null || content === void 0 ? void 0 : content.contains(target));
342
+ const isPointerOutsideGraceArea = !$a093c7e1ec25a057$var$isPointInPolygon(pointerPosition, pointerGraceArea);
343
+ if (hasEnteredTarget) handleRemoveGraceArea();
344
+ else if (isPointerOutsideGraceArea) {
345
+ handleRemoveGraceArea();
346
+ onClose();
347
+ }
348
+ };
349
+ document.addEventListener('pointermove', handleTrackPointerGrace);
350
+ return ()=>document.removeEventListener('pointermove', handleTrackPointerGrace)
351
+ ;
352
+ }
353
+ }, [
354
+ trigger,
355
+ content,
356
+ pointerGraceArea,
357
+ onClose,
358
+ handleRemoveGraceArea
359
+ ]);
360
+ return /*#__PURE__*/ $8wepK$createElement($a093c7e1ec25a057$var$TooltipContentImpl, $8wepK$babelruntimehelpersesmextends({}, props, {
361
+ ref: composedRefs
362
+ }));
363
+ });
364
+ const [$a093c7e1ec25a057$var$VisuallyHiddenContentContextProvider, $a093c7e1ec25a057$var$useVisuallyHiddenContentContext] = $a093c7e1ec25a057$var$createTooltipContext($a093c7e1ec25a057$var$TOOLTIP_NAME, {
365
+ isInside: false
366
+ });
367
+ const $a093c7e1ec25a057$var$TooltipContentImpl = /*#__PURE__*/ $8wepK$forwardRef((props, forwardedRef)=>{
368
+ const { __scopeTooltip: __scopeTooltip , children: children , 'aria-label': ariaLabel , onEscapeKeyDown: onEscapeKeyDown , onPointerDownOutside: onPointerDownOutside , ...contentProps } = props;
369
+ const context = $a093c7e1ec25a057$var$useTooltipContext($a093c7e1ec25a057$var$CONTENT_NAME, __scopeTooltip);
370
+ const popperScope = $a093c7e1ec25a057$var$usePopperScope(__scopeTooltip);
371
+ const { onClose: onClose } = context; // Close this tooltip if another one opens
372
+ $8wepK$useEffect(()=>{
373
+ document.addEventListener($a093c7e1ec25a057$var$TOOLTIP_OPEN, onClose);
374
+ return ()=>document.removeEventListener($a093c7e1ec25a057$var$TOOLTIP_OPEN, onClose)
375
+ ;
376
+ }, [
377
+ onClose
378
+ ]); // Close the tooltip if the trigger is scrolled
379
+ $8wepK$useEffect(()=>{
380
+ if (context.trigger) {
381
+ const handleScroll = (event)=>{
382
+ const target = event.target;
383
+ if (target !== null && target !== void 0 && target.contains(context.trigger)) onClose();
384
+ };
385
+ window.addEventListener('scroll', handleScroll, {
386
+ capture: true
387
+ });
388
+ return ()=>window.removeEventListener('scroll', handleScroll, {
389
+ capture: true
390
+ })
391
+ ;
392
+ }
393
+ }, [
394
+ context.trigger,
395
+ onClose
396
+ ]);
397
+ return /*#__PURE__*/ $8wepK$createElement($8wepK$DismissableLayer, {
398
+ asChild: true,
399
+ disableOutsidePointerEvents: false,
400
+ onEscapeKeyDown: onEscapeKeyDown,
401
+ onPointerDownOutside: onPointerDownOutside,
402
+ onFocusOutside: (event)=>event.preventDefault()
403
+ ,
404
+ onDismiss: onClose
405
+ }, /*#__PURE__*/ $8wepK$createElement($8wepK$Content, $8wepK$babelruntimehelpersesmextends({
406
+ "data-state": context.stateAttribute
407
+ }, popperScope, contentProps, {
408
+ ref: forwardedRef,
409
+ style: {
410
+ ...contentProps.style,
411
+ // re-namespace exposed content custom property
412
+ ['--radix-tooltip-content-transform-origin']: 'var(--radix-popper-transform-origin)'
413
+ }
414
+ }), /*#__PURE__*/ $8wepK$createElement($8wepK$Slottable, null, children), /*#__PURE__*/ $8wepK$createElement($a093c7e1ec25a057$var$VisuallyHiddenContentContextProvider, {
415
+ scope: __scopeTooltip,
416
+ isInside: true
417
+ }, /*#__PURE__*/ $8wepK$createElement($8wepK$Root1, {
418
+ id: context.contentId,
419
+ role: "tooltip"
420
+ }, ariaLabel || children))));
421
+ });
422
+ /*#__PURE__*/ Object.assign($a093c7e1ec25a057$export$e9003e2be37ec060, {
423
+ displayName: $a093c7e1ec25a057$var$CONTENT_NAME
424
+ });
425
+ /* -------------------------------------------------------------------------------------------------
426
+ * TooltipArrow
427
+ * -----------------------------------------------------------------------------------------------*/ const $a093c7e1ec25a057$var$ARROW_NAME = 'TooltipArrow';
428
+ const $a093c7e1ec25a057$export$c27ee0ad710f7559 = /*#__PURE__*/ $8wepK$forwardRef((props, forwardedRef)=>{
429
+ const { __scopeTooltip: __scopeTooltip , ...arrowProps } = props;
430
+ const popperScope = $a093c7e1ec25a057$var$usePopperScope(__scopeTooltip);
431
+ const visuallyHiddenContentContext = $a093c7e1ec25a057$var$useVisuallyHiddenContentContext($a093c7e1ec25a057$var$ARROW_NAME, __scopeTooltip); // if the arrow is inside the `VisuallyHidden`, we don't want to render it all to
432
+ // prevent issues in positioning the arrow due to the duplicate
433
+ return visuallyHiddenContentContext.isInside ? null : /*#__PURE__*/ $8wepK$createElement($8wepK$Arrow, $8wepK$babelruntimehelpersesmextends({}, popperScope, arrowProps, {
434
+ ref: forwardedRef
435
+ }));
436
+ });
437
+ /*#__PURE__*/ Object.assign($a093c7e1ec25a057$export$c27ee0ad710f7559, {
438
+ displayName: $a093c7e1ec25a057$var$ARROW_NAME
439
+ });
440
+ /* -----------------------------------------------------------------------------------------------*/ function $a093c7e1ec25a057$var$getExitSideFromRect(point, rect) {
441
+ const top = Math.abs(rect.top - point.y);
442
+ const bottom = Math.abs(rect.bottom - point.y);
443
+ const right = Math.abs(rect.right - point.x);
444
+ const left = Math.abs(rect.left - point.x);
445
+ switch(Math.min(top, bottom, right, left)){
446
+ case left:
447
+ return 'left';
448
+ case right:
449
+ return 'right';
450
+ case top:
451
+ return 'top';
452
+ case bottom:
453
+ return 'bottom';
454
+ default:
455
+ return null;
456
+ }
457
+ }
458
+ function $a093c7e1ec25a057$var$getPointsFromRect(rect) {
459
+ const { top: top , right: right , bottom: bottom , left: left } = rect;
460
+ return [
461
+ {
462
+ x: left,
463
+ y: top
464
+ },
465
+ {
466
+ x: right,
467
+ y: top
468
+ },
469
+ {
470
+ x: right,
471
+ y: bottom
472
+ },
473
+ {
474
+ x: left,
475
+ y: bottom
476
+ }
477
+ ];
478
+ } // Determine if a point is inside of a polygon.
479
+ // Based on https://github.com/substack/point-in-polygon
480
+ function $a093c7e1ec25a057$var$isPointInPolygon(point, polygon) {
481
+ const { x: x , y: y } = point;
482
+ let inside = false;
483
+ for(let i = 0, j = polygon.length - 1; i < polygon.length; j = i++){
484
+ const xi = polygon[i].x;
485
+ const yi = polygon[i].y;
486
+ const xj = polygon[j].x;
487
+ const yj = polygon[j].y; // prettier-ignore
488
+ const intersect = yi > y !== yj > y && x < (xj - xi) * (y - yi) / (yj - yi) + xi;
489
+ if (intersect) inside = !inside;
490
+ }
491
+ return inside;
492
+ } // Returns a new array of points representing the convex hull of the given set of points.
493
+ // https://www.nayuki.io/page/convex-hull-algorithm
494
+ function $a093c7e1ec25a057$var$getHull(points) {
495
+ const newPoints = points.slice();
496
+ newPoints.sort((a, b)=>{
497
+ if (a.x < b.x) return -1;
498
+ else if (a.x > b.x) return 1;
499
+ else if (a.y < b.y) return -1;
500
+ else if (a.y > b.y) return 1;
501
+ else return 0;
502
+ });
503
+ return $a093c7e1ec25a057$var$getHullPresorted(newPoints);
504
+ } // Returns the convex hull, assuming that each points[i] <= points[i + 1]. Runs in O(n) time.
505
+ function $a093c7e1ec25a057$var$getHullPresorted(points) {
506
+ if (points.length <= 1) return points.slice();
507
+ const upperHull = [];
508
+ for(let i = 0; i < points.length; i++){
509
+ const p = points[i];
510
+ while(upperHull.length >= 2){
511
+ const q = upperHull[upperHull.length - 1];
512
+ const r = upperHull[upperHull.length - 2];
513
+ if ((q.x - r.x) * (p.y - r.y) >= (q.y - r.y) * (p.x - r.x)) upperHull.pop();
514
+ else break;
515
+ }
516
+ upperHull.push(p);
517
+ }
518
+ upperHull.pop();
519
+ const lowerHull = [];
520
+ for(let i1 = points.length - 1; i1 >= 0; i1--){
521
+ const p = points[i1];
522
+ while(lowerHull.length >= 2){
523
+ const q = lowerHull[lowerHull.length - 1];
524
+ const r = lowerHull[lowerHull.length - 2];
525
+ if ((q.x - r.x) * (p.y - r.y) >= (q.y - r.y) * (p.x - r.x)) lowerHull.pop();
526
+ else break;
527
+ }
528
+ lowerHull.push(p);
529
+ }
530
+ lowerHull.pop();
531
+ if (upperHull.length === 1 && lowerHull.length === 1 && upperHull[0].x === lowerHull[0].x && upperHull[0].y === lowerHull[0].y) return upperHull;
532
+ else return upperHull.concat(lowerHull);
533
+ }
534
+ const $a093c7e1ec25a057$export$2881499e37b75b9a = $a093c7e1ec25a057$export$f78649fb9ca566b8;
535
+ const $a093c7e1ec25a057$export$be92b6f5f03c0fe9 = $a093c7e1ec25a057$export$28c660c63b792dea;
536
+ const $a093c7e1ec25a057$export$41fb9f06171c75f4 = $a093c7e1ec25a057$export$8c610744efcf8a1d;
537
+ const $a093c7e1ec25a057$export$602eac185826482c = $a093c7e1ec25a057$export$7b36b8f925ab7497;
538
+ const $a093c7e1ec25a057$export$7c6e2c02157bb7d2 = $a093c7e1ec25a057$export$e9003e2be37ec060;
539
+ const $a093c7e1ec25a057$export$21b07c8f274aebd5 = $a093c7e1ec25a057$export$c27ee0ad710f7559;
540
+
541
+
542
+
543
+
544
+ export {$a093c7e1ec25a057$export$1c540a2224f0d865 as createTooltipScope, $a093c7e1ec25a057$export$f78649fb9ca566b8 as TooltipProvider, $a093c7e1ec25a057$export$28c660c63b792dea as Tooltip, $a093c7e1ec25a057$export$8c610744efcf8a1d as TooltipTrigger, $a093c7e1ec25a057$export$7b36b8f925ab7497 as TooltipPortal, $a093c7e1ec25a057$export$e9003e2be37ec060 as TooltipContent, $a093c7e1ec25a057$export$c27ee0ad710f7559 as TooltipArrow, $a093c7e1ec25a057$export$2881499e37b75b9a as Provider, $a093c7e1ec25a057$export$be92b6f5f03c0fe9 as Root, $a093c7e1ec25a057$export$41fb9f06171c75f4 as Trigger, $a093c7e1ec25a057$export$602eac185826482c as Portal, $a093c7e1ec25a057$export$7c6e2c02157bb7d2 as Content, $a093c7e1ec25a057$export$21b07c8f274aebd5 as Arrow};
2
545
  //# sourceMappingURL=index.module.js.map