UNPKG

@razorpay/blade

Version:

The Design System that powers Razorpay

70 lines (67 loc) 3.15 kB
import { createAction, createListenerMiddleware } from '../../../@reduxjs/toolkit/dist/redux-toolkit.modern.js'; import { setMouseOverAxisIndex, setActiveMouseOverItemIndex } from './tooltipSlice.js'; import { selectActivePropsFromChartPointer } from './selectors/selectActivePropsFromChartPointer.js'; import { getChartPointer } from '../util/getChartPointer.js'; import { selectTooltipEventType } from './selectors/selectTooltipEventType.js'; import { DATA_ITEM_INDEX_ATTRIBUTE_NAME, DATA_ITEM_GRAPHICAL_ITEM_ID_ATTRIBUTE_NAME } from '../util/Constants.js'; import { selectTooltipCoordinate } from './selectors/touchSelectors.js'; import { selectAllGraphicalItemsSettings } from './selectors/tooltipSelectors.js'; var touchEventAction = createAction('touchMove'); var touchEventMiddleware = createListenerMiddleware(); touchEventMiddleware.startListening({ actionCreator: touchEventAction, effect: (action, listenerApi) => { var touchEvent = action.payload; if (touchEvent.touches == null || touchEvent.touches.length === 0) { return; } var state = listenerApi.getState(); var tooltipEventType = selectTooltipEventType(state, state.tooltip.settings.shared); if (tooltipEventType === 'axis') { var touch = touchEvent.touches[0]; if (touch == null) { return; } var activeProps = selectActivePropsFromChartPointer(state, getChartPointer({ clientX: touch.clientX, clientY: touch.clientY, currentTarget: touchEvent.currentTarget })); if ((activeProps === null || activeProps === void 0 ? void 0 : activeProps.activeIndex) != null) { listenerApi.dispatch(setMouseOverAxisIndex({ activeIndex: activeProps.activeIndex, activeDataKey: undefined, activeCoordinate: activeProps.activeCoordinate })); } } else if (tooltipEventType === 'item') { var _target$getAttribute; var _touch = touchEvent.touches[0]; if (document.elementFromPoint == null || _touch == null) { return; } var target = document.elementFromPoint(_touch.clientX, _touch.clientY); if (!target || !target.getAttribute) { return; } var itemIndex = target.getAttribute(DATA_ITEM_INDEX_ATTRIBUTE_NAME); var graphicalItemId = (_target$getAttribute = target.getAttribute(DATA_ITEM_GRAPHICAL_ITEM_ID_ATTRIBUTE_NAME)) !== null && _target$getAttribute !== void 0 ? _target$getAttribute : undefined; var settings = selectAllGraphicalItemsSettings(state).find(item => item.id === graphicalItemId); if (itemIndex == null || settings == null || graphicalItemId == null) { return; } var { dataKey } = settings; var coordinate = selectTooltipCoordinate(state, itemIndex, graphicalItemId); listenerApi.dispatch(setActiveMouseOverItemIndex({ activeDataKey: dataKey, activeIndex: itemIndex, activeCoordinate: coordinate, activeGraphicalItemId: graphicalItemId })); } } }); export { touchEventAction, touchEventMiddleware }; //# sourceMappingURL=touchEventsMiddleware.js.map