@mui/x-charts
Version:
The community edition of the Charts components (MUI X).
46 lines • 1.19 kB
JavaScript
import * as React from 'react';
import { InteractionContext } from '../context/InteractionProvider';
import { useHighlighted } from '../context';
export const useInteractionItemProps = skip => {
const {
dispatch: dispatchInteraction
} = React.useContext(InteractionContext);
const {
setHighlighted,
clearHighlighted
} = useHighlighted();
if (skip) {
return () => ({});
}
const getInteractionItemProps = data => {
const onPointerDown = event => {
if (event.currentTarget.hasPointerCapture(event.pointerId)) {
event.currentTarget.releasePointerCapture(event.pointerId);
}
};
const onPointerEnter = () => {
dispatchInteraction({
type: 'enterItem',
data
});
setHighlighted({
seriesId: data.seriesId,
dataIndex: data.dataIndex
});
};
const onPointerLeave = event => {
event.currentTarget.releasePointerCapture(event.pointerId);
dispatchInteraction({
type: 'leaveItem',
data
});
clearHighlighted();
};
return {
onPointerEnter,
onPointerLeave,
onPointerDown
};
};
return getInteractionItemProps;
};