source: imaps-frontend/node_modules/react-use/lib/useWindowScroll.js@ 0c6b92a

main
Last change on this file since 0c6b92a was d565449, checked in by stefan toskovski <stefantoska84@…>, 3 months ago

Update repo after prototype presentation

  • Property mode set to 100644
File size: 1.6 KB
Line 
1"use strict";
2Object.defineProperty(exports, "__esModule", { value: true });
3var tslib_1 = require("tslib");
4var react_1 = require("react");
5var util_1 = require("./misc/util");
6var useRafState_1 = tslib_1.__importDefault(require("./useRafState"));
7var useWindowScroll = function () {
8 var _a = useRafState_1.default(function () { return ({
9 x: util_1.isBrowser ? window.pageXOffset : 0,
10 y: util_1.isBrowser ? window.pageYOffset : 0,
11 }); }), state = _a[0], setState = _a[1];
12 react_1.useEffect(function () {
13 var handler = function () {
14 setState(function (state) {
15 var pageXOffset = window.pageXOffset, pageYOffset = window.pageYOffset;
16 //Check state for change, return same state if no change happened to prevent rerender
17 //(see useState/setState documentation). useState/setState is used internally in useRafState/setState.
18 return state.x !== pageXOffset || state.y !== pageYOffset
19 ? {
20 x: pageXOffset,
21 y: pageYOffset,
22 }
23 : state;
24 });
25 };
26 //We have to update window scroll at mount, before subscription.
27 //Window scroll may be changed between render and effect handler.
28 handler();
29 util_1.on(window, 'scroll', handler, {
30 capture: false,
31 passive: true,
32 });
33 return function () {
34 util_1.off(window, 'scroll', handler);
35 };
36 }, []);
37 return state;
38};
39exports.default = useWindowScroll;
Note: See TracBrowser for help on using the repository browser.