mirror of
https://github.com/danog/telegram-tt.git
synced 2025-01-22 05:11:55 +01:00
Intersection Observer: Make sure to always unfreeze
This commit is contained in:
parent
a185fd9407
commit
97453fec52
@ -22,6 +22,8 @@ interface Response {
|
||||
unfreeze: NoneToVoidFunction;
|
||||
}
|
||||
|
||||
const AUTO_UNFREEZE_TIMEOUT = 2000;
|
||||
|
||||
export function useIntersectionObserver({
|
||||
rootRef,
|
||||
throttleMs,
|
||||
@ -42,14 +44,11 @@ export function useIntersectionObserver({
|
||||
const controllerRef = useRef<IntersectionController>();
|
||||
const rootCallbackRef = useRef<RootCallback>();
|
||||
const freezeFlagsRef = useRef(0);
|
||||
const autoUnfreezeTimeoutRef = useRef<number>();
|
||||
const onUnfreezeRef = useRef<NoneToVoidFunction>();
|
||||
|
||||
rootCallbackRef.current = rootCallback;
|
||||
|
||||
const freeze = useCallback(() => {
|
||||
freezeFlagsRef.current++;
|
||||
}, []);
|
||||
|
||||
const unfreeze = useCallback(() => {
|
||||
if (!freezeFlagsRef.current) {
|
||||
return;
|
||||
@ -63,6 +62,27 @@ export function useIntersectionObserver({
|
||||
}
|
||||
}, []);
|
||||
|
||||
const freeze = useCallback(() => {
|
||||
freezeFlagsRef.current++;
|
||||
|
||||
if (autoUnfreezeTimeoutRef.current) {
|
||||
clearTimeout(autoUnfreezeTimeoutRef.current);
|
||||
autoUnfreezeTimeoutRef.current = undefined;
|
||||
}
|
||||
|
||||
// Make sure to unfreeze even if unfreeze callback was not called (which was some hardly-reproducible bug)
|
||||
autoUnfreezeTimeoutRef.current = window.setTimeout(() => {
|
||||
autoUnfreezeTimeoutRef.current = undefined;
|
||||
|
||||
if (!freezeFlagsRef.current) {
|
||||
return;
|
||||
}
|
||||
|
||||
freezeFlagsRef.current = 1;
|
||||
unfreeze();
|
||||
}, AUTO_UNFREEZE_TIMEOUT);
|
||||
}, [unfreeze]);
|
||||
|
||||
useHeavyAnimationCheck(freeze, unfreeze);
|
||||
|
||||
useEffect(() => {
|
||||
|
Loading…
x
Reference in New Issue
Block a user