import React, { forwardRef, useMemo } from 'react'; import { useLink } from './useLink'; import { mergeRefs } from '@gluestack-ui/utils'; import { composeEventHandlers } from '@gluestack-ui/utils'; import { useFocusRing, useFocus } from '@react-native-aria/focus'; import { useHover, usePress } from '@react-native-aria/interactions'; import { LinkContext } from './Context'; export const Link = (StyledLink: React.ComponentType) => forwardRef( ( { children, isDisabled, isHovered: isHoveredProp, isPressed: isPressedProp, isFocused: isFocusedProp, isFocusVisible: isFocusVisibleProp, isExternal, href, onPress, ...props }: any, ref?: any ) => { const { isFocusVisible, focusProps: focusRingProps }: any = useFocusRing(); const { pressProps, isPressed } = usePress({ isDisabled }); const { isFocused, focusProps } = useFocus(); const { isHovered, hoverProps }: any = useHover(); const _ref = React.useRef(null); const { linkProps } = useLink({ isExternal, href, onPress, _ref, isDisabled, }); const contextValue = useMemo(() => { return { isHovered: isHoveredProp || isHovered, isFocused: isFocusedProp || isFocused, isPressed: isPressedProp || isPressed, isDisabled: isDisabled, isFocusVisible: isFocusVisibleProp || isFocusVisible, }; }, [ isHoveredProp, isHovered, isFocusedProp, isFocused, isPressedProp, isPressed, isDisabled, isFocusVisibleProp, isFocusVisible, ]); return ( {children} ); } );