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);