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

We got some fetching logic 🔥

This commit is contained in:
Captain Jack Sparrow 2024-06-14 05:14:48 +00:00
parent d1d1cc767f
commit 0f7fcc0fa1

View file

@ -1,6 +1,8 @@
import React, { useEffect, useRef, useState } from "react"; import React, { useEffect, useRef, useState } from "react";
import { MediaItem } from "@/utils/mediaTypes"; import { MediaItem } from "@/utils/mediaTypes";
import { get } from "@/backend/metadata/tmdb";
import { conf } from "@/setup/config";
interface PopupModalProps { interface PopupModalProps {
isVisible: boolean; isVisible: boolean;
@ -13,7 +15,6 @@ interface PopupModalProps {
media: MediaItem; media: MediaItem;
} }
// Define the type for the style state
type StyleState = { type StyleState = {
opacity: number; opacity: number;
visibility: "visible" | "hidden" | undefined; visibility: "visible" | "hidden" | undefined;
@ -26,18 +27,17 @@ export function PopupModal({
media, media,
}: PopupModalProps) { }: PopupModalProps) {
const modalRef = useRef<HTMLDivElement>(null); const modalRef = useRef<HTMLDivElement>(null);
// Use the StyleState type for the style state
const [style, setStyle] = useState<StyleState>({ const [style, setStyle] = useState<StyleState>({
opacity: 0, opacity: 0,
visibility: "hidden", visibility: "hidden",
}); });
// Use any or a more generic type here
const [data, setData] = useState<any>(null);
const [error, setError] = useState<string | null>(null); // State for storing API errors
useEffect(() => { useEffect(() => {
function handleClickOutside(event: MouseEvent) { function handleClickOutside(event: MouseEvent) {
if ( if (modalRef.current && !modalRef.current.contains(event.target as Node)) {
modalRef.current &&
!modalRef.current.contains(event.target as Node)
) {
onClose(); onClose();
} }
} }
@ -56,10 +56,35 @@ export function PopupModal({
} }
}, [isVisible]); }, [isVisible]);
useEffect(() => {
const fetchData = async () => {
if (!isVisible) return; // Ensure fetchData does not proceed if the modal is not visible
try {
const mediaTypePath = media.type === 'show' ? 'tv' : media.type;
const result = await get<any>(`/${mediaTypePath}/${media.id}`, {
api_key: conf().TMDB_READ_API_KEY,
language: "en-US",
});
setData(result);
setError(null); // Reset error state on successful fetch
} catch (err) {
setError('Failed to fetch media data');
console.error(err);
}
};
fetchData();
}, [media.id, media.type, isVisible]); // Dependency array remains the same
if (!isVisible && style.visibility === "hidden") return null; if (!isVisible && style.visibility === "hidden") return null;
// In hindsight we dont need the store but lets keep it until discover console.log(data);
// page works bc maybe we have to hack it into there // Handle error state in the UI
if (error) {
return <div>Error: {error}</div>;
}
return ( return (
<div <div
className="fixed inset-0 bg-opacity-50 flex justify-center items-center z-50 transition-opacity duration-100" className="fixed inset-0 bg-opacity-50 flex justify-center items-center z-50 transition-opacity duration-100"
@ -67,10 +92,15 @@ export function PopupModal({
> >
<div <div
ref={modalRef} ref={modalRef}
className="min-w-96 min-h-64 rounded-xl bg-mediaCard-hoverBackground flex justify-center items-center transition-opacity duration-200" className="rounded-xl p-3 bg-mediaCard-hoverBackground flex justify-center items-center transition-opacity duration-200 w-full max-w-3xl"
style={{ opacity: style.opacity }} style={{ opacity: style.opacity }}
> >
{media.title} <div className="aspect-w-16 aspect-h-9 w-full">
<img
src={`https://image.tmdb.org/t/p/original/${data?.backdrop_path}`}
className="rounded-xl object-cover w-full h-full"
/>
</div>
</div> </div>
</div> </div>
); );