@wordpress/components
Version:
UI components for WordPress.
45 lines (39 loc) • 1.1 kB
JavaScript
/**
* External dependencies
*/
import { cx } from 'emotion';
// eslint-disable-next-line no-restricted-imports
import { Tooltip as ReakitTooltip } from 'reakit';
/**
* Internal dependencies
*/
import { contextConnect, useContextSystem } from '../context';
import { View } from '../view';
import { useTooltipContext } from './context';
import * as styles from './styles';
const { TooltipPopoverView } = styles;
/**
*
* @param {import('../context').ViewOwnProps<import('reakit').TooltipProps, 'div'>} props
* @param {import('react').Ref<any>} forwardedRef
*/
function TooltipContent( props, forwardedRef ) {
const { children, className, ...otherProps } = useContextSystem(
props,
'TooltipContent'
);
const { tooltip } = useTooltipContext();
const classes = cx( styles.TooltipContent, className );
return (
<ReakitTooltip
as={ View }
{ ...otherProps }
{ ...tooltip }
className={ classes }
ref={ forwardedRef }
>
<TooltipPopoverView>{ children }</TooltipPopoverView>
</ReakitTooltip>
);
}
export default contextConnect( TooltipContent, 'TooltipContent' );