Implement scroll lock for previews (#10180)

* Implement scroll lock

* Fix seekbar not working
This commit is contained in:
Nicolas Mowen
2024-03-01 17:34:41 -07:00
committed by GitHub
parent ebf34ce378
commit a67e970fca
3 changed files with 53 additions and 6 deletions

View File

@@ -0,0 +1,38 @@
import { MutableRefObject, useCallback, useEffect, useState } from "react";
import { isMobile } from "react-device-detect";
export function useScrollLockout(ref: MutableRefObject<HTMLElement | null>) {
const [scrollLock, setScrollLockout] = useState(false);
const onScroll = useCallback(() => {
if (!scrollLock) {
setScrollLockout(true);
}
}, [scrollLock, setScrollLockout]);
const onMouseMove = useCallback(() => {
if (scrollLock) {
setScrollLockout(false);
}
}, [scrollLock, setScrollLockout]);
useEffect(() => {
if (isMobile) {
return;
}
if (!ref.current) {
return;
}
const content = ref.current;
content.addEventListener("scroll", onScroll);
content.addEventListener("mousemove", onMouseMove);
return () => {
content.removeEventListener("scroll", onScroll);
content.removeEventListener("mousemove", onMouseMove);
};
}, [ref, onScroll, onMouseMove]);
return scrollLock;
}