UNPKG

recharts

Version:
48 lines (46 loc) 2.32 kB
import { createAction, createListenerMiddleware } from '@reduxjs/toolkit'; import { mouseLeaveChart, setMouseClickAxisIndex, setMouseOverAxisIndex } from './tooltipSlice'; import { selectActivePropsFromChartPointer } from './selectors/selectActivePropsFromChartPointer'; import { selectTooltipEventType } from './selectors/selectTooltipEventType'; import { getChartPointer } from '../util/getChartPointer'; export var mouseClickAction = createAction('mouseClick'); export var mouseClickMiddleware = createListenerMiddleware(); // TODO: there's a bug here when you click the chart the activeIndex resets to zero mouseClickMiddleware.startListening({ actionCreator: mouseClickAction, effect: (action, listenerApi) => { var mousePointer = action.payload; var activeProps = selectActivePropsFromChartPointer(listenerApi.getState(), getChartPointer(mousePointer)); if ((activeProps === null || activeProps === void 0 ? void 0 : activeProps.activeIndex) != null) { listenerApi.dispatch(setMouseClickAxisIndex({ activeIndex: activeProps.activeIndex, activeDataKey: undefined, activeCoordinate: activeProps.activeCoordinate })); } } }); export var mouseMoveAction = createAction('mouseMove'); export var mouseMoveMiddleware = createListenerMiddleware(); mouseMoveMiddleware.startListening({ actionCreator: mouseMoveAction, effect: (action, listenerApi) => { var mousePointer = action.payload; var state = listenerApi.getState(); var tooltipEventType = selectTooltipEventType(state, state.tooltip.settings.shared); var activeProps = selectActivePropsFromChartPointer(state, getChartPointer(mousePointer)); // this functionality only applies to charts that have axes if (tooltipEventType === 'axis') { if ((activeProps === null || activeProps === void 0 ? void 0 : activeProps.activeIndex) != null) { listenerApi.dispatch(setMouseOverAxisIndex({ activeIndex: activeProps.activeIndex, activeDataKey: undefined, activeCoordinate: activeProps.activeCoordinate })); } else { // this is needed to clear tooltip state when the mouse moves out of the inRange (svg - offset) function, but not yet out of the svg listenerApi.dispatch(mouseLeaveChart()); } } } });