1
0
Fork 0
mirror of https://github.com/sussy-code/smov.git synced 2025-01-04 16:47:40 +01:00

Fix scrolling bug

This commit is contained in:
Cooper Ransom 2024-04-04 10:06:09 -04:00
parent a2b39ee288
commit af74657f1a

View file

@ -197,14 +197,22 @@ export function Discover() {
} }
}, [movieWidth]); // Added movieWidth to the dependency array }, [movieWidth]); // Added movieWidth to the dependency array
let isScrolling = false;
function handleWheel(e: React.WheelEvent, categorySlug: string) { function handleWheel(e: React.WheelEvent, categorySlug: string) {
if (isScrolling) {
return;
}
isScrolling = true;
const carousel = carouselRefs.current[categorySlug]; const carousel = carouselRefs.current[categorySlug];
if (carousel) { if (carousel) {
const movieElements = carousel.getElementsByTagName("a"); const movieElements = carousel.getElementsByTagName("a");
if (movieElements.length > 0) { if (movieElements.length > 0) {
const posterWidth = movieElements[0].offsetWidth; const posterWidth = movieElements[0].offsetWidth;
const visibleMovies = Math.floor(carousel.offsetWidth / posterWidth); const visibleMovies = Math.floor(carousel.offsetWidth / posterWidth);
const scrollAmount = posterWidth * visibleMovies * 0.625; const scrollAmount = posterWidth * visibleMovies * 0.6;
if (e.deltaY < 5) { if (e.deltaY < 5) {
carousel.scrollBy({ left: -scrollAmount, behavior: "smooth" }); carousel.scrollBy({ left: -scrollAmount, behavior: "smooth" });
} else { } else {
@ -212,6 +220,10 @@ export function Discover() {
} }
} }
} }
setTimeout(() => {
isScrolling = false;
}, 345); // Disable scrolling every 3 milliseconds after interaction (only for mouse wheel doe)
} }
const [isHovered, setIsHovered] = useState(false); const [isHovered, setIsHovered] = useState(false);