@radix-ui/react-tooltip 0.1.8-rc.45 → 0.1.8-rc.48
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.d.ts +10 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +263 -71
- package/dist/index.js.map +1 -1
- package/dist/index.module.js +248 -56
- package/dist/index.module.js.map +1 -1
- package/package.json +13 -13
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"mappings":"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","sources":["packages/react/tooltip/src/index.ts","packages/react/tooltip/src/Tooltip.tsx"],"sourcesContent":["export * from './Tooltip';\n","import * as React from 'react';\nimport { composeEventHandlers } from '@radix-ui/primitive';\nimport { useComposedRefs } from '@radix-ui/react-compose-refs';\nimport { createContextScope } from '@radix-ui/react-context';\nimport { DismissableLayer } from '@radix-ui/react-dismissable-layer';\nimport { useId } from '@radix-ui/react-id';\nimport * as PopperPrimitive from '@radix-ui/react-popper';\nimport { createPopperScope } from '@radix-ui/react-popper';\nimport { Portal as PortalPrimitive } from '@radix-ui/react-portal';\nimport { Presence } from '@radix-ui/react-presence';\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slottable } from '@radix-ui/react-slot';\nimport { useControllableState } from '@radix-ui/react-use-controllable-state';\nimport * as VisuallyHiddenPrimitive from '@radix-ui/react-visually-hidden';\n\nimport type * as Radix from '@radix-ui/react-primitive';\nimport type { Scope } from '@radix-ui/react-context';\n\ntype ScopedProps<P = {}> = P & { __scopeTooltip?: Scope };\nconst [createTooltipContext, createTooltipScope] = createContextScope('Tooltip', [\n createPopperScope,\n]);\nconst usePopperScope = createPopperScope();\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipProvider\n * -----------------------------------------------------------------------------------------------*/\n\nconst PROVIDER_NAME = 'TooltipProvider';\nconst DEFAULT_DELAY_DURATION = 700;\nconst TOOLTIP_OPEN = 'tooltip.open';\n\ntype TooltipProviderContextValue = {\n isOpenDelayed: boolean;\n delayDuration: number;\n onOpen(): void;\n onClose(): void;\n};\n\nconst [TooltipProviderContextProvider, useTooltipProviderContext] =\n createTooltipContext<TooltipProviderContextValue>(PROVIDER_NAME, {\n isOpenDelayed: true,\n delayDuration: DEFAULT_DELAY_DURATION,\n onOpen: () => {},\n onClose: () => {},\n });\n\ninterface TooltipProviderProps {\n children: React.ReactNode;\n /**\n * The duration from when the pointer enters the trigger until the tooltip gets opened.\n * @defaultValue 700\n */\n delayDuration?: number;\n /**\n * How much time a user has to enter another trigger without incurring a delay again.\n * @defaultValue 300\n */\n skipDelayDuration?: number;\n}\n\nconst TooltipProvider: React.FC<TooltipProviderProps> = (\n props: ScopedProps<TooltipProviderProps>\n) => {\n const {\n __scopeTooltip,\n delayDuration = DEFAULT_DELAY_DURATION,\n skipDelayDuration = 300,\n children,\n } = props;\n const [isOpenDelayed, setIsOpenDelayed] = React.useState(true);\n const skipDelayTimerRef = React.useRef(0);\n\n React.useEffect(() => {\n const skipDelayTimer = skipDelayTimerRef.current;\n return () => window.clearTimeout(skipDelayTimer);\n }, []);\n\n return (\n <TooltipProviderContextProvider\n scope={__scopeTooltip}\n isOpenDelayed={isOpenDelayed}\n delayDuration={delayDuration}\n onOpen={React.useCallback(() => {\n window.clearTimeout(skipDelayTimerRef.current);\n setIsOpenDelayed(false);\n }, [])}\n onClose={React.useCallback(() => {\n window.clearTimeout(skipDelayTimerRef.current);\n skipDelayTimerRef.current = window.setTimeout(\n () => setIsOpenDelayed(true),\n skipDelayDuration\n );\n }, [skipDelayDuration])}\n >\n {children}\n </TooltipProviderContextProvider>\n );\n};\n\nTooltipProvider.displayName = PROVIDER_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * Tooltip\n * -----------------------------------------------------------------------------------------------*/\n\nconst TOOLTIP_NAME = 'Tooltip';\n\ntype TooltipContextValue = {\n contentId: string;\n open: boolean;\n stateAttribute: 'closed' | 'delayed-open' | 'instant-open';\n trigger: TooltipTriggerElement | null;\n onTriggerChange(trigger: TooltipTriggerElement | null): void;\n onTriggerEnter(): void;\n onOpen(): void;\n onClose(): void;\n};\n\nconst [TooltipContextProvider, useTooltipContext] =\n createTooltipContext<TooltipContextValue>(TOOLTIP_NAME);\n\ninterface TooltipProps {\n children?: React.ReactNode;\n open?: boolean;\n defaultOpen?: boolean;\n onOpenChange?: (open: boolean) => void;\n\n /**\n * The duration from when the pointer enters the trigger until the tooltip gets opened. This will\n * override the prop with the same name passed to Provider.\n * @defaultValue 700\n */\n delayDuration?: number;\n}\n\nconst Tooltip: React.FC<TooltipProps> = (props: ScopedProps<TooltipProps>) => {\n const {\n __scopeTooltip,\n children,\n open: openProp,\n defaultOpen = false,\n onOpenChange,\n delayDuration: delayDurationProp,\n } = props;\n const context = useTooltipProviderContext(TOOLTIP_NAME, __scopeTooltip);\n const popperScope = usePopperScope(__scopeTooltip);\n const [trigger, setTrigger] = React.useState<HTMLButtonElement | null>(null);\n const contentId = useId();\n const openTimerRef = React.useRef(0);\n const delayDuration = delayDurationProp ?? context.delayDuration;\n const wasOpenDelayedRef = React.useRef(false);\n const { onOpen, onClose } = context;\n const [open = false, setOpen] = useControllableState({\n prop: openProp,\n defaultProp: defaultOpen,\n onChange: (open) => {\n if (open) {\n // we dispatch here so `TooltipProvider` isn't required to\n // ensure other tooltips are aware of this one opening.\n //\n // as `onChange` is called within a lifecycle method we\n // avoid dispatching via `dispatchDiscreteCustomEvent`.\n document.dispatchEvent(new CustomEvent(TOOLTIP_OPEN));\n onOpen();\n }\n onOpenChange?.(open);\n },\n });\n const stateAttribute = React.useMemo(() => {\n return open ? (wasOpenDelayedRef.current ? 'delayed-open' : 'instant-open') : 'closed';\n }, [open]);\n\n const handleOpen = React.useCallback(() => {\n window.clearTimeout(openTimerRef.current);\n wasOpenDelayedRef.current = false;\n setOpen(true);\n }, [setOpen]);\n\n const handleDelayedOpen = React.useCallback(() => {\n window.clearTimeout(openTimerRef.current);\n openTimerRef.current = window.setTimeout(() => {\n wasOpenDelayedRef.current = true;\n setOpen(true);\n }, delayDuration);\n }, [delayDuration, setOpen]);\n\n React.useEffect(() => {\n return () => window.clearTimeout(openTimerRef.current);\n }, []);\n\n return (\n <PopperPrimitive.Root {...popperScope}>\n <TooltipContextProvider\n scope={__scopeTooltip}\n contentId={contentId}\n open={open}\n stateAttribute={stateAttribute}\n trigger={trigger}\n onTriggerChange={setTrigger}\n onTriggerEnter={React.useCallback(() => {\n if (context.isOpenDelayed) handleDelayedOpen();\n else handleOpen();\n }, [context.isOpenDelayed, handleDelayedOpen, handleOpen])}\n onOpen={React.useCallback(handleOpen, [handleOpen])}\n onClose={React.useCallback(() => {\n window.clearTimeout(openTimerRef.current);\n setOpen(false);\n onClose();\n }, [setOpen, onClose])}\n >\n {children}\n </TooltipContextProvider>\n </PopperPrimitive.Root>\n );\n};\n\nTooltip.displayName = TOOLTIP_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipTrigger\n * -----------------------------------------------------------------------------------------------*/\n\nconst TRIGGER_NAME = 'TooltipTrigger';\n\ntype TooltipTriggerElement = React.ElementRef<typeof Primitive.button>;\ntype PrimitiveButtonProps = Radix.ComponentPropsWithoutRef<typeof Primitive.button>;\ninterface TooltipTriggerProps extends PrimitiveButtonProps {}\n\nconst TooltipTrigger = React.forwardRef<TooltipTriggerElement, TooltipTriggerProps>(\n (props: ScopedProps<TooltipTriggerProps>, forwardedRef) => {\n const { __scopeTooltip, ...triggerProps } = props;\n const context = useTooltipContext(TRIGGER_NAME, __scopeTooltip);\n const popperScope = usePopperScope(__scopeTooltip);\n const composedTriggerRef = useComposedRefs(forwardedRef, context.onTriggerChange);\n const isPointerDownRef = React.useRef(false);\n const handlePointerUp = React.useCallback(() => (isPointerDownRef.current = false), []);\n\n React.useEffect(() => {\n return () => document.removeEventListener('pointerup', handlePointerUp);\n }, [handlePointerUp]);\n\n return (\n <PopperPrimitive.Anchor asChild {...popperScope}>\n <Primitive.button\n // We purposefully avoid adding `type=button` here because tooltip triggers are also\n // commonly anchors and the anchor `type` attribute signifies MIME type.\n aria-describedby={context.open ? context.contentId : undefined}\n data-state={context.stateAttribute}\n {...triggerProps}\n ref={composedTriggerRef}\n onPointerEnter={composeEventHandlers(props.onPointerEnter, (event) => {\n if (event.pointerType !== 'touch') context.onTriggerEnter();\n })}\n onPointerLeave={composeEventHandlers(props.onPointerLeave, context.onClose)}\n onPointerDown={composeEventHandlers(props.onPointerDown, () => {\n isPointerDownRef.current = true;\n document.addEventListener('pointerup', handlePointerUp, { once: true });\n })}\n onFocus={composeEventHandlers(props.onFocus, () => {\n if (!isPointerDownRef.current) context.onOpen();\n })}\n onBlur={composeEventHandlers(props.onBlur, context.onClose)}\n onClick={composeEventHandlers(props.onClick, (event) => {\n // keyboard click will occur under different conditions for different node\n // types so we use `onClick` instead of `onKeyDown` to respect that\n const isKeyboardClick = event.detail === 0;\n if (isKeyboardClick) context.onClose();\n })}\n />\n </PopperPrimitive.Anchor>\n );\n }\n);\n\nTooltipTrigger.displayName = TRIGGER_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipPortal\n * -----------------------------------------------------------------------------------------------*/\n\nconst PORTAL_NAME = 'TooltipPortal';\n\ntype PortalContextValue = { forceMount?: true };\nconst [PortalProvider, usePortalContext] = createTooltipContext<PortalContextValue>(PORTAL_NAME, {\n forceMount: undefined,\n});\n\ntype PortalProps = React.ComponentPropsWithoutRef<typeof PortalPrimitive>;\ninterface TooltipPortalProps extends Omit<PortalProps, 'asChild'> {\n children?: React.ReactNode;\n /**\n * Used to force mounting when more control is needed. Useful when\n * controlling animation with React animation libraries.\n */\n forceMount?: true;\n}\n\nconst TooltipPortal: React.FC<TooltipPortalProps> = (props: ScopedProps<TooltipPortalProps>) => {\n const { __scopeTooltip, forceMount, children, container } = props;\n const context = useTooltipContext(PORTAL_NAME, __scopeTooltip);\n return (\n <PortalProvider scope={__scopeTooltip} forceMount={forceMount}>\n <Presence present={forceMount || context.open}>\n <PortalPrimitive asChild container={container}>\n {children}\n </PortalPrimitive>\n </Presence>\n </PortalProvider>\n );\n};\n\nTooltipPortal.displayName = PORTAL_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipContent\n * -----------------------------------------------------------------------------------------------*/\n\nconst CONTENT_NAME = 'TooltipContent';\n\ntype TooltipContentElement = TooltipContentImplElement;\ninterface TooltipContentProps extends TooltipContentImplProps {\n /**\n * Used to force mounting when more control is needed. Useful when\n * controlling animation with React animation libraries.\n */\n forceMount?: true;\n}\n\nconst TooltipContent = React.forwardRef<TooltipContentElement, TooltipContentProps>(\n (props: ScopedProps<TooltipContentProps>, forwardedRef) => {\n const portalContext = usePortalContext(CONTENT_NAME, props.__scopeTooltip);\n const { forceMount = portalContext.forceMount, ...contentProps } = props;\n const context = useTooltipContext(CONTENT_NAME, props.__scopeTooltip);\n return (\n <Presence present={forceMount || context.open}>\n <TooltipContentImpl ref={forwardedRef} {...contentProps} />\n </Presence>\n );\n }\n);\n\ntype TooltipContentImplElement = React.ElementRef<typeof PopperPrimitive.Content>;\ntype DismissableLayerProps = Radix.ComponentPropsWithoutRef<typeof DismissableLayer>;\ntype PopperContentProps = Radix.ComponentPropsWithoutRef<typeof PopperPrimitive.Content>;\ninterface TooltipContentImplProps extends PopperContentProps {\n /**\n * A more descriptive label for accessibility purpose\n */\n 'aria-label'?: string;\n\n /**\n * Event handler called when the escape key is down.\n * Can be prevented.\n */\n onEscapeKeyDown?: DismissableLayerProps['onEscapeKeyDown'];\n /**\n * Event handler called when the a `pointerdown` event happens outside of the `Tooltip`.\n * Can be prevented.\n */\n onPointerDownOutside?: DismissableLayerProps['onPointerDownOutside'];\n}\n\nconst TooltipContentImpl = React.forwardRef<TooltipContentImplElement, TooltipContentImplProps>(\n (props: ScopedProps<TooltipContentImplProps>, forwardedRef) => {\n const {\n __scopeTooltip,\n children,\n 'aria-label': ariaLabel,\n onEscapeKeyDown,\n onPointerDownOutside,\n ...contentProps\n } = props;\n const context = useTooltipContext(CONTENT_NAME, __scopeTooltip);\n const popperScope = usePopperScope(__scopeTooltip);\n const { onClose } = context;\n\n // Close this tooltip if another one opens\n React.useEffect(() => {\n document.addEventListener(TOOLTIP_OPEN, onClose);\n return () => document.removeEventListener(TOOLTIP_OPEN, onClose);\n }, [onClose]);\n\n // Close the tooltip if the trigger is scrolled\n React.useEffect(() => {\n if (context.trigger) {\n const handleScroll = (event: Event) => {\n const target = event.target as HTMLElement;\n if (target?.contains(context.trigger)) onClose();\n };\n window.addEventListener('scroll', handleScroll, { capture: true });\n return () => window.removeEventListener('scroll', handleScroll, { capture: true });\n }\n }, [context.trigger, onClose]);\n\n return (\n <DismissableLayer\n asChild\n disableOutsidePointerEvents={false}\n onEscapeKeyDown={onEscapeKeyDown}\n onPointerDownOutside={onPointerDownOutside}\n onFocusOutside={(event) => event.preventDefault()}\n onDismiss={onClose}\n >\n <PopperPrimitive.Content\n data-state={context.stateAttribute}\n {...popperScope}\n {...contentProps}\n ref={forwardedRef}\n style={{\n ...contentProps.style,\n // re-namespace exposed content custom property\n ['--radix-tooltip-content-transform-origin' as any]:\n 'var(--radix-popper-transform-origin)',\n }}\n >\n <Slottable>{children}</Slottable>\n <VisuallyHiddenPrimitive.Root id={context.contentId} role=\"tooltip\">\n {ariaLabel || children}\n </VisuallyHiddenPrimitive.Root>\n </PopperPrimitive.Content>\n </DismissableLayer>\n );\n }\n);\n\nTooltipContent.displayName = CONTENT_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipArrow\n * -----------------------------------------------------------------------------------------------*/\n\nconst ARROW_NAME = 'TooltipArrow';\n\ntype TooltipArrowElement = React.ElementRef<typeof PopperPrimitive.Arrow>;\ntype PopperArrowProps = Radix.ComponentPropsWithoutRef<typeof PopperPrimitive.Arrow>;\ninterface TooltipArrowProps extends PopperArrowProps {}\n\nconst TooltipArrow = React.forwardRef<TooltipArrowElement, TooltipArrowProps>(\n (props: ScopedProps<TooltipArrowProps>, forwardedRef) => {\n const { __scopeTooltip, ...arrowProps } = props;\n const popperScope = usePopperScope(__scopeTooltip);\n return <PopperPrimitive.Arrow {...popperScope} {...arrowProps} ref={forwardedRef} />;\n }\n);\n\nTooltipArrow.displayName = ARROW_NAME;\n\n/* -----------------------------------------------------------------------------------------------*/\n\nconst Provider = TooltipProvider;\nconst Root = Tooltip;\nconst Trigger = TooltipTrigger;\nconst Portal = TooltipPortal;\nconst Content = TooltipContent;\nconst Arrow = TooltipArrow;\n\nexport {\n createTooltipScope,\n //\n TooltipProvider,\n Tooltip,\n TooltipTrigger,\n TooltipPortal,\n TooltipContent,\n TooltipArrow,\n //\n Provider,\n Root,\n Trigger,\n Portal,\n Content,\n Arrow,\n};\nexport type {\n TooltipProps,\n TooltipTriggerProps,\n TooltipPortalProps,\n TooltipContentProps,\n TooltipArrowProps,\n};\n"],"names":["React","composeEventHandlers","useComposedRefs","createContextScope","DismissableLayer","useId","PopperPrimitive","createPopperScope","Portal","PortalPrimitive","Presence","Primitive","Slottable","useControllableState","VisuallyHiddenPrimitive","createTooltipContext","createTooltipScope","usePopperScope","PROVIDER_NAME","DEFAULT_DELAY_DURATION","TOOLTIP_OPEN","TooltipProviderContextProvider","useTooltipProviderContext","isOpenDelayed","delayDuration","onOpen","onClose","TooltipProvider","props","__scopeTooltip","skipDelayDuration","children","setIsOpenDelayed","useState","skipDelayTimerRef","useRef","useEffect","skipDelayTimer","current","window","clearTimeout","useCallback","setTimeout","TOOLTIP_NAME","TooltipContextProvider","useTooltipContext","Tooltip","open","openProp","defaultOpen","onOpenChange","delayDurationProp","context","popperScope","trigger","setTrigger","contentId","openTimerRef","wasOpenDelayedRef","setOpen","prop","defaultProp","onChange","document","dispatchEvent","CustomEvent","stateAttribute","useMemo","handleOpen","handleDelayedOpen","TRIGGER_NAME","TooltipTrigger","forwardRef","forwardedRef","triggerProps","composedTriggerRef","onTriggerChange","isPointerDownRef","handlePointerUp","removeEventListener","undefined","onPointerEnter","event","pointerType","onTriggerEnter","onPointerLeave","onPointerDown","addEventListener","once","onFocus","onBlur","onClick","isKeyboardClick","detail","PORTAL_NAME","PortalProvider","usePortalContext","forceMount","TooltipPortal","container","CONTENT_NAME","TooltipContent","portalContext","contentProps","TooltipContentImpl","ariaLabel","onEscapeKeyDown","onPointerDownOutside","handleScroll","target","contains","capture","preventDefault","style","ARROW_NAME","TooltipArrow","arrowProps","Provider","Root","Trigger","Content","Arrow"],"version":3,"file":"index.js.map"}
|
|
1
|
+
{"mappings":"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","sources":["packages/react/tooltip/src/index.ts","packages/react/tooltip/src/Tooltip.tsx"],"sourcesContent":["export {\n createTooltipScope,\n //\n TooltipProvider,\n Tooltip,\n TooltipTrigger,\n TooltipPortal,\n TooltipContent,\n TooltipArrow,\n //\n Provider,\n Root,\n Trigger,\n Portal,\n Content,\n Arrow,\n} from './Tooltip';\nexport type {\n TooltipProps,\n TooltipTriggerProps,\n TooltipPortalProps,\n TooltipContentProps,\n TooltipArrowProps,\n} from './Tooltip';\n","import * as React from 'react';\nimport { composeEventHandlers } from '@radix-ui/primitive';\nimport { useComposedRefs } from '@radix-ui/react-compose-refs';\nimport { createContextScope } from '@radix-ui/react-context';\nimport { DismissableLayer } from '@radix-ui/react-dismissable-layer';\nimport { useId } from '@radix-ui/react-id';\nimport * as PopperPrimitive from '@radix-ui/react-popper';\nimport { createPopperScope } from '@radix-ui/react-popper';\nimport { Portal as PortalPrimitive } from '@radix-ui/react-portal';\nimport { Presence } from '@radix-ui/react-presence';\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slottable } from '@radix-ui/react-slot';\nimport { useControllableState } from '@radix-ui/react-use-controllable-state';\nimport * as VisuallyHiddenPrimitive from '@radix-ui/react-visually-hidden';\n\nimport type * as Radix from '@radix-ui/react-primitive';\nimport type { Scope } from '@radix-ui/react-context';\n\ntype ScopedProps<P = {}> = P & { __scopeTooltip?: Scope };\nconst [createTooltipContext, createTooltipScope] = createContextScope('Tooltip', [\n createPopperScope,\n]);\nconst usePopperScope = createPopperScope();\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipProvider\n * -----------------------------------------------------------------------------------------------*/\n\nconst PROVIDER_NAME = 'TooltipProvider';\nconst DEFAULT_DELAY_DURATION = 700;\nconst TOOLTIP_OPEN = 'tooltip.open';\n\ntype TooltipProviderContextValue = {\n isOpenDelayed: boolean;\n delayDuration: number;\n onOpen(): void;\n onClose(): void;\n onPointerInTransitChange(inTransit: boolean): void;\n isPointerInTransitRef: React.MutableRefObject<boolean>;\n disableHoverableContent: boolean;\n};\n\nconst [TooltipProviderContextProvider, useTooltipProviderContext] =\n createTooltipContext<TooltipProviderContextValue>(PROVIDER_NAME);\n\ninterface TooltipProviderProps {\n children: React.ReactNode;\n /**\n * The duration from when the pointer enters the trigger until the tooltip gets opened.\n * @defaultValue 700\n */\n delayDuration?: number;\n /**\n * How much time a user has to enter another trigger without incurring a delay again.\n * @defaultValue 300\n */\n skipDelayDuration?: number;\n /**\n * When `true`, trying to hover the content will result in the tooltip closing as the pointer leaves the trigger.\n * @defaultValue false\n */\n disableHoverableContent?: boolean;\n}\n\nconst TooltipProvider: React.FC<TooltipProviderProps> = (\n props: ScopedProps<TooltipProviderProps>\n) => {\n const {\n __scopeTooltip,\n delayDuration = DEFAULT_DELAY_DURATION,\n skipDelayDuration = 300,\n disableHoverableContent = false,\n children,\n } = props;\n const [isOpenDelayed, setIsOpenDelayed] = React.useState(true);\n const isPointerInTransitRef = React.useRef(false);\n const skipDelayTimerRef = React.useRef(0);\n\n React.useEffect(() => {\n const skipDelayTimer = skipDelayTimerRef.current;\n return () => window.clearTimeout(skipDelayTimer);\n }, []);\n\n return (\n <TooltipProviderContextProvider\n scope={__scopeTooltip}\n isOpenDelayed={isOpenDelayed}\n delayDuration={delayDuration}\n onOpen={React.useCallback(() => {\n window.clearTimeout(skipDelayTimerRef.current);\n setIsOpenDelayed(false);\n }, [])}\n onClose={React.useCallback(() => {\n window.clearTimeout(skipDelayTimerRef.current);\n skipDelayTimerRef.current = window.setTimeout(\n () => setIsOpenDelayed(true),\n skipDelayDuration\n );\n }, [skipDelayDuration])}\n isPointerInTransitRef={isPointerInTransitRef}\n onPointerInTransitChange={React.useCallback((inTransit: boolean) => {\n isPointerInTransitRef.current = inTransit;\n }, [])}\n disableHoverableContent={disableHoverableContent}\n >\n {children}\n </TooltipProviderContextProvider>\n );\n};\n\nTooltipProvider.displayName = PROVIDER_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * Tooltip\n * -----------------------------------------------------------------------------------------------*/\n\nconst TOOLTIP_NAME = 'Tooltip';\n\ntype TooltipContextValue = {\n contentId: string;\n open: boolean;\n stateAttribute: 'closed' | 'delayed-open' | 'instant-open';\n trigger: TooltipTriggerElement | null;\n onTriggerChange(trigger: TooltipTriggerElement | null): void;\n onTriggerEnter(): void;\n onTriggerLeave(): void;\n onOpen(): void;\n onClose(): void;\n disableHoverableContent: boolean;\n};\n\nconst [TooltipContextProvider, useTooltipContext] =\n createTooltipContext<TooltipContextValue>(TOOLTIP_NAME);\n\ninterface TooltipProps {\n children?: React.ReactNode;\n open?: boolean;\n defaultOpen?: boolean;\n onOpenChange?: (open: boolean) => void;\n /**\n * The duration from when the pointer enters the trigger until the tooltip gets opened. This will\n * override the prop with the same name passed to Provider.\n * @defaultValue 700\n */\n delayDuration?: number;\n /**\n * When `true`, trying to hover the content will result in the tooltip closing as the pointer leaves the trigger.\n * @defaultValue false\n */\n disableHoverableContent?: boolean;\n}\n\nconst Tooltip: React.FC<TooltipProps> = (props: ScopedProps<TooltipProps>) => {\n const {\n __scopeTooltip,\n children,\n open: openProp,\n defaultOpen = false,\n onOpenChange,\n disableHoverableContent: disableHoverableContentProp,\n delayDuration: delayDurationProp,\n } = props;\n const providerContext = useTooltipProviderContext(TOOLTIP_NAME, props.__scopeTooltip);\n const popperScope = usePopperScope(__scopeTooltip);\n const [trigger, setTrigger] = React.useState<HTMLButtonElement | null>(null);\n const contentId = useId();\n const openTimerRef = React.useRef(0);\n const disableHoverableContent =\n disableHoverableContentProp ?? providerContext.disableHoverableContent;\n const delayDuration = delayDurationProp ?? providerContext.delayDuration;\n const wasOpenDelayedRef = React.useRef(false);\n const [open = false, setOpen] = useControllableState({\n prop: openProp,\n defaultProp: defaultOpen,\n onChange: (open) => {\n if (open) {\n providerContext.onOpen();\n\n // as `onChange` is called within a lifecycle method we\n // avoid dispatching via `dispatchDiscreteCustomEvent`.\n document.dispatchEvent(new CustomEvent(TOOLTIP_OPEN));\n } else {\n providerContext.onClose();\n }\n onOpenChange?.(open);\n },\n });\n const stateAttribute = React.useMemo(() => {\n return open ? (wasOpenDelayedRef.current ? 'delayed-open' : 'instant-open') : 'closed';\n }, [open]);\n\n const handleOpen = React.useCallback(() => {\n window.clearTimeout(openTimerRef.current);\n wasOpenDelayedRef.current = false;\n setOpen(true);\n }, [setOpen]);\n\n const handleClose = React.useCallback(() => {\n window.clearTimeout(openTimerRef.current);\n setOpen(false);\n }, [setOpen]);\n\n const handleDelayedOpen = React.useCallback(() => {\n window.clearTimeout(openTimerRef.current);\n openTimerRef.current = window.setTimeout(() => {\n wasOpenDelayedRef.current = true;\n setOpen(true);\n }, delayDuration);\n }, [delayDuration, setOpen]);\n\n React.useEffect(() => {\n return () => window.clearTimeout(openTimerRef.current);\n }, []);\n\n return (\n <PopperPrimitive.Root {...popperScope}>\n <TooltipContextProvider\n scope={__scopeTooltip}\n contentId={contentId}\n open={open}\n stateAttribute={stateAttribute}\n trigger={trigger}\n onTriggerChange={setTrigger}\n onTriggerEnter={React.useCallback(() => {\n if (providerContext.isOpenDelayed) handleDelayedOpen();\n else handleOpen();\n }, [providerContext.isOpenDelayed, handleDelayedOpen, handleOpen])}\n onTriggerLeave={React.useCallback(() => {\n if (disableHoverableContent) {\n handleClose();\n } else {\n // Clear the timer in case the pointer leaves the trigger before the tooltip is opened.\n window.clearTimeout(openTimerRef.current);\n }\n }, [handleClose, disableHoverableContent])}\n onOpen={handleOpen}\n onClose={handleClose}\n disableHoverableContent={disableHoverableContent}\n >\n {children}\n </TooltipContextProvider>\n </PopperPrimitive.Root>\n );\n};\n\nTooltip.displayName = TOOLTIP_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipTrigger\n * -----------------------------------------------------------------------------------------------*/\n\nconst TRIGGER_NAME = 'TooltipTrigger';\n\ntype TooltipTriggerElement = React.ElementRef<typeof Primitive.button>;\ntype PrimitiveButtonProps = Radix.ComponentPropsWithoutRef<typeof Primitive.button>;\ninterface TooltipTriggerProps extends PrimitiveButtonProps {}\n\nconst TooltipTrigger = React.forwardRef<TooltipTriggerElement, TooltipTriggerProps>(\n (props: ScopedProps<TooltipTriggerProps>, forwardedRef) => {\n const { __scopeTooltip, ...triggerProps } = props;\n const context = useTooltipContext(TRIGGER_NAME, __scopeTooltip);\n const providerContext = useTooltipProviderContext(TRIGGER_NAME, __scopeTooltip);\n const popperScope = usePopperScope(__scopeTooltip);\n const ref = React.useRef<TooltipTriggerElement>(null);\n const composedRefs = useComposedRefs(forwardedRef, ref, context.onTriggerChange);\n const isPointerDownRef = React.useRef(false);\n const hasPointerMoveOpenedRef = React.useRef(false);\n const handlePointerUp = React.useCallback(() => (isPointerDownRef.current = false), []);\n\n React.useEffect(() => {\n return () => document.removeEventListener('pointerup', handlePointerUp);\n }, [handlePointerUp]);\n\n return (\n <PopperPrimitive.Anchor asChild {...popperScope}>\n <Primitive.button\n // We purposefully avoid adding `type=button` here because tooltip triggers are also\n // commonly anchors and the anchor `type` attribute signifies MIME type.\n aria-describedby={context.open ? context.contentId : undefined}\n data-state={context.stateAttribute}\n {...triggerProps}\n ref={composedRefs}\n onPointerMove={composeEventHandlers(props.onPointerMove, (event) => {\n if (event.pointerType === 'touch') return;\n if (\n !hasPointerMoveOpenedRef.current &&\n !providerContext.isPointerInTransitRef.current\n ) {\n context.onTriggerEnter();\n hasPointerMoveOpenedRef.current = true;\n }\n })}\n onPointerLeave={composeEventHandlers(props.onPointerLeave, () => {\n context.onTriggerLeave();\n hasPointerMoveOpenedRef.current = false;\n })}\n onPointerDown={composeEventHandlers(props.onPointerDown, () => {\n isPointerDownRef.current = true;\n document.addEventListener('pointerup', handlePointerUp, { once: true });\n })}\n onFocus={composeEventHandlers(props.onFocus, () => {\n if (!isPointerDownRef.current) context.onOpen();\n })}\n onBlur={composeEventHandlers(props.onBlur, context.onClose)}\n onClick={composeEventHandlers(props.onClick, (event) => {\n // keyboard click will occur under different conditions for different node\n // types so we use `onClick` instead of `onKeyDown` to respect that\n const isKeyboardClick = event.detail === 0;\n if (isKeyboardClick) context.onClose();\n })}\n />\n </PopperPrimitive.Anchor>\n );\n }\n);\n\nTooltipTrigger.displayName = TRIGGER_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipPortal\n * -----------------------------------------------------------------------------------------------*/\n\nconst PORTAL_NAME = 'TooltipPortal';\n\ntype PortalContextValue = { forceMount?: true };\nconst [PortalProvider, usePortalContext] = createTooltipContext<PortalContextValue>(PORTAL_NAME, {\n forceMount: undefined,\n});\n\ntype PortalProps = React.ComponentPropsWithoutRef<typeof PortalPrimitive>;\ninterface TooltipPortalProps extends Omit<PortalProps, 'asChild'> {\n children?: React.ReactNode;\n /**\n * Used to force mounting when more control is needed. Useful when\n * controlling animation with React animation libraries.\n */\n forceMount?: true;\n}\n\nconst TooltipPortal: React.FC<TooltipPortalProps> = (props: ScopedProps<TooltipPortalProps>) => {\n const { __scopeTooltip, forceMount, children, container } = props;\n const context = useTooltipContext(PORTAL_NAME, __scopeTooltip);\n return (\n <PortalProvider scope={__scopeTooltip} forceMount={forceMount}>\n <Presence present={forceMount || context.open}>\n <PortalPrimitive asChild container={container}>\n {children}\n </PortalPrimitive>\n </Presence>\n </PortalProvider>\n );\n};\n\nTooltipPortal.displayName = PORTAL_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipContent\n * -----------------------------------------------------------------------------------------------*/\n\nconst CONTENT_NAME = 'TooltipContent';\n\ntype TooltipContentElement = TooltipContentImplElement;\ninterface TooltipContentProps extends TooltipContentImplProps {\n /**\n * Used to force mounting when more control is needed. Useful when\n * controlling animation with React animation libraries.\n */\n forceMount?: true;\n}\n\nconst TooltipContent = React.forwardRef<TooltipContentElement, TooltipContentProps>(\n (props: ScopedProps<TooltipContentProps>, forwardedRef) => {\n const portalContext = usePortalContext(CONTENT_NAME, props.__scopeTooltip);\n const { forceMount = portalContext.forceMount, side = 'top', ...contentProps } = props;\n const context = useTooltipContext(CONTENT_NAME, props.__scopeTooltip);\n\n return (\n <Presence present={forceMount || context.open}>\n {context.disableHoverableContent ? (\n <TooltipContentImpl side={side} {...contentProps} ref={forwardedRef} />\n ) : (\n <TooltipContentHoverable side={side} {...contentProps} ref={forwardedRef} />\n )}\n </Presence>\n );\n }\n);\n\ntype Point = { x: number; y: number };\ntype Polygon = Point[];\n\ntype TooltipContentHoverableElement = TooltipContentImplElement;\ninterface TooltipContentHoverableProps extends TooltipContentImplProps {}\n\nconst TooltipContentHoverable = React.forwardRef<\n TooltipContentHoverableElement,\n TooltipContentHoverableProps\n>((props: ScopedProps<TooltipContentHoverableProps>, forwardedRef) => {\n const context = useTooltipContext(CONTENT_NAME, props.__scopeTooltip);\n const providerContext = useTooltipProviderContext(CONTENT_NAME, props.__scopeTooltip);\n const ref = React.useRef<TooltipContentHoverableElement>(null);\n const composedRefs = useComposedRefs(forwardedRef, ref);\n const [pointerGraceArea, setPointerGraceArea] = React.useState<Polygon | null>(null);\n\n const { trigger, onClose } = context;\n const content = ref.current;\n\n const { onPointerInTransitChange } = providerContext;\n\n const handleRemoveGraceArea = React.useCallback(() => {\n setPointerGraceArea(null);\n onPointerInTransitChange(false);\n }, [onPointerInTransitChange]);\n\n const handleCreateGraceArea = React.useCallback(\n (event: PointerEvent, hoverTarget: HTMLElement) => {\n const currentTarget = event.currentTarget as HTMLElement;\n const exitPoint = { x: event.clientX, y: event.clientY };\n const exitSide = getExitSideFromRect(exitPoint, currentTarget.getBoundingClientRect());\n\n const bleed = exitSide === 'right' || exitSide === 'bottom' ? -5 : 5;\n const isXAxis = exitSide === 'right' || exitSide === 'left';\n const startPoint = isXAxis\n ? { x: event.clientX + bleed, y: event.clientY }\n : { x: event.clientX, y: event.clientY + bleed };\n\n const hoverTargetPoints = getPointsFromRect(hoverTarget.getBoundingClientRect());\n const graceArea = getHull([startPoint, ...hoverTargetPoints]);\n setPointerGraceArea(graceArea);\n onPointerInTransitChange(true);\n },\n [onPointerInTransitChange]\n );\n\n React.useEffect(() => {\n return () => handleRemoveGraceArea();\n }, [handleRemoveGraceArea]);\n\n React.useEffect(() => {\n if (trigger && content) {\n const handleTriggerLeave = (event: PointerEvent) => handleCreateGraceArea(event, content);\n const handleContentLeave = (event: PointerEvent) => handleCreateGraceArea(event, trigger);\n\n trigger.addEventListener('pointerleave', handleTriggerLeave);\n content.addEventListener('pointerleave', handleContentLeave);\n return () => {\n trigger.removeEventListener('pointerleave', handleTriggerLeave);\n content.removeEventListener('pointerleave', handleContentLeave);\n };\n }\n }, [trigger, content, handleCreateGraceArea, handleRemoveGraceArea]);\n\n React.useEffect(() => {\n if (pointerGraceArea) {\n const handleTrackPointerGrace = (event: PointerEvent) => {\n const target = event.target as HTMLElement;\n const pointerPosition = { x: event.clientX, y: event.clientY };\n const hasEnteredTarget = trigger?.contains(target) || content?.contains(target);\n const isPointerOutsideGraceArea = !isPointInPolygon(pointerPosition, pointerGraceArea);\n\n if (hasEnteredTarget) {\n handleRemoveGraceArea();\n } else if (isPointerOutsideGraceArea) {\n handleRemoveGraceArea();\n onClose();\n }\n };\n document.addEventListener('pointermove', handleTrackPointerGrace);\n return () => document.removeEventListener('pointermove', handleTrackPointerGrace);\n }\n }, [trigger, content, pointerGraceArea, onClose, handleRemoveGraceArea]);\n\n return <TooltipContentImpl {...props} ref={composedRefs} />;\n});\n\ntype TooltipContentImplElement = React.ElementRef<typeof PopperPrimitive.Content>;\ntype DismissableLayerProps = Radix.ComponentPropsWithoutRef<typeof DismissableLayer>;\ntype PopperContentProps = Radix.ComponentPropsWithoutRef<typeof PopperPrimitive.Content>;\ninterface TooltipContentImplProps extends PopperContentProps {\n /**\n * A more descriptive label for accessibility purpose\n */\n 'aria-label'?: string;\n\n /**\n * Event handler called when the escape key is down.\n * Can be prevented.\n */\n onEscapeKeyDown?: DismissableLayerProps['onEscapeKeyDown'];\n /**\n * Event handler called when the a `pointerdown` event happens outside of the `Tooltip`.\n * Can be prevented.\n */\n onPointerDownOutside?: DismissableLayerProps['onPointerDownOutside'];\n}\n\nconst TooltipContentImpl = React.forwardRef<TooltipContentImplElement, TooltipContentImplProps>(\n (props: ScopedProps<TooltipContentImplProps>, forwardedRef) => {\n const {\n __scopeTooltip,\n children,\n 'aria-label': ariaLabel,\n onEscapeKeyDown,\n onPointerDownOutside,\n ...contentProps\n } = props;\n const context = useTooltipContext(CONTENT_NAME, __scopeTooltip);\n const popperScope = usePopperScope(__scopeTooltip);\n const { onClose } = context;\n\n // Close this tooltip if another one opens\n React.useEffect(() => {\n document.addEventListener(TOOLTIP_OPEN, onClose);\n return () => document.removeEventListener(TOOLTIP_OPEN, onClose);\n }, [onClose]);\n\n // Close the tooltip if the trigger is scrolled\n React.useEffect(() => {\n if (context.trigger) {\n const handleScroll = (event: Event) => {\n const target = event.target as HTMLElement;\n if (target?.contains(context.trigger)) onClose();\n };\n window.addEventListener('scroll', handleScroll, { capture: true });\n return () => window.removeEventListener('scroll', handleScroll, { capture: true });\n }\n }, [context.trigger, onClose]);\n\n return (\n <DismissableLayer\n asChild\n disableOutsidePointerEvents={false}\n onEscapeKeyDown={onEscapeKeyDown}\n onPointerDownOutside={onPointerDownOutside}\n onFocusOutside={(event) => event.preventDefault()}\n onDismiss={onClose}\n >\n <PopperPrimitive.Content\n data-state={context.stateAttribute}\n {...popperScope}\n {...contentProps}\n ref={forwardedRef}\n style={{\n ...contentProps.style,\n // re-namespace exposed content custom property\n ['--radix-tooltip-content-transform-origin' as any]:\n 'var(--radix-popper-transform-origin)',\n }}\n >\n <Slottable>{children}</Slottable>\n <VisuallyHiddenPrimitive.Root id={context.contentId} role=\"tooltip\">\n {ariaLabel || children}\n </VisuallyHiddenPrimitive.Root>\n </PopperPrimitive.Content>\n </DismissableLayer>\n );\n }\n);\n\nTooltipContent.displayName = CONTENT_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipArrow\n * -----------------------------------------------------------------------------------------------*/\n\nconst ARROW_NAME = 'TooltipArrow';\n\ntype TooltipArrowElement = React.ElementRef<typeof PopperPrimitive.Arrow>;\ntype PopperArrowProps = Radix.ComponentPropsWithoutRef<typeof PopperPrimitive.Arrow>;\ninterface TooltipArrowProps extends PopperArrowProps {}\n\nconst TooltipArrow = React.forwardRef<TooltipArrowElement, TooltipArrowProps>(\n (props: ScopedProps<TooltipArrowProps>, forwardedRef) => {\n const { __scopeTooltip, ...arrowProps } = props;\n const popperScope = usePopperScope(__scopeTooltip);\n return <PopperPrimitive.Arrow {...popperScope} {...arrowProps} ref={forwardedRef} />;\n }\n);\n\nTooltipArrow.displayName = ARROW_NAME;\n\n/* -----------------------------------------------------------------------------------------------*/\n\nfunction getExitSideFromRect(point: Point, rect: DOMRect) {\n const top = Math.abs(rect.top - point.y);\n const bottom = Math.abs(rect.bottom - point.y);\n const right = Math.abs(rect.right - point.x);\n const left = Math.abs(rect.left - point.x);\n\n switch (Math.min(top, bottom, right, left)) {\n case left:\n return 'left';\n case right:\n return 'right';\n case top:\n return 'top';\n case bottom:\n return 'bottom';\n default:\n return null;\n }\n}\n\nfunction getPointsFromRect(rect: DOMRect) {\n const { top, right, bottom, left } = rect;\n return [\n { x: left, y: top },\n { x: right, y: top },\n { x: right, y: bottom },\n { x: left, y: bottom },\n ];\n}\n\n// Determine if a point is inside of a polygon.\n// Based on https://github.com/substack/point-in-polygon\nfunction isPointInPolygon(point: Point, polygon: Polygon) {\n const { x, y } = point;\n let inside = false;\n for (let i = 0, j = polygon.length - 1; i < polygon.length; j = i++) {\n const xi = polygon[i].x;\n const yi = polygon[i].y;\n const xj = polygon[j].x;\n const yj = polygon[j].y;\n\n // prettier-ignore\n const intersect = ((yi > y) !== (yj > y)) && (x < (xj - xi) * (y - yi) / (yj - yi) + xi);\n if (intersect) inside = !inside;\n }\n\n return inside;\n}\n\n// Returns a new array of points representing the convex hull of the given set of points.\n// https://www.nayuki.io/page/convex-hull-algorithm\nfunction getHull<P extends Point>(points: Readonly<Array<P>>): Array<P> {\n const newPoints: Array<P> = points.slice();\n newPoints.sort((a: Point, b: Point) => {\n if (a.x < b.x) return -1;\n else if (a.x > b.x) return +1;\n else if (a.y < b.y) return -1;\n else if (a.y > b.y) return +1;\n else return 0;\n });\n return getHullPresorted(newPoints);\n}\n\n// Returns the convex hull, assuming that each points[i] <= points[i + 1]. Runs in O(n) time.\nfunction getHullPresorted<P extends Point>(points: Readonly<Array<P>>): Array<P> {\n if (points.length <= 1) return points.slice();\n\n const upperHull: Array<P> = [];\n for (let i = 0; i < points.length; i++) {\n const p = points[i];\n while (upperHull.length >= 2) {\n const q = upperHull[upperHull.length - 1];\n const r = upperHull[upperHull.length - 2];\n if ((q.x - r.x) * (p.y - r.y) >= (q.y - r.y) * (p.x - r.x)) upperHull.pop();\n else break;\n }\n upperHull.push(p);\n }\n upperHull.pop();\n\n const lowerHull: Array<P> = [];\n for (let i = points.length - 1; i >= 0; i--) {\n const p = points[i];\n while (lowerHull.length >= 2) {\n const q = lowerHull[lowerHull.length - 1];\n const r = lowerHull[lowerHull.length - 2];\n if ((q.x - r.x) * (p.y - r.y) >= (q.y - r.y) * (p.x - r.x)) lowerHull.pop();\n else break;\n }\n lowerHull.push(p);\n }\n lowerHull.pop();\n\n if (\n upperHull.length === 1 &&\n lowerHull.length === 1 &&\n upperHull[0].x === lowerHull[0].x &&\n upperHull[0].y === lowerHull[0].y\n ) {\n return upperHull;\n } else {\n return upperHull.concat(lowerHull);\n }\n}\n\nconst Provider = TooltipProvider;\nconst Root = Tooltip;\nconst Trigger = TooltipTrigger;\nconst Portal = TooltipPortal;\nconst Content = TooltipContent;\nconst Arrow = TooltipArrow;\n\nexport {\n createTooltipScope,\n //\n TooltipProvider,\n Tooltip,\n TooltipTrigger,\n TooltipPortal,\n TooltipContent,\n TooltipArrow,\n //\n Provider,\n Root,\n Trigger,\n Portal,\n Content,\n Arrow,\n};\nexport type {\n TooltipProps,\n TooltipTriggerProps,\n TooltipPortalProps,\n TooltipContentProps,\n TooltipArrowProps,\n};\n"],"names":["createTooltipScope","TooltipProvider","Tooltip","TooltipTrigger","TooltipPortal","TooltipContent","TooltipArrow","Provider","Root","Trigger","Portal","Content","Arrow","React","composeEventHandlers","useComposedRefs","createContextScope","DismissableLayer","useId","PopperPrimitive","createPopperScope","PortalPrimitive","Presence","Primitive","Slottable","useControllableState","VisuallyHiddenPrimitive","createTooltipContext","usePopperScope","PROVIDER_NAME","DEFAULT_DELAY_DURATION","TOOLTIP_OPEN","TooltipProviderContextProvider","useTooltipProviderContext","props","__scopeTooltip","delayDuration","skipDelayDuration","disableHoverableContent","children","isOpenDelayed","setIsOpenDelayed","useState","isPointerInTransitRef","useRef","skipDelayTimerRef","useEffect","skipDelayTimer","current","window","clearTimeout","useCallback","setTimeout","inTransit","TOOLTIP_NAME","TooltipContextProvider","useTooltipContext","open","openProp","defaultOpen","onOpenChange","disableHoverableContentProp","delayDurationProp","providerContext","popperScope","trigger","setTrigger","contentId","openTimerRef","wasOpenDelayedRef","setOpen","prop","defaultProp","onChange","onOpen","document","dispatchEvent","CustomEvent","onClose","stateAttribute","useMemo","handleOpen","handleClose","handleDelayedOpen","TRIGGER_NAME","forwardRef","forwardedRef","triggerProps","context","ref","composedRefs","onTriggerChange","isPointerDownRef","hasPointerMoveOpenedRef","handlePointerUp","removeEventListener","undefined","onPointerMove","event","pointerType","onTriggerEnter","onPointerLeave","onTriggerLeave","onPointerDown","addEventListener","once","onFocus","onBlur","onClick","isKeyboardClick","detail","PORTAL_NAME","PortalProvider","usePortalContext","forceMount","container","CONTENT_NAME","portalContext","side","contentProps","TooltipContentHoverable","pointerGraceArea","setPointerGraceArea","content","onPointerInTransitChange","handleRemoveGraceArea","handleCreateGraceArea","hoverTarget","currentTarget","exitPoint","x","clientX","y","clientY","exitSide","getExitSideFromRect","getBoundingClientRect","bleed","isXAxis","startPoint","hoverTargetPoints","getPointsFromRect","graceArea","getHull","handleTriggerLeave","handleContentLeave","handleTrackPointerGrace","target","pointerPosition","hasEnteredTarget","contains","isPointerOutsideGraceArea","isPointInPolygon","TooltipContentImpl","ariaLabel","onEscapeKeyDown","onPointerDownOutside","handleScroll","capture","preventDefault","style","ARROW_NAME","arrowProps","point","rect","top","Math","abs","bottom","right","left","min","polygon","inside","i","j","length","xi","yi","xj","yj","intersect","points","newPoints","slice","sort","a","b","getHullPresorted","upperHull","p","q","r","pop","push","lowerHull","concat"],"version":3,"file":"index.js.map"}
|
package/dist/index.module.js
CHANGED
|
@@ -13,24 +13,6 @@ import {Slottable as $8wepK$Slottable} from "@radix-ui/react-slot";
|
|
|
13
13
|
import {useControllableState as $8wepK$useControllableState} from "@radix-ui/react-use-controllable-state";
|
|
14
14
|
import {Root as $8wepK$Root1} from "@radix-ui/react-visually-hidden";
|
|
15
15
|
|
|
16
|
-
function $parcel$export(e, n, v, s) {
|
|
17
|
-
Object.defineProperty(e, n, {get: v, set: s, enumerable: true, configurable: true});
|
|
18
|
-
}
|
|
19
|
-
var $a093c7e1ec25a057$exports = {};
|
|
20
|
-
|
|
21
|
-
$parcel$export($a093c7e1ec25a057$exports, "createTooltipScope", () => $a093c7e1ec25a057$export$1c540a2224f0d865);
|
|
22
|
-
$parcel$export($a093c7e1ec25a057$exports, "TooltipProvider", () => $a093c7e1ec25a057$export$f78649fb9ca566b8);
|
|
23
|
-
$parcel$export($a093c7e1ec25a057$exports, "Tooltip", () => $a093c7e1ec25a057$export$28c660c63b792dea);
|
|
24
|
-
$parcel$export($a093c7e1ec25a057$exports, "TooltipTrigger", () => $a093c7e1ec25a057$export$8c610744efcf8a1d);
|
|
25
|
-
$parcel$export($a093c7e1ec25a057$exports, "TooltipPortal", () => $a093c7e1ec25a057$export$7b36b8f925ab7497);
|
|
26
|
-
$parcel$export($a093c7e1ec25a057$exports, "TooltipContent", () => $a093c7e1ec25a057$export$e9003e2be37ec060);
|
|
27
|
-
$parcel$export($a093c7e1ec25a057$exports, "TooltipArrow", () => $a093c7e1ec25a057$export$c27ee0ad710f7559);
|
|
28
|
-
$parcel$export($a093c7e1ec25a057$exports, "Provider", () => $a093c7e1ec25a057$export$2881499e37b75b9a);
|
|
29
|
-
$parcel$export($a093c7e1ec25a057$exports, "Root", () => $a093c7e1ec25a057$export$be92b6f5f03c0fe9);
|
|
30
|
-
$parcel$export($a093c7e1ec25a057$exports, "Trigger", () => $a093c7e1ec25a057$export$41fb9f06171c75f4);
|
|
31
|
-
$parcel$export($a093c7e1ec25a057$exports, "Portal", () => $a093c7e1ec25a057$export$602eac185826482c);
|
|
32
|
-
$parcel$export($a093c7e1ec25a057$exports, "Content", () => $a093c7e1ec25a057$export$7c6e2c02157bb7d2);
|
|
33
|
-
$parcel$export($a093c7e1ec25a057$exports, "Arrow", () => $a093c7e1ec25a057$export$21b07c8f274aebd5);
|
|
34
16
|
|
|
35
17
|
|
|
36
18
|
|
|
@@ -55,15 +37,11 @@ const $a093c7e1ec25a057$var$usePopperScope = $8wepK$createPopperScope();
|
|
|
55
37
|
* -----------------------------------------------------------------------------------------------*/ const $a093c7e1ec25a057$var$PROVIDER_NAME = 'TooltipProvider';
|
|
56
38
|
const $a093c7e1ec25a057$var$DEFAULT_DELAY_DURATION = 700;
|
|
57
39
|
const $a093c7e1ec25a057$var$TOOLTIP_OPEN = 'tooltip.open';
|
|
58
|
-
const [$a093c7e1ec25a057$var$TooltipProviderContextProvider, $a093c7e1ec25a057$var$useTooltipProviderContext] = $a093c7e1ec25a057$var$createTooltipContext($a093c7e1ec25a057$var$PROVIDER_NAME
|
|
59
|
-
isOpenDelayed: true,
|
|
60
|
-
delayDuration: $a093c7e1ec25a057$var$DEFAULT_DELAY_DURATION,
|
|
61
|
-
onOpen: ()=>{},
|
|
62
|
-
onClose: ()=>{}
|
|
63
|
-
});
|
|
40
|
+
const [$a093c7e1ec25a057$var$TooltipProviderContextProvider, $a093c7e1ec25a057$var$useTooltipProviderContext] = $a093c7e1ec25a057$var$createTooltipContext($a093c7e1ec25a057$var$PROVIDER_NAME);
|
|
64
41
|
const $a093c7e1ec25a057$export$f78649fb9ca566b8 = (props)=>{
|
|
65
|
-
const { __scopeTooltip: __scopeTooltip , delayDuration: delayDuration = $a093c7e1ec25a057$var$DEFAULT_DELAY_DURATION , skipDelayDuration: skipDelayDuration = 300 , children: children } = props;
|
|
42
|
+
const { __scopeTooltip: __scopeTooltip , delayDuration: delayDuration = $a093c7e1ec25a057$var$DEFAULT_DELAY_DURATION , skipDelayDuration: skipDelayDuration = 300 , disableHoverableContent: disableHoverableContent = false , children: children } = props;
|
|
66
43
|
const [isOpenDelayed, setIsOpenDelayed] = $8wepK$useState(true);
|
|
44
|
+
const isPointerInTransitRef = $8wepK$useRef(false);
|
|
67
45
|
const skipDelayTimerRef = $8wepK$useRef(0);
|
|
68
46
|
$8wepK$useEffect(()=>{
|
|
69
47
|
const skipDelayTimer = skipDelayTimerRef.current;
|
|
@@ -84,7 +62,12 @@ const $a093c7e1ec25a057$export$f78649fb9ca566b8 = (props)=>{
|
|
|
84
62
|
, skipDelayDuration);
|
|
85
63
|
}, [
|
|
86
64
|
skipDelayDuration
|
|
87
|
-
])
|
|
65
|
+
]),
|
|
66
|
+
isPointerInTransitRef: isPointerInTransitRef,
|
|
67
|
+
onPointerInTransitChange: $8wepK$useCallback((inTransit)=>{
|
|
68
|
+
isPointerInTransitRef.current = inTransit;
|
|
69
|
+
}, []),
|
|
70
|
+
disableHoverableContent: disableHoverableContent
|
|
88
71
|
}, children);
|
|
89
72
|
};
|
|
90
73
|
/*#__PURE__*/ Object.assign($a093c7e1ec25a057$export$f78649fb9ca566b8, {
|
|
@@ -95,28 +78,24 @@ const $a093c7e1ec25a057$export$f78649fb9ca566b8 = (props)=>{
|
|
|
95
78
|
* -----------------------------------------------------------------------------------------------*/ const $a093c7e1ec25a057$var$TOOLTIP_NAME = 'Tooltip';
|
|
96
79
|
const [$a093c7e1ec25a057$var$TooltipContextProvider, $a093c7e1ec25a057$var$useTooltipContext] = $a093c7e1ec25a057$var$createTooltipContext($a093c7e1ec25a057$var$TOOLTIP_NAME);
|
|
97
80
|
const $a093c7e1ec25a057$export$28c660c63b792dea = (props)=>{
|
|
98
|
-
const { __scopeTooltip: __scopeTooltip , children: children , open: openProp , defaultOpen: defaultOpen = false , onOpenChange: onOpenChange , delayDuration: delayDurationProp } = props;
|
|
99
|
-
const
|
|
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);
|
|
100
83
|
const popperScope = $a093c7e1ec25a057$var$usePopperScope(__scopeTooltip);
|
|
101
84
|
const [trigger, setTrigger] = $8wepK$useState(null);
|
|
102
85
|
const contentId = $8wepK$useId();
|
|
103
86
|
const openTimerRef = $8wepK$useRef(0);
|
|
104
|
-
const
|
|
87
|
+
const disableHoverableContent = disableHoverableContentProp !== null && disableHoverableContentProp !== void 0 ? disableHoverableContentProp : providerContext.disableHoverableContent;
|
|
88
|
+
const delayDuration = delayDurationProp !== null && delayDurationProp !== void 0 ? delayDurationProp : providerContext.delayDuration;
|
|
105
89
|
const wasOpenDelayedRef = $8wepK$useRef(false);
|
|
106
|
-
const { onOpen: onOpen , onClose: onClose } = context;
|
|
107
90
|
const [open1 = false, setOpen] = $8wepK$useControllableState({
|
|
108
91
|
prop: openProp,
|
|
109
92
|
defaultProp: defaultOpen,
|
|
110
93
|
onChange: (open)=>{
|
|
111
94
|
if (open) {
|
|
112
|
-
//
|
|
113
|
-
// ensure other tooltips are aware of this one opening.
|
|
114
|
-
//
|
|
115
|
-
// as `onChange` is called within a lifecycle method we
|
|
95
|
+
providerContext.onOpen(); // as `onChange` is called within a lifecycle method we
|
|
116
96
|
// avoid dispatching via `dispatchDiscreteCustomEvent`.
|
|
117
97
|
document.dispatchEvent(new CustomEvent($a093c7e1ec25a057$var$TOOLTIP_OPEN));
|
|
118
|
-
|
|
119
|
-
}
|
|
98
|
+
} else providerContext.onClose();
|
|
120
99
|
onOpenChange === null || onOpenChange === void 0 || onOpenChange(open);
|
|
121
100
|
}
|
|
122
101
|
});
|
|
@@ -132,6 +111,12 @@ const $a093c7e1ec25a057$export$28c660c63b792dea = (props)=>{
|
|
|
132
111
|
}, [
|
|
133
112
|
setOpen
|
|
134
113
|
]);
|
|
114
|
+
const handleClose = $8wepK$useCallback(()=>{
|
|
115
|
+
window.clearTimeout(openTimerRef.current);
|
|
116
|
+
setOpen(false);
|
|
117
|
+
}, [
|
|
118
|
+
setOpen
|
|
119
|
+
]);
|
|
135
120
|
const handleDelayedOpen = $8wepK$useCallback(()=>{
|
|
136
121
|
window.clearTimeout(openTimerRef.current);
|
|
137
122
|
openTimerRef.current = window.setTimeout(()=>{
|
|
@@ -154,24 +139,24 @@ const $a093c7e1ec25a057$export$28c660c63b792dea = (props)=>{
|
|
|
154
139
|
trigger: trigger,
|
|
155
140
|
onTriggerChange: setTrigger,
|
|
156
141
|
onTriggerEnter: $8wepK$useCallback(()=>{
|
|
157
|
-
if (
|
|
142
|
+
if (providerContext.isOpenDelayed) handleDelayedOpen();
|
|
158
143
|
else handleOpen();
|
|
159
144
|
}, [
|
|
160
|
-
|
|
145
|
+
providerContext.isOpenDelayed,
|
|
161
146
|
handleDelayedOpen,
|
|
162
147
|
handleOpen
|
|
163
148
|
]),
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
onClose: $8wepK$useCallback(()=>{
|
|
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.
|
|
168
152
|
window.clearTimeout(openTimerRef.current);
|
|
169
|
-
setOpen(false);
|
|
170
|
-
onClose();
|
|
171
153
|
}, [
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
])
|
|
154
|
+
handleClose,
|
|
155
|
+
disableHoverableContent
|
|
156
|
+
]),
|
|
157
|
+
onOpen: handleOpen,
|
|
158
|
+
onClose: handleClose,
|
|
159
|
+
disableHoverableContent: disableHoverableContent
|
|
175
160
|
}, children));
|
|
176
161
|
};
|
|
177
162
|
/*#__PURE__*/ Object.assign($a093c7e1ec25a057$export$28c660c63b792dea, {
|
|
@@ -183,9 +168,12 @@ const $a093c7e1ec25a057$export$28c660c63b792dea = (props)=>{
|
|
|
183
168
|
const $a093c7e1ec25a057$export$8c610744efcf8a1d = /*#__PURE__*/ $8wepK$forwardRef((props, forwardedRef)=>{
|
|
184
169
|
const { __scopeTooltip: __scopeTooltip , ...triggerProps } = props;
|
|
185
170
|
const context = $a093c7e1ec25a057$var$useTooltipContext($a093c7e1ec25a057$var$TRIGGER_NAME, __scopeTooltip);
|
|
171
|
+
const providerContext = $a093c7e1ec25a057$var$useTooltipProviderContext($a093c7e1ec25a057$var$TRIGGER_NAME, __scopeTooltip);
|
|
186
172
|
const popperScope = $a093c7e1ec25a057$var$usePopperScope(__scopeTooltip);
|
|
187
|
-
const
|
|
173
|
+
const ref = $8wepK$useRef(null);
|
|
174
|
+
const composedRefs = $8wepK$useComposedRefs(forwardedRef, ref, context.onTriggerChange);
|
|
188
175
|
const isPointerDownRef = $8wepK$useRef(false);
|
|
176
|
+
const hasPointerMoveOpenedRef = $8wepK$useRef(false);
|
|
189
177
|
const handlePointerUp = $8wepK$useCallback(()=>isPointerDownRef.current = false
|
|
190
178
|
, []);
|
|
191
179
|
$8wepK$useEffect(()=>{
|
|
@@ -202,11 +190,18 @@ const $a093c7e1ec25a057$export$8c610744efcf8a1d = /*#__PURE__*/ $8wepK$forwardRe
|
|
|
202
190
|
"aria-describedby": context.open ? context.contentId : undefined,
|
|
203
191
|
"data-state": context.stateAttribute
|
|
204
192
|
}, triggerProps, {
|
|
205
|
-
ref:
|
|
206
|
-
|
|
207
|
-
if (event.pointerType
|
|
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;
|
|
208
204
|
}),
|
|
209
|
-
onPointerLeave: $8wepK$composeEventHandlers(props.onPointerLeave, context.onClose),
|
|
210
205
|
onPointerDown: $8wepK$composeEventHandlers(props.onPointerDown, ()=>{
|
|
211
206
|
isPointerDownRef.current = true;
|
|
212
207
|
document.addEventListener('pointerup', handlePointerUp, {
|
|
@@ -255,13 +250,116 @@ const $a093c7e1ec25a057$export$7b36b8f925ab7497 = (props)=>{
|
|
|
255
250
|
* -----------------------------------------------------------------------------------------------*/ const $a093c7e1ec25a057$var$CONTENT_NAME = 'TooltipContent';
|
|
256
251
|
const $a093c7e1ec25a057$export$e9003e2be37ec060 = /*#__PURE__*/ $8wepK$forwardRef((props, forwardedRef)=>{
|
|
257
252
|
const portalContext = $a093c7e1ec25a057$var$usePortalContext($a093c7e1ec25a057$var$CONTENT_NAME, props.__scopeTooltip);
|
|
258
|
-
const { forceMount: forceMount = portalContext.forceMount , ...contentProps } = props;
|
|
253
|
+
const { forceMount: forceMount = portalContext.forceMount , side: side = 'top' , ...contentProps } = props;
|
|
259
254
|
const context = $a093c7e1ec25a057$var$useTooltipContext($a093c7e1ec25a057$var$CONTENT_NAME, props.__scopeTooltip);
|
|
260
255
|
return /*#__PURE__*/ $8wepK$createElement($8wepK$Presence, {
|
|
261
256
|
present: forceMount || context.open
|
|
262
|
-
}, /*#__PURE__*/ $8wepK$createElement($a093c7e1ec25a057$var$TooltipContentImpl, $8wepK$babelruntimehelpersesmextends({
|
|
257
|
+
}, context.disableHoverableContent ? /*#__PURE__*/ $8wepK$createElement($a093c7e1ec25a057$var$TooltipContentImpl, $8wepK$babelruntimehelpersesmextends({
|
|
258
|
+
side: side
|
|
259
|
+
}, contentProps, {
|
|
263
260
|
ref: forwardedRef
|
|
264
|
-
},
|
|
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
|
+
}));
|
|
265
363
|
});
|
|
266
364
|
const $a093c7e1ec25a057$var$TooltipContentImpl = /*#__PURE__*/ $8wepK$forwardRef((props, forwardedRef)=>{
|
|
267
365
|
const { __scopeTooltip: __scopeTooltip , children: children , 'aria-label': ariaLabel , onEscapeKeyDown: onEscapeKeyDown , onPointerDownOutside: onPointerDownOutside , ...contentProps } = props;
|
|
@@ -331,7 +429,101 @@ const $a093c7e1ec25a057$export$c27ee0ad710f7559 = /*#__PURE__*/ $8wepK$forwardRe
|
|
|
331
429
|
/*#__PURE__*/ Object.assign($a093c7e1ec25a057$export$c27ee0ad710f7559, {
|
|
332
430
|
displayName: $a093c7e1ec25a057$var$ARROW_NAME
|
|
333
431
|
});
|
|
334
|
-
/* -----------------------------------------------------------------------------------------------*/
|
|
432
|
+
/* -----------------------------------------------------------------------------------------------*/ function $a093c7e1ec25a057$var$getExitSideFromRect(point, rect) {
|
|
433
|
+
const top = Math.abs(rect.top - point.y);
|
|
434
|
+
const bottom = Math.abs(rect.bottom - point.y);
|
|
435
|
+
const right = Math.abs(rect.right - point.x);
|
|
436
|
+
const left = Math.abs(rect.left - point.x);
|
|
437
|
+
switch(Math.min(top, bottom, right, left)){
|
|
438
|
+
case left:
|
|
439
|
+
return 'left';
|
|
440
|
+
case right:
|
|
441
|
+
return 'right';
|
|
442
|
+
case top:
|
|
443
|
+
return 'top';
|
|
444
|
+
case bottom:
|
|
445
|
+
return 'bottom';
|
|
446
|
+
default:
|
|
447
|
+
return null;
|
|
448
|
+
}
|
|
449
|
+
}
|
|
450
|
+
function $a093c7e1ec25a057$var$getPointsFromRect(rect) {
|
|
451
|
+
const { top: top , right: right , bottom: bottom , left: left } = rect;
|
|
452
|
+
return [
|
|
453
|
+
{
|
|
454
|
+
x: left,
|
|
455
|
+
y: top
|
|
456
|
+
},
|
|
457
|
+
{
|
|
458
|
+
x: right,
|
|
459
|
+
y: top
|
|
460
|
+
},
|
|
461
|
+
{
|
|
462
|
+
x: right,
|
|
463
|
+
y: bottom
|
|
464
|
+
},
|
|
465
|
+
{
|
|
466
|
+
x: left,
|
|
467
|
+
y: bottom
|
|
468
|
+
}
|
|
469
|
+
];
|
|
470
|
+
} // Determine if a point is inside of a polygon.
|
|
471
|
+
// Based on https://github.com/substack/point-in-polygon
|
|
472
|
+
function $a093c7e1ec25a057$var$isPointInPolygon(point, polygon) {
|
|
473
|
+
const { x: x , y: y } = point;
|
|
474
|
+
let inside = false;
|
|
475
|
+
for(let i = 0, j = polygon.length - 1; i < polygon.length; j = i++){
|
|
476
|
+
const xi = polygon[i].x;
|
|
477
|
+
const yi = polygon[i].y;
|
|
478
|
+
const xj = polygon[j].x;
|
|
479
|
+
const yj = polygon[j].y; // prettier-ignore
|
|
480
|
+
const intersect = yi > y !== yj > y && x < (xj - xi) * (y - yi) / (yj - yi) + xi;
|
|
481
|
+
if (intersect) inside = !inside;
|
|
482
|
+
}
|
|
483
|
+
return inside;
|
|
484
|
+
} // Returns a new array of points representing the convex hull of the given set of points.
|
|
485
|
+
// https://www.nayuki.io/page/convex-hull-algorithm
|
|
486
|
+
function $a093c7e1ec25a057$var$getHull(points) {
|
|
487
|
+
const newPoints = points.slice();
|
|
488
|
+
newPoints.sort((a, b)=>{
|
|
489
|
+
if (a.x < b.x) return -1;
|
|
490
|
+
else if (a.x > b.x) return 1;
|
|
491
|
+
else if (a.y < b.y) return -1;
|
|
492
|
+
else if (a.y > b.y) return 1;
|
|
493
|
+
else return 0;
|
|
494
|
+
});
|
|
495
|
+
return $a093c7e1ec25a057$var$getHullPresorted(newPoints);
|
|
496
|
+
} // Returns the convex hull, assuming that each points[i] <= points[i + 1]. Runs in O(n) time.
|
|
497
|
+
function $a093c7e1ec25a057$var$getHullPresorted(points) {
|
|
498
|
+
if (points.length <= 1) return points.slice();
|
|
499
|
+
const upperHull = [];
|
|
500
|
+
for(let i = 0; i < points.length; i++){
|
|
501
|
+
const p = points[i];
|
|
502
|
+
while(upperHull.length >= 2){
|
|
503
|
+
const q = upperHull[upperHull.length - 1];
|
|
504
|
+
const r = upperHull[upperHull.length - 2];
|
|
505
|
+
if ((q.x - r.x) * (p.y - r.y) >= (q.y - r.y) * (p.x - r.x)) upperHull.pop();
|
|
506
|
+
else break;
|
|
507
|
+
}
|
|
508
|
+
upperHull.push(p);
|
|
509
|
+
}
|
|
510
|
+
upperHull.pop();
|
|
511
|
+
const lowerHull = [];
|
|
512
|
+
for(let i1 = points.length - 1; i1 >= 0; i1--){
|
|
513
|
+
const p = points[i1];
|
|
514
|
+
while(lowerHull.length >= 2){
|
|
515
|
+
const q = lowerHull[lowerHull.length - 1];
|
|
516
|
+
const r = lowerHull[lowerHull.length - 2];
|
|
517
|
+
if ((q.x - r.x) * (p.y - r.y) >= (q.y - r.y) * (p.x - r.x)) lowerHull.pop();
|
|
518
|
+
else break;
|
|
519
|
+
}
|
|
520
|
+
lowerHull.push(p);
|
|
521
|
+
}
|
|
522
|
+
lowerHull.pop();
|
|
523
|
+
if (upperHull.length === 1 && lowerHull.length === 1 && upperHull[0].x === lowerHull[0].x && upperHull[0].y === lowerHull[0].y) return upperHull;
|
|
524
|
+
else return upperHull.concat(lowerHull);
|
|
525
|
+
}
|
|
526
|
+
const $a093c7e1ec25a057$export$2881499e37b75b9a = $a093c7e1ec25a057$export$f78649fb9ca566b8;
|
|
335
527
|
const $a093c7e1ec25a057$export$be92b6f5f03c0fe9 = $a093c7e1ec25a057$export$28c660c63b792dea;
|
|
336
528
|
const $a093c7e1ec25a057$export$41fb9f06171c75f4 = $a093c7e1ec25a057$export$8c610744efcf8a1d;
|
|
337
529
|
const $a093c7e1ec25a057$export$602eac185826482c = $a093c7e1ec25a057$export$7b36b8f925ab7497;
|