diff --git a/website/src/components/detailsToggle/index.js b/website/src/components/detailsToggle/index.js index 514ca52ba13..d337ece096c 100644 --- a/website/src/components/detailsToggle/index.js +++ b/website/src/components/detailsToggle/index.js @@ -1,65 +1,22 @@ -import React, { useState, useEffect } from 'react'; +import React, { useState } from 'react'; import styles from './styles.module.css'; function detailsToggle({ children, alt_header = null }) { const [isOn, setOn] = useState(false); - const [isScrolling, setIsScrolling] = useState(false); // New state to track scrolling - const [hoverTimeout, setHoverTimeout] = useState(null); const handleToggleClick = () => { - setOn(current => !current); // Toggle the current state + setOn(current => !current); }; - const handleMouseEnter = () => { - if (isOn || isScrolling) return; // Ignore hover if already open or if scrolling - const timeout = setTimeout(() => { - if (!isScrolling) setOn(true); - }, 700); // - setHoverTimeout(timeout); - }; - - const handleMouseLeave = () => { - if (!isOn) { - clearTimeout(hoverTimeout); - setOn(false); - } - }; - - const handleScroll = () => { - setIsScrolling(true); - clearTimeout(hoverTimeout); - //setOn(false); - - - // Reset scrolling state after a delay - setTimeout(() => { - setIsScrolling(false); - }, 800); - }; - - useEffect(() => { - window.addEventListener('scroll', handleScroll); - return () => { - window.removeEventListener('scroll', handleScroll); - }; - }, []); - - useEffect(() => { - return () => clearTimeout(hoverTimeout); - }, [hoverTimeout]); return (
  {alt_header} - {/* Visual disclaimer */} - Hover to view
{ - setHoverTimeout(setTimeout(() => { - setOn(true); - }, 500)); - }; - - const handleMouseLeave = () => { - if (!isOn) { - clearTimeout(hoverTimeout); - setOn(false); - } -}; - - useEffect(() => { - return () => { - if (hoverTimeout) { - clearTimeout(hoverTimeout); - } - }; - }, [hoverTimeout]); - - const toggleOn = () => { - if (hoverTimeout) { - clearTimeout(hoverTimeout); - } + const toggleOn = function () { setOn(!isOn); - }; + } return ( -
+
{alt_header || (fileContent?.meta && fileContent.meta.title)} - Hover to view
{fileContent?.contents} diff --git a/website/src/components/lightbox/index.js b/website/src/components/lightbox/index.js index a846c51b150..875ed6ff063 100644 --- a/website/src/components/lightbox/index.js +++ b/website/src/components/lightbox/index.js @@ -12,7 +12,7 @@ function Lightbox({ src, collapsed = false, alignment = "center", alt = undefine if (isHovered && !isScrolling) { timeoutId = setTimeout(() => { setExpandImage(true); - }, 300); + }, 200); } return () => clearTimeout(timeoutId); }, [isHovered, isScrolling]);