UNPKG

react-aria

Version:
121 lines (112 loc) 4.93 kB
import {getInteractionModality as $8f5a2122b0992be3$export$630ff653c5ada6a9, isFocusVisible as $8f5a2122b0992be3$export$b9b3dfddab17db27} from "../interactions/useFocusVisible.mjs"; import {mergeProps as $bbaa08b3cd72f041$export$9d1611c77c2fe928} from "../utils/mergeProps.mjs"; import {useFocusable as $d1116acdf220c2da$export$4c014de7c8940b4c} from "../interactions/useFocusable.mjs"; import {useHover as $e969f22b6713ca4a$export$ae780daf29e6d456} from "../interactions/useHover.mjs"; import {useId as $390e54f620492c70$export$f680877a34711e37} from "../utils/useId.mjs"; import {useRef as $t8vQD$useRef, useEffect as $t8vQD$useEffect} from "react"; /* * Copyright 2020 Adobe. All rights reserved. * This file is licensed to you under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. You may obtain a copy * of the License at http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software distributed under * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS * OF ANY KIND, either express or implied. See the License for the specific language * governing permissions and limitations under the License. */ function $85908aa8a35f0fac$export$a6da6c504e4bba8b(props, state, ref) { let { isDisabled: isDisabled, trigger: trigger, shouldCloseOnPress: shouldCloseOnPress = true } = props; let tooltipId = (0, $390e54f620492c70$export$f680877a34711e37)(); let isHovered = (0, $t8vQD$useRef)(false); let isFocused = (0, $t8vQD$useRef)(false); let handleShow = ()=>{ if (isHovered.current || isFocused.current) state.open(isFocused.current); }; let handleHide = (immediate)=>{ if (!isHovered.current && !isFocused.current) state.close(immediate); }; (0, $t8vQD$useEffect)(()=>{ let onKeyDown = (e)=>{ if (ref && ref.current) // Escape after clicking something can give it keyboard focus // dismiss tooltip on esc key press { if (e.key === 'Escape') { e.stopPropagation(); state.close(true); } } }; if (state.isOpen) { document.addEventListener('keydown', onKeyDown, true); return ()=>{ document.removeEventListener('keydown', onKeyDown, true); }; } }, [ ref, state ]); let onHoverStart = ()=>{ if (trigger === 'focus') return; // In chrome, if you hover a trigger, then another element obscures it, due to keyboard // interactions for example, hover will end. When hover is restored after that element disappears, // focus moves on for example, then the tooltip will reopen. We check the modality to know if the hover // is the result of moving the mouse. if ((0, $8f5a2122b0992be3$export$630ff653c5ada6a9)() === 'pointer') isHovered.current = true; else isHovered.current = false; handleShow(); }; let onHoverEnd = ()=>{ if (trigger === 'focus') return; // no matter how the trigger is left, we should close the tooltip isFocused.current = false; isHovered.current = false; handleHide(); }; let onPressStart = ()=>{ // if shouldCloseOnPress is false, we should not close the tooltip if (!shouldCloseOnPress) return; // no matter how the trigger is pressed, we should close the tooltip isFocused.current = false; isHovered.current = false; handleHide(true); }; let onFocus = ()=>{ let isVisible = (0, $8f5a2122b0992be3$export$b9b3dfddab17db27)(); if (isVisible) { isFocused.current = true; handleShow(); } }; let onBlur = ()=>{ isFocused.current = false; isHovered.current = false; handleHide(true); }; let { hoverProps: hoverProps } = (0, $e969f22b6713ca4a$export$ae780daf29e6d456)({ isDisabled: isDisabled, onHoverStart: onHoverStart, onHoverEnd: onHoverEnd }); let { focusableProps: focusableProps } = (0, $d1116acdf220c2da$export$4c014de7c8940b4c)({ isDisabled: isDisabled, onFocus: onFocus, onBlur: onBlur }, ref); return { triggerProps: { 'aria-describedby': state.isOpen ? tooltipId : undefined, ...(0, $bbaa08b3cd72f041$export$9d1611c77c2fe928)(focusableProps, hoverProps, { onPointerDown: onPressStart, onKeyDown: onPressStart }), tabIndex: undefined }, tooltipProps: { id: tooltipId } }; } export {$85908aa8a35f0fac$export$a6da6c504e4bba8b as useTooltipTrigger}; //# sourceMappingURL=useTooltipTrigger.mjs.map