Press n or j to go to the next uncovered block, b, p or k for the previous block.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 | 1x 1x 1x 4x 4x 4x 4x 4x 4x 4x 4x 4x 4x 4x 4x 4x 4x 4x 4x 4x 4x 4x 4x 4x 4x | // Reasonable defaults const PIXEL_STEP = 10; const LINE_HEIGHT = 40; const PAGE_HEIGHT = 800; /** * Normalizes wheel events and provides properties that are more * consistent and helpful across different browsers * * @param event - the original mouse event * @returns a normalized eventDetail */ export default function normalizeWheel(event) { let spinX = 0, spinY = 0, pixelX = 0, pixelY = 0; // Legacy Eif ('detail' in event) { spinY = event.detail; } Eif ('wheelDelta' in event) { spinY = -event.wheelDelta / 120; } Eif ('wheelDeltaY' in event) { spinY = -event.wheelDeltaY / 120; } Eif ('wheelDeltaX' in event) { spinX = -event.wheelDeltaX / 120; } pixelX = spinX * PIXEL_STEP; pixelY = spinY * PIXEL_STEP; Eif ('deltaY' in event) { pixelY = event.deltaY; } Eif ('deltaX' in event) { pixelX = event.deltaX; } Iif ((pixelX || pixelY) && event.deltaMode) { if (event.deltaMode === 1) { // Delta in LINE units pixelX *= LINE_HEIGHT; pixelY *= LINE_HEIGHT; } else { // Delta in PAGE units pixelX *= PAGE_HEIGHT; pixelY *= PAGE_HEIGHT; } } // Fall-back if spin cannot be determined Iif (pixelX && !spinX) { spinX = pixelX < 1 ? -1 : 1; } Iif (pixelY && !spinY) { spinY = pixelY < 1 ? -1 : 1; } return { spinX, spinY, pixelX, pixelY, }; } |