forked from iamharshika/Concise-Moviepedia
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsimilar_media.js
84 lines (75 loc) · 2.76 KB
/
similar_media.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
var parent = document.querySelector(".result");
var simMedia;
var mediaId;
var tokens;
var currentPage;
window.addEventListener('DOMContentLoaded', (event) => {
// using a loader
var results = document.querySelector('.result');
var loader = document.querySelector('.loader');
var x = setInterval(function () {
if (results.childElementCount > 0) {
loader.style.display = 'none';
clearInterval(x);
} else {
loader.style.display = 'block';
}
}, 100);
var sim_str = location.search.substring(1);
if(sim_str === "") {
noResults();
return;
}
tokens = sim_str.split('&');
console.log(tokens);
if ((tokens[0] !== "movie" && tokens[0] !== "tv") || tokens.length <= 2 || tokens[2] === "") {
noResults();
return;
}
simMedia = tokens[0];
mediaId = tokens[1];
currPage = tokens[2];
getSimilarMedia();
});
function getSimilarMedia() {
query_url = getQueryUrl("/" + simMedia + "/" + mediaId + "/similar")([orderby.popularity, options.page(currPage)]);
fetchData(query_url, displaySimilarResults);
}
function displaySimilarResults(data) {
console.log(data);
if(data.total_results == 0) {
noResults();
return;
}
var final_str = "";
data.results.forEach(element => {
final_str += constructHTMLStr(element, simMedia);
});
parent.innerHTML = final_str + getFooter();
document.querySelector('footer span').textContent = data.page;
// event listeener for details
addEventListenerToItems();
// adding event listener to the buttons
addEventListenerToButtons(data.page, data.total_pages);
}
function addEventListenerToButtons(currentPage, totalPages) {
var prevBtn = document.querySelector('.prev-btn');
var nextBtn = document.querySelector('.next-btn');
nextBtn.addEventListener('click', function() {
if(currentPage < totalPages) {
window.location.assign('similar_media.html?' + simMedia + '&' + mediaId + '&' + (currentPage + 1));
} else {
alert("This is the last page!")
}
});
prevBtn.addEventListener('click', function() {
if(currentPage >= 2) {
window.location.assign('similar_media.html?' + simMedia + '&' + mediaId + '=' + (currentPage - 1));
} else {
alert("This is the first page!");
}
});
}
function noResults() {
document.querySelector('.main-content').innerHTML = '<h1 style="text-align:center"><i style="color: #affc41" class="fa fa-frown-o" aria-hidden="true"></i> No results found!</h1>';
}