You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
InternshipProject/node_modules/rc-overflow/es/hooks/useBatchFrameState.js

50 lines
1.3 KiB

import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
import { useRef, useState, useEffect } from 'react';
import raf from "rc-util/es/raf";
/**
* State generate. Return a `setState` but it will flush all state with one render to save perf.
* This is not a realization of `unstable_batchedUpdates`.
*/
export function useBatchFrameState() {
var _useState = useState({}),
_useState2 = _slicedToArray(_useState, 2),
forceUpdate = _useState2[1];
var statesRef = useRef([]);
var destroyRef = useRef(false);
var walkingIndex = 0;
var beforeFrameId = 0;
useEffect(function () {
return function () {
destroyRef.current = true;
};
}, []);
function createState(defaultValue) {
var myIndex = walkingIndex;
walkingIndex += 1; // Fill value if not exist yet
if (statesRef.current.length < myIndex + 1) {
statesRef.current[myIndex] = defaultValue;
} // Return filled as `setState`
var value = statesRef.current[myIndex];
function setValue(val) {
statesRef.current[myIndex] = typeof val === 'function' ? val(statesRef.current[myIndex]) : val;
raf.cancel(beforeFrameId); // Flush with batch
beforeFrameId = raf(function () {
if (!destroyRef.current) {
forceUpdate({});
}
});
}
return [value, setValue];
}
return createState;
}