diff --git a/src/components/Game.tsx b/src/components/Game.tsx index ee38c69..54685eb 100644 --- a/src/components/Game.tsx +++ b/src/components/Game.tsx @@ -1,38 +1,74 @@ -import { VFC, useState, useEffect } from "react"; +import { VFC, useState, useEffect, useRef } from "react"; import { Button } from "decky-frontend-lib"; -const Game = ({ item, game, random, launchGame, fixArtwork, loadMore, setIsFocus, isFocus }) => { +const Game = ({ item, game, random, launchGame, fixArtwork, loadMore }) => { + const [isFocus, setIsFocus] = useState(false); + const [isVisible, setIsVisible] = useState(false); + const targetRef = useRef(null); + + useEffect(() => { + const observer = new IntersectionObserver( + ([entry]) => { + setIsVisible(entry.isIntersecting); + }, + { + root: null, // viewport + rootMargin: "0px", // no margin + threshold: 0.5, // 50% of target visible + } + ); + + if (targetRef.current) { + observer.observe(targetRef.current); + } + + // Clean up the observer + return () => { + if (targetRef.current) { + observer.unobserve(targetRef.current); + } + }; + }, []); + return ( ); }; diff --git a/src/components/Games.tsx b/src/components/Games.tsx index 774c106..7d146d9 100644 --- a/src/components/Games.tsx +++ b/src/components/Games.tsx @@ -212,7 +212,6 @@ const Games: VFC<{ serverAPI: any }> = ({ serverAPI }) => { }); const [percentage, setPercentage] = useState(0); const [searchTerm, setSearchTerm] = useState(""); - const [isFocus, setIsFocus] = useState(false); const [currentTab, setCurrentTab] = useState("Tab1"); const [visibleCount, setVisibleCount] = useState(20); @@ -356,8 +355,6 @@ const Games: VFC<{ serverAPI: any }> = ({ serverAPI }) => { launchGame={launchGame} fixArtwork={fixArtwork} loadMore={loadMore} - setIsFocus={setIsFocus} - isFocus={isFocus} /> ); })}