wrapperr/web/js/get_stats.js
aunefyren 1a7c66c4b4 Major refactor
Basic Auth on front end
Switched to GIN for http routing
Reworked middleware
2023-10-25 15:14:02 +02:00

1247 lines
No EOL
58 KiB
JavaScript

var loaded = false;
function get_stats() {
var loading_icon = document.getElementById("loading_icon");
stats_form = {
"caching" : false,
"cache_limit": 0,
"plex_identity": plex_identity
};
var stats_data = JSON.stringify(stats_form);
var xhttp = new XMLHttpRequest();
xhttp.onreadystatechange = function() {
if (this.readyState == 4 && (this.status == 200 || this.status == 400 || this.status == 500)) {
try {
var result= JSON.parse(this.responseText);
} catch(error) {
if(this.responseText.includes('Maximum execution time of')) {
loading_icon.style.display = "none";
document.getElementById("search_wrapped_button").disabled = false;
document.getElementById("search_wrapped_button").style.opacity = '1';
document.getElementById("plex_signout_button").disabled = false;
document.getElementById("plex_signout_button").style.opacity = '1';
document.getElementById('results_error').innerHTML = 'PHP runtime exceeded and stopped execution. Admin must shorten wrapped period or perform caching.';
} else {
console.log('Error: ' + error);
console.log(this.responseText);
loading_icon.style.display = "none";
document.getElementById("search_wrapped_button").disabled = false;
document.getElementById("search_wrapped_button").style.opacity = '1';
document.getElementById("plex_signout_button").disabled = false;
document.getElementById("plex_signout_button").style.opacity = '1';
document.getElementById('results_error').innerHTML = "API response can't be parsed.";
}
return;
}
if(result.error) {
loading_icon.style.display = "none";
document.getElementById("search_wrapped_button").disabled = false;
document.getElementById("search_wrapped_button").style.opacity = '1';
document.getElementById("plex_signout_button").disabled = false;
document.getElementById("plex_signout_button").style.opacity = '1';
document.getElementById('results_error').innerHTML = result.error;
} else {
results = result;
load_page(results);
}
}
};
xhttp.withCredentials = true;
xhttp.open("post", api_url + "get/statistics");
xhttp.setRequestHeader("Content-Type", "application/json;charset=UTF-8");
xhttp.setRequestHeader("Authorization", cookie);
xhttp.send(stats_data);
loading_icon.style.display = "inline";
}
function load_page(data){
// Remove snow and background
document.getElementById('snowflakes').style.display = 'none';
document.getElementById('snowflakes2').style.display = 'none';
document.getElementById('background_image').style.display = 'none';
// Set body background color to introduction
document.getElementById("body").classList.add('color-red');
// Enable changing background colors JS
loaded = true;
if(results.error) {
$('#results_error').html(results.message);
loading_icon.style.display = "none";
search_button("SEARCH");
return
}
// Find HTML elements and hide them
var search_box = document.getElementById("search_input");
var login_content = document.getElementById("login_content");
var footer = document.getElementById("footer");
search_box.style.display = "none";
login_content.style.display = "none";
footer.style.display = "none";
// Load the introduction
load_introduction();
// Load the segments based on configuration
if(!results.user.user_movies.error && functions.get_user_movie_stats) {
load_movies();
}
if(!results.user.user_shows.error && functions.get_user_show_stats) {
load_shows();
}
if(!results.user.user_music.error && functions.get_user_music_stats) {
load_music();
}
if(!results.year_stats.error && (functions.get_year_stats_movies || functions.get_year_stats_shows || functions.get_year_stats_music)) {
load_users();
}
// Load the outro
load_outro();
}
//INTRODUCTION
function load_introduction() {
var text = "";
text += "<div class='boks' data-color='red' style='width: 100%; padding-bottom: 15em; padding-top: 15em; height:auto; background-color:none'>";
text += "<div class='boks3'>";
text += "<div class='boks2'>";
text += '<img src="assets/img/finished-illustration.svg" style="width:100%; ">';
text += "</div>";
text += "<div class='boks2' style='margin: auto 0;'>";
text += "<h1>" + ReplaceStandardStrings(functions.stats_intro_title) + "</h1>";
text += "<h2>" + ReplaceStandardStrings(functions.stats_intro_subtitle) + "</h2>";
text += "</div>";
text += "</div>";
text += "</div>";
document.getElementById("search_results").innerHTML += text;
}
// Toggle list to plays or duration
function top_list_sort_by(array, title, music, show, year, div_id, button_id, functions_data) {
document.getElementById(div_id).outerHTML = top_list(array, title, music, show, year, div_id);
var button_text = document.getElementById(button_id + '_text');
if(button_text.innerHTML.includes(functions_data.wrapperr_sort_plays)) {
button_text.innerHTML = functions_data.wrapperr_sort_duration;
} else {
button_text.innerHTML = functions_data.wrapperr_sort_plays;
}
var button = document.getElementById(button_id);
if(button.getAttribute('onclick').includes('_duration')) {
button.setAttribute( "onclick", button.getAttribute('onclick').replaceAll('_duration', '_plays'));
} else {
button.setAttribute( "onclick", button.getAttribute('onclick').replaceAll('_plays', '_duration'));
}
}
//MOVIES
function load_movies() {
var text = "";
if(results.user.user_movies.data.movie_plays > 1) {
text += "<div class='boks' data-color='orangered' style='height: auto !important; width: 100%; padding-bottom: 25em; padding-top: 25em; height:10em; background-color: none;'>";
// Get custom text fron functions
text += "<div class='boks3'>";
text += "<h1>" + functions.get_user_movie_stats_title + "</h1>";
text += "</div>";
// Replace custom string with movie plays
text += "<div class='boks3'>";
text += "<h2>" + ReplaceStandardStrings(functions.get_user_movie_stats_subtitle) + "</h2>";
text += "</div>";
text += "<div class='boks3'>";
text += "<p>" + ReplaceStandardStrings(functions.get_user_movie_stats_subsubtitle) + "</p>";
text += "</div>";
// Place stats
text += "<div class='boks3'>";
text += "<div class='boks2'>";
if(functions.stats_order_by_plays !== false && functions.stats_order_by_duration !== false) {
text += '<button class="form-control btn" style="margin: 0.5em auto; width: fit-content;" name="user_movies_data_movies_button" id="user_movies_data_movies_button" onclick="top_list_sort_by(results.user.user_movies.data.movies_plays, functions.get_user_movie_stats_top_movie_plural, false, false, true, \'user_movies_data_movies\', \'user_movies_data_movies_button\', functions);"><img src="assets/tweak.svg" class="btn_logo"><p2 id="user_movies_data_movies_button_text">' + functions.wrapperr_sort_plays + '</p2></button>';
}
if(functions.stats_order_by_duration !== false) {
text += top_list(results.user.user_movies.data.movies_duration, functions.get_user_movie_stats_top_movie_plural, false, false, true, 'user_movies_data_movies');
} else {
text += top_list(results.user.user_movies.data.movies_plays, functions.get_user_movie_stats_top_movie_plural, false, false, true, 'user_movies_data_movies');
}
text += "</div>";
text += "<div class='boks2' style='padding: 0;'>";
text += "<div class='boks2'>";
text += completion_movie(results.user.user_movies.data.user_movie_finishing_percent, false, functions);
text += "</div>";
text += "<div class='boks2'>";
text += paused_movie(results.user.user_movies.data.user_movie_most_paused, false, functions);
text += "</div>";
if(!results.user.user_movies.data.user_movie_oldest.error) {
text += "<div class='boks2'>";
text += oldest_movie(results.user.user_movies.data.user_movie_oldest, functions);
text += "</div>";
}
text += "<div class='boks2'>";
text += you_spent(results.user.user_movies.data.movie_duration, 'movies', functions);
text += "</div>";
text += "</div>";
text += "</div>";
text += "</div>";
} else if(results.user.user_movies.data.movie_plays == 1) {
text += "<div class='boks' data-color='orangered' style='height: auto !important; width: 100%; padding-bottom: 25em; padding-top: 25em; height:10em; background-color:none;'>";
text += "<div class='boks3'>";
text += "<h1>" + ReplaceStandardStrings(functions.get_user_movie_stats_title) + "</h1>";
text += "</div>";
text += "<div class='boks3'>";
text += "<h2>" + ReplaceStandardStrings(functions.get_user_movie_stats_subtitle_one) + "</h2>";
text += "</div>";
text += "<div class='boks3'>";
text += "<p>" + ReplaceStandardStrings(functions.get_user_movie_stats_subsubtitle_one) + "</p>";
text += "</div>";
text += "<div class='boks3'>";
text += "<div class='boks2'>";
text += top_list(results.user.user_movies.data.movies_duration, functions.get_user_movie_stats_top_movie, false, false, true);
text += "</div>";
text += "<div class='boks2' style='padding: 0;'>";
text += "<div class='boks2'>";
text += completion_movie(results.user.user_movies.data.user_movie_finishing_percent, true, functions);
text += "</div>";
text += "<div class='boks2'>";
text += paused_movie(results.user.user_movies.data.user_movie_most_paused, true, functions);
text += "</div>";
text += "</div>";
text += "</div>";
text += "</div>";
} else {
text += "<div class='boks' data-color='orangered' style='height: auto !important; width: 100%; padding-bottom: 25em; padding-top: 25em; height:10em; background-color:none;'>";
text += "<div class='boks3'>";
text += "<div class='boks2'>";
text += "<div class='status'>";
text += "<h1>" + ReplaceStandardStrings(functions.get_user_movie_stats_title) + "</h1>";
text += "<h2>" + ReplaceStandardStrings(functions.get_user_movie_stats_subtitle_none) + "</h2>";
text += "<p>" + ReplaceStandardStrings(functions.get_user_movie_stats_subsubtitle_none) + "</p>";
text += '<img src="assets/img/bored.svg" style="margin: auto; display: block; width: 15em;">';
text += "</div>";
text += "</div>";
text += "</div>";
text += "</div>";
}
document.getElementById("search_results").innerHTML += text;
}
//SHOWS
function load_shows() {
var text = "";
if(results.user.user_shows.data.show_plays > 1) {
text += "<div class='boks' data-color='orangeyellow' style='height: auto !important; width: 100%; padding-bottom: 25em; padding-top: 25em; height:10em; background-color:none;'>";
text += "<div class='boks3'>";
text += "<h1>" + functions.get_user_show_stats_title + "</h1>";
text += "</div>";
text += "<div class='boks3'>";
text += "<h2>" + ReplaceStandardStrings(functions.get_user_show_stats_subtitle) + "</h2>";
text += "</div>";
text += "<div class='boks3'>";
text += "<p>" + ReplaceStandardStrings(functions.get_user_show_stats_subsubtitle) + "</p>";
text += "</div>";
text += "<div class='boks3'>";
text += "<div class='boks2'>";
if(functions.stats_order_by_plays !== false && functions.stats_order_by_duration !== false) {
text += '<button class="form-control btn" style="margin: 0.5em auto; width: fit-content;" name="user_shows_data_shows_button" id="user_shows_data_shows_button" onclick="top_list_sort_by(results.user.user_shows.data.shows_plays, functions.get_user_show_stats_top_show_plural, false, true, false, \'user_shows_data_shows\', \'user_shows_data_shows_button\', functions);"><img src="assets/tweak.svg" class="btn_logo"><p2 id="user_shows_data_shows_button_text">' + functions.wrapperr_sort_plays + '</p2></button>';
}
if(functions.stats_order_by_duration !== false) {
text += top_list(results.user.user_shows.data.shows_duration, functions.get_user_show_stats_top_show_plural, false, true, false, 'user_shows_data_shows');
} else {
text += top_list(results.user.user_shows.data.shows_plays, functions.get_user_show_stats_top_show_plural, false, true, false, 'user_shows_data_shows');
}
text += "</div>";
text += "<div class='boks2' style='padding: 0;'>";
if(results.user.user_shows.data.shows_duration.length > 0 && !results.user.user_shows.data.show_buddy.error && functions.get_user_show_stats_buddy) {
text += "<div class='boks2'>";
text += load_showbuddy(results.user.user_shows.data.show_buddy, results.user.user_shows.data.shows_duration[0], functions);
text += "</div>";
}
if(results.user.user_shows.data.episode_duration_longest.plays != 0 && results.user.user_shows.data.episode_duration_longest.duration != 0) {
text += "<div class='boks2'>";
text += load_longest_episode(results.user.user_shows.data.episode_duration_longest, functions);
text += "</div>";
}
text += "<div class='boks2'>";
text += you_spent(results.user.user_shows.data.show_duration, 'shows', functions);
text += "</div>";
text += "</div>";
text += "</div>";
text += "</div>";
} else if(results.user.user_shows.data.show_plays == 1) {
text += "<div class='boks' data-color='orangeyellow' style='height: auto !important; width: 100%; padding-bottom: 25em; padding-top: 25em; height:10em; background-color:none;'>";
text += "<div class='boks3'>";
text += "<h1>" + ReplaceStandardStrings(functions.get_user_show_stats_title) + "</h1>";
text += "</div>";
text += "<div class='boks3'>";
text += "<h2>" + ReplaceStandardStrings(functions.get_user_show_stats_subtitle_one) + "</h2>";
text += "</div>";
text += "<div class='boks3'>";
text += "<p>" + ReplaceStandardStrings(functions.get_user_show_stats_subsubtitle_one) + "</p>";
text += "</div>";
text += "<div class='boks3'>";
text += "<div class='boks2'>";
text += top_list(results.user.user_shows.data.shows_duration, functions.get_user_show_stats_top_show, false, true, false);
text += "</div>";
if(results.user.user_shows.data.shows_duration.length > 0 && !results.user.user_shows.data.show_buddy.error && functions.get_user_show_stats_buddy) {
text += "<div class='boks2'>";
text += load_showbuddy(results.user.user_shows.data.show_buddy, results.user.user_shows.data.shows_duration[0], functions);
text += "</div>";
}
if(results.user.user_shows.data.episode_duration_longest.plays != 0 && results.user.user_shows.data.episode_duration_longest.duration != 0) {
text += "<div class='boks2'>";
text += load_longest_episode(results.user.user_shows.data.episode_duration_longest, functions);
text += "</div>";
}
text += "</div>";
text += "</div>";
} else {
text += "<div class='boks' data-color='orangeyellow' style='height: auto !important; width: 100%; padding-bottom: 25em; padding-top: 25em; height:10em; background-color:none;'>";
text += "<div class='boks3'>";
text += "<div class='boks2'>";
text += "<div class='status'>";
text += "<h1>" + ReplaceStandardStrings(functions.get_user_show_stats_title) + "</h1>";
text += "<h2>" + ReplaceStandardStrings(functions.get_user_show_stats_subtitle_none) + "</h2>";
text += "<p>" + ReplaceStandardStrings(functions.get_user_show_stats_subsubtitle_none) + "</p>";
text += '<img src="assets/img/bored.svg" style="margin: auto; display: block; width: 15em;">';
text += "</div>";
text += "</div>";
text += "</div>";
text += "</div>";
}
document.getElementById("search_results").innerHTML += text;
}
//MUSIC
function load_music() {
var text = "";
if(results.user.user_music.data.track_plays > 1) {
text += "<div class='boks' data-color='mango' style='height: auto !important; width: 100%; padding-bottom: 25em; padding-top: 25em; height:10em; background-color:none;'>";
text += "<div class='boks3'>";
text += "<h1>" + ReplaceStandardStrings(functions.get_user_music_stats_title) + "</h1>";
text += "</div>";
text += "<div class='boks3'>";
text += "<h2>" + ReplaceStandardStrings(functions.get_user_music_stats_subtitle.replaceAll('{track_count}', number_with_spaces(results.user.user_music.data.track_plays))) + "</h2>";
text += "</div>";
text += "<div class='boks3'>";
text += "<p>" + ReplaceStandardStrings(functions.get_user_music_stats_subsubtitle) + "</p>";
text += "</div>";
text += "<div class='boks3'>";
text += "<div class='boks2'>";
if(functions.stats_order_by_plays !== false && functions.stats_order_by_duration !== false) {
text += '<button class="form-control btn" style="margin: 0.5em auto; width: fit-content;" name="user_music_data_tracks_button" id="user_music_data_tracks_button" onclick="top_list_sort_by(results.user.user_music.data.tracks_plays, functions.get_user_music_stats_top_track_plural, \'track\', false, false, \'user_music_data_tracks\', \'user_music_data_tracks_button\', functions);"><img src="assets/tweak.svg" class="btn_logo"><p2 id="user_music_data_tracks_button_text">' + functions.wrapperr_sort_plays + '</p2></button>';
}
if(functions.stats_order_by_duration !== false) {
text += top_list(results.user.user_music.data.tracks_duration, functions.get_user_music_stats_top_track_plural, "track", false, false, 'user_music_data_tracks');
} else {
text += top_list(results.user.user_music.data.tracks_plays, functions.get_user_music_stats_top_track_plural, "track", false, false, 'user_music_data_tracks');
}
text += "</div>";
text += "<div class='boks2'>";
if(functions.stats_order_by_plays !== false && functions.stats_order_by_duration !== false) {
text += '<button class="form-control btn" style="margin: 0.5em auto; width: fit-content;" name="user_music_data_albums_button" id="user_music_data_albums_button" onclick="top_list_sort_by(results.user.user_music.data.albums_plays, functions.get_user_music_stats_top_album_plural, \'album\', false, false, \'user_music_data_albums\', \'user_music_data_albums_button\', functions);"><img src="assets/tweak.svg" class="btn_logo"><p2 id="user_music_data_albums_button_text">' + functions.wrapperr_sort_plays + '</p2></button>';
}
if(functions.stats_order_by_duration !== false) {
text += top_list(results.user.user_music.data.albums_duration, functions.get_user_music_stats_top_album_plural, "album", false, false, 'user_music_data_albums');
} else {
text += top_list(results.user.user_music.data.albums_plays, functions.get_user_music_stats_top_album_plural, "album", false, false, 'user_music_data_albums');
}
text += "</div>";
text += "<div class='boks2'>";
if(functions.stats_order_by_plays !== false && functions.stats_order_by_duration !== false) {
text += '<button class="form-control btn" style="margin: 0.5em auto; width: fit-content;" name="user_music_data_artists_button" id="user_music_data_artists_button" onclick="top_list_sort_by(results.user.user_music.data.artists_plays, functions.get_user_music_stats_top_artist_plural, \'artist\', false, false, \'user_music_data_artists\', \'user_music_data_artists_button\', functions);"><img src="assets/tweak.svg" class="btn_logo"><p2 id="user_music_data_artists_button_text">' + functions.wrapperr_sort_plays + '</p2></button>';
}
if(functions.stats_order_by_duration !== false) {
text += top_list(results.user.user_music.data.artists_duration, functions.get_user_music_stats_top_artist_plural, "artist", false, false, 'user_music_data_artists');
} else {
text += top_list(results.user.user_music.data.artists_plays, functions.get_user_music_stats_top_artist_plural, "artist", false, false, 'user_music_data_artists');
}
text += "</div>";
text += "</div>";
text += "<div class='boks3'>";
text += "<div class='boks2' style='padding: 0;'>";
if(!results.user.user_music.data.user_album_oldest.error) {
text += "<div class='boks2'>";
text += oldest_album(results.user.user_music.data.user_album_oldest, functions);
text += "</div>";
}
text += "<div class='boks2'>";
text += you_spent(results.user.user_music.data.track_duration, 'music', functions);
text += "</div>";
text += "</div>";
text += "</div>";
text += "</div>";
} else if(results.user.user_music.data.track_plays == 1) {
text += "<div class='boks' data-color='mango' style='height: auto !important; width: 100%; padding-bottom: 25em; padding-top: 25em; height:10em; background-color:none;'>";
text += "<div class='boks3'>";
text += "<h1>" + ReplaceStandardStrings(functions.get_user_music_stats_title) + "</h1>";
text += "</div>";
text += "<div class='boks3'>";
text += "<h2>" + ReplaceStandardStrings(functions.get_user_music_stats_subtitle_one) + "</h2>";
text += "</div>";
text += "<div class='boks3'>";
text += "<p>" + ReplaceStandardStrings(functions.get_user_music_stats_subsubtitle_one) + "</p>";
text += "</div>";
text += "<div class='boks3'>";
text += "<div class='boks2'>";
text += top_list(results.user.user_music.data.tracks_duration, functions.get_user_music_stats_top_track, true, false, false);
text += "</div>";
text += "</div>";
text += "</div>";
} else {
text += "<div class='boks' data-color='mango' style='height: auto !important; width: 100%; padding-bottom: 25em; padding-top: 25em; height:10em; background-color:none;'>";
text += "<div class='boks3'>";
text += "<div class='boks2'>";
text += "<div class='status'>";
text += "<h1>" + ReplaceStandardStrings(functions.get_user_music_stats_title) + "</h1>";
text += "<h2>" + ReplaceStandardStrings(functions.get_user_music_stats_subtitle_none) + "</h2>";
text += "<p>" + ReplaceStandardStrings(functions.get_user_music_stats_subsubtitle_none) + "</p>";
text += '<img src="assets/img/bored.svg" style="margin: auto; display: block; width: 15em;">';
text += "</div>";
text += "</div>";
text += "</div>";
text += "</div>";
}
document.getElementById("search_results").innerHTML += text;
}
function oldest_movie(array, functions_data) {
var html = "";
html += "<div class='status' id='list3' style='padding:1em;min-width:15em;'>";
html += "<div class='stats'>";
html += ReplaceStandardStrings(functions_data.get_user_movie_stats_oldest_title.replaceAll('{movie_title}', '<b>' + array.title + "</b> (" + array.year + ")"));
html += '<br>';
html += '<br>';
if(array.year < 1950) {
html += ReplaceStandardStrings(functions_data.get_user_movie_stats_oldest_subtitle_pre_1950);
} else if(array.year < 1975) {
html += ReplaceStandardStrings(functions_data.get_user_movie_stats_oldest_subtitle_pre_1975);
} else if(array.year < 2000) {
html += ReplaceStandardStrings(functions_data.get_user_movie_stats_oldest_subtitle_pre_2000);
} else {
html += ReplaceStandardStrings(functions_data.get_user_movie_stats_oldest_subtitle);
}
html += '<br><img src="assets/img/old-man.svg" style="margin: auto; display: block; width: 15em;">';
html += "</div>";
html += "</div>";
return html;
}
function oldest_album(album, functions_data) {
var html = "";
html += "<div class='status' id='list3' style='padding:1em;min-width:15em;'>";
html += "<div class='stats'>";
html += ReplaceStandardStrings(functions_data.get_user_music_stats_oldest_album_title.replaceAll('{album_title}', '<b>' + album.parent_title + "</b> (" + album.year + ")</b>").replaceAll('{album_artist}', album.grandparent_title));
html += "<br><br>";
html += ReplaceStandardStrings(functions_data.get_user_music_stats_oldest_album_subtitle);
html += '<br><img src="assets/img/old-man.svg" style="margin: auto; display: block; width: 15em;">';
html += "</div>";
html += "</div>";
return html;
}
function completion_movie(user_movie_finishing_percent, single, functions_data) {
var html = "";
html += "<div class='status' id='list3' style='padding:1em;min-width:15em;'>";
html += "<div class='stats'>";
var str = JSON.stringify(user_movie_finishing_percent);
if(str.includes('.')) {
var percent = str.split('.');
percent = percent[0] + '.' + percent[1].slice(0, 2);
} else {
var percent = str;
}
if(!single) {
html += "<b>" + ReplaceStandardStrings(functions_data.get_user_movie_stats_movie_completion_title_plural.replaceAll('{movie_finish_percent}', percent)) + "</b>";
} else {
html += "<b>" + ReplaceStandardStrings(functions_data.get_user_movie_stats_movie_completion_title.replaceAll('{movie_finish_percent}', percent)) + "</b>";
}
if(user_movie_finishing_percent >= 90.0) {
html += '<img src="assets/img/champion.svg" style="margin: 1em auto; display: block; width: 15em;">';
} else {
html += '<br><br>';
}
html += functions_data.get_user_movie_stats_movie_completion_subtitle;
html += "</div>";
html += "</div>";
return html;
}
function paused_movie(array, single, functions_data) {
var html = "";
html += "<div class='status' id='list3' style='padding:1em;min-width:15em;'>";
if(array.paused_counter > 0) {
var pause_time = seconds_to_time(array.paused_counter, false);
if(!single) {
html += "<div class='stats'>";
html += ReplaceStandardStrings(functions_data.get_user_movie_stats_pause_title.replaceAll('{movie_title}', '<b>' + array.title + '</b>' + ' (' + array.year + ')'));
html += "<br>";
html += "<br>";
html += ReplaceStandardStrings(functions_data.get_user_movie_stats_pause_subtitle.replaceAll('{pause_duration}', pause_time));
html += "</div>";
} else {
html += "<div class='stats'>";
html += ReplaceStandardStrings(functions_data.get_user_movie_stats_pause_title_one);
html += "<br>";
html += "<br>";
html += ReplaceStandardStrings(functions_data.get_user_movie_stats_pause_subtitle_one.replaceAll('{pause_duration}', pause_time));
html += "</div>";
}
} else {
html += "<div class='stats'>";
html += '<b>' + ReplaceStandardStrings(functions_data.get_user_movie_stats_pause_title_none) + '</b>';
html += '<br><img src="assets/img/awards.svg" style="margin: auto; display: block; width: 15em;">';
html += "<br>";
html += ReplaceStandardStrings(functions_data.get_user_movie_stats_pause_subtitle_none);
html += "</div>";
}
html += "</div>";
return html;
}
function load_showbuddy(buddy_object, top_show, functions_data) {
var html = "";
html += "<div class='status' id='list3' style='padding:1em;min-width:15em;'>";
html += "<div class='stats'>";
if(!buddy_object.error) {
if(!buddy_object.buddy_found) {
html += ReplaceStandardStrings(functions_data.get_user_show_stats_buddy_title_none.replaceAll('{top_show_title}', '<b>' + top_show.grandparent_title + '</b>'));
html += '<br><img src="assets/img/quest.svg" style="margin: auto; display: block; width: 15em;"><br>';
html += ReplaceStandardStrings(functions_data.get_user_show_stats_buddy_subtitle_none);
} else {
html += ReplaceStandardStrings(functions_data.get_user_show_stats_buddy_title.replaceAll('{top_show_title}', '<b>' + top_show.grandparent_title + '</b>').replaceAll('{buddy_username}', buddy_object.buddy_name));
var combined = parseInt(top_show.duration) + parseInt(buddy_object.buddy_duration);
var combined_2 = seconds_to_time(combined);
html += '<img src="assets/img/social-event.svg" style="margin: auto; display: block; width: 15em;">';
html += ReplaceStandardStrings(functions_data.get_user_show_stats_buddy_subtitle.replaceAll('{buddy_duration_sum}', combined_2).replaceAll('{top_show_title}', top_show.grandparent_title));
}
}
html += "</div>";
html += "</div>";
return html;
}
function load_longest_episode(array, functions_data) {
var html = "";
html += "<div class='status' id='list3' style='padding:1em;min-width:15em;'>";
html += "<div class='stats'>";
html += ReplaceStandardStrings(functions_data.get_user_show_stats_most_played_title.replaceAll('{show_episode}', '<b>' + array.title + '</b>').replaceAll('{show_title}', array.grandparent_title));
html += '<br><br>';
html += ReplaceStandardStrings(functions_data.get_user_show_stats_most_played_subtitle.replaceAll('{episode_play_sum}', play_plays(array.plays)).replaceAll('{episode_duration_sum}', seconds_to_time(array.duration, false)));
html += "</div>";
html += "</div>";
return html;
}
function you_spent(time, category, functions_data) {
var html = "";
var time_str = seconds_to_time(time, false);
if(category === 'movies') {
html += "<div class='status' id='list3' style='padding:1em;min-width:15em;'>";
html += "<div class='stats'>";
html += ReplaceStandardStrings(functions_data.get_user_movie_stats_spent_title.replaceAll('{movie_sum_duration}', time_str));
html += '<br><img src="assets/img/watching-tv.svg" style="margin: auto; display: block; width: 15em;">';
html += "</div>";
html += "</div>";
} else if(category === 'shows') {
html += "<div class='status' id='list3' style='padding:1em;min-width:15em;'>";
html += ReplaceStandardStrings(functions_data.get_user_show_stats_spent_title.replaceAll('{show_sum_duration}', time_str));
html += '<br><img src="assets/img/watching-tv.svg" style="margin: auto; display: block; width: 15em;">';
html += "</div>";
} else if(category === 'music') {
html += "<div class='status' id='list3' style='padding:1em;min-width:15em;'>";
html += "<div class='stats'>";
html += ReplaceStandardStrings(functions_data.get_user_music_stats_spent_title.replaceAll('{music_sum_duration}', time_str));
if(time > 3600) {
var time_min = Math.floor(time / 60);
html += '<br><br>';
html += ReplaceStandardStrings(functions_data.get_user_music_stats_spent_subtitle.replaceAll('{music_sum_minutes}', number_with_spaces(time_min)));
}
html += '<br><img src="assets/img/music.svg" style="margin: auto; display: block; width: 15em;">';
html += "</div>";
html += "</div>";
} else {
html += "<div class='status' id='list3' style='padding:1em;min-width:15em;'>";
html += "Unknown category.";
html += "</div>";
}
return html;
}
function top_list(array, title, music, show, year, div_id) {
var html = "";
html += "<div class='status' id='" + div_id + "'>";
html += "<div class='stats'>";
html += "<div class='status-title'>" + ReplaceStandardStrings(title) + "</div>";
html += "<div class='stats-list'>";
for(i = 0; (i < array.length); i++) {
html += "<div class='item'>";
html += "<div class='number'>";
html += i+1 + ". ";
html += "</div>";
html += "<div class='movie_name'>";
if(music === "track" || music === "album") {
html+= array[i].grandparent_title + "<br>";
} else if(show) {
html+= "<b>" + array[i].grandparent_title + "</b>";
}
if(!show) {
html += "<b>";
if(music === "album") {
html += array[i].parent_title;
} else if(music === "artist") {
html += array[i].grandparent_title;
} else {
html += array[i].title;
}
}
html += "</b>";
var movie_hour = seconds_to_time(array[i].duration, true);
if(typeof(array[i].year) !== "undefined" && year) {
html += " (" + array[i].year + ")";
}
html += "<br>" + movie_hour + "<br>" + play_plays(array[i].plays);
html += "</div>";
html += "</div>";
}
html += "</div>";
html += "</div>";
html += "</div>";
return html;
}
function top_list_names(array, title, div_id) {
var html = "";
html += "<div class='status' id='" + div_id + "'>";
html += "<div class='stats'>";
html += "<div class='status-title'>" + ReplaceStandardStrings(title) + "</div>";
html += "<div class='stats-list'>";
for(i = 0; i < array.length; i++) {
if(i == 0) {
html += "<div class='item gold'>";
} else if(i == 1) {
html += "<div class='item silver'>";
} else if(i == 2) {
html += "<div class='item bronze'>";
} else {
html += "<div class='item'>";
}
html += "<div class='number'>";
html += i+1 + ". ";
html += "</div>";
html += "<div class='name'>";
html += array[i].user;
if(array[i].duration !== 0 && array[i].plays !== 0) {
var duration_string = seconds_to_time(array[i].duration, true);
html += "<br>"
html += duration_string
html += "<br>"
html += play_plays(array[i].plays)
}
html += "</div>";
html += "</div>";
}
html += "</div>";
html += "</div>";
html += "</div>";
return html;
}
// Toggle names list to plays or duration
function top_list_names_sort_by(array, title, div_id, button_id, functions_data) {
document.getElementById(div_id).outerHTML = top_list_names(array, title, div_id);
var button_text = document.getElementById(button_id + '_text');
if(button_text.innerHTML.includes(functions_data.wrapperr_sort_plays)) {
button_text.innerHTML = button_text.innerHTML = functions_data.wrapperr_sort_duration;
} else {
button_text.innerHTML = button_text.innerHTML = functions_data.wrapperr_sort_plays;
}
var button = document.getElementById(button_id);
if(button.getAttribute('onclick').includes('_duration')) {
button.setAttribute( "onclick", button.getAttribute('onclick').replaceAll('_duration', '_plays'));
} else {
button.setAttribute( "onclick", button.getAttribute('onclick').replaceAll('_plays', '_duration'));
}
}
//TOP USERS
function load_users() {
var text = "";
text += "<div class='boks' data-color='pistach' style='height: auto !important; width: 100%; padding-bottom: 25em; padding-top: 25em; height:10em; background-color: none;'>";
text += "<h1>" + ReplaceStandardStrings(functions.get_year_stats_title) + "</h1>";
text += "<h2>" + ReplaceStandardStrings(functions.get_year_stats_subtitle) + "</h2>";
text += "<p>" + ReplaceStandardStrings(functions.get_year_stats_subsubtitle) + "</p>";
text += "<div class='boks3'>";
if(functions.get_year_stats_leaderboard) {
text += "<div class='boks2'>";
if(functions.stats_order_by_plays !== false && functions.stats_order_by_duration !== false) {
text += '<button class="form-control btn" style="margin: 0.5em auto; width: fit-content;" name="year_stats_year_users_button" id="year_stats_year_users_button" onclick="top_list_names_sort_by(results.year_stats.year_users.data.users_plays, \'Top users\', \'year_stats_year_users\', \'year_stats_year_users_button\', functions);"><img src="assets/tweak.svg" class="btn_logo"><p2 id="year_stats_year_users_button_text">' + functions.wrapperr_sort_plays + '</p2></button>';
}
if(functions.stats_order_by_duration !== false) {
text += top_list_names(results.year_stats.year_users.data.users_duration, functions.get_year_stats_leaderboard_title, 'year_stats_year_users');
} else {
text += top_list_names(results.year_stats.year_users.data.users_plays, functions.get_year_stats_leaderboard_title, 'year_stats_year_users');
}
text += "</div>";
var time_movies = seconds_to_time(results.year_stats.year_movies.data.movie_duration, false);
var time_shows = seconds_to_time(results.year_stats.year_shows.data.show_duration, false);
var time_artists = seconds_to_time(results.year_stats.year_music.data.music_duration, false);
var function_sum = 0;
var time = 0;
text += "<div class='boks2'>";
text += "<div class='status' id='list3' style='padding:1em;min-width:15em;'>";
text += "<div class='stats'>";
if(functions.get_year_stats_movies && results.year_stats.year_movies.data.movie_plays > 0) {
text += ReplaceStandardStrings(functions.get_year_stats_movies_duration_title.replaceAll('{movie_duration_sum}', '<b>' + time_movies + '</b>'));
text += "<br><br>";
function_sum += 1;
time += results.year_stats.year_movies.data.movie_duration;
}
if(functions.get_year_stats_shows && results.year_stats.year_shows.data.show_plays > 0) {
text += ReplaceStandardStrings(functions.get_year_stats_shows_duration_title.replaceAll('{show_duration_sum}', '<b>' + time_shows + '</b>'));
text += "<br><br>";
function_sum += 1;
time += results.year_stats.year_shows.data.show_duration;
}
if(functions.get_year_stats_music && results.year_stats.year_music.data.music_plays > 0) {
text += ReplaceStandardStrings(functions.get_year_stats_music_duration_title.replaceAll('{music_duration_sum}', '<b>' + time_artists + '</b>'));
text += "<br><br>";
function_sum += 1;
time += results.year_stats.year_music.data.music_duration;
}
if(function_sum > 1) {
var time_all = seconds_to_time(Math.floor(time), false);
text += ReplaceStandardStrings(functions.get_year_stats_duration_sum_title.replaceAll('{all_duration_sum}', '<b>' + time_all + '</b>'));
}
text += '<img src="assets/img/home.svg" style="margin: auto; display: block; width: 15em;">';
text += "</div>";
text += "</div>";
text += "</div>";
}
text += "</div>";
text += "<div class='boks3'>";
if(functions.get_year_stats_movies && results.year_stats.year_movies.data.movie_plays > 0) {
text += "<div class='boks2'>";
if(functions.stats_order_by_plays !== false && functions.stats_order_by_duration !== false) {
text += '<button class="form-control btn" style="margin: 0.5em auto; width: fit-content;" name="year_stats_year_movies_button" id="year_stats_year_movies_button" onclick="top_list_sort_by(results.year_stats.year_movies.data.movies_plays, \'Top movies\', false, false, true, \'year_stats_year_movies\', \'year_stats_year_movies_button\', functions);"><img src="assets/tweak.svg" class="btn_logo"><p2 id="year_stats_year_movies_button_text">' + functions.wrapperr_sort_plays + '</p2></button>';
}
if(functions.stats_order_by_duration !== false) {
text += top_list(results.year_stats.year_movies.data.movies_duration, functions.get_year_stats_movies_title, false, false, true, 'year_stats_year_movies');
} else {
text += top_list(results.year_stats.year_movies.data.movies_plays, functions.get_year_stats_movies_title, false, false, true, 'year_stats_year_movies');
}
text += "</div>";
}
if(functions.get_year_stats_shows && results.year_stats.year_shows.data.show_plays > 0) {
text += "<div class='boks2'>";
if(functions.stats_order_by_plays !== false && functions.stats_order_by_duration !== false) {
text += '<button class="form-control btn" style="margin: 0.5em auto; width: fit-content;" name="year_stats_year_shows_button" id="year_stats_year_shows_button" onclick="top_list_sort_by(results.year_stats.year_shows.data.shows_plays, \'Top shows\', false, true, false, \'year_stats_year_shows\', \'year_stats_year_shows_button\', functions);"><img src="assets/tweak.svg" class="btn_logo"><p2 id="year_stats_year_shows_button_text">' + functions.wrapperr_sort_plays + '</p2></button>';
}
if(functions.stats_order_by_duration !== false) {
text += top_list(results.year_stats.year_shows.data.shows_duration, functions.get_year_stats_shows_title, false, true, false, 'year_stats_year_shows');
} else {
text += top_list(results.year_stats.year_shows.data.shows_plays, functions.get_year_stats_shows_title, false, true, false, 'year_stats_year_shows');
}
text += "</div>";
}
if(functions.get_year_stats_music && results.year_stats.year_music.data.music_plays > 0) {
text += "<div class='boks2'>";
if(functions.stats_order_by_plays !== false && functions.stats_order_by_duration !== false) {
text += '<button class="form-control btn" style="margin: 0.5em auto; width: fit-content;" name="year_stats_year_music_button" id="year_stats_year_music_button" onclick="top_list_sort_by(results.year_stats.year_music.data.artists_plays, \'Top artists\', \'artist\', false, false, \'year_stats_year_music\', \'year_stats_year_music_button\', functions);"><img src="assets/tweak.svg" class="btn_logo"><p2 id="year_stats_year_music_button_text">' + functions.wrapperr_sort_plays + '</p2></button>';
}
if(functions.stats_order_by_duration !== false) {
text += top_list(results.year_stats.year_music.data.artists_duration, functions.get_year_stats_music_title, "artist", false, false, 'year_stats_year_music');
} else {
text += top_list(results.year_stats.year_music.data.artists_plays, functions.get_year_stats_music_title, "artist", false, false, 'year_stats_year_music');
}
text += "</div>";
}
text += "</div>";
text += "</div>";
document.getElementById("search_results").innerHTML += text;
}
//Outro
function load_outro() {
var text = "";
text += "<div class='boks' data-color='charcoal' style='height: auto !important; width: 100%; padding-bottom: 15em; padding-top: 15em; height:10em; background-color:none;'>";
text += "<div class='boks3'>";
text += "<div class='boks2' style='margin: auto 0;'>";
text += '<img src="assets/img/new-years.svg" style="width:100%; ">';
text += "</div>";
text += "<div class='boks2' style='margin: auto 0;'>";
text += "<h1>" + ReplaceStandardStrings(functions.stats_outro_title) + "</h1>";
text += "<h2>" + ReplaceStandardStrings(functions.stats_outro_subtitle) + "</h2>";
text += "</div>";
text += "</div>";
text += "<div class='boks3'>";
text += "<div class='boks2' style='margin-top:5em;'>";
if(!link_mode && functions.create_share_links) {
text += "<div class='form-group' id='share_wrapped_div' style=''>";
text += "<button class='form-control btn' name='share_wrapped_button' id='share_wrapped_button' onclick='create_wrapped_link()'>";
text += "<img src='assets/share.svg' class='btn_logo'>";
text += "<p2 id='share_wrapped_button_text'>Share wrapped page</p2>";
text += "</button>";
text += "</div>";
text += "<div class='form-group' id='share_wrapped_results_title_div' style='margin: 0; display: none;'>";
text += "<p style='margin: 0'>Shareable link (valid for 7 days):</p>";
text += "</div>";
text += "<div class='form-group' id='share_wrapped_results_div' style='display: none; flex-direction: row; flex-wrap: wrap; align-content: flex-start; justify-content: center; align-items: flex-start; border-radius: 6px; margin: 0 0 0.5em 0; padding: 0.5em;'>";
text += "<div class='form-control btn' id='share_wrapped_delete_button' style='background-color: var(--white); cursor: default;'>";
text += "<span id='share_wrapped_results_url' class='share_wrapped_url' style=''></span>";
text += "<img id='share_wrapped_copy' src='assets/share.svg' style='' title='Click to copy the URL' onclick='copy_link_user();'>";
if(functions.plex_auth) {
text += "<img id='share_wrapped_delete' src='assets/trash.svg' style='' title='Click to delete this URL' onclick='delete_new_link_user();'>";
}
text += "</div>";
text += "</div>";
}
var url_home = window.location.href.split('?')[0];
text += "<div class='form-group' id='return_home_div' style=''>";
text += `<button class='form-control btn' name='return_home_button' id='return_home_button' onclick='window.location.href = "` + url_home + `";'>`;
text += "<img src='assets/restart.svg' class='btn_logo'>";
text += "<p2 id='return_home_text'>Return</p2>";
text += "</button>";
text += "</div>";
text += "</div>";
text += "</div>";
text += "</div>";
document.getElementById("search_results").innerHTML += text;
}
function create_wrapped_link() {
document.getElementById("share_wrapped_button").disabled = true;
document.getElementById("share_wrapped_button").style.opacity = '0.5';
wrapped_form = {
"data" : results,
"functions" : functions
};
var wrapped_data = JSON.stringify(wrapped_form);
// Debug lines
// console.log(wrapped_data);
// return;
var bearerToken = ""
if(functions.plex_auth) {
bearerToken = cookie
}
var xhttp = new XMLHttpRequest();
xhttp.onreadystatechange = function() {
if (this.readyState == 4 && (this.status == 200 || this.status == 201 || this.status == 400 || this.status == 500)) {
try {
var result= JSON.parse(this.responseText);
} catch(error) {
alert("API response can't be parsed.");
console.log('Error: ' + error);
console.log(this.responseText);
document.getElementById("share_wrapped_button").disabled = false;
document.getElementById("share_wrapped_button").style.opacity = '1';
}
if(result.error) {
alert(result.message);
document.getElementById("share_wrapped_button").disabled = false;
document.getElementById("share_wrapped_button").style.opacity = '1';
} else {
document.getElementById('share_wrapped_results_url').innerHTML = window.location.href.split('?')[0] + '?hash=' + result.data;
document.getElementById('share_wrapped_results_title_div').style.display = 'block';
document.getElementById('share_wrapped_results_div').style.display = 'flex';
document.getElementById("share_wrapped_button").disabled = true;
document.getElementById("share_wrapped_button").style.opacity = '0.5';
}
}
};
xhttp.withCredentials = true;
xhttp.open("post", api_url + "create/share-link");
xhttp.setRequestHeader("Content-Type", "application/json;charset=UTF-8");
xhttp.setRequestHeader("Authorization", bearerToken);
xhttp.send(wrapped_data);
}
//Converting seconds to time in string
var seconds_in_day = 86400;
var seconds_in_hour = 3600;
var seconds_in_minute = 60;
function seconds_to_time(seconds, comma) {
if(seconds >= seconds_in_day) {
var time = seconds_to_days(seconds, comma, functions);
} else if(seconds >= seconds_in_hour) {
var time = seconds_to_hours(seconds, comma, functions);
} else if(seconds >= seconds_in_minute) {
var time = seconds_to_minutes(seconds, comma, functions);
} else {
var time = seconds_to_seconds(seconds, functions);
}
return time;
}
function copy_link_user() {
/* Get the text field */
var copyText = document.getElementById("share_wrapped_results_url").innerHTML
/* Copy the text inside the text field */
navigator.clipboard.writeText(copyText)
alert("URL copied to clipboard.")
}
function delete_new_link_user() {
if(!confirm('Are you sure you want to delete this link?')) {
return;
}
cookie_form = {};
var cookie_data = JSON.stringify(cookie_form);
var xhttp = new XMLHttpRequest();
xhttp.onreadystatechange = function() {
if (this.readyState == 4 && this.status == 200) {
try {
var result= JSON.parse(this.responseText);
} catch(error) {
console.log('Failed to parse Wrapperr response. Response: ' + this.responseText)
}
if(!result.error) {
document.getElementById('share_wrapped_results_url').innerHTML = "";
document.getElementById('share_wrapped_results_title_div').style.display = 'none';
document.getElementById('share_wrapped_results_div').style.display = 'none';
document.getElementById("share_wrapped_button").disabled = false;
document.getElementById("share_wrapped_button").style.opacity = '1';
} else {
console.log(result.message);
}
}
};
xhttp.withCredentials = true;
xhttp.open("post", api_url + "delete/user-share-link");
xhttp.setRequestHeader("Content-Type", "application/json;charset=UTF-8");
xhttp.setRequestHeader("Authorization", cookie);
xhttp.send(cookie_data);
return;
}
// Change background color for each category
$(window).scroll(function() {
if(loaded) {
// Select the window, body and elements containing stats
var $window = $(window),
$body = $('body'),
$panel = $('.boks');
// Change 33% earlier than scroll position so colour is there when you arrive
var scroll = $window.scrollTop() + ($window.height() / 3);
$panel.each(function () {
var $this = $(this);
// If position is within range of this panel.
// So position of (position of top of div <= scroll position) && (position of bottom of div > scroll position).
// Remember we set the scroll to 33% earlier in scroll var.
if ($this.position().top <= scroll && $this.position().top + $this.height() > scroll) {
// Remove all classes on body with color-
$body.removeClass(function (index, css) {
return (css.match (/(^|\s)color-\S+/g) || []).join(' ');
});
// Add class of currently active div
$body.addClass('color-' + $(this).data('color'));
}
});
}
}).scroll();
function ReplaceStandardStrings(string) {
var currentTime = new Date()
try {
string = string.replaceAll('{track_count}', number_with_spaces(results.user.user_music.data.track_plays))
} catch (e) {
console.log('{track_count} replace failed')
}
try {
string = string.replaceAll('{movie_count}', number_with_spaces(results.user.user_movies.data.movie_plays))
} catch (e) {
console.log('{movie_count} replace failed')
}
try {
string = string.replaceAll('{show_count}', number_with_spaces(results.user.user_shows.data.show_plays))
} catch (e) {
console.log('{show_count} replace failed')
}
try {
string = string.replaceAll('{user}', results.user.name)
} catch (e) {
console.log('{user} replace failed')
}
try {
string = string.replaceAll('{user_id}', results.user.id)
} catch (e) {
console.log('{user_id} replace failed')
}
try {
string = string.replaceAll('{wrapperr_version}', wrapperr_version)
} catch (e) {
console.log('{wrapperr_version} replace failed')
}
try {
string = string.replaceAll('{application_name}', application_name)
} catch (e) {
console.log('{application_name} replace failed')
}
try {
const splits = results.date.split('-');
string = string.replaceAll('{current_year}', splits[0])
} catch (e) {
console.log('{current_year} replace failed')
}
try {
string = string.replaceAll('{current_date}', results.date)
} catch (e) {
console.log('{current_date} replace failed')
}
return string
}