UNPKG

element-plus

Version:

A Component Library for Vue 3

45 lines (42 loc) 1.15 kB
import '../../../../utils/index.mjs'; import { cAF, rAF } from '../../../../utils/raf.mjs'; const useGridWheel = ({ atXEndEdge, atXStartEdge, atYEndEdge, atYStartEdge }, onWheelDelta) => { let frameHandle = null; let xOffset = 0; let yOffset = 0; const hasReachedEdge = (x, y) => { const xEdgeReached = x <= 0 && atXStartEdge.value || x >= 0 && atXEndEdge.value; const yEdgeReached = y <= 0 && atYStartEdge.value || y >= 0 && atYEndEdge.value; return xEdgeReached && yEdgeReached; }; const onWheel = (e) => { cAF(frameHandle); let x = e.deltaX; let y = e.deltaY; if (Math.abs(x) > Math.abs(y)) { y = 0; } else { x = 0; } if (e.shiftKey && y !== 0) { x = y; y = 0; } if (hasReachedEdge(xOffset, yOffset) && hasReachedEdge(xOffset + x, yOffset + y)) return; xOffset += x; yOffset += y; e.preventDefault(); frameHandle = rAF(() => { onWheelDelta(xOffset, yOffset); xOffset = 0; yOffset = 0; }); }; return { hasReachedEdge, onWheel }; }; export { useGridWheel }; //# sourceMappingURL=use-grid-wheel.mjs.map