Co-authored-by: tobi <tobi.smethurst@protonmail.com> Reviewed-on: https://codeberg.org/superseriousbusiness/masto-fe-standalone/pulls/88 Co-authored-by: Zoë Bijl <moiety@noreply.codeberg.org> Co-committed-by: Zoë Bijl <moiety@noreply.codeberg.org>
22 lines
489 B
TypeScript
22 lines
489 B
TypeScript
import { useCallback, useState } from "react";
|
|
|
|
export const useHovering = (animate?: boolean) => {
|
|
const [hovering, setHovering] = useState<boolean>(animate ?? false);
|
|
|
|
const handleMouseEnter = useCallback(() => {
|
|
if (animate) {
|
|
return;
|
|
}
|
|
setHovering(true);
|
|
}, [animate]);
|
|
|
|
const handleMouseLeave = useCallback(() => {
|
|
if (animate) {
|
|
return;
|
|
}
|
|
setHovering(false);
|
|
}, [animate]);
|
|
|
|
return { hovering, handleMouseEnter, handleMouseLeave };
|
|
};
|