@radix-ui/react-tooltip 1.0.8-rc.9 → 1.1.0-rc.1

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