mirror of
https://github.com/streamyfin/streamyfin.git
synced 2026-01-15 23:59:08 +00:00
36 lines
946 B
TypeScript
36 lines
946 B
TypeScript
import { useRef, useCallback, useState, useEffect } from "react";
|
|
|
|
export const useControlsVisibility = (timeout: number = 3000) => {
|
|
const [isVisible, setIsVisible] = useState(true);
|
|
const hideControlsTimerRef = useRef<ReturnType<typeof setTimeout> | null>(
|
|
null
|
|
);
|
|
|
|
const showControls = useCallback(() => {
|
|
setIsVisible(true);
|
|
if (hideControlsTimerRef.current) {
|
|
clearTimeout(hideControlsTimerRef.current);
|
|
}
|
|
hideControlsTimerRef.current = setTimeout(() => {
|
|
setIsVisible(false);
|
|
}, timeout);
|
|
}, [timeout]);
|
|
|
|
const hideControls = useCallback(() => {
|
|
setIsVisible(false);
|
|
if (hideControlsTimerRef.current) {
|
|
clearTimeout(hideControlsTimerRef.current);
|
|
}
|
|
}, []);
|
|
|
|
useEffect(() => {
|
|
return () => {
|
|
if (hideControlsTimerRef.current) {
|
|
clearTimeout(hideControlsTimerRef.current);
|
|
}
|
|
};
|
|
}, []);
|
|
|
|
return { isVisible, showControls, hideControls };
|
|
};
|