From c82510aa82f63d7d01adcc5d22e810aa13f8de45 Mon Sep 17 00:00:00 2001 From: Siddharth Kamble <96260439+siddharthsky@users.noreply.github.com> Date: Wed, 22 May 2024 23:22:35 +0530 Subject: [PATCH] Add fetchWithTimeout --- index.html | 47 +++++++++++++++++++++++++++++++++-------------- 1 file changed, 33 insertions(+), 14 deletions(-) diff --git a/index.html b/index.html index 2a0aeaa..1b0faca 100644 --- a/index.html +++ b/index.html @@ -118,6 +118,16 @@
Search movies and TV series
} } return savedAPI = null; + + + function fetchWithTimeout(url, timeout = 5000) { + return Promise.race([ + fetch(url) , + new Promise((_, reject) => + setTimeout(() => reject(new Error('Request timed out')), timeout) + ) + ]); + } } @@ -207,8 +217,8 @@
Search movies and TV series
const encodedSearchText = encodeURIComponent(searchText); // Encode the search text const apiUrl = `https://www.omdbapi.com/?s=${searchText}&apikey=${apiKey}`; - fetch(apiUrl) - .then(response => response.json()) + fetchWithTimeout(apiUrl) + .then(data => { if (data.Response === "True") { displayMovies(data.Search); @@ -227,6 +237,15 @@
Search movies and TV series
}); }); +function fetchWithTimeout(url, timeout = 5000) { + return Promise.race([ + fetch(url).then(response => response.json()), + new Promise((_, reject) => + setTimeout(() => reject(new Error('Request timed out')), timeout) + ) + ]); + } + // Function to display movies let apiKey; @@ -272,8 +291,8 @@
Search movies and TV series
// Function to fetch and display seasons for a series function displaySeasons(imdbID) { alertZreset() - fetch(`https://www.omdbapi.com/?i=${imdbID}&apikey=${apiKey}`) - .then(response => response.json()) + fetchWithTimeout(`https://www.omdbapi.com/?i=${imdbID}&apikey=${apiKey}`, 5000) + .then(data => { const seasons = data.totalSeasons; let seasonButtons = ''; @@ -301,15 +320,15 @@
Search movies and TV series
// Function to fetch and display episodes for a specific season function displayEpisodes(imdbID, seasonNumber) { alertZreset() - fetch(`https://www.omdbapi.com/?i=${imdbID}&Season=${seasonNumber}&apikey=${apiKey}`) - .then(response => response.json()) + fetchWithTimeout(`https://www.omdbapi.com/?i=${imdbID}&Season=${seasonNumber}&apikey=${apiKey}`) + .then(data => { const episodes = data.Episodes; let episodePromises = []; // Array to store episode fetch promises episodes.forEach(episode => { - const promise = fetch(`https://www.omdbapi.com/?i=${episode.imdbID}&apikey=${apiKey}`) - .then(response => response.json()) + const promise = fetchWithTimeout(`https://www.omdbapi.com/?i=${episode.imdbID}&apikey=${apiKey}`) + .then(episodeData => episodeData); episodePromises.push(promise); @@ -386,8 +405,8 @@
Search movies and TV series
const encodedSearchText = encodeURIComponent(searchText); // Encode the search text const apiUrl = `https://www.omdbapi.com/?s=${encodedSearchText}&apikey=${apiKey}`; - fetch(apiUrl) - .then(response => response.json()) + fetchWithTimeout(apiUrl) + .then(data => { if (data.Response === "True") { displayMovies(data.Search); @@ -414,8 +433,8 @@
Search movies and TV series
const encodedSearchText = encodeURIComponent(searchText); // Encode the search text const apiUrl = `https://www.omdbapi.com/?s=${encodedSearchText}&apikey=${apiKey}`; - fetch(apiUrl) - .then(response => response.json()) + fetchWithTimeout(apiUrl) + .then(data => { if (data.Response === "True") { displayMovies(data.Search); @@ -442,8 +461,8 @@
Search movies and TV series
// Function to fetch movie data based on page number function fetchMovies(apiUrl, page) { - fetch(apiUrl) - .then(response => response.json()) + fetchWithTimeout(apiUrl) + .then(data => { if (data.Response === "True") { displayMovies(data.Search);