import React, { useState, useEffect } from "react"; import axios from "axios"; import RecentlyAddedCard from "./RecentlyAdded/recently-added-card"; import "../../css/users/user-details.css"; import ErrorBoundary from "../general/ErrorBoundary"; function RecentlyAdded(props) { const [data, setData] = useState(); const token = localStorage.getItem('token'); useEffect(() => { const fetchData = async () => { try { let url=`/proxy/getRecentlyAdded`; if(props.LibraryId) { url+=`?libraryid=${props.LibraryId}`; } const itemData = await axios.get(url, { headers: { Authorization: `Bearer ${token}`, "Content-Type": "application/json", }, }); if(itemData && typeof itemData.data === 'object' && Array.isArray(itemData.data)) { setData(itemData.data.filter((item) => ["Series", "Movie","Audio","Episode"].includes(item.Type))); } } catch (error) { console.log(error); } }; if (!data) { fetchData(); } const intervalId = setInterval(fetchData, 60000 * 5); return () => clearInterval(intervalId); }, [data, props.LibraryId,token]); if (!data) { return <>>; } return (