react-aria
Version:
Spectrum UI components in React
121 lines (112 loc) • 4.93 kB
JavaScript
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