diff options
author | fusagiko / takayamaki <24884114+takayamaki@users.noreply.github.com> | 2023-04-03 10:31:39 +0900 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-04-03 03:31:39 +0200 |
commit | 4520e6473afe901005e7ac532317f4b4f1af9ead (patch) | |
tree | 1ac8b7caa6c2ad0e565b99afaae3a46c0d9a77c7 /app/javascript/hooks | |
parent | 2f7c3cb628ddf0438452325c52359f575aab6890 (diff) |
[Proposal] Make able to write React in Typescript (#16210)
Co-authored-by: berlysia <berlysia@gmail.com> Co-authored-by: fusagiko / takayamaki <takayamaki@users.noreply.github.com>
Diffstat (limited to 'app/javascript/hooks')
-rw-r--r-- | app/javascript/hooks/useHovering.ts | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/app/javascript/hooks/useHovering.ts b/app/javascript/hooks/useHovering.ts new file mode 100644 index 000000000..2062e70d2 --- /dev/null +++ b/app/javascript/hooks/useHovering.ts @@ -0,0 +1,17 @@ +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 }; +}; |