UNPKG

1.24 kBJavaScriptView Raw
1"use strict";
2
3exports.__esModule = true;
4exports.default = void 0;
5
6var _react = require("react");
7
8var _useCommittedRef = _interopRequireDefault(require("./useCommittedRef"));
9
10function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
11
12function useRafInterval(fn, ms, paused) {
13 if (paused === void 0) {
14 paused = false;
15 }
16
17 var handle;
18 var start = new Date().getTime();
19 var fnRef = (0, _useCommittedRef.default)(fn); // this ref is necessary b/c useEffect will sometimes miss a paused toggle
20 // orphaning a setTimeout chain in the aether, so relying on it's refresh logic is not reliable.
21
22 var pausedRef = (0, _useCommittedRef.default)(paused);
23
24 function loop() {
25 var current = new Date().getTime();
26 var delta = current - start;
27 if (pausedRef.current) return;
28
29 if (delta >= ms && fnRef.current) {
30 fnRef.current();
31 start = new Date().getTime();
32 }
33
34 cancelAnimationFrame(handle);
35 handle = requestAnimationFrame(loop);
36 }
37
38 (0, _react.useEffect)(function () {
39 handle = requestAnimationFrame(loop);
40 return function () {
41 return cancelAnimationFrame(handle);
42 };
43 }, []);
44}
45
46var _default = useRafInterval;
47exports.default = _default;
\No newline at end of file