source: imaps-frontend/node_modules/react-use/esm/useIdle.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.7 KB
Line 
1import { useEffect, useState } from 'react';
2import { throttle } from 'throttle-debounce';
3import { off, on } from './misc/util';
4var defaultEvents = ['mousemove', 'mousedown', 'resize', 'keydown', 'touchstart', 'wheel'];
5var oneMinute = 60e3;
6var useIdle = function (ms, initialState, events) {
7 if (ms === void 0) { ms = oneMinute; }
8 if (initialState === void 0) { initialState = false; }
9 if (events === void 0) { events = defaultEvents; }
10 var _a = useState(initialState), state = _a[0], setState = _a[1];
11 useEffect(function () {
12 var mounted = true;
13 var timeout;
14 var localState = state;
15 var set = function (newState) {
16 if (mounted) {
17 localState = newState;
18 setState(newState);
19 }
20 };
21 var onEvent = throttle(50, function () {
22 if (localState) {
23 set(false);
24 }
25 clearTimeout(timeout);
26 timeout = setTimeout(function () { return set(true); }, ms);
27 });
28 var onVisibility = function () {
29 if (!document.hidden) {
30 onEvent();
31 }
32 };
33 for (var i = 0; i < events.length; i++) {
34 on(window, events[i], onEvent);
35 }
36 on(document, 'visibilitychange', onVisibility);
37 timeout = setTimeout(function () { return set(true); }, ms);
38 return function () {
39 mounted = false;
40 for (var i = 0; i < events.length; i++) {
41 off(window, events[i], onEvent);
42 }
43 off(document, 'visibilitychange', onVisibility);
44 };
45 }, [ms, events]);
46 return state;
47};
48export default useIdle;
Note: See TracBrowser for help on using the repository browser.