UNPKG

@base-ui/react

Version:

Base UI is a library of headless ('unstyled') React components and low-level hooks. You gain complete control over your app's CSS and accessibility features.

44 lines (43 loc) 1.57 kB
"use strict"; 'use client'; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default; Object.defineProperty(exports, "__esModule", { value: true }); exports.useOpenInteractionType = useOpenInteractionType; var React = _interopRequireWildcard(require("react")); var _useStableCallback = require("@base-ui/utils/useStableCallback"); var _useEnhancedClickHandler = require("@base-ui/utils/useEnhancedClickHandler"); var _detectBrowser = require("@base-ui/utils/detectBrowser"); /** * Determines the interaction type (keyboard, mouse, touch, etc.) that opened the component. * * @param open The open state of the component. */ function useOpenInteractionType(open) { const [openMethod, setOpenMethod] = React.useState(null); const handleTriggerClick = (0, _useStableCallback.useStableCallback)((_, interactionType) => { if (!open) { setOpenMethod(interactionType || ( // On iOS Safari, the hitslop around touch targets means tapping outside an element's // bounds does not fire `pointerdown` but does fire `mousedown`. The `interactionType` // will be "" in that case. _detectBrowser.isIOS ? 'touch' : '')); } }); const reset = React.useCallback(() => { setOpenMethod(null); }, []); const { onClick, onPointerDown } = (0, _useEnhancedClickHandler.useEnhancedClickHandler)(handleTriggerClick); return React.useMemo(() => ({ openMethod, reset, triggerProps: { onClick, onPointerDown } }), [openMethod, reset, onClick, onPointerDown]); }