2021-03-08 18:45:06 +00:00
function topFunction ( ) {
document . body . scrollTop = 0 ; // For Safari
document . documentElement . scrollTop = 0 ; // For Chrome, Firefox, IE and Opera
}
2023-10-24 13:56:37 +00:00
function login _menu ( basic _auth ) {
2021-03-08 18:45:06 +00:00
topFunction ( ) ;
2022-01-11 13:33:30 +00:00
var html = '<h2>Admin Login</h2>' ;
2023-10-24 13:56:37 +00:00
html += '<form id="password_login_form" onsubmit="log_in(' + basic _auth + ');return false">'
2021-03-08 18:45:06 +00:00
2021-10-04 12:26:50 +00:00
2023-10-24 13:56:37 +00:00
if ( ! basic _auth ) {
html += '<div class="form-group newline">' ;
html += '<label for="username" title="The username chosen during first-time setup.">Username:</label>' ;
html += '<input type="text" class="form-control" id="username" value="" placeholder="" minlength=4 autocomplete="on" required />' ;
html += '</div>' ;
html += '<div class="form-group newline">' ;
html += '<label for="password" title="The password chosen during first-time setup.">Password:</label>' ;
html += '<input type="password" class="form-control" id="password" value="" autocomplete="off" required />' ;
html += '</div>' ;
}
2021-03-08 18:45:06 +00:00
2022-01-11 13:33:30 +00:00
html += '<div class="form-group newline">' ;
html += '<div id="password_login_form_error"></div>' ;
html += '</div>' ;
html += '<div class="form-group newline">' ;
2022-12-09 16:38:23 +00:00
html += '<button type="submit" class="form-control btn" id="log_in_button"><img src="./assets/done.svg" class="btn_logo"><p2>Log in</p2></button>' ;
2021-03-08 18:45:06 +00:00
html += '</div>' ;
html += '</form>' ;
document . getElementById ( "setup" ) . innerHTML = html ;
}
2023-10-24 13:56:37 +00:00
function log _in ( basic _auth ) {
2022-01-11 13:33:30 +00:00
// Disable button
document . getElementById ( "log_in_button" ) . disabled = true ;
document . getElementById ( "log_in_button" ) . style . opacity = '0.5' ;
// Get variables
2023-10-24 13:56:37 +00:00
if ( ! basic _auth ) {
password = document . getElementById ( 'password' ) . value ;
username = document . getElementById ( 'username' ) . value ;
2022-01-11 13:33:30 +00:00
2023-10-24 13:56:37 +00:00
admin _login _form = { "admin_password" : password , "admin_username" : username } ;
2022-01-11 13:33:30 +00:00
2023-10-24 13:56:37 +00:00
var admin _login _data = JSON . stringify ( admin _login _form ) ;
} else {
var admin _login _data = ""
}
2022-01-11 13:33:30 +00:00
var xhttp = new XMLHttpRequest ( ) ;
xhttp . onreadystatechange = function ( ) {
2022-07-04 15:47:59 +00:00
if ( this . readyState == 4 ) {
2022-01-11 13:33:30 +00:00
try {
var result = JSON . parse ( this . responseText ) ;
} catch ( error ) {
console . log ( 'Failed to parse API response. Response: ' + this . responseText )
document . getElementById ( "log_in_button" ) . disabled = false ;
document . getElementById ( "log_in_button" ) . style . opacity = '1' ;
document . getElementById ( 'password' ) . value = '' ;
2022-07-04 22:11:19 +00:00
return ;
2022-01-11 13:33:30 +00:00
}
if ( result . error ) {
2023-10-25 13:14:02 +00:00
try {
document . getElementById ( "password_login_form_error" ) . innerHTML = result . error ;
document . getElementById ( "log_in_button" ) . disabled = false ;
document . getElementById ( "log_in_button" ) . style . opacity = '1' ;
document . getElementById ( 'password' ) . value = '' ;
} catch ( e ) {
console . log ( "Failed to reset input fields. Error: " + e )
}
2022-01-11 13:33:30 +00:00
} else {
2023-10-25 13:14:02 +00:00
tokenPrefix = "Bearer "
set _cookie ( "wrapperr-admin" , tokenPrefix + result . data , 3 ) ;
2022-01-11 13:33:30 +00:00
location . reload ( ) ;
}
}
} ;
xhttp . withCredentials = true ;
2022-12-03 12:06:48 +00:00
xhttp . open ( "post" , api _url + "login/admin" ) ;
2022-01-11 13:33:30 +00:00
xhttp . send ( admin _login _data ) ;
return ;
}
function set _password _form ( ) {
2021-03-08 18:45:06 +00:00
topFunction ( ) ;
2022-01-11 13:33:30 +00:00
var html = '<h2>Create admin</h2>' ;
html += '<form id="password_form" onsubmit="set_password();return false;">'
2021-03-08 18:45:06 +00:00
2022-01-11 13:33:30 +00:00
html += '<div class="form-group newline">' ;
2021-12-12 16:31:15 +00:00
html += '<label for="username" title="The username needed to log in as administrator and change the config-file remotely.">Set an admin username:</label>' ;
html += '<input type="text" class="form-control" id="username" value="' + username + '" placeholder="" minlength=4 autocomplete="on" required />' ;
2021-10-04 12:26:50 +00:00
html += '</div>' ;
2021-03-08 18:45:06 +00:00
html += '<div class="form-group">' ;
2021-12-12 16:31:15 +00:00
html += '<label for="password" title="The password needed to change the config-file remotely.">Set an admin password:</label>' ;
html += '<input type="password" class="form-control" id="password" value="' + password + '" placeholder="" autocomplete="off" required />' ;
2021-03-08 18:45:06 +00:00
html += '</div>' ;
html += '<div class="form-group">' ;
2021-12-12 16:31:15 +00:00
html += '<label for="password_2" title="The password needed to change the config-file remotely.">Repeat the password:</label>' ;
html += '<input type="password" class="form-control" id="password_2" value="' + password + '" placeholder="" autocomplete="off" required />' ;
2021-03-08 18:45:06 +00:00
html += '</div>' ;
2022-01-11 13:33:30 +00:00
html += '<div class="form-group newline">' ;
html += '<div id="password_form_error"></div>' ;
html += '</div>' ;
html += '<div class="form-group newline">' ;
2022-12-09 16:38:23 +00:00
html += '<button type="submit" class="form-control btn" id="create_admin_button"><img src="./assets/done.svg" class="btn_logo"><p2>Create account</p2></button>' ;
2021-03-08 18:45:06 +00:00
html += '</div>' ;
html += '</form>' ;
document . getElementById ( "setup" ) . innerHTML = html ;
}
2022-01-11 13:33:30 +00:00
function set _password ( ) {
// Disable button
document . getElementById ( "create_admin_button" ) . disabled = true ;
document . getElementById ( "create_admin_button" ) . style . opacity = '0.5' ;
// Check password match
if ( document . getElementById ( 'password' ) . value != document . getElementById ( 'password_2' ) . value ) {
alert ( "The passwords must match." ) ;
document . getElementById ( 'password' ) . value = "" ;
document . getElementById ( 'password_2' ) . value = "" ;
document . getElementById ( 'password' ) . focus ( ) ;
document . getElementById ( "create_admin_button" ) . disabled = false ;
document . getElementById ( "create_admin_button" ) . style . opacity = '1' ;
return false ;
} else {
password = document . getElementById ( 'password' ) . value ;
username = document . getElementById ( 'username' ) . value ;
}
2021-03-13 22:55:08 +00:00
2022-07-04 15:47:59 +00:00
admin _create _form = { "admin_password" : password , "admin_username" : username } ;
2022-01-11 13:33:30 +00:00
var admin _create _data = JSON . stringify ( admin _create _form ) ;
var xhttp = new XMLHttpRequest ( ) ;
xhttp . onreadystatechange = function ( ) {
2022-07-04 22:11:19 +00:00
if ( this . readyState == 4 ) {
2022-01-11 13:33:30 +00:00
try {
var result = JSON . parse ( this . responseText ) ;
} catch ( error ) {
console . log ( 'Failed to parse API response. Response: ' + this . responseText )
document . getElementById ( "create_admin_button" ) . disabled = false ;
document . getElementById ( "create_admin_button" ) . style . opacity = '1' ;
2022-07-04 22:11:19 +00:00
return ;
2022-01-11 13:33:30 +00:00
}
if ( result . error ) {
2023-10-25 13:14:02 +00:00
document . getElementById ( "password_form_error" ) . innerHTML = result . error ;
2022-01-11 13:33:30 +00:00
document . getElementById ( "create_admin_button" ) . disabled = false ;
document . getElementById ( "create_admin_button" ) . style . opacity = '1' ;
} else {
location . reload ( ) ;
}
}
} ;
xhttp . withCredentials = true ;
2022-12-03 12:06:48 +00:00
xhttp . open ( "post" , api _url + "create/admin" ) ;
2022-01-11 13:33:30 +00:00
xhttp . send ( admin _create _data ) ;
return ;
}
function update _password _form ( ) {
2021-03-08 18:45:06 +00:00
topFunction ( ) ;
2022-01-11 13:33:30 +00:00
var html = '<div class="form-group newline">' ;
2022-12-09 16:38:23 +00:00
html += '<button class="form-control btn" name="admin_menu_return_button" id="admin_menu_return_button" onclick="get_config(get_cookie(\'wrapperr-admin\'));"><img src="./assets/trash.svg" class="btn_logo"></img><p2 id="admin_menu_return_button_text">Return</p2></button>' ;
2022-01-11 13:33:30 +00:00
html += '</div>' ;
html += '<div class="form-group newline">' ;
html += '<hr>' ;
html += '</div>' ;
html += '<form id="update_password_form" onsubmit="return false;">'
html += '<div class="form-group newline">' ;
html += '<label for="username" title="The username needed to log in as administrator and change the config-file remotely.">Update admin username:</label>' ;
html += '<input type="text" class="form-control" id="username" value="' + username + '" placeholder="" minlength=4 autocomplete="on" required />' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="password" title="The password needed to change the config-file remotely.">Update admin password:</label>' ;
html += '<input type="password" class="form-control" id="password" value="" placeholder="" autocomplete="off" required />' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="password_2" title="The password needed to change the config-file remotely.">Repeat the password:</label>' ;
html += '<input type="password" class="form-control" id="password_2" value="" placeholder="" autocomplete="off" required />' ;
html += '</div>' ;
2023-10-25 13:14:02 +00:00
html += '<div class="form-group newline">' ;
html += '<label for="password_original" title="The current login password.">Current password:</label>' ;
html += '<input type="password" class="form-control" id="password_original" value="" placeholder="" autocomplete="off" required />' ;
html += '</div>' ;
2022-01-11 13:33:30 +00:00
html += '<div class="form-group newline">' ;
html += '<div id="password_form_error"></div>' ;
html += '</div>' ;
html += '<div class="form-group newline">' ;
2022-12-09 16:38:23 +00:00
html += '<button type="submit" class="form-control btn" onclick="update_password();" id="update_admin_button"><img src="./assets/done.svg" class="btn_logo"><p2>Update account</p2></button>' ;
2022-01-11 13:33:30 +00:00
html += '</div>' ;
html += '</form>' ;
document . getElementById ( "setup" ) . innerHTML = html ;
}
function update _password ( ) {
// Disable button
document . getElementById ( "update_admin_button" ) . disabled = true ;
document . getElementById ( "update_admin_button" ) . style . opacity = '0.5' ;
// Check password match
if ( document . getElementById ( 'password' ) . value != document . getElementById ( 'password_2' ) . value ) {
alert ( "The passwords must match." ) ;
document . getElementById ( 'password' ) . value = "" ;
document . getElementById ( 'password_2' ) . value = "" ;
document . getElementById ( 'password' ) . focus ( ) ;
document . getElementById ( "update_admin_button" ) . disabled = false ;
document . getElementById ( "update_admin_button" ) . style . opacity = '1' ;
return false ;
} else {
password = document . getElementById ( 'password' ) . value ;
2023-10-25 13:14:02 +00:00
password _original = document . getElementById ( 'password_original' ) . value ;
2022-01-11 13:33:30 +00:00
username = document . getElementById ( 'username' ) . value ;
2021-03-08 18:45:06 +00:00
}
2023-10-25 13:14:02 +00:00
admin _create _form = { "admin_password" : password , "admin_password_original" : password _original , "admin_username" : username } ;
2022-01-11 13:33:30 +00:00
var admin _create _data = JSON . stringify ( admin _create _form ) ;
var xhttp = new XMLHttpRequest ( ) ;
xhttp . onreadystatechange = function ( ) {
2022-07-04 22:11:19 +00:00
if ( this . readyState == 4 ) {
2022-01-11 13:33:30 +00:00
try {
var result = JSON . parse ( this . responseText ) ;
} catch ( error ) {
document . getElementById ( "password_form_error" ) . innerHTML = 'Failed to parse API response.' ;
console . log ( 'Failed to parse API response. Response: ' + this . responseText )
document . getElementById ( "update_admin_button" ) . disabled = false ;
document . getElementById ( "update_admin_button" ) . style . opacity = '1' ;
2022-07-04 22:11:19 +00:00
return ;
2022-01-11 13:33:30 +00:00
}
if ( result . error ) {
2023-10-25 13:14:02 +00:00
document . getElementById ( "password_form_error" ) . innerHTML = result . error ;
2022-01-11 13:33:30 +00:00
document . getElementById ( "update_admin_button" ) . disabled = false ;
document . getElementById ( "update_admin_button" ) . style . opacity = '1' ;
} else {
set _cookie ( "wrapperr-admin" , "" , 1 ) ;
location . reload ( ) ;
}
}
} ;
xhttp . withCredentials = true ;
2022-12-03 12:06:48 +00:00
xhttp . open ( "post" , api _url + "update/admin" ) ;
2022-07-04 15:47:59 +00:00
xhttp . setRequestHeader ( "Content-Type" , "application/json;charset=UTF-8" ) ;
2023-10-25 13:14:02 +00:00
xhttp . setRequestHeader ( "Authorization" , cookie ) ;
2022-01-11 13:33:30 +00:00
xhttp . send ( admin _create _data ) ;
return ;
}
function sign _out ( ) {
set _cookie ( "wrapperr-admin" , "" , 1 ) ;
location . reload ( ) ;
}
function admin _menu ( ) {
2021-03-08 18:45:06 +00:00
var html = '<div class="form-group">' ;
2022-12-09 16:38:23 +00:00
html += '<button class="form-control btn" onclick="update_password_form()"><img src="./assets/config.svg" class="btn_logo"><p2>Admin settings</p2></button>' ;
2022-01-11 13:33:30 +00:00
html += '</div>' ;
html += '<div class="form-group">' ;
2022-12-09 16:38:23 +00:00
html += '<button class="form-control btn" name="plex_signout_button" id="plex_signout_button" onclick="sign_out()"><img src="./assets/close.svg" class="btn_logo"></img><p2 id="plex_signout_button_text">Sign Out</p2></button>' ;
2022-01-11 13:33:30 +00:00
html += '</div>' ;
html += '<div class="form-group newline">' ;
html += '<hr>' ;
html += '</div>' ;
html += '<div class="form-group newline">' ;
2022-12-09 16:38:23 +00:00
html += '<button class="form-control btn" onclick="set_tautulli_settings()" id="set_tautulli_settings"><img src="./assets/config.svg" class="btn_logo"><p2>Tautulli settings</p2></button>' ;
2022-01-11 13:33:30 +00:00
html += '</div>' ;
html += '<div class="form-group newline">' ;
2022-12-09 16:38:23 +00:00
html += '<button class="form-control btn" onclick="set_wrapperr_settings()" id="set_wrapperr_settings"><img src="./assets/config.svg" class="btn_logo"><p2>Wrapperr settings</p2></button>' ;
2022-01-11 13:33:30 +00:00
html += '</div>' ;
html += '<div class="form-group newline">' ;
2022-12-09 16:38:23 +00:00
html += '<button class="form-control btn" onclick="set_wrapperr_customization()" id="set_wrapperr_customization"><img src="./assets/config.svg" class="btn_logo"><p2>Wrapperr customization</p2></button>' ;
2022-01-11 13:33:30 +00:00
html += '</div>' ;
html += '<div class="form-group newline">' ;
2022-12-09 16:38:23 +00:00
html += '<button class="form-control btn" onclick="caching_menu()" id="caching_menu"><img src="./assets/download.svg" class="btn_logo"><p2>Caching</p2></button>' ;
2022-01-11 13:33:30 +00:00
html += '</div>' ;
2022-07-04 15:47:59 +00:00
html += '<div class="form-group newline">' ;
2022-12-09 16:38:23 +00:00
html += '<button class="form-control btn" onclick="log_menu()" id="log_menu"><img src="./assets/document.svg" class="btn_logo"><p2>Log</p2></button>' ;
2022-07-04 15:47:59 +00:00
html += '</div>' ;
2022-01-11 13:33:30 +00:00
document . getElementById ( "setup" ) . innerHTML = html ;
if ( timezone === '' ) {
document . getElementById ( "set_wrapperr_settings" ) . style . border = '0.15em dashed var(--red)' ;
document . getElementById ( "caching_menu" ) . disabled = true ;
document . getElementById ( "caching_menu" ) . style . opacity = '0.5' ;
}
if ( wrapped _start === '' || wrapped _end === '' ) {
document . getElementById ( "set_wrapperr_customization" ) . style . border = '0.15em dashed var(--red)' ;
document . getElementById ( "caching_menu" ) . disabled = true ;
document . getElementById ( "caching_menu" ) . style . opacity = '0.5' ;
}
2022-11-27 17:12:11 +00:00
if ( tautulli [ 0 ] . tautulli _ip === '' || tautulli [ 0 ] . tautulli _apikey === '' || tautulli [ 0 ] . tautulli _length === '' || tautulli [ 0 ] . tautulli _port == 0 || tautulli [ 0 ] . tautulli _length == 0 ) {
2022-01-11 13:33:30 +00:00
document . getElementById ( "set_tautulli_settings" ) . style . border = '0.15em dashed var(--red)' ;
document . getElementById ( "caching_menu" ) . disabled = true ;
document . getElementById ( "caching_menu" ) . style . opacity = '0.5' ;
}
2022-07-04 15:47:59 +00:00
if ( ! use _logs ) {
document . getElementById ( "log_menu" ) . disabled = true ;
document . getElementById ( "log_menu" ) . style . opacity = '0.5' ;
}
2022-01-11 13:33:30 +00:00
}
function set _tautulli _settings ( ) {
topFunction ( ) ;
2022-11-27 17:12:11 +00:00
var html = '<div>' ;
html += '<div class="form-group newline">' ;
2022-12-09 16:38:23 +00:00
html += '<button class="form-control btn" name="admin_menu_return_button" id="admin_menu_return_button" onclick="get_config(get_cookie(\'wrapperr-admin\'));"><img src="./assets/trash.svg" class="btn_logo"></img><p2 id="admin_menu_return_button_text">Return</p2></button>' ;
2021-03-08 18:45:06 +00:00
html += '</div>' ;
2022-01-11 13:33:30 +00:00
html += '<div class="form-group newline">' ;
2021-12-12 16:31:15 +00:00
html += '<hr>' ;
2022-01-11 13:33:30 +00:00
html += '</div>' ;
2021-12-12 16:31:15 +00:00
2022-01-11 13:33:30 +00:00
html += '<form id="set_tautulli_form" onsubmit="return false;">'
2021-03-08 18:45:06 +00:00
2022-11-27 17:12:11 +00:00
for ( var i = 0 ; i < tautulli . length ; i ++ ) {
2021-03-08 18:45:06 +00:00
2022-11-27 17:12:11 +00:00
if ( tautulli . length > 1 ) {
html += '<div class="form-group newline">' ;
2022-12-09 16:38:23 +00:00
html += '<button style="" type="button" class="form-control btn" id="remove_tautulli_ ' + i + '" onclick="remove_tautulli_server(' + i + ');"><img src="./assets/trash.svg" class="btn_logo"><p2 id="test_tautulli_text">Remove Tautulli server</p2></button>' ;
2022-11-27 17:12:11 +00:00
html += '</div>' ;
}
2021-03-08 18:45:06 +00:00
2022-11-27 17:12:11 +00:00
html += '<div class="form-group">' ;
html += '<label for="tautulli_name_' + i + '" title="Just what we shall name your server.">Tautulli Server name:</label>' ;
html += '<input type="text" class="form-control" id="tautulli_name_' + i + '" value="' + tautulli [ i ] . tautulli _name + '" autocomplete="off" required placeholder="" /><br>' ;
html += '</div>' ;
2021-03-08 18:45:06 +00:00
2022-11-27 17:12:11 +00:00
html += '<div class="form-group">' ;
html += '<label for="tautulli_apikey_' + i + '" title="The API key is needed for Plex-Wrapped to interact with Tautulli. Commonly found at Tautulli->Settings->Web Interface->API Key.">Tautulli API key:</label>' ;
html += '<input type="text" class="form-control" id="tautulli_apikey_' + i + '" value="' + tautulli [ i ] . tautulli _apikey + '" autocomplete="off" required placeholder="" /><br>' ;
html += '</div>' ;
2021-03-08 18:45:06 +00:00
2022-11-27 17:12:11 +00:00
html += '<div class="form-group">' ;
html += '<label for="tautulli_ip_' + i + '" title="The IP address or domain that connects to Tautulli. No subfolders, as this is another setting, but subdomains can be defined.">IP or domain for Tautulli connection:</label>' ;
html += '<input type="text" class="form-control" id="tautulli_ip_' + i + '" value="' + tautulli [ i ] . tautulli _ip + '" required placeholder="" /><br>' ;
html += '</div>' ;
2021-03-08 18:45:06 +00:00
2022-11-27 17:12:11 +00:00
html += '<div class="form-group">' ;
html += '<label for="tautulli_port_' + i + '" title="The port Tautulli uses for connections. Typically 80 or 443 if a domain is used.">Port for Tautulli:</label>' ;
html += '<input type="number" class="form-control" id="tautulli_port_' + i + '" value="' + tautulli [ i ] . tautulli _port + '" placeholder="" required /><br>' ;
html += '</div>' ;
2021-10-04 20:21:43 +00:00
2022-11-27 17:12:11 +00:00
html += '<div class="form-group">' ;
html += '<label for="tautulli_length_' + i + '" title="The max amount of entries Tautulli responds with during API calls. Typically doesn\'t need to be changed, but if you have more than 5000 entries in a day, they won\'t be loaded.">Tautlli item length:</label>' ;
html += '<input type="number" min="0" class="form-control" id="tautulli_length_' + i + '" value="' + tautulli [ i ] . tautulli _length + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
2022-01-20 19:20:26 +00:00
2022-11-27 17:12:11 +00:00
html += '<div class="form-group">' ;
html += '<label for="tautulli_root_' + i + '" title="Subfolder for Tautulli, no slashes needed at the beginning or end. It is the folder accessed after the main IP/domain. For example: \'tautulli.com/subfolder\' would mean you enter \'subfolder\' here.">Tautulli URL Base: (Optional)</label>' ;
html += '<input type="text" class="form-control" id="tautulli_root_' + i + '" value="' + tautulli [ i ] . tautulli _root + '" autocomplete="off" placeholder=""/><br>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="tautulli_libraries_' + i + '" title="Comma separated list of ID\'s to use for statistics. If none are given, it will search all.">Library ID\'s to use: (Optional)</label>' ;
html += '<input type="text" class="form-control" id="tautulli_libraries_' + i + '" value="' + tautulli [ i ] . tautulli _libraries + '" autocomplete="off" placeholder=""/><br>' ;
html += '</div>' ;
html += '<div class="form-group newline">' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="tautulli_https_' + i + '" title="Enable if your connection uses HTTPS.">Use HTTPS:</label>' ;
html += '<input type="checkbox" class="form-control" id="tautulli_https_' + i + '" ' ;
if ( tautulli [ i ] . tautulli _https ) {
html += 'checked="' + tautulli [ i ] . tautulli _https + '" ' ;
}
html += '/><br>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="tautulli_grouping_' + i + '" title="If Tautulli should group related plays into one entry.">Use Tautulli grouping:</label>' ;
html += '<input type="checkbox" class="form-control" id="tautulli_grouping_' + i + '" ' ;
if ( tautulli [ i ] . tautulli _grouping ) {
html += 'checked="' + tautulli [ i ] . tautulli _grouping + '" ' ;
}
html += '/><br>' ;
html += '</div>' ;
html += '<div class="form-group newline">' ;
2022-12-09 16:38:23 +00:00
html += '<button style="background-color: lightgrey;" type="button" class="form-control btn" id="test_connection_' + i + '" onclick="test_tautulli_connection(' + i + ')"><img src="./assets/synchronize.svg" class="btn_logo"><p2 id="test_tautulli_text">Test Tautulli connection</p2></button>' ;
2022-11-27 17:12:11 +00:00
html += '</div>' ;
html += '<div class="form-group newline">' ;
html += '<hr>' ;
html += '</div>' ;
2022-01-11 13:33:30 +00:00
2022-01-20 19:20:26 +00:00
}
2022-11-27 17:12:11 +00:00
html += '<div class="form-group newline">' ;
2022-12-09 16:38:23 +00:00
html += '<button style="" type="button" class="form-control btn" id="add_tautulli_server" onclick="additional_tautulli_server();"><img src="./assets/plus.svg" class="btn_logo"><p2 id="test_tautulli_text">Add Tautulli server</p2></button>' ;
2022-01-20 19:20:26 +00:00
html += '</div>' ;
2022-01-11 13:33:30 +00:00
html += '<div class="form-group newline">' ;
2022-11-27 17:12:11 +00:00
html += '<hr>' ;
2022-01-11 13:33:30 +00:00
html += '</div>' ;
2022-11-29 18:32:30 +00:00
html += '<div class="form-group newline">' ;
html += '<div class="warning">!<br>If you changed any server names you must clear the cache for Wrapperr to function.</div>' ;
html += '</div>' ;
2022-07-04 15:47:59 +00:00
html += '<div class="form-group newline" title="Clear the cache now to include the newest settings.">' ;
html += '<label for="clear_cache">Clear cache now:<br>' ;
html += '<input type="checkbox" class="form-control" id="clear_cache" checked /></label>' ;
html += '</div>' ;
2022-01-11 13:33:30 +00:00
html += '<div class="form-group newline">' ;
2022-12-09 16:38:23 +00:00
html += '<button type="submit" class="form-control btn" onclick="set_tautulli_settings_call();" id="set_tautulli_form_button"><img src="./assets/done.svg" class="btn_logo"></img><p2 id="set_tautulli_form_button_text">Save</p2></button>' ;
2022-01-11 13:33:30 +00:00
html += '</div>' ;
html += '</form>' ;
2022-11-27 17:12:11 +00:00
html += '</div>' ;
2022-01-11 13:33:30 +00:00
document . getElementById ( "setup" ) . innerHTML = html ;
}
2022-11-27 17:12:11 +00:00
function additional _tautulli _server ( ) {
tautulli _apikey = ""
tautulli _ip = ""
tautulli _port = ""
tautulli _length = 5000
tautulli _root = ""
tautulli _libraries = ""
tautulli _grouping = true
tautulli _https = false
tautulli _name = ""
tautulli _object = {
"tautulli_apikey" : tautulli _apikey ,
"tautulli_ip" : tautulli _ip ,
"tautulli_port" : tautulli _port ,
"tautulli_length" : tautulli _length ,
"tautulli_root" : tautulli _root ,
"tautulli_libraries" : tautulli _libraries ,
"tautulli_grouping" : tautulli _grouping ,
"tautulli_https" : tautulli _https ,
"tautulli_name" : ""
} ;
tautulli . push ( tautulli _object ) ;
set _tautulli _settings ( ) ;
return ;
}
function remove _tautulli _server ( index ) {
if ( tautulli . length < 2 ) {
return
}
tautullinew = [ ]
for ( var i = 0 ; i < tautulli . length ; i ++ ) {
if ( i !== index ) {
tautullinew . push ( tautulli [ i ] )
}
}
tautulli = tautullinew
set _tautulli _settings ( ) ;
return ;
}
2022-01-11 13:33:30 +00:00
function set _tautulli _settings _call ( ) {
document . getElementById ( "set_tautulli_form_button" ) . disabled = true ;
document . getElementById ( "set_tautulli_form_button" ) . style . opacity = '0.5' ;
2022-11-27 17:12:11 +00:00
var tautulli _settings _array = [ ]
2022-01-11 13:33:30 +00:00
2022-11-27 17:12:11 +00:00
for ( var i = 0 ; i < 100 ; i ++ ) {
try {
tautulli _apikey = document . getElementById ( 'tautulli_apikey_' + i ) . value ;
} catch {
break ;
}
tautulli _apikey = document . getElementById ( 'tautulli_apikey_' + i ) . value ;
tautulli _ip = document . getElementById ( 'tautulli_ip_' + i ) . value ;
tautulli _port = parseInt ( document . getElementById ( 'tautulli_port_' + i ) . value ) ;
tautulli _length = parseInt ( document . getElementById ( 'tautulli_length_' + i ) . value ) ;
tautulli _root = document . getElementById ( 'tautulli_root_' + i ) . value ;
tautulli _libraries = document . getElementById ( 'tautulli_libraries_' + i ) . value ;
tautulli _grouping = document . getElementById ( 'tautulli_grouping_' + i ) . checked ;
tautulli _https = document . getElementById ( 'tautulli_https_' + i ) . checked ;
tautulli _name = document . getElementById ( 'tautulli_name_' + i ) . value ;
if ( tautulli _apikey === '' ) {
document . getElementById ( "set_tautulli_form_button" ) . disabled = false ;
document . getElementById ( "set_tautulli_form_button" ) . style . opacity = '1' ;
alert ( 'API key is required for Tautulli to function.' ) ;
document . getElementById ( 'tautulli_apikey_' + i ) . focus ( ) ;
return ;
}
if ( tautulli _apikey === '' ) {
document . getElementById ( "set_tautulli_form_button" ) . disabled = false ;
document . getElementById ( "set_tautulli_form_button" ) . style . opacity = '1' ;
alert ( 'Server name is required for Tautulli to function.' ) ;
document . getElementById ( 'tautulli_name_' + i ) . focus ( ) ;
return ;
}
if ( tautulli _ip === '' ) {
document . getElementById ( "set_tautulli_form_button" ) . disabled = false ;
document . getElementById ( "set_tautulli_form_button" ) . style . opacity = '1' ;
alert ( 'Tautulli IP is required for Tautulli to function.' ) ;
document . getElementById ( 'tautulli_ip_' + i ) . focus ( ) ;
return ;
}
if ( tautulli _length == 0 ) {
document . getElementById ( "set_tautulli_form_button" ) . disabled = false ;
document . getElementById ( "set_tautulli_form_button" ) . style . opacity = '1' ;
alert ( 'Tautulli item length is required for Tautulli to function.' ) ;
document . getElementById ( 'tautulli_length_' + i ) . focus ( ) ;
return ;
}
if ( tautulli _port == 0 ) {
document . getElementById ( "set_tautulli_form_button" ) . disabled = false ;
document . getElementById ( "set_tautulli_form_button" ) . style . opacity = '1' ;
alert ( 'Tautulli port is required for Tautulli to function. Use 80 for HTTP, 443 for HTTPS.' ) ;
document . getElementById ( 'tautulli_port_' + i ) . focus ( ) ;
return ;
}
tautulli _object = {
"tautulli_apikey" : tautulli _apikey ,
"tautulli_ip" : tautulli _ip ,
"tautulli_port" : tautulli _port ,
"tautulli_length" : tautulli _length ,
"tautulli_root" : tautulli _root ,
"tautulli_libraries" : tautulli _libraries ,
"tautulli_grouping" : tautulli _grouping ,
"tautulli_https" : tautulli _https ,
"tautulli_name" : tautulli _name
} ;
tautulli _settings _array . push ( tautulli _object )
2022-01-11 13:33:30 +00:00
}
2022-11-27 17:12:11 +00:00
if ( tautulli _settings _array . length < 1 ) {
alert ( "Failed to save Tautulli settings." )
2022-01-11 13:33:30 +00:00
document . getElementById ( "set_tautulli_form_button" ) . disabled = false ;
document . getElementById ( "set_tautulli_form_button" ) . style . opacity = '1' ;
2022-11-27 17:12:11 +00:00
return
2022-01-11 13:33:30 +00:00
}
2022-11-27 17:12:11 +00:00
var name _array = [ ]
for ( var i = 0 ; i < tautulli _settings _array . length ; i ++ ) {
var found _name = false
for ( var j = 0 ; j < name _array . length ; j ++ ) {
if ( tautulli _settings _array [ i ] . tautulli _name == name _array [ j ] ) {
found _name = true
}
}
if ( found _name ) {
alert ( "Tautulli server names must be unique." )
document . getElementById ( "set_tautulli_form_button" ) . disabled = false ;
document . getElementById ( "set_tautulli_form_button" ) . style . opacity = '1' ;
return
} else {
name _array . push ( tautulli _settings _array [ i ] . tautulli _name )
}
2022-07-04 15:47:59 +00:00
}
2022-11-27 17:12:11 +00:00
clear _cache = document . getElementById ( 'clear_cache' ) . checked ;
2022-01-11 13:33:30 +00:00
tautulli _settings _form = {
2022-07-04 15:47:59 +00:00
"clear_cache" : clear _cache ,
"data_type" : "tautulli_config" ,
2022-11-27 17:12:11 +00:00
"tautulli_config" : tautulli _settings _array ,
2022-07-04 15:47:59 +00:00
"wrapperr_data" : { } ,
"wrapperr_customize" : { }
2022-01-11 13:33:30 +00:00
} ;
var tautulli _settings _data = JSON . stringify ( tautulli _settings _form ) ;
2022-11-27 17:12:11 +00:00
console . log ( tautulli _settings _data )
//return;
2022-01-11 13:33:30 +00:00
var xhttp = new XMLHttpRequest ( ) ;
xhttp . onreadystatechange = function ( ) {
2022-07-04 22:11:19 +00:00
if ( this . readyState == 4 ) {
2022-01-11 13:33:30 +00:00
try {
var result = JSON . parse ( this . responseText ) ;
} catch ( error ) {
alert ( 'Failed to parse API response.' ) ;
console . log ( 'Failed to parse API response. Response: ' + this . responseText )
document . getElementById ( "set_tautulli_form_button" ) . disabled = false ;
document . getElementById ( "set_tautulli_form_button" ) . style . opacity = '1' ;
2022-07-04 22:11:19 +00:00
return ;
2022-01-11 13:33:30 +00:00
}
if ( result . error ) {
2023-10-25 13:14:02 +00:00
alert ( result . error ) ;
2022-01-11 13:33:30 +00:00
document . getElementById ( "set_tautulli_form_button" ) . disabled = false ;
document . getElementById ( "set_tautulli_form_button" ) . style . opacity = '1' ;
} else {
get _config ( get _cookie ( 'wrapperr-admin' ) ) ;
}
}
} ;
xhttp . withCredentials = true ;
2022-12-03 12:06:48 +00:00
xhttp . open ( "post" , api _url + "set/config" ) ;
2022-07-04 15:47:59 +00:00
xhttp . setRequestHeader ( "Content-Type" , "application/json;charset=UTF-8" ) ;
2023-10-25 13:14:02 +00:00
xhttp . setRequestHeader ( "Authorization" , cookie ) ;
2022-01-11 13:33:30 +00:00
xhttp . send ( tautulli _settings _data ) ;
return ;
}
function set _wrapperr _settings ( ) {
topFunction ( ) ;
var html = '<div class="form-group newline">' ;
2022-12-09 16:38:23 +00:00
html += '<button class="form-control btn" name="admin_menu_return_button" id="admin_menu_return_button" onclick="get_config(get_cookie(\'wrapperr-admin\'));"><img src="./assets/trash.svg" class="btn_logo"></img><p2 id="admin_menu_return_button_text">Return</p2></button>' ;
2022-01-11 13:33:30 +00:00
html += '</div>' ;
html += '<div class="form-group newline">' ;
html += '<hr>' ;
html += '</div>' ;
html += '<form id="wrapperr_settings_form" onsubmit="return false;">'
2022-07-04 15:47:59 +00:00
var wrapped _start _obj = new Date ( wrapped _start ) ;
var temp _date = wrapped _start _obj . toLocaleString ( "sv-SE" , {
year : "numeric" ,
month : "2-digit" ,
day : "2-digit" ,
hour : "2-digit" ,
minute : "2-digit" ,
second : "2-digit"
} ) . replace ( " " , "T" ) ;
html += '<div class="form-group newline">' ;
html += '<div class="warning">!<br>The more unique days in the wrapped period, the more Tautulli API calls. It is recommended to enable "Cache results for later use" to prevent long load times.</div>' ;
html += '</div>' ;
2021-03-08 18:45:06 +00:00
html += '<div class="form-group">' ;
2022-07-04 15:47:59 +00:00
html += '<label for="wrapped_start" title="The start of the period you want wrapped.">Start of wrapped period:<br>' ;
html += '<input type="datetime-local" class="form-control" id="wrapped_start" value="' + temp _date + '" required /><br>' ;
html += '</div>' ;
var wrapped _end _obj = new Date ( wrapped _end ) ;
var temp _date = wrapped _end _obj . toLocaleString ( "sv-SE" , {
year : "numeric" ,
month : "2-digit" ,
day : "2-digit" ,
hour : "2-digit" ,
minute : "2-digit" ,
second : "2-digit"
} ) . replace ( " " , "T" ) ;
html += '<div class="form-group">' ;
html += '<label for="wrapped_end" title="The end of your wrapped period. All data until this point is viable.">End of wrapped period:<br>' ;
html += '<input type="datetime-local" class="form-control" id="wrapped_end" value="' + temp _date + '" required /></label>' ;
html += '</div>' ;
html += '<div class="form-group newline">' ;
html += '<hr>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
2022-12-11 16:39:53 +00:00
html += '<label for="timezone" title="The timezone the data is located in, like \'Europe/Oslo\'. Type it exactly as it is specified in the IANA Time Zone database.">Timezone: <a href="https://en.wikipedia.org/wiki/List_of_tz_database_time_zones" target="_blank">(List)</a></label>' ;
2021-12-12 16:31:15 +00:00
html += '<input type="text" class="form-control" id="timezone" value="' + timezone + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
2022-01-11 13:33:30 +00:00
html += '<label for="application_name_str" title="Title of application shown on the pages. Replaces Wrapperr.">Application Name: (Optional)</label>' ;
html += '<input type="text" class="form-control" id="application_name_str" value="' + application _name _str + '" autocomplete="off" placeholder=""/><br>' ;
2021-03-08 18:45:06 +00:00
html += '</div>' ;
2021-03-12 22:45:44 +00:00
html += '<div class="form-group">' ;
2022-01-11 13:33:30 +00:00
html += '<label for="application_url_str" title="The domain/URL for Wrapperr. For example \'https://wrapperr-is-cool.example\'.">Wrapperr URL: (Optional)</label>' ;
html += '<input type="text" class="form-control" id="application_url_str" value="' + application _url _str + '" autocomplete="off" placeholder=""/><br>' ;
2021-03-12 22:45:44 +00:00
html += '</div>' ;
2021-03-08 18:45:06 +00:00
html += '<div class="form-group">' ;
2022-01-11 13:33:30 +00:00
html += '<label for="wrapperr_root" title="Subfolder for Wrapperr, no slashes needed at the beginning or end. It is the folder accessed after the main IP/domain. For example: \'mycooldomain.com/wrapperr\' would mean you enter \'wrapperr\' here.">Wrapperr URL Base: (Optional)</label>' ;
html += '<input type="text" class="form-control" id="wrapperr_root" value="' + wrapperr _root + '" autocomplete="off" placeholder=""/><br>' ;
html += '</div>' ;
html += '<div class="form-group newline">' ;
html += '</div>' ;
html += '<div class="form-group">' ;
2022-07-04 15:47:59 +00:00
html += '<label for="create_share_links" title="Grants users the ability to create a URL for sharing. URL is valid for 7 days.">Allow shareable URL creation:<br>' ;
2022-01-11 13:33:30 +00:00
html += '<input type="checkbox" class="form-control" id="create_share_links" ' ;
if ( create _share _links ) {
html += 'checked="' + create _share _links + '" ' ;
}
html += '/><br>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
2023-10-25 13:14:02 +00:00
html += '<label for="use_logs" title="Logs most actions into a log-file in the config folder. Requires a Wrapperr restart.">Log to file:<br>' ;
2022-01-11 13:33:30 +00:00
html += '<input type="checkbox" class="form-control" id="use_logs" ' ;
if ( use _logs ) {
html += 'checked="' + use _logs + '" ' ;
}
html += '/><br>' ;
html += '</div>' ;
2022-01-18 16:57:26 +00:00
2023-10-25 13:14:02 +00:00
html += '<div class="form-group">' ;
html += '<label for="basic_auth" title="Whether the admin can login in using the HTTP Basic standard.">Use Basic Auth:<br>' ;
html += '<input type="checkbox" class="form-control" id="basic_auth" ' ;
if ( basic _auth ) {
html += 'checked="' + basic _auth + '" ' ;
}
html += '/><br>' ;
html += '</div>' ;
2022-01-18 16:57:26 +00:00
html += '<div class="form-group">' ;
2022-07-04 15:47:59 +00:00
html += '<label for="plex_auth" title="Whether users can unwrap stats using any given Plex username/e-mail or by signing into Plex.">Use Plex Auth:<br>' ;
html += '<input type="checkbox" class="form-control" id="plex_auth" ' ;
if ( plex _auth ) {
html += 'checked="' + plex _auth + '" ' ;
2022-01-18 16:57:26 +00:00
}
html += '/><br>' ;
html += '</div>' ;
2022-07-04 15:47:59 +00:00
html += '<div class="form-group">' ;
html += '<label for="winter_theme" title="Disable if you don\'t like snow :(">Winter theme:<br>' ;
html += '<input type="checkbox" class="form-control" id="winter_theme" ' ;
if ( winter _theme ) {
html += 'checked="' + winter _theme + '" ' ;
}
html += '/><br>' ;
html += '</div>' ;
html += '<div class="form-group newline">' ;
html += '<hr>' ;
html += '</div>' ;
2022-01-11 13:33:30 +00:00
html += '<div class="form-group newline">' ;
2022-07-04 15:47:59 +00:00
html += '<div class="warning">!<br>Have this enabled to ensure short load times for users. Especially if the wrapped period is long.</div>' ;
2022-01-11 13:33:30 +00:00
html += '</div>' ;
html += '<div class="form-group newline">' ;
html += '<label for="use_cache" title="Caches your results in cache.json for later use.">Cache results for later use:<br>' ;
html += '<input type="checkbox" class="form-control" id="use_cache" ' ;
if ( use _cache ) {
html += 'checked="' + use _cache + '" ' ;
}
html += '/><br>' ;
html += '</div>' ;
2022-07-04 15:47:59 +00:00
html += '<div class="form-group newline">' ;
html += '<hr>' ;
html += '</div>' ;
2022-01-11 13:33:30 +00:00
html += '<div class="form-group newline" title="Clear the cache now to include the newest settings.">' ;
html += '<label for="clear_cache">Clear cache now:<br>' ;
html += '<input type="checkbox" class="form-control" id="clear_cache" checked /></label>' ;
html += '</div>' ;
html += '<div class="form-group newline">' ;
2022-12-09 16:38:23 +00:00
html += '<button type="submit" class="form-control btn" onclick="set_wrapperr_settings_call();" id="set_wrapperr_settings_form_button"><img src="./assets/done.svg" class="btn_logo"></img><p2 id="set_wrapperr_settings_form_button_text">Save</p2></button>' ;
2021-03-08 18:45:06 +00:00
html += '</div>' ;
html += '</form>' ;
document . getElementById ( "setup" ) . innerHTML = html ;
}
2022-01-11 13:33:30 +00:00
function set _wrapperr _settings _call ( ) {
2022-12-04 15:06:16 +00:00
var wrapperr _root _original = wrapperr _root ;
2022-01-11 13:33:30 +00:00
document . getElementById ( "set_wrapperr_settings_form_button" ) . disabled = true ;
document . getElementById ( "set_wrapperr_settings_form_button" ) . style . opacity = '0.5' ;
2022-07-04 15:47:59 +00:00
wrapped _start = new Date ( document . getElementById ( 'wrapped_start' ) . value ) ;
wrapped _end = new Date ( document . getElementById ( 'wrapped_end' ) . value ) ;
2022-01-11 13:33:30 +00:00
use _cache = document . getElementById ( 'use_cache' ) . checked ;
use _logs = document . getElementById ( 'use_logs' ) . checked ;
2022-07-04 15:47:59 +00:00
plex _auth = document . getElementById ( 'plex_auth' ) . checked ;
2023-10-25 13:14:02 +00:00
basic _auth = document . getElementById ( 'basic_auth' ) . checked ;
2022-01-11 13:33:30 +00:00
wrapperr _root = document . getElementById ( 'wrapperr_root' ) . value ;
application _name _str = document . getElementById ( 'application_name_str' ) . value ;
application _url _str = document . getElementById ( 'application_url_str' ) . value ;
create _share _links = document . getElementById ( 'create_share_links' ) . checked ;
timezone = document . getElementById ( 'timezone' ) . value ;
clear _cache = document . getElementById ( 'clear_cache' ) . checked ;
2022-07-04 15:47:59 +00:00
winter _theme = document . getElementById ( 'winter_theme' ) . checked ;
2022-01-11 13:33:30 +00:00
2022-12-04 15:06:16 +00:00
if ( wrapperr _root _original !== wrapperr _root ) {
if ( ! confirm ( "You have changed the Wrapperr root/base URL. Wrapperr will attempt to restart and the interface to access this webpage will change. If you are using an URL base you must use a trailing '/' at the end of your new URL." ) ) {
return ;
}
}
if ( wrapperr _root !== "" ) {
var wrapperr _root _last _char = wrapperr _root . charAt ( wrapperr _root . length - 1 ) ;
var wrapperr _root _first _char = wrapperr _root . charAt ( 0 ) ;
if ( wrapperr _root _last _char == "/" || wrapperr _root _first _char == "/" ) {
document . getElementById ( "set_wrapperr_settings_form_button" ) . disabled = false ;
document . getElementById ( "set_wrapperr_settings_form_button" ) . style . opacity = '1' ;
alert ( "No trailing or initial '/' needed for URL base." ) ;
document . getElementById ( 'wrapperr_root' ) . focus ( ) ;
return ;
}
}
2022-01-11 13:33:30 +00:00
if ( timezone === '' ) {
document . getElementById ( "set_wrapperr_settings_form_button" ) . disabled = false ;
document . getElementById ( "set_wrapperr_settings_form_button" ) . style . opacity = '1' ;
alert ( 'Timezone is required for Wrapperr to function.' ) ;
document . getElementById ( 'timezone' ) . focus ( ) ;
return ;
2021-03-08 18:45:06 +00:00
}
2022-07-04 15:47:59 +00:00
if ( wrapped _end < wrapped _start ) {
2022-12-03 12:06:48 +00:00
document . getElementById ( "set_wrapperr_settings_form_button" ) . disabled = false ;
document . getElementById ( "set_wrapperr_settings_form_button" ) . style . opacity = '1' ;
2022-07-04 15:47:59 +00:00
alert ( 'The wrapped end period must be later than the wrapped start period.' ) ;
document . getElementById ( 'wrapped_end' ) . focus ( ) ;
return ;
}
if ( wrapped _end === '' ) {
2022-12-03 12:06:48 +00:00
document . getElementById ( "set_wrapperr_settings_form_button" ) . disabled = false ;
document . getElementById ( "set_wrapperr_settings_form_button" ) . style . opacity = '1' ;
2022-07-04 15:47:59 +00:00
alert ( 'Ending of wrapped period is required for Wrapperr to function.' ) ;
document . getElementById ( 'wrapped_end' ) . focus ( ) ;
return ;
}
if ( wrapped _start === '' ) {
2022-12-03 12:06:48 +00:00
document . getElementById ( "set_wrapperr_settings_form_button" ) . disabled = false ;
document . getElementById ( "set_wrapperr_settings_form_button" ) . style . opacity = '1' ;
2022-07-04 15:47:59 +00:00
alert ( 'Start of wrapped period is required for Wrapperr to function.' ) ;
document . getElementById ( 'wrapped_start' ) . focus ( ) ;
return ;
}
2022-01-11 13:33:30 +00:00
wrapperr _settings _form = {
"clear_cache" : clear _cache ,
2022-07-04 15:47:59 +00:00
"data_type" : "wrapperr_data" ,
2022-12-03 12:06:48 +00:00
"tautulli_config" : [ ] ,
2022-07-04 15:47:59 +00:00
"wrapperr_customize" : { } ,
"wrapperr_data" : {
2022-01-11 13:33:30 +00:00
"use_cache" : use _cache ,
"use_logs" : use _logs ,
2022-07-04 15:47:59 +00:00
"plex_auth" : plex _auth ,
2023-10-25 13:14:02 +00:00
"basic_auth" : basic _auth ,
2022-01-11 13:33:30 +00:00
"wrapperr_root" : wrapperr _root ,
"create_share_links" : create _share _links ,
"timezone" : timezone ,
"application_name" : application _name _str ,
2022-07-04 15:47:59 +00:00
"application_url" : application _url _str ,
"wrapped_start" : Math . round ( wrapped _start . getTime ( ) / 1000 ) ,
"wrapped_end" : Math . round ( wrapped _end . getTime ( ) / 1000 ) ,
"winter_theme" : winter _theme
2022-01-11 13:33:30 +00:00
}
} ;
var wrapperr _settings _data = JSON . stringify ( wrapperr _settings _form ) ;
var xhttp = new XMLHttpRequest ( ) ;
xhttp . onreadystatechange = function ( ) {
2022-07-04 15:47:59 +00:00
if ( this . readyState == 4 ) {
2021-03-08 18:45:06 +00:00
2022-01-11 13:33:30 +00:00
try {
var result = JSON . parse ( this . responseText ) ;
} catch ( error ) {
alert ( 'Failed to parse API response.' ) ;
console . log ( 'Failed to parse API response. Response: ' + this . responseText ) ;
document . getElementById ( "set_wrapperr_settings_form_button" ) . disabled = false ;
document . getElementById ( "set_wrapperr_settings_form_button" ) . style . opacity = '1' ;
2022-07-04 22:11:19 +00:00
return ;
2022-01-11 13:33:30 +00:00
}
if ( result . error ) {
2023-10-25 13:14:02 +00:00
alert ( result . error ) ;
2022-01-11 13:33:30 +00:00
document . getElementById ( "set_wrapperr_settings_form_button" ) . disabled = false ;
document . getElementById ( "set_wrapperr_settings_form_button" ) . style . opacity = '1' ;
} else {
get _config ( get _cookie ( 'wrapperr-admin' ) ) ;
}
2021-12-12 16:31:15 +00:00
2022-01-11 13:33:30 +00:00
}
} ;
xhttp . withCredentials = true ;
2022-12-03 12:06:48 +00:00
xhttp . open ( "post" , api _url + "set/config" ) ;
2022-07-04 15:47:59 +00:00
xhttp . setRequestHeader ( "Content-Type" , "application/json;charset=UTF-8" ) ;
2023-10-25 13:14:02 +00:00
xhttp . setRequestHeader ( "Authorization" , cookie ) ;
2022-01-11 13:33:30 +00:00
xhttp . send ( wrapperr _settings _data ) ;
return ;
}
2021-03-08 18:45:06 +00:00
2022-01-11 13:33:30 +00:00
function set _wrapperr _customization ( ) {
topFunction ( ) ;
var html = '<div class="form-group newline">' ;
2022-12-09 16:38:23 +00:00
html += '<button class="form-control btn" name="admin_menu_return_button" id="admin_menu_return_button" onclick="get_config(get_cookie(\'wrapperr-admin\'));"><img src="./assets/trash.svg" class="btn_logo"></img><p2 id="admin_menu_return_button_text">Return</p2></button>' ;
2022-01-11 13:33:30 +00:00
html += '</div>' ;
html += '<div class="form-group newline">' ;
html += '<hr>' ;
2021-12-12 16:31:15 +00:00
html += '</div>' ;
2022-01-11 13:33:30 +00:00
html += '<form id="wrapperr_customization_form" onsubmit="return false;">'
2022-01-20 19:20:26 +00:00
html += '<div class="form-group">' ;
html += '<label for="stats_order_by_plays" title="Whether top lists can be ordered by plays.">Order lists by plays:<br>' ;
html += '<input type="checkbox" class="form-control" id="stats_order_by_plays" ' ;
if ( stats _order _by _plays ) {
html += 'checked="' + stats _order _by _plays + '" ' ;
}
html += '/><br>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="stats_order_by_duration" title="Whether top lists can be ordered by duration. Automatically enabled if Wrapperr can\'t order by plays.">Order lists by duration:<br>' ;
html += '<input type="checkbox" class="form-control" id="stats_order_by_duration" ' ;
if ( stats _order _by _duration ) {
html += 'checked="' + stats _order _by _duration + '" ' ;
}
html += '/><br>' ;
html += '</div>' ;
2022-01-11 13:33:30 +00:00
html += '<div class="form-group newline">' ;
2022-01-20 19:20:26 +00:00
html += '<hr>' ;
html += '</div>' ;
2022-10-15 20:07:15 +00:00
html += '<div class="form-group">' ;
html += '<label for="stats_top_list_length" title="Use 0 for no limit.">Maximum length of top lists:<br>' ;
html += '<input type="number" class="form-control" id="stats_top_list_length" value="' + stats _top _list _length + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
2023-02-07 07:52:38 +00:00
html += '<div class="form-group">' ;
html += '<label for="obfuscate_other_users" title="Replace other\'s username with randomly generated names.">Obfuscate other usernames:<br>' ;
html += '<input type="checkbox" class="form-control" id="obfuscate_other_users" ' ;
if ( obfuscate _other _users ) {
html += 'checked="' + obfuscate _other _users + '" ' ;
}
html += '/><br>' ;
html += '</div>' ;
2022-10-15 20:07:15 +00:00
html += '<div class="form-group newline">' ;
html += '<hr>' ;
html += '</div>' ;
2023-10-22 16:36:20 +00:00
html += '<div class="form-group newline">' ;
html += '<div class="warning">!<br>You can use string variables within the custom text.<br><a style="text-decoration: underline; cursor: pointer;" href="https://github.com/aunefyren/wrapperr/wiki/Wrapperr-customization" target="_blank">Read more here</a>.</div>' ;
html += '</div>' ;
html += '<div class="form-group newline">' ;
html += '<hr>' ;
html += '</div>' ;
2022-01-21 10:44:03 +00:00
html += '<div class="form-group">' ;
html += '<label for="wrapperr_front_page_title" title="Introduction title that is shown on top of the front page.">Introduction title for the front page:<br>' ;
html += '<textarea cols="40" rows="5" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 5em;" id="wrapperr_front_page_title" name="wrapperr_front_page_title" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="wrapperr_front_page_subtitle" title="Introduction subtitle text that is shown on the front page.">Introduction subtitle for the front page:<br>' ;
html += '<textarea cols="40" rows="5" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 5em;" id="wrapperr_front_page_subtitle" name="wrapperr_front_page_subtitle" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group newline">' ;
html += '<hr>' ;
html += '</div>' ;
2022-01-20 19:20:26 +00:00
html += '<div class="form-group">' ;
html += '<label for="stats_intro_title" title="Introduction title that is shown when the statistics are done loading.">Introduction title for statistics page:<br>' ;
html += '<textarea cols="40" rows="5" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 5em;" id="stats_intro_title" name="stats_intro_title" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="stats_intro_subtitle" title="Introduction subtitle text that is shown when the statistics are done loading. Could be used to inform about chosen timeframe.">Introduction subtitle for statistics page:<br>' ;
html += '<textarea cols="40" rows="5" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 5em;" id="stats_intro_subtitle" name="stats_intro_subtitle" value="" autocomplete="off"></textarea></label>' ;
2022-01-11 13:33:30 +00:00
html += '</div>' ;
html += '<div class="form-group newline">' ;
html += '<hr>' ;
html += '</div>' ;
html += '<div class="form-group newline">' ;
html += '<label for="get_user_movie_stats" title="Includes movie statistics in your wrapped period.">Get users movie statistics:<br>' ;
html += '<input type="checkbox" class="form-control" id="get_user_movie_stats" ' ;
if ( get _user _movie _stats ) {
html += 'checked="' + get _user _movie _stats + '" ' ;
}
html += '/><br>' ;
html += '</div>' ;
html += '<div class="form_hidden" id="get_user_movie_stats_custom">' ;
html += '<div class="form_block" id="plural">' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_movie_stats_title" title="Title on top of this section.">Movies title:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_movie_stats_title" name="get_user_movie_stats_title" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_movie_stats_subtitle" title="Subtitle underneath title on top of this section.">Movies subtitle:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_movie_stats_subtitle" name="get_user_movie_stats_subtitle" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_movie_stats_subsubtitle" title="Sub-subtitle underneath subtitle on top of this section.">Movies sub-subtitle:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_movie_stats_subsubtitle" name="get_user_movie_stats_subsubtitle" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block" id="singular">' ;
html += '<div class="form-group" id="singular">' ;
html += '<label for="get_user_movie_stats_subtitle_one" title="Subtitle underneath title on top of this section.">Movies subtitle for one movie:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_movie_stats_subtitle_one" name="get_user_movie_stats_subtitle_one" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_movie_stats_subsubtitle_one" title="Sub-subtitle underneath subtitle on top of this section.">Movies sub-subtitle for one movie:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_movie_stats_subsubtitle_one" name="get_user_movie_stats_subsubtitle_one" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block" id="none">' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_movie_stats_subtitle_none" title="Subtitle underneath title on top of this section.">Movies subtitle for no movies:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_movie_stats_subtitle_none" name="get_user_movie_stats_subtitle_none" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_movie_stats_subsubtitle_none" title="Sub-subtitle underneath subtitle on top of this section.">Movies sub-subtitle for no movies:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_movie_stats_subsubtitle_none" name="get_user_movie_stats_subsubtitle_none" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block">' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_movie_stats_top_movie" title="Custom title of the list of top movies (singular).">Title of top movie list:<br>' ;
html += '<input type="text" class="form-control" id="get_user_movie_stats_top_movie" value="' + get _user _movie _stats _top _movie + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_movie_stats_top_movie_plural" title="Custom title of the list of top movies (plural).">Title of top movies list:<br>' ;
html += '<input type="text" class="form-control" id="get_user_movie_stats_top_movie_plural" value="' + get _user _movie _stats _top _movie _plural + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block">' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_movie_stats_movie_completion_title" title="Title stating the completion of the seen movie.">Movie completion title:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_movie_stats_movie_completion_title" name="get_user_movie_stats_movie_completion_title" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_movie_stats_movie_completion_title_plural" title="Title stating the average completion of the seen movies.">Movies average completion title:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_movie_stats_movie_completion_title_plural" name="get_user_movie_stats_movie_completion_title_plural" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_movie_stats_movie_completion_subtitle" title="Subtitle underneath the movie-completion title.">Movies/movie completion subtitle:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_movie_stats_movie_completion_subtitle" name="get_user_movie_stats_movie_completion_subtitle" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block" id="plural">' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_movie_stats_pause_title" title="Title of the paused movie section.">Movie paused title:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_movie_stats_pause_title" name="get_user_movie_stats_pause_title" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_movie_stats_pause_subtitle" title="Subtitle of the paused movie section.">Movie paused subtitle:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_movie_stats_pause_subtitle" name="get_user_movie_stats_pause_subtitle" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block" id="singular">' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_movie_stats_pause_title_one" title="Title of the paused movie section when one movie was watched, but still paused.">One movie paused title:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_movie_stats_pause_title_one" name="get_user_movie_stats_pause_title_one" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_movie_stats_pause_subtitle_one" title="Subtitle of the paused movie section when one movie was watched, but still paused paused.">One movie paused subtitle:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_movie_stats_pause_subtitle_one" name="get_user_movie_stats_pause_subtitle_one" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block" id="none">' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_movie_stats_pause_title_none" title="Title of the paused movie section when no movies were ever paused.">No movie paused title:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_movie_stats_pause_title_none" name="get_user_movie_stats_pause_title_none" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_movie_stats_pause_subtitle_none" title="Subtitle of the paused movie section when no movies were ever paused.">No movie paused subtitle:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_movie_stats_pause_subtitle_none" name="get_user_movie_stats_pause_subtitle_none" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block">' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_movie_stats_oldest_title" title="Title of the oldest movie section.">Movie oldest title:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_movie_stats_oldest_title" name="get_user_movie_stats_oldest_title" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
2022-12-31 16:58:36 +00:00
html += '<label for="get_user_movie_stats_oldest_subtitle" title="Subtitle of the oldest movie section. Applied if the other specific ones are not applicable.">Movie oldest subtitle:<br>' ;
2022-01-11 13:33:30 +00:00
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_movie_stats_oldest_subtitle" name="get_user_movie_stats_oldest_subtitle" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_movie_stats_oldest_subtitle_pre_1950" title="Subtitle of the oldest movie section. Applied if movie is older than 1950.">Movie oldest subtitle (<1950):<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_movie_stats_oldest_subtitle_pre_1950" name="get_user_movie_stats_oldest_subtitle_pre_1950" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_movie_stats_oldest_subtitle_pre_1975" title="Subtitle of the oldest movie section. Applied if movie is older than 1975.">Movie oldest subtitle (<1975):<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_movie_stats_oldest_subtitle_pre_1975" name="get_user_movie_stats_oldest_subtitle_pre_1975" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_movie_stats_oldest_subtitle_pre_2000" title="Subtitle of the oldest movie section. Applied if movie is older than 2000.">Movie oldest subtitle (<2000):<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_movie_stats_oldest_subtitle_pre_2000" name="get_user_movie_stats_oldest_subtitle_pre_2000" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block">' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_movie_stats_spent_title" title="Title of the time spent on movies section.">Movie spent title:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_movie_stats_spent_title" name="get_user_movie_stats_spent_title" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form-group newline">' ;
2022-12-09 16:38:23 +00:00
html += '<button class="form-control btn" name="get_user_movie_stats_custom_button" id="get_user_movie_stats_custom_button" onclick="toggle_hidden_form(\'get_user_movie_stats_custom\')"><img src="./assets/tweak.svg" class="btn_logo"></img><p2 id="get_user_movie_stats_custom_button_text">Custom text</p2></button>' ;
2022-01-11 13:33:30 +00:00
html += '</div>' ;
html += '<div class="form-group newline">' ;
html += '<hr>' ;
2021-10-12 12:38:54 +00:00
html += '</div>' ;
2021-12-12 16:31:15 +00:00
html += '<div class="form-group">' ;
2022-01-11 13:33:30 +00:00
html += '<label for="get_user_show_stats" title="Includes show statistics in your wrapped period.">Get users show statistics:<br>' ;
html += '<input type="checkbox" class="form-control" id="get_user_show_stats" ' ;
if ( get _user _show _stats ) {
html += 'checked="' + get _user _show _stats + '" ' ;
}
html += '/><br>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_show_stats_buddy" title="Includes the users top show-buddy in your wrapped period. Requires show stats.">Get users show-buddy:<br>' ;
html += '<input type="checkbox" class="form-control" id="get_user_show_stats_buddy" ' ;
if ( get _user _show _stats _buddy ) {
html += 'checked="' + get _user _show _stats _buddy + '" ' ;
}
html += '/><br>' ;
html += '</div>' ;
html += '<div class="form-group newline">' ;
html += '</div>' ;
html += '<div class="form_hidden" id="get_user_show_stats_custom">' ;
html += '<div class="form_block" id="plural">' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_show_stats_title" title="Title on top of this section.">Shows title:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_show_stats_title" name="get_user_show_stats_title" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_show_stats_subtitle" title="Subtitle underneath title on top of this section.">Shows subtitle:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_show_stats_subtitle" name="get_user_show_stats_subtitle" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_show_stats_subsubtitle" title="Sub-subtitle underneath subtitle on top of this section.">Shows sub-subtitle:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_show_stats_subsubtitle" name="get_user_show_stats_subsubtitle" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block" id="singular">' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_show_stats_subtitle_one" title="Subtitle underneath title on top of this section.">Shows subtitle for one show:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_show_stats_subtitle_one" name="get_user_show_stats_subtitle_one" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_show_stats_subsubtitle_one" title="Sub-subtitle underneath subtitle on top of this section.">Shows sub-subtitle for one show:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_show_stats_subsubtitle_one" name="get_user_show_stats_subsubtitle_one" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block" id="none">' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_show_stats_subtitle_none" title="Subtitle underneath title on top of this section.">Shows subtitle for no shows:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_show_stats_subtitle_none" name="get_user_show_stats_subtitle_none" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_show_stats_subsubtitle_none" title="Sub-subtitle underneath subtitle on top of this section.">Shows sub-subtitle for no shows:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_show_stats_subsubtitle_none" name="get_user_show_stats_subsubtitle_none" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block">' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_show_stats_top_show" title="Custom title of the list of top show (singular).">Title of top show list:<br>' ;
html += '<input type="text" class="form-control" id="get_user_show_stats_top_show" value="' + get _user _show _stats _top _show + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_show_stats_top_show_plural" title="Custom title of the list of top shows (plural).">Title of top shows list:<br>' ;
html += '<input type="text" class="form-control" id="get_user_show_stats_top_show_plural" value="' + get _user _show _stats _top _show _plural + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block">' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_show_stats_most_played_title" title="Title on top of this section showing the top played episode.">Shows title for top episode:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_show_stats_most_played_title" name="get_user_show_stats_most_played_title" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_show_stats_most_played_subtitle" title="Subtitle underneath the title of this section.">Shows subtitle for top episode:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_show_stats_most_played_subtitle" name="get_user_show_stats_most_played_subtitle" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block">' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_show_stats_buddy_title" title="Title on top of this section showing the top show and the buddy who watches it as well.">Shows title buddy section:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_show_stats_buddy_title" name="get_user_show_stats_buddy_title" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_show_stats_buddy_subtitle" title="Subtitle underneath the title of this section.">Shows subtitle buddy section:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_show_stats_buddy_subtitle" name="get_user_show_stats_buddy_subtitle" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block" id="none">' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_show_stats_buddy_title_none" title="Title on top of this section showing the top show and the buddy who watches it as well, only, no buddy could be found.">Shows title buddy section (none):<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_show_stats_buddy_title_none" name="get_user_show_stats_buddy_title_none" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_show_stats_buddy_subtitle_none" title="Subtitle underneath the title of this section.">Shows subtitle buddy section (none):<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_show_stats_buddy_subtitle_none" name="get_user_show_stats_buddy_subtitle_none" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block">' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_show_stats_spent_title" title="Title of the time spent on shows section.">Show spent title:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_show_stats_spent_title" name="get_user_show_stats_spent_title" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form-group newline">' ;
2022-12-09 16:38:23 +00:00
html += '<button class="form-control btn" name="get_user_show_stats_custom_button" id="get_user_show_stats_custom_button" onclick="toggle_hidden_form(\'get_user_show_stats_custom\')"><img src="./assets/tweak.svg" class="btn_logo"></img><p2 id="get_user_show_stats_custom_button_text">Custom text</p2></button>' ;
2022-01-11 13:33:30 +00:00
html += '</div>' ;
html += '<div class="form-group newline">' ;
html += '<hr>' ;
html += '</div>' ;
html += '<div class="form-group newline">' ;
html += '<label for="get_user_music_stats" title="Includes music statistics in your wrapped period.">Get users music statistics:<br>' ;
html += '<input type="checkbox" class="form-control" id="get_user_music_stats" ' ;
if ( get _user _music _stats ) {
html += 'checked="' + get _user _music _stats + '" ' ;
2021-12-12 16:31:15 +00:00
}
html += '/><br>' ;
html += '</div>' ;
2022-01-11 13:33:30 +00:00
html += '<div class="form_hidden" id="get_user_music_stats_custom">' ;
html += '<div class="form_block">' ;
html += '<div class="form-group" id="plural">' ;
html += '<label for="get_user_music_stats_title" title="Title on top of this section.">Music title:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_music_stats_title" name="get_user_music_stats_title" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_music_stats_subtitle" title="Subtitle underneath title on top of this section.">Music subtitle:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_music_stats_subtitle" name="get_user_music_stats_subtitle" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_music_stats_subsubtitle" title="Sub-subtitle underneath subtitle on top of this section.">Music sub-subtitle:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_music_stats_subsubtitle" name="get_user_music_stats_subsubtitle" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block" id="singular">' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_music_stats_subtitle_one" title="Subtitle underneath title on top of this section.">Music subtitle for one track:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_music_stats_subtitle_one" name="get_user_music_stats_subtitle_one" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_music_stats_subsubtitle_one" title="Sub-subtitle underneath subtitle on top of this section.">Music sub-subtitle for one track:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_music_stats_subsubtitle_one" name="get_user_music_stats_subsubtitle_one" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block" id="none">' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_music_stats_subtitle_none" title="Subtitle underneath title on top of this section.">Music subtitle for no tracks:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_music_stats_subtitle_none" name="get_user_music_stats_subtitle_none" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_music_stats_subsubtitle_none" title="Sub-subtitle underneath subtitle on top of this section.">Music sub-subtitle for no tracks:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_music_stats_subsubtitle_none" name="get_user_music_stats_subsubtitle_none" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block" id="singular">' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_music_stats_top_track" title="Custom title of the list of top track (singular).">Title of top track list:<br>' ;
html += '<input type="text" class="form-control" id="get_user_music_stats_top_track" value="' + get _user _music _stats _top _track + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block" id="plural">' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_music_stats_top_track_plural" title="Custom title of the list of top tracks (plural).">Title of top tracks list:<br>' ;
html += '<input type="text" class="form-control" id="get_user_music_stats_top_track_plural" value="' + get _user _music _stats _top _track _plural + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_music_stats_top_album_plural" title="Custom title of the list of top albums (plural).">Title of top albums list:<br>' ;
html += '<input type="text" class="form-control" id="get_user_music_stats_top_album_plural" value="' + get _user _music _stats _top _album _plural + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_music_stats_top_artist_plural" title="Custom title of the list of top artists (plural).">Title of top artists list:<br>' ;
html += '<input type="text" class="form-control" id="get_user_music_stats_top_artist_plural" value="' + get _user _music _stats _top _artist _plural + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block">' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_music_stats_oldest_album_title" title="Title on top of this section.">Music title for oldest album:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_music_stats_oldest_album_title" name="get_user_music_stats_oldest_album_title" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
2021-10-04 12:57:28 +00:00
2022-01-11 13:33:30 +00:00
html += '<div class="form-group">' ;
html += '<label for="get_user_music_stats_oldest_album_subtitle" title="Subtitle underneath title of this section.">Music subtitle for oldest album:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_music_stats_oldest_album_subtitle" name="get_user_music_stats_oldest_album_subtitle" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
2021-03-08 18:45:06 +00:00
2022-01-11 13:33:30 +00:00
html += '</div>' ;
html += '<div class="form_block">' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_music_stats_spent_title" title="Title on top of this section showing time spent listening to music.">Music spent title:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_music_stats_spent_title" name="get_user_music_stats_spent_title" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_user_music_stats_spent_subtitle" title="Subtitle underneath title of this section.">Music spent subtitle:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_user_music_stats_spent_subtitle" name="get_user_music_stats_spent_subtitle" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '</div>' ;
2021-03-08 18:45:06 +00:00
html += '</div>' ;
2022-01-11 13:33:30 +00:00
html += '<div class="form-group newline">' ;
2022-12-09 16:38:23 +00:00
html += '<button class="form-control btn" name="get_user_music_stats_custom_button" id="get_user_music_stats_custom_button" onclick="toggle_hidden_form(\'get_user_music_stats_custom\')"><img src="./assets/tweak.svg" class="btn_logo"></img><p2 id="get_user_music_stats_custom_button_text">Custom text</p2></button>' ;
2021-10-01 23:21:18 +00:00
html += '</div>' ;
2022-01-11 13:33:30 +00:00
html += '<div class="form-group newline">' ;
2021-10-04 12:57:28 +00:00
html += '<hr>' ;
2022-01-11 13:33:30 +00:00
html += '</div>' ;
2021-10-04 12:57:28 +00:00
2021-10-01 23:21:18 +00:00
html += '<div class="form-group">' ;
2021-12-12 16:31:15 +00:00
html += '<label for="get_year_stats_movies" title="Includes server-wide movie statistics in your wrapped period.">Get server-wide movie statistics:<br>' ;
2021-10-01 23:21:18 +00:00
html += '<input type="checkbox" class="form-control" id="get_year_stats_movies" ' ;
if ( get _year _stats _movies ) {
html += 'checked="' + get _year _stats _movies + '" ' ;
}
html += '/><br>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
2021-12-12 16:31:15 +00:00
html += '<label for="get_year_stats_shows" title="Includes server-wide show statistics in your wrapped period.">Get server-wide show statistics:<br>' ;
2021-10-01 23:21:18 +00:00
html += '<input type="checkbox" class="form-control" id="get_year_stats_shows" ' ;
if ( get _year _stats _shows ) {
html += 'checked="' + get _year _stats _shows + '" ' ;
}
html += '/><br>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
2021-12-12 16:31:15 +00:00
html += '<label for="get_year_stats_music" title="Includes server-wide music statistics in your wrapped period.">Get server-wide music statistics:<br>' ;
2021-10-01 23:21:18 +00:00
html += '<input type="checkbox" class="form-control" id="get_year_stats_music" ' ;
if ( get _year _stats _music ) {
html += 'checked="' + get _year _stats _music + '" ' ;
}
html += '/><br>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
2021-12-12 16:31:15 +00:00
html += '<label for="get_year_stats_leaderboard" title="Creates a user leaderboard based on the server-wide statistics in your wrapped period.">Get server-wide leaderboard rankings:<br>' ;
2021-10-01 23:21:18 +00:00
html += '<input type="checkbox" class="form-control" id="get_year_stats_leaderboard" ' ;
if ( get _year _stats _leaderboard ) {
html += 'checked="' + get _year _stats _leaderboard + '" ' ;
2021-03-08 18:45:06 +00:00
}
html += '/><br>' ;
2021-09-21 13:01:14 +00:00
html += '</div>' ;
2021-10-04 12:57:28 +00:00
2022-10-15 21:47:53 +00:00
html += '<div class="form-group">' ;
html += '<label for="get_year_stats_leaderboard_numbers" title="Displays the statistics of users on the leaderboard.">Display server-wide leaderboard numbers:<br>' ;
html += '<input type="checkbox" class="form-control" id="get_year_stats_leaderboard_numbers" ' ;
if ( get _year _stats _leaderboard _numbers ) {
html += 'checked="' + get _year _stats _leaderboard _numbers + '" ' ;
}
html += '/><br>' ;
html += '</div>' ;
2022-01-11 13:33:30 +00:00
html += '<div class="form-group newline">' ;
html += '</div>' ;
html += '<div class="form_hidden" id="get_year_stats_custom">' ;
html += '<div class="form_block">' ;
html += '<div class="form-group">' ;
html += '<label for="get_year_stats_title" title="Title on top of this section.">Server-wide title:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_year_stats_title" name="get_year_stats_title" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_year_stats_subtitle" title="Subtitle underneath title on top of this section.">Server-wide subtitle:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_year_stats_subtitle" name="get_year_stats_subtitle" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_year_stats_subsubtitle" title="Sub-subtitle underneath subtitle on top of this section.">Server-wide sub-subtitle:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_year_stats_subsubtitle" name="get_year_stats_subsubtitle" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block" id="">' ;
html += '<div class="form-group">' ;
html += '<label for="get_year_stats_movies_title" title="Custom title of the list of top movies.">Title of top movies list:<br>' ;
html += '<input type="text" class="form-control" id="get_year_stats_movies_title" value="' + get _year _stats _movies _title + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_year_stats_shows_title" title="Custom title of the list of top shows.">Title of top shows list:<br>' ;
html += '<input type="text" class="form-control" id="get_year_stats_shows_title" value="' + get _year _stats _shows _title + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_year_stats_music_title" title="Custom title of the list of top artists.">Title of top artists list:<br>' ;
html += '<input type="text" class="form-control" id="get_year_stats_music_title" value="' + get _year _stats _music _title + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_year_stats_leaderboard_title" title="Custom title of the list of top users.">Title of top users list:<br>' ;
html += '<input type="text" class="form-control" id="get_year_stats_leaderboard_title" value="' + get _year _stats _leaderboard _title + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block">' ;
html += '<div class="form-group">' ;
html += '<label for="get_year_stats_movies_duration_title" title="Title on top of this section showing duration spent on movies.">Server-wide movie duration:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_year_stats_movies_duration_title" name="get_year_stats_movies_duration_title" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_year_stats_shows_duration_title" title="Title on top of this section showing duration spent on shows.">Server-wide show duration:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_year_stats_shows_duration_title" name="get_year_stats_shows_duration_title" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_year_stats_music_duration_title" title="Title on top of this section showing duration spent on music.">Server-wide music duration:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_year_stats_music_duration_title" name="get_year_stats_music_duration_title" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="get_year_stats_duration_sum_title" title="Title on top of this section showing duration spent on all categories.">Server-wide content duration:<br>' ;
html += '<textarea cols="40" rows="2" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 2em;" id="get_year_stats_duration_sum_title" name="get_year_stats_duration_sum_title" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form-group newline">' ;
2022-12-09 16:38:23 +00:00
html += '<button class="form-control btn" name="get_year_stats_custom_button" id="get_year_stats_custom_button" onclick="toggle_hidden_form(\'get_year_stats_custom\')"><img src="./assets/tweak.svg" class="btn_logo"></img><p2 id="get_year_stats_custom_button_text">Custom text</p2></button>' ;
2022-01-11 13:33:30 +00:00
html += '</div>' ;
html += '<div class="form-group newline">' ;
2021-10-04 12:57:28 +00:00
html += '<hr>' ;
2021-03-08 18:45:06 +00:00
html += '</div>' ;
2022-01-11 13:33:30 +00:00
2022-01-20 19:20:26 +00:00
html += '<div class="form-group">' ;
html += '<label for="stats_outro_title" title="Title that is shown at the bottom, when the statistics are done.">Outro title for statistics page:<br>' ;
html += '<textarea cols="40" rows="5" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 5em;" id="stats_outro_title" name="stats_outro_title" value="" autocomplete="off"></textarea></label>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="stats_outro_subtitle" title="Subtitle that is shown at the bottom, when the statistics are done.">Outro subtitle for statistics page:<br>' ;
html += '<textarea cols="40" rows="5" class="form-control" style="overflow-x: hidden;resize:vertical;min-height: 5em;" id="stats_outro_subtitle" name="stats_outro_subtitle" value="" autocomplete="off"></textarea></label>' ;
2022-01-11 13:33:30 +00:00
html += '</div>' ;
html += '<div class="form-group newline">' ;
html += '<hr>' ;
html += '</div>' ;
html += '<div class="form_hidden" id="wrapperr_language">' ;
html += '<div class="form_block">' ;
html += '<div class="form-group">' ;
html += '<label for="wrapperr_and" title="Word alternative for when \'and\' appears.">Alternative for \'and\':<br>' ;
html += '<input type="text" class="form-control" id="wrapperr_and" value="' + wrapperr _and + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block">' ;
html += '<div class="form-group">' ;
html += '<label for="wrapperr_play" title="Word alternative for when \'play\' appears.">Alternative for \'play\':<br>' ;
html += '<input type="text" class="form-control" id="wrapperr_play" value="' + wrapperr _play + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="wrapperr_play_plural" title="Word alternative for when \'plays\' appears.">Alternative for \'plays\':<br>' ;
html += '<input type="text" class="form-control" id="wrapperr_play_plural" value="' + wrapperr _play _plural + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block">' ;
html += '<div class="form-group">' ;
html += '<label for="wrapperr_day" title="Word alternative for when \'day\' appears.">Alternative for \'day\':<br>' ;
html += '<input type="text" class="form-control" id="wrapperr_day" value="' + wrapperr _day + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="wrapperr_day_plural" title="Word alternative for when \'days\' appears.">Alternative for \'days\':<br>' ;
html += '<input type="text" class="form-control" id="wrapperr_day_plural" value="' + wrapperr _day _plural + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block">' ;
html += '<div class="form-group">' ;
html += '<label for="wrapperr_hour" title="Word alternative for when \'hour\' appears.">Alternative for \'hour\':<br>' ;
html += '<input type="text" class="form-control" id="wrapperr_hour" value="' + wrapperr _hour + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="wrapperr_hour_plural" title="Word alternative for when \'hours\' appears.">Alternative for \'hours\':<br>' ;
html += '<input type="text" class="form-control" id="wrapperr_hour_plural" value="' + wrapperr _hour _plural + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block">' ;
html += '<div class="form-group">' ;
html += '<label for="wrapperr_minute" title="Word alternative for when \'minute\' appears.">Alternative for \'minute\':<br>' ;
html += '<input type="text" class="form-control" id="wrapperr_minute" value="' + wrapperr _minute + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="wrapperr_minute_plural" title="Word alternative for when \'minutes\' appears.">Alternative for \'minutes\':<br>' ;
html += '<input type="text" class="form-control" id="wrapperr_minute_plural" value="' + wrapperr _minute _plural + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block">' ;
html += '<div class="form-group">' ;
html += '<label for="wrapperr_second" title="Word alternative for when \'second\' appears.">Alternative for \'second\':<br>' ;
html += '<input type="text" class="form-control" id="wrapperr_second" value="' + wrapperr _second + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="wrapperr_second_plural" title="Word alternative for when \'seconds\' appears.">Alternative for \'seconds\':<br>' ;
html += '<input type="text" class="form-control" id="wrapperr_second_plural" value="' + wrapperr _second _plural + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form_block">' ;
html += '<div class="form-group">' ;
html += '<label for="wrapperr_sort_plays" title="Text alternative for \'Sort by plays\' button.">\'Sort by plays\' alternative:<br>' ;
html += '<input type="text" class="form-control" id="wrapperr_sort_plays" value="' + wrapperr _sort _plays + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
html += '<div class="form-group">' ;
html += '<label for="wrapperr_sort_duration" title="Text alternative for \'Sort by duration\' button.">\'Sort by duration\' alternative:<br>' ;
html += '<input type="text" class="form-control" id="wrapperr_sort_duration" value="' + wrapperr _sort _duration + '" autocomplete="off" placeholder="" required /><br>' ;
html += '</div>' ;
html += '</div>' ;
html += '</div>' ;
html += '<div class="form-group newline">' ;
2022-12-09 16:38:23 +00:00
html += '<button class="form-control btn" name="wrapperr_language_button" id="get_user_show_stats_custom_button" onclick="toggle_hidden_form(\'wrapperr_language\')"><img src="./assets/tweak.svg" class="btn_logo"></img><p2 id="wrapperr_language_button_text">Custom language</p2></button>' ;
2022-01-11 13:33:30 +00:00
html += '</div>' ;
html += '<div class="form-group newline">' ;
html += '<hr>' ;
2021-03-08 18:45:06 +00:00
html += '</div>' ;
2022-11-29 18:32:30 +00:00
html += '<div class="form-group newline">' ;
html += '<div class="warning">!<br>Many of the settings here need a clean cache to be applied.</div>' ;
html += '</div>' ;
2022-01-11 13:33:30 +00:00
html += '<div class="form-group newline" title="Clear the cache now to include the newest settings.">' ;
2021-12-12 16:31:15 +00:00
html += '<label for="clear_cache">Clear cache now:<br>' ;
2021-03-08 18:45:06 +00:00
html += '<input type="checkbox" class="form-control" id="clear_cache" checked /></label>' ;
html += '</div>' ;
2022-01-11 13:33:30 +00:00
html += '<div class="form-group newline">' ;
2022-12-09 16:38:23 +00:00
html += '<button type="submit" class="form-control btn" onclick="set_wrapperr_customization_call();" id="set_wrapperr_customization_form_button"><img src="./assets/done.svg" class="btn_logo"></img><p2 id="set_wrapperr_customization_form_button_text">Save</p2></button>' ;
2021-03-08 18:45:06 +00:00
html += '</div>' ;
html += '</form>' ;
2022-01-11 13:33:30 +00:00
// Place content from config
2021-03-08 18:45:06 +00:00
document . getElementById ( "setup" ) . innerHTML = html ;
2022-01-11 13:33:30 +00:00
2022-01-21 10:44:03 +00:00
document . getElementById ( "wrapperr_front_page_title" ) . value = wrapperr _front _page _title ;
document . getElementById ( "wrapperr_front_page_subtitle" ) . value = wrapperr _front _page _subtitle ;
2022-01-20 19:20:26 +00:00
document . getElementById ( "stats_intro_title" ) . value = stats _intro _title ;
document . getElementById ( "stats_intro_subtitle" ) . value = stats _intro _subtitle ;
document . getElementById ( "stats_outro_title" ) . value = stats _outro _title ;
document . getElementById ( "stats_outro_subtitle" ) . value = stats _outro _subtitle ;
2022-10-15 20:07:15 +00:00
document . getElementById ( "stats_top_list_length" ) . value = stats _top _list _length ;
2022-01-11 13:33:30 +00:00
document . getElementById ( "get_user_movie_stats_title" ) . value = get _user _movie _stats _title ;
document . getElementById ( "get_user_movie_stats_subtitle" ) . value = get _user _movie _stats _subtitle ;
document . getElementById ( "get_user_movie_stats_subsubtitle" ) . value = get _user _movie _stats _subsubtitle ;
document . getElementById ( "get_user_movie_stats_subtitle_one" ) . value = get _user _movie _stats _subtitle _one ;
document . getElementById ( "get_user_movie_stats_subsubtitle_one" ) . value = get _user _movie _stats _subsubtitle _one ;
document . getElementById ( "get_user_movie_stats_subtitle_none" ) . value = get _user _movie _stats _subtitle _none ;
document . getElementById ( "get_user_movie_stats_subsubtitle_none" ) . value = get _user _movie _stats _subsubtitle _none ;
document . getElementById ( "get_user_movie_stats_movie_completion_title" ) . value = get _user _movie _stats _movie _completion _title ;
document . getElementById ( "get_user_movie_stats_movie_completion_title_plural" ) . value = get _user _movie _stats _movie _completion _title _plural ;
document . getElementById ( "get_user_movie_stats_movie_completion_subtitle" ) . value = get _user _movie _stats _movie _completion _subtitle ;
document . getElementById ( "get_user_movie_stats_pause_title" ) . value = get _user _movie _stats _pause _title ;
document . getElementById ( "get_user_movie_stats_pause_subtitle" ) . value = get _user _movie _stats _pause _subtitle ;
document . getElementById ( "get_user_movie_stats_pause_title_one" ) . value = get _user _movie _stats _pause _title _one ;
document . getElementById ( "get_user_movie_stats_pause_subtitle_one" ) . value = get _user _movie _stats _pause _subtitle _one ;
document . getElementById ( "get_user_movie_stats_pause_title_none" ) . value = get _user _movie _stats _pause _title _none ;
document . getElementById ( "get_user_movie_stats_pause_subtitle_none" ) . value = get _user _movie _stats _pause _subtitle _none ;
document . getElementById ( "get_user_movie_stats_oldest_title" ) . value = get _user _movie _stats _oldest _title ;
document . getElementById ( "get_user_movie_stats_oldest_subtitle" ) . value = get _user _movie _stats _oldest _subtitle ;
document . getElementById ( "get_user_movie_stats_oldest_subtitle_pre_1950" ) . value = get _user _movie _stats _oldest _subtitle _pre _1950 ;
document . getElementById ( "get_user_movie_stats_oldest_subtitle_pre_1975" ) . value = get _user _movie _stats _oldest _subtitle _pre _1975 ;
document . getElementById ( "get_user_movie_stats_oldest_subtitle_pre_2000" ) . value = get _user _movie _stats _oldest _subtitle _pre _2000 ;
document . getElementById ( "get_user_movie_stats_spent_title" ) . value = get _user _movie _stats _spent _title ;
document . getElementById ( "get_user_show_stats_title" ) . value = get _user _show _stats _title ;
document . getElementById ( "get_user_show_stats_subtitle" ) . value = get _user _show _stats _subtitle ;
document . getElementById ( "get_user_show_stats_subsubtitle" ) . value = get _user _show _stats _subsubtitle ;
document . getElementById ( "get_user_show_stats_subtitle_one" ) . value = get _user _show _stats _subtitle _one ;
document . getElementById ( "get_user_show_stats_subsubtitle_one" ) . value = get _user _show _stats _subsubtitle _one ;
document . getElementById ( "get_user_show_stats_subtitle_none" ) . value = get _user _show _stats _subtitle _none ;
document . getElementById ( "get_user_show_stats_subsubtitle_none" ) . value = get _user _show _stats _subsubtitle _none ;
document . getElementById ( "get_user_show_stats_most_played_title" ) . value = get _user _show _stats _most _played _title ;
document . getElementById ( "get_user_show_stats_most_played_subtitle" ) . value = get _user _show _stats _most _played _subtitle ;
document . getElementById ( "get_user_show_stats_buddy_title" ) . value = get _user _show _stats _buddy _title ;
document . getElementById ( "get_user_show_stats_buddy_subtitle" ) . value = get _user _show _stats _buddy _subtitle ;
document . getElementById ( "get_user_show_stats_buddy_title_none" ) . value = get _user _show _stats _buddy _title _none ;
document . getElementById ( "get_user_show_stats_buddy_subtitle_none" ) . value = get _user _show _stats _buddy _subtitle _none ;
document . getElementById ( "get_user_show_stats_spent_title" ) . value = get _user _show _stats _spent _title ;
document . getElementById ( "get_user_music_stats_title" ) . value = get _user _music _stats _title ;
document . getElementById ( "get_user_music_stats_subtitle" ) . value = get _user _music _stats _subtitle ;
document . getElementById ( "get_user_music_stats_subsubtitle" ) . value = get _user _music _stats _subsubtitle ;
document . getElementById ( "get_user_music_stats_subtitle_one" ) . value = get _user _music _stats _subtitle _one ;
document . getElementById ( "get_user_music_stats_subsubtitle_one" ) . value = get _user _music _stats _subsubtitle _one ;
document . getElementById ( "get_user_music_stats_subtitle_none" ) . value = get _user _music _stats _subtitle _none ;
document . getElementById ( "get_user_music_stats_subsubtitle_none" ) . value = get _user _music _stats _subsubtitle _none ;
document . getElementById ( "get_user_music_stats_spent_title" ) . value = get _user _music _stats _spent _title ;
document . getElementById ( "get_user_music_stats_spent_subtitle" ) . value = get _user _music _stats _spent _subtitle ;
document . getElementById ( "get_user_music_stats_oldest_album_title" ) . value = get _user _music _stats _oldest _album _title ;
document . getElementById ( "get_user_music_stats_oldest_album_subtitle" ) . value = get _user _music _stats _oldest _album _subtitle ;
document . getElementById ( "get_year_stats_title" ) . value = get _year _stats _title ;
document . getElementById ( "get_year_stats_subtitle" ) . value = get _year _stats _subtitle ;
document . getElementById ( "get_year_stats_subsubtitle" ) . value = get _year _stats _subsubtitle ;
document . getElementById ( "get_year_stats_movies_duration_title" ) . value = get _year _stats _movies _duration _title ;
document . getElementById ( "get_year_stats_shows_duration_title" ) . value = get _year _stats _shows _duration _title ;
document . getElementById ( "get_year_stats_music_duration_title" ) . value = get _year _stats _music _duration _title ;
document . getElementById ( "get_year_stats_duration_sum_title" ) . value = get _year _stats _duration _sum _title ;
}
function toggle _hidden _form ( div _id ) {
var div = document . getElementById ( div _id ) ;
if ( div . className === "form_shown" ) {
div . classList . remove ( 'form_shown' ) ;
div . classList . add ( 'form_hidden' ) ;
} else {
div . classList . remove ( 'form_hidden' ) ;
div . classList . add ( 'form_shown' ) ;
}
}
function set _wrapperr _customization _call ( ) {
document . getElementById ( "set_wrapperr_customization_form_button" ) . disabled = true ;
document . getElementById ( "set_wrapperr_customization_form_button" ) . style . opacity = '0.5' ;
2022-01-21 10:44:03 +00:00
wrapperr _front _page _title = document . getElementById ( 'wrapperr_front_page_title' ) . value ;
wrapperr _front _page _subtitle = document . getElementById ( 'wrapperr_front_page_subtitle' ) . value ;
2022-01-20 19:20:26 +00:00
stats _intro _title = document . getElementById ( 'stats_intro_title' ) . value ;
stats _intro _subtitle = document . getElementById ( 'stats_intro_subtitle' ) . value ;
stats _outro _title = document . getElementById ( 'stats_outro_title' ) . value ;
stats _outro _subtitle = document . getElementById ( 'stats_outro_subtitle' ) . value ;
stats _order _by _plays = document . getElementById ( 'stats_order_by_plays' ) . checked ;
stats _order _by _duration = document . getElementById ( 'stats_order_by_duration' ) . checked ;
2022-10-15 20:07:15 +00:00
stats _top _list _length = parseInt ( document . getElementById ( "stats_top_list_length" ) . value ) ;
2023-02-07 07:52:38 +00:00
obfuscate _other _users = document . getElementById ( 'obfuscate_other_users' ) . checked ;
2022-01-11 13:33:30 +00:00
get _user _movie _stats = document . getElementById ( 'get_user_movie_stats' ) . checked ;
get _user _movie _stats _title = document . getElementById ( 'get_user_movie_stats_title' ) . value ;
get _user _movie _stats _subtitle = document . getElementById ( 'get_user_movie_stats_subtitle' ) . value ;
get _user _movie _stats _subsubtitle = document . getElementById ( 'get_user_movie_stats_subsubtitle' ) . value ;
get _user _movie _stats _subtitle _one = document . getElementById ( 'get_user_movie_stats_subtitle_one' ) . value ;
get _user _movie _stats _subsubtitle _one = document . getElementById ( 'get_user_movie_stats_subsubtitle_one' ) . value ;
get _user _movie _stats _subtitle _none = document . getElementById ( 'get_user_movie_stats_subtitle_none' ) . value ;
get _user _movie _stats _subsubtitle _none = document . getElementById ( 'get_user_movie_stats_subsubtitle_none' ) . value ;
get _user _movie _stats _top _movie = document . getElementById ( 'get_user_movie_stats_top_movie' ) . value ;
get _user _movie _stats _top _movie _plural = document . getElementById ( 'get_user_movie_stats_top_movie_plural' ) . value ;
get _user _movie _stats _movie _completion _title = document . getElementById ( 'get_user_movie_stats_movie_completion_title' ) . value ;
get _user _movie _stats _movie _completion _title _plural = document . getElementById ( 'get_user_movie_stats_movie_completion_title_plural' ) . value ;
get _user _movie _stats _movie _completion _subtitle = document . getElementById ( 'get_user_movie_stats_movie_completion_subtitle' ) . value ;
get _user _movie _stats _pause _title = document . getElementById ( 'get_user_movie_stats_pause_title' ) . value ;
get _user _movie _stats _pause _subtitle = document . getElementById ( 'get_user_movie_stats_pause_subtitle' ) . value ;
get _user _movie _stats _pause _title _one = document . getElementById ( 'get_user_movie_stats_pause_title_one' ) . value ;
get _user _movie _stats _pause _subtitle _one = document . getElementById ( 'get_user_movie_stats_pause_subtitle_one' ) . value ;
get _user _movie _stats _pause _title _none = document . getElementById ( 'get_user_movie_stats_pause_title_none' ) . value ;
get _user _movie _stats _pause _subtitle _none = document . getElementById ( 'get_user_movie_stats_pause_subtitle_none' ) . value ;
get _user _movie _stats _oldest _title = document . getElementById ( 'get_user_movie_stats_oldest_title' ) . value ;
get _user _movie _stats _oldest _subtitle = document . getElementById ( 'get_user_movie_stats_oldest_subtitle' ) . value ;
get _user _movie _stats _oldest _subtitle _pre _1950 = document . getElementById ( 'get_user_movie_stats_oldest_subtitle_pre_1950' ) . value ;
get _user _movie _stats _oldest _subtitle _pre _1975 = document . getElementById ( 'get_user_movie_stats_oldest_subtitle_pre_1975' ) . value ;
get _user _movie _stats _oldest _subtitle _pre _2000 = document . getElementById ( 'get_user_movie_stats_oldest_subtitle_pre_2000' ) . value ;
get _user _movie _stats _spent _title = document . getElementById ( 'get_user_movie_stats_spent_title' ) . value ;
get _user _show _stats = document . getElementById ( 'get_user_show_stats' ) . checked ;
get _user _show _stats _buddy = document . getElementById ( 'get_user_show_stats_buddy' ) . checked ;
get _user _show _stats _title = document . getElementById ( 'get_user_show_stats_title' ) . value ;
get _user _show _stats _subtitle = document . getElementById ( 'get_user_show_stats_subtitle' ) . value ;
get _user _show _stats _subsubtitle = document . getElementById ( 'get_user_show_stats_subsubtitle' ) . value ;
get _user _show _stats _subtitle _one = document . getElementById ( 'get_user_show_stats_subtitle_one' ) . value ;
get _user _show _stats _subsubtitle _one = document . getElementById ( 'get_user_show_stats_subsubtitle_one' ) . value ;
get _user _show _stats _subtitle _none = document . getElementById ( 'get_user_show_stats_subtitle_none' ) . value ;
get _user _show _stats _subsubtitle _none = document . getElementById ( 'get_user_show_stats_subsubtitle_none' ) . value ;
get _user _show _stats _top _show = document . getElementById ( 'get_user_show_stats_top_show' ) . value ;
get _user _show _stats _top _show _plural = document . getElementById ( 'get_user_show_stats_top_show_plural' ) . value ;
get _user _show _stats _most _played _title = document . getElementById ( 'get_user_show_stats_most_played_title' ) . value ;
get _user _show _stats _most _played _subtitle = document . getElementById ( 'get_user_show_stats_most_played_subtitle' ) . value ;
get _user _show _stats _buddy _title = document . getElementById ( 'get_user_show_stats_buddy_title' ) . value ;
get _user _show _stats _buddy _subtitle = document . getElementById ( 'get_user_show_stats_buddy_subtitle' ) . value ;
get _user _show _stats _buddy _title _none = document . getElementById ( 'get_user_show_stats_buddy_title_none' ) . value ;
get _user _show _stats _buddy _subtitle _none = document . getElementById ( 'get_user_show_stats_buddy_subtitle_none' ) . value ;
get _user _show _stats _spent _title = document . getElementById ( 'get_user_show_stats_spent_title' ) . value ;
get _user _music _stats = document . getElementById ( 'get_user_music_stats' ) . checked ;
get _user _music _stats _title = document . getElementById ( 'get_user_music_stats_title' ) . value ;
get _user _music _stats _subtitle = document . getElementById ( 'get_user_music_stats_subtitle' ) . value ;
get _user _music _stats _subsubtitle = document . getElementById ( 'get_user_music_stats_subsubtitle' ) . value ;
get _user _music _stats _subtitle _one = document . getElementById ( 'get_user_music_stats_subtitle_one' ) . value ;
get _user _music _stats _subsubtitle _one = document . getElementById ( 'get_user_music_stats_subsubtitle_one' ) . value ;
get _user _music _stats _subtitle _none = document . getElementById ( 'get_user_music_stats_subtitle_none' ) . value ;
get _user _music _stats _subsubtitle _none = document . getElementById ( 'get_user_music_stats_subsubtitle_none' ) . value ;
get _user _music _stats _top _track = document . getElementById ( 'get_user_music_stats_top_track' ) . value ;
get _user _music _stats _top _track _plural = document . getElementById ( 'get_user_music_stats_top_track_plural' ) . value ;
get _user _music _stats _top _album _plural = document . getElementById ( 'get_user_music_stats_top_album_plural' ) . value ;
get _user _music _stats _top _artist _plural = document . getElementById ( 'get_user_music_stats_top_artist_plural' ) . value ;
get _user _music _stats _spent _title = document . getElementById ( 'get_user_music_stats_spent_title' ) . value ;
get _user _music _stats _spent _subtitle = document . getElementById ( 'get_user_music_stats_spent_subtitle' ) . value ;
get _user _music _stats _oldest _album _title = document . getElementById ( 'get_user_music_stats_oldest_album_title' ) . value ;
get _user _music _stats _oldest _album _subtitle = document . getElementById ( 'get_user_music_stats_oldest_album_subtitle' ) . value ;
get _year _stats _title = document . getElementById ( 'get_year_stats_title' ) . value ;
get _year _stats _subtitle = document . getElementById ( 'get_year_stats_subtitle' ) . value ;
get _year _stats _subsubtitle = document . getElementById ( 'get_year_stats_subsubtitle' ) . value ;
get _year _stats _movies = document . getElementById ( 'get_year_stats_movies' ) . checked ;
get _year _stats _movies _title = document . getElementById ( 'get_year_stats_movies_title' ) . value ;
get _year _stats _movies _duration _title = document . getElementById ( 'get_year_stats_movies_duration_title' ) . value ;
get _year _stats _shows = document . getElementById ( 'get_year_stats_shows' ) . checked ;
get _year _stats _shows _title = document . getElementById ( 'get_year_stats_shows_title' ) . value ;
get _year _stats _shows _duration _title = document . getElementById ( 'get_year_stats_shows_duration_title' ) . value ;
get _year _stats _music = document . getElementById ( 'get_year_stats_music' ) . checked ;
get _year _stats _music _title = document . getElementById ( 'get_year_stats_music_title' ) . value ;
get _year _stats _music _duration _title = document . getElementById ( 'get_year_stats_music_duration_title' ) . value ;
get _year _stats _leaderboard = document . getElementById ( 'get_year_stats_leaderboard' ) . checked ;
2022-10-15 21:47:53 +00:00
get _year _stats _leaderboard _numbers = document . getElementById ( 'get_year_stats_leaderboard_numbers' ) . checked ;
2022-01-11 13:33:30 +00:00
get _year _stats _leaderboard _title = document . getElementById ( 'get_year_stats_leaderboard_title' ) . value ;
get _year _stats _duration _sum _title = document . getElementById ( 'get_year_stats_duration_sum_title' ) . value ;
clear _cache = document . getElementById ( 'clear_cache' ) . checked ;
wrapperr _and = document . getElementById ( "wrapperr_and" ) . value ;
wrapperr _play = document . getElementById ( "wrapperr_play" ) . value ;
wrapperr _play _plural = document . getElementById ( "wrapperr_play_plural" ) . value ;
wrapperr _day = document . getElementById ( "wrapperr_day" ) . value ;
wrapperr _day _plural = document . getElementById ( "wrapperr_day_plural" ) . value ;
wrapperr _hour = document . getElementById ( "wrapperr_hour" ) . value ;
wrapperr _hour _plural = document . getElementById ( "wrapperr_hour_plural" ) . value ;
wrapperr _minute = document . getElementById ( "wrapperr_minute" ) . value ;
wrapperr _minute _plural = document . getElementById ( "wrapperr_minute_plural" ) . value ;
wrapperr _second = document . getElementById ( "wrapperr_second" ) . value ;
wrapperr _second _plural = document . getElementById ( "wrapperr_second_plural" ) . value ;
wrapperr _sort _plays = document . getElementById ( "wrapperr_sort_plays" ) . value ;
wrapperr _sort _duration = document . getElementById ( "wrapperr_sort_duration" ) . value ;
wrapperr _customization _form = {
"clear_cache" : clear _cache ,
2022-07-04 15:47:59 +00:00
"data_type" : "wrapperr_customize" ,
2022-12-03 12:06:48 +00:00
"tautulli_config" : [ ] ,
2022-07-04 15:47:59 +00:00
"wrapperr_data" : { } ,
"wrapperr_customize" : {
2022-01-21 10:44:03 +00:00
"wrapperr_front_page_title" : wrapperr _front _page _title ,
"wrapperr_front_page_subtitle" : wrapperr _front _page _subtitle ,
2022-01-20 19:20:26 +00:00
"stats_intro_title" : stats _intro _title ,
"stats_intro_subtitle" : stats _intro _subtitle ,
"stats_outro_title" : stats _outro _title ,
"stats_outro_subtitle" : stats _outro _subtitle ,
"stats_order_by_plays" : stats _order _by _plays ,
"stats_order_by_duration" : stats _order _by _duration ,
2022-10-15 20:07:15 +00:00
"stats_top_list_length" : stats _top _list _length ,
2023-02-07 07:52:38 +00:00
"obfuscate_other_users" : obfuscate _other _users ,
2022-01-11 13:33:30 +00:00
"get_user_movie_stats" : get _user _movie _stats ,
"get_user_movie_stats_title" : get _user _movie _stats _title ,
"get_user_movie_stats_subtitle" : get _user _movie _stats _subtitle ,
"get_user_movie_stats_subsubtitle" : get _user _movie _stats _subsubtitle ,
"get_user_movie_stats_subtitle_one" : get _user _movie _stats _subtitle _one ,
"get_user_movie_stats_subsubtitle_one" : get _user _movie _stats _subsubtitle _one ,
"get_user_movie_stats_subtitle_none" : get _user _movie _stats _subtitle _none ,
"get_user_movie_stats_subsubtitle_none" : get _user _movie _stats _subsubtitle _none ,
"get_user_movie_stats_top_movie" : get _user _movie _stats _top _movie ,
"get_user_movie_stats_top_movie_plural" : get _user _movie _stats _top _movie _plural ,
"get_user_movie_stats_movie_completion_title" : get _user _movie _stats _movie _completion _title ,
"get_user_movie_stats_movie_completion_title_plural" : get _user _movie _stats _movie _completion _title _plural ,
"get_user_movie_stats_movie_completion_subtitle" : get _user _movie _stats _movie _completion _subtitle ,
"get_user_movie_stats_pause_title" : get _user _movie _stats _pause _title ,
"get_user_movie_stats_pause_subtitle" : get _user _movie _stats _pause _subtitle ,
"get_user_movie_stats_pause_title_one" : get _user _movie _stats _pause _title _one ,
"get_user_movie_stats_pause_subtitle_one" : get _user _movie _stats _pause _subtitle _one ,
"get_user_movie_stats_pause_title_none" : get _user _movie _stats _pause _title _none ,
"get_user_movie_stats_pause_subtitle_none" : get _user _movie _stats _pause _subtitle _none ,
"get_user_movie_stats_oldest_title" : get _user _movie _stats _oldest _title ,
"get_user_movie_stats_oldest_subtitle" : get _user _movie _stats _oldest _subtitle ,
"get_user_movie_stats_oldest_subtitle_pre_1950" : get _user _movie _stats _oldest _subtitle _pre _1950 ,
"get_user_movie_stats_oldest_subtitle_pre_1975" : get _user _movie _stats _oldest _subtitle _pre _1975 ,
"get_user_movie_stats_oldest_subtitle_pre_2000" : get _user _movie _stats _oldest _subtitle _pre _2000 ,
"get_user_movie_stats_spent_title" : get _user _movie _stats _spent _title ,
"get_user_show_stats" : get _user _show _stats ,
"get_user_show_stats_buddy" : get _user _show _stats _buddy ,
"get_user_show_stats_title" : get _user _show _stats _title ,
"get_user_show_stats_subtitle" : get _user _show _stats _subtitle ,
"get_user_show_stats_subsubtitle" : get _user _show _stats _subsubtitle ,
"get_user_show_stats_subtitle_one" : get _user _show _stats _subtitle _one ,
"get_user_show_stats_subsubtitle_one" : get _user _show _stats _subsubtitle _one ,
"get_user_show_stats_subtitle_none" : get _user _show _stats _subtitle _none ,
"get_user_show_stats_subsubtitle_none" : get _user _show _stats _subsubtitle _none ,
"get_user_show_stats_top_show" : get _user _show _stats _top _show ,
"get_user_show_stats_top_show_plural" : get _user _show _stats _top _show _plural ,
"get_user_show_stats_spent_title" : get _user _show _stats _spent _title ,
"get_user_show_stats_most_played_title" : get _user _show _stats _most _played _title ,
"get_user_show_stats_most_played_subtitle" : get _user _show _stats _most _played _subtitle ,
"get_user_show_stats_buddy_title" : get _user _show _stats _buddy _title ,
"get_user_show_stats_buddy_subtitle" : get _user _show _stats _buddy _subtitle ,
"get_user_show_stats_buddy_title_none" : get _user _show _stats _buddy _title _none ,
"get_user_show_stats_buddy_subtitle_none" : get _user _show _stats _buddy _subtitle _none ,
"get_user_music_stats" : get _user _music _stats ,
"get_user_music_stats_title" : get _user _music _stats _title ,
"get_user_music_stats_subtitle" : get _user _music _stats _subtitle ,
"get_user_music_stats_subsubtitle" : get _user _music _stats _subsubtitle ,
"get_user_music_stats_subtitle_one" : get _user _music _stats _subtitle _one ,
"get_user_music_stats_subsubtitle_one" : get _user _music _stats _subsubtitle _one ,
"get_user_music_stats_subtitle_none" : get _user _music _stats _subtitle _none ,
"get_user_music_stats_subsubtitle_none" : get _user _music _stats _subsubtitle _none ,
"get_user_music_stats_top_track" : get _user _music _stats _top _track ,
"get_user_music_stats_top_track_plural" : get _user _music _stats _top _track _plural ,
"get_user_music_stats_top_album_plural" : get _user _music _stats _top _album _plural ,
"get_user_music_stats_top_artist_plural" : get _user _music _stats _top _artist _plural ,
"get_user_music_stats_spent_title" : get _user _music _stats _spent _title ,
"get_user_music_stats_spent_subtitle" : get _user _music _stats _spent _subtitle ,
"get_user_music_stats_oldest_album_title" : get _user _music _stats _oldest _album _title ,
"get_user_music_stats_oldest_album_subtitle" : get _user _music _stats _oldest _album _subtitle ,
"get_year_stats_title" : get _year _stats _title ,
"get_year_stats_subtitle" : get _year _stats _subtitle ,
"get_year_stats_subsubtitle" : get _year _stats _subsubtitle ,
"get_year_stats_movies" : get _year _stats _movies ,
"get_year_stats_movies_title" : get _year _stats _movies _title ,
"get_year_stats_movies_duration_title" : get _year _stats _movies _duration _title ,
"get_year_stats_shows" : get _year _stats _shows ,
"get_year_stats_shows_title" : get _year _stats _shows _title ,
"get_year_stats_shows_duration_title" : get _year _stats _shows _duration _title ,
"get_year_stats_music" : get _year _stats _music ,
"get_year_stats_music_title" : get _year _stats _music _title ,
"get_year_stats_music_duration_title" : get _year _stats _music _duration _title ,
"get_year_stats_leaderboard" : get _year _stats _leaderboard ,
2022-10-15 21:47:53 +00:00
"get_year_stats_leaderboard_numbers" : get _year _stats _leaderboard _numbers ,
2022-01-11 13:33:30 +00:00
"get_year_stats_leaderboard_title" : get _year _stats _leaderboard _title ,
"get_year_stats_duration_sum_title" : get _year _stats _duration _sum _title ,
"wrapperr_and" : wrapperr _and ,
"wrapperr_play" : wrapperr _play ,
"wrapperr_play_plural" : wrapperr _play _plural ,
"wrapperr_day" : wrapperr _day ,
"wrapperr_day_plural" : wrapperr _day _plural ,
"wrapperr_hour" : wrapperr _hour ,
"wrapperr_hour_plural" : wrapperr _hour _plural ,
"wrapperr_minute" : wrapperr _minute ,
"wrapperr_minute_plural" : wrapperr _minute _plural ,
"wrapperr_second" : wrapperr _second ,
"wrapperr_second_plural" : wrapperr _second _plural ,
"wrapperr_sort_plays" : wrapperr _sort _plays ,
"wrapperr_sort_duration" : wrapperr _sort _duration
}
} ;
var wrapperr _customization _data = JSON . stringify ( wrapperr _customization _form ) ;
2022-07-04 15:47:59 +00:00
2022-10-15 20:07:15 +00:00
// Debug line
// console.log(wrapperr_customization_data);
2022-01-11 13:33:30 +00:00
var xhttp = new XMLHttpRequest ( ) ;
xhttp . onreadystatechange = function ( ) {
2022-07-04 22:11:19 +00:00
if ( this . readyState == 4 ) {
2022-01-11 13:33:30 +00:00
try {
var result = JSON . parse ( this . responseText ) ;
} catch ( error ) {
alert ( 'Failed to parse API response.' ) ;
console . log ( 'Failed to parse API response. Response: ' + this . responseText ) ;
document . getElementById ( "set_wrapperr_customization_form_button" ) . disabled = false ;
document . getElementById ( "set_wrapperr_customization_form_button" ) . style . opacity = '1' ;
2022-07-04 22:11:19 +00:00
return ;
2022-01-11 13:33:30 +00:00
}
if ( result . error ) {
2023-10-25 13:14:02 +00:00
alert ( result . error ) ;
2022-01-11 13:33:30 +00:00
document . getElementById ( "set_wrapperr_customization_form_button" ) . disabled = false ;
document . getElementById ( "set_wrapperr_customization_form_button" ) . style . opacity = '1' ;
} else {
get _config ( get _cookie ( 'wrapperr-admin' ) ) ;
}
}
} ;
xhttp . withCredentials = true ;
2022-12-03 12:06:48 +00:00
xhttp . open ( "post" , api _url + "set/config" ) ;
2022-07-04 15:47:59 +00:00
xhttp . setRequestHeader ( "Content-Type" , "application/json;charset=UTF-8" ) ;
2023-10-25 13:14:02 +00:00
xhttp . setRequestHeader ( "Authorization" , cookie ) ;
2022-01-11 13:33:30 +00:00
xhttp . send ( wrapperr _customization _data ) ;
return ;
}
function caching _menu ( ) {
var html = '<div class="form-group newline">' ;
2022-12-09 16:38:23 +00:00
html += '<button class="form-control btn" name="admin_menu_return_button" id="admin_menu_return_button" onclick="get_config(get_cookie(\'wrapperr-admin\'));"><img src="./assets/trash.svg" class="btn_logo"></img><p2 id="admin_menu_return_button_text">Return</p2></button>' ;
2022-01-11 13:33:30 +00:00
html += '</div>' ;
html += '<div class="form-group newline">' ;
html += '<hr>' ;
html += '</div>' ;
2022-11-29 18:32:30 +00:00
var min _day _length = 1 ;
if ( tautulli . length > 1 ) {
min _day _length = tautulli . length + 1
}
2022-01-11 13:33:30 +00:00
html += `
2023-02-10 08:32:32 +00:00
< div class = 'form-group newline' >
< h3 >
Caching Tautulli data for later use to prevent long load times .
< / h 3 >
< div class = "form_hidden" id = "caching_desc" >
< p style = "font-size:1em;" >
When you configured a wrapped period , you set the number of days to process . Each unique day in that period is a new API request to Tautulli , which holds the data which needs processing .
< br >
< br >
Wrapperr can cache data from Tautulli to decrease load times , but it needs to be loaded once . If the time frame is long this can take several minutes . Instead of loading your own stats , you can perform caching here . Afterward , everything is cached and saved . Only additional / new data is downloaded on future Wrapperr usage .
< br >
< br >
The loop used on this page ensures the cache is saved after a certain amount of days are downloaded . If the value below is set to 50 , it will save the cache for every 50 days downloaded .
< br >
< br >
< / p >
< / d i v >
< div class = "form-group newline" >
< button class = "form-control btn" name = "get_user_show_stats_custom_button" id = "get_user_show_stats_custom_button" onclick = "toggle_hidden_form(\'caching_desc\')" > < img src = "./assets/about.svg" class = "btn_logo" > < / i m g > < p 2 i d = " g e t _ u s e r _ s h o w _ s t a t s _ c u s t o m _ b u t t o n _ t e x t " > I n f o < / p 2 > < / b u t t o n >
< / d i v >
< / d i v >
< form id = 'stats_form' class = 'form' onsubmit = 'event.preventDefault(); cache_initiate();' action = "" method = "post" >
2022-01-11 13:33:30 +00:00
< div class = 'form-group newline' >
2022-07-04 15:47:59 +00:00
< label for = "days" title = "" > Days between safety - save of cache : < / l a b e l >
2022-11-29 18:32:30 +00:00
< input type = "number" class = 'form-control' name = "days" id = "days" min = '` + min_day_length + `' value = '50' autocomplete = "off" required / >
2022-01-11 13:33:30 +00:00
< / d i v >
< div class = "form-group newline" >
2022-12-09 16:38:23 +00:00
< button class = "form-control btn" type = "submit" name = "cache_button" id = "cache_button" > < img src = "./assets/download.svg" class = "btn_logo" > < / i m g > < p 2 i d = " c a c h e _ b u t t o n _ t e x t " > C a c h e < / p 2 > < / b u t t o n >
2022-01-11 13:33:30 +00:00
< / d i v >
< div id = "cache" > < / d i v >
< / f o r m >
` ;
document . getElementById ( "setup" ) . innerHTML = html ;
}
2022-07-04 15:47:59 +00:00
function add _to _cache _log ( log _message , state , color ) {
var today = new Date ( ) ;
var time = pad _number ( today . getHours ( ) , 2 ) + ":" + pad _number ( today . getMinutes ( ) , 2 ) + ":" + pad _number ( today . getSeconds ( ) , 2 ) ;
if ( state ) {
style = 'color:' + color + ';' ;
} else {
style = '' ;
}
var tablerow = `
< tr class = 'cacher-tr' >
< td class = 'cacher-td' > ` + time + ` < / t d >
< td class = 'cacher-td' style = '` + style + `' > ` + log_message + ` < / t d >
< / t r >
` ;
document . getElementById ( 'cache_results_body' ) . innerHTML += tablerow
}
2022-01-11 13:33:30 +00:00
function cache _initiate ( ) {
2022-07-04 15:47:59 +00:00
var days = parseInt ( document . getElementById ( 'days' ) . value ) ;
2022-01-11 13:33:30 +00:00
var html = `
< form id = 'stats_form' class = 'form' onsubmit = 'return false' action = "" method = "post" >
< div class = 'form-group newline' >
2022-12-09 16:38:23 +00:00
< img id = "loading_icon" src = "./assets/loading.gif" style = "border-radius: 25px; background-color: white; padding: 1em; width: 4em; height: 4em; display: inline;" >
2022-01-11 13:33:30 +00:00
< / d i v >
< h3 > Caching log : < / h 3 >
< div id = "cache_results" style = "max-height: 15em; overflow-y: scroll;" >
2022-07-04 15:47:59 +00:00
< table class = 'cacher-table' >
< tbody id = "cache_results_body" >
< tr >
< th class = 'cacher-th' style = 'width: 25%' > Time < / t h >
< th class = 'cacher-th' style = 'width: 75%' > Message < / t h >
< / t r >
< / t b o d y >
< / t a b l e
2022-01-11 13:33:30 +00:00
< / d i v >
< / f o r m >
` ;
document . getElementById ( 'cache' ) . innerHTML = html ;
2022-07-04 15:47:59 +00:00
add _to _cache _log ( 'Creating new cache request. Maximum ' + days + ' days.' )
2022-01-11 13:33:30 +00:00
get _stats ( days ) ;
}
function cache _log ( days , result , complete ) {
if ( result ) {
2022-07-04 15:47:59 +00:00
add _to _cache _log ( 'Completed caching with a maximum of ' + days + ' days.' , false , '' ) ;
2022-01-11 13:33:30 +00:00
} else {
2022-07-04 15:47:59 +00:00
add _to _cache _log ( 'Error caching ' + days + ' days. Stopping.' , true , 'var(--red)' ) ;
2022-01-11 13:33:30 +00:00
document . getElementById ( 'loading_icon' ) . style . display = "none" ;
document . getElementById ( "cache_button" ) . disabled = false ;
document . getElementById ( "cache_button" ) . style . opacity = '1' ;
}
if ( complete ) {
2022-07-04 15:47:59 +00:00
add _to _cache _log ( 'Finished caching request.' , true , 'var(--green)' ) ;
2022-01-11 13:33:30 +00:00
document . getElementById ( 'loading_icon' ) . style . display = "none" ;
document . getElementById ( "cache_button" ) . disabled = false ;
document . getElementById ( "cache_button" ) . style . opacity = '1' ;
} else {
2022-07-04 15:47:59 +00:00
add _to _cache _log ( 'Requesting new cache from Wrapperr. Maximum ' + days + ' days.' , false , '' ) ;
2022-01-11 13:33:30 +00:00
}
var cache _results = document . getElementById ( "cache_results" ) ;
cache _results . scrollTop = cache _results . scrollHeight ;
}
function get _stats ( days ) {
document . getElementById ( "cache_button" ) . disabled = true ;
document . getElementById ( "cache_button" ) . style . opacity = '0.5' ;
stats _form = {
"caching" : true ,
"cache_limit" : days
} ;
var stats _data = JSON . stringify ( stats _form ) ;
var xhttp = new XMLHttpRequest ( ) ;
xhttp . onreadystatechange = function ( ) {
2022-07-04 15:47:59 +00:00
if ( this . readyState == 4 ) {
2022-01-11 13:33:30 +00:00
try {
var result = JSON . parse ( this . responseText ) ;
} catch ( error ) {
if ( this . responseText . includes ( 'Maximum execution time of' ) ) {
cache _log ( days , false , true ) ;
document . getElementById ( "cache_button" ) . disabled = false ;
document . getElementById ( "cache_button" ) . style . opacity = '1' ;
alert ( 'PHP runtime was exceeded and stopped execution. Lower days cached to prevent this.' ) ;
console . log ( 'Failed to parse API response. Error: ' + this . responseText ) ;
} else {
cache _log ( days , false , true ) ;
alert ( 'Failed to parse API response.' ) ;
console . log ( 'Failed to parse API response. Error: ' + this . responseText ) ;
document . getElementById ( "cache_button" ) . disabled = false ;
document . getElementById ( "cache_button" ) . style . opacity = '1' ;
}
return ;
}
if ( result . error ) {
2023-10-25 13:14:02 +00:00
alert ( result . error ) ;
2022-01-11 13:33:30 +00:00
cache _log ( days , false , true ) ;
} else {
2022-07-04 15:47:59 +00:00
if ( ! result . data ) {
cache _log ( days , true , result . data ) ;
2022-01-11 13:33:30 +00:00
get _stats ( days ) ;
} else {
2022-07-04 15:47:59 +00:00
cache _log ( days , true , result . data ) ;
2022-01-11 13:33:30 +00:00
}
}
}
} ;
xhttp . withCredentials = true ;
2022-12-03 12:06:48 +00:00
xhttp . open ( "post" , api _url + "get/statistics" , ) ;
2022-07-04 15:47:59 +00:00
xhttp . setRequestHeader ( "Content-Type" , "application/json;charset=UTF-8" ) ;
2023-10-25 13:14:02 +00:00
xhttp . setRequestHeader ( "Authorization" , cookie ) ;
2022-01-11 13:33:30 +00:00
xhttp . send ( stats _data ) ;
return ;
2021-03-08 18:45:06 +00:00
}
2022-07-04 15:47:59 +00:00
function log _menu ( ) {
var html = '<div class="form-group newline">' ;
2022-12-09 16:38:23 +00:00
html += '<button class="form-control btn" name="admin_menu_return_button" id="admin_menu_return_button" onclick="get_config(get_cookie(\'wrapperr-admin\'));"><img src="./assets/trash.svg" class="btn_logo"></img><p2 id="admin_menu_return_button_text">Return</p2></button>' ;
2022-07-04 15:47:59 +00:00
html += '</div>' ;
html += '<div class="form-group newline">' ;
html += '<hr>' ;
html += '</div>' ;
html += `
< form id = 'stats_form' class = 'form' onsubmit = 'return false' action = "" method = "post" >
< div class = 'form-group newline' >
< h3 >
Wrapperr log file
< / h 3 >
< p id = 'log_result_text' >
< / p >
< / d i v >
< div id = "cache" >
< div id = "log_results" style = "max-height: 15em; overflow-y: scroll;" >
< table class = 'log-table' >
< tbody id = "log_results_body" >
< tr >
< th class = 'log-th' style = 'width: 15%' > Date < / t h >
< th class = 'log-th' style = 'width: 15%' > Time < / t h >
< th class = 'log-th' style = 'width: 70%' > Message < / t h >
< / t r >
< / t b o d y >
< / t a b l e >
< / d i v >
< / d i v >
< div class = "form-group newline" >
2022-12-09 16:38:23 +00:00
< button class = "form-control btn" name = "log_button" id = "log_button" onclick = "get_log();" style = "opacity: 0.5;" disabled > < img src = "./assets/synchronize.svg" class = "btn_logo" > < / i m g > < p 2 i d = " c a c h e _ b u t t o n _ t e x t " > R e f r e s h < / p 2 > < / b u t t o n >
2022-07-04 15:47:59 +00:00
< / d i v >
< / f o r m >
` ;
document . getElementById ( "setup" ) . innerHTML = html ;
get _log ( ) ;
}
function get _log ( ) {
document . getElementById ( "log_button" ) . disabled = true ;
document . getElementById ( "log_button" ) . style . opacity = '0.5' ;
log _data _form = { } ;
var log _data _data = JSON . stringify ( log _form ) ;
var xhttp = new XMLHttpRequest ( ) ;
xhttp . onreadystatechange = function ( ) {
if ( this . readyState == 4 ) {
try {
var result = JSON . parse ( this . responseText ) ;
} catch ( error ) {
alert ( 'Failed to parse API response.' ) ;
console . log ( 'Failed to parse API response. Error: ' + this . responseText ) ;
document . getElementById ( "log_button" ) . disabled = false ;
document . getElementById ( "log_button" ) . style . opacity = '1' ;
return ;
}
if ( result . error ) {
document . getElementById ( "log_button" ) . disabled = false ;
document . getElementById ( "log_button" ) . style . opacity = '1' ;
2023-10-25 13:14:02 +00:00
alert ( result . error ) ;
2022-07-04 15:47:59 +00:00
} else {
document . getElementById ( "log_button" ) . disabled = false ;
document . getElementById ( "log_button" ) . style . opacity = '1' ;
log _form ( result . data , result . limit ) ;
}
}
} ;
xhttp . withCredentials = true ;
2022-12-03 12:06:48 +00:00
xhttp . open ( "post" , api _url + "get/log" , ) ;
2022-07-04 15:47:59 +00:00
xhttp . setRequestHeader ( "Content-Type" , "application/json;charset=UTF-8" ) ;
2023-10-25 13:14:02 +00:00
xhttp . setRequestHeader ( "Authorization" , cookie ) ;
2022-07-04 15:47:59 +00:00
xhttp . send ( log _data _data ) ;
return ;
}
function log _form ( log _lines _array , limit ) {
var log _table = `
< tr >
< th class = 'log-th' style = 'width: 15%' > Date < / t h >
< th class = 'log-th' style = 'width: 15%' > Time < / t h >
< th class = 'log-th' style = 'width: 70%' > Message < / t h >
< / t r >
` ;
for ( index = 0 ; index < log _lines _array . length ; index ++ ) {
var tablerow = `
< tr class = 'cacher-tr' >
< td class = 'cacher-td' > ` + log_lines_array[index].date + ` < / t d >
< td class = 'cacher-td' > ` + log_lines_array[index].time + ` < / t d >
< td class = 'cacher-td' > ` + log_lines_array[index].message + ` < / t d >
< / t r >
` ;
log _table += tablerow
}
document . getElementById ( 'log_results_body' ) . innerHTML = log _table
document . getElementById ( 'log_result_text' ) . innerHTML = 'Retrieved last ' + limit + ' lines.' ;
var log _results = document . getElementById ( "log_results" ) ;
log _results . scrollTop = log _results . scrollHeight ;
}
2022-11-27 17:12:11 +00:00
function test _tautulli _connection ( tautulli _id ) {
document . getElementById ( "test_connection_" + tautulli _id ) . disabled = true ;
document . getElementById ( "test_connection_" + tautulli _id ) . style . opacity = '0.5' ;
2021-12-12 16:31:15 +00:00
2022-11-27 17:12:11 +00:00
var button = document . getElementById ( 'test_connection_' + tautulli _id ) ;
2021-03-12 22:45:44 +00:00
button . style . backgroundColor = 'lightgrey' ;
2022-11-27 17:12:11 +00:00
https _temp = document . getElementById ( 'tautulli_https_' + tautulli _id ) . checked ;
ip _temp = document . getElementById ( 'tautulli_ip_' + tautulli _id ) . value ;
root _temp = document . getElementById ( 'tautulli_root_' + tautulli _id ) . value ;
port _temp = parseInt ( document . getElementById ( 'tautulli_port_' + tautulli _id ) . value ) ;
api _temp = document . getElementById ( 'tautulli_apikey_' + tautulli _id ) . value ;
2021-03-12 22:45:44 +00:00
2022-07-04 15:47:59 +00:00
config _form = { "tautulli_https" : https _temp , "tautulli_apikey" : api _temp , "tautulli_port" : port _temp , "tautulli_root" : root _temp , "tautulli_ip" : ip _temp } ;
2021-03-12 22:45:44 +00:00
var config _data = JSON . stringify ( config _form ) ;
var xhttp = new XMLHttpRequest ( ) ;
xhttp . onreadystatechange = function ( ) {
2022-07-04 15:47:59 +00:00
if ( this . readyState == 4 ) {
2022-01-11 13:33:30 +00:00
try {
var result = JSON . parse ( this . responseText ) ;
} catch ( error ) {
console . log ( 'Failed to parse API response. Response: ' + this . responseText )
alert ( 'Failed to parse API response.' ) ;
button . style . backgroundColor = 'var(--red)' ;
2022-11-27 17:12:11 +00:00
document . getElementById ( "test_connection_" + tautulli _id ) . disabled = false ;
document . getElementById ( "test_connection_" + tautulli _id ) . style . opacity = '1' ;
2022-07-04 22:11:19 +00:00
return ;
2022-01-11 13:33:30 +00:00
}
2022-07-04 15:47:59 +00:00
if ( result . error ) {
button . style . backgroundColor = 'var(--red)' ;
2022-11-27 17:12:11 +00:00
document . getElementById ( "test_connection_" + tautulli _id ) . disabled = false ;
document . getElementById ( "test_connection_" + tautulli _id ) . style . opacity = '1' ;
2023-10-25 13:14:02 +00:00
alert ( result . error ) ;
2022-07-04 15:47:59 +00:00
return
}
if ( result . data ) {
2022-01-11 13:33:30 +00:00
button . style . backgroundColor = 'var(--green)' ;
2022-11-27 17:12:11 +00:00
document . getElementById ( "test_connection_" + tautulli _id ) . disabled = false ;
document . getElementById ( "test_connection_" + tautulli _id ) . style . opacity = '1' ;
2021-03-12 22:45:44 +00:00
} else {
2022-01-11 13:33:30 +00:00
button . style . backgroundColor = 'var(--red)' ;
2022-11-27 17:12:11 +00:00
document . getElementById ( "test_connection_" + tautulli _id ) . disabled = false ;
document . getElementById ( "test_connection_" + tautulli _id ) . style . opacity = '1' ;
2021-03-12 22:45:44 +00:00
}
}
} ;
xhttp . withCredentials = true ;
2022-12-03 12:06:48 +00:00
xhttp . open ( "post" , api _url + 'get/tautulli-connection' ) ;
2021-03-12 22:45:44 +00:00
xhttp . send ( config _data ) ;
}
2022-01-11 13:33:30 +00:00
function get _wrapper _version ( ) {
var xhttp = new XMLHttpRequest ( ) ;
xhttp . onreadystatechange = function ( ) {
2022-07-04 15:47:59 +00:00
if ( this . readyState == 4 ) {
2022-01-11 13:33:30 +00:00
try {
var result = JSON . parse ( this . responseText ) ;
} catch ( error ) {
console . log ( 'Failed to parse Wrapperr version. Response: ' + this . responseText )
2022-07-04 22:11:19 +00:00
alert ( "Failed to parse API response" ) ;
return ;
2022-01-11 13:33:30 +00:00
}
if ( ! result . error ) {
document . getElementById ( 'github_link' ) . innerHTML = 'GitHub (' + result . wrapperr _version + ')' ;
if ( result . application _name && result . application _name !== '' ) {
document . getElementById ( 'application_name' ) . innerHTML = result . application _name + ' Setup' ;
document . title = result . application _name ;
}
2022-12-03 12:06:48 +00:00
if ( result . wrapperr _root != "" ) {
api _url = window . location . origin + "/" + result . wrapperr _root + "/api/" ;
console . log ( "URL: " + api _url )
}
2023-10-24 13:56:37 +00:00
get _admin _state ( result . basic _auth ) ;
2023-10-25 13:14:02 +00:00
} else {
get _admin _state ( false ) ;
2022-01-11 13:33:30 +00:00
}
2022-07-04 15:47:59 +00:00
} else if ( this . readyState == 4 && this . status !== 200 ) {
var html = '<h2>' + this . status + ' Error</h2>' ;
html += '<p>The API did not respond correctly.</p>' ;
document . getElementById ( "setup" ) . innerHTML = html ;
2021-03-08 18:45:06 +00:00
}
2022-01-11 13:33:30 +00:00
} ;
xhttp . withCredentials = true ;
2022-12-03 12:06:48 +00:00
2022-12-10 12:42:37 +00:00
// Get the root without "/admin"
2022-12-03 12:06:48 +00:00
root = window . location . pathname . replace ( '/admin' , '' )
2022-12-10 12:42:37 +00:00
// Maybe add trailing slash depending on the end of "window.location.origin"
2022-12-09 16:38:23 +00:00
var trailingslash = ""
if ( window . location . origin . charAt ( window . location . origin . length - 1 ) != "/" ) {
trailingslash = "/"
}
2022-12-10 12:42:37 +00:00
// Reach the API to get URL base
2023-10-25 13:14:02 +00:00
xhttp . open ( "post" , root + trailingslash + "api/get/wrapperr-version" ) ;
2022-01-11 13:33:30 +00:00
xhttp . send ( ) ;
return ;
2021-10-17 11:47:58 +00:00
}
2021-12-12 16:31:15 +00:00
2022-01-11 13:33:30 +00:00
// Get admin configuration state
2023-10-24 13:56:37 +00:00
function get _admin _state ( basic _auth ) {
2021-12-12 16:31:15 +00:00
var xhttp = new XMLHttpRequest ( ) ;
xhttp . onreadystatechange = function ( ) {
2022-07-04 22:11:19 +00:00
if ( this . readyState == 4 ) {
2021-12-12 16:31:15 +00:00
try {
var result = JSON . parse ( this . responseText ) ;
} catch ( error ) {
2022-01-11 13:33:30 +00:00
console . log ( 'Failed to parse API response. Response: ' + this . responseText )
2022-07-04 22:11:19 +00:00
return ;
2021-12-12 16:31:15 +00:00
}
2022-01-11 13:33:30 +00:00
if ( result . error ) {
2023-10-25 13:14:02 +00:00
console . log ( result . error ) ;
2022-07-04 15:47:59 +00:00
} else if ( ! result . data ) {
2022-01-11 13:33:30 +00:00
first _time = true ;
set _password _form ( ) ;
} else {
cookie = get _cookie ( 'wrapperr-admin' ) ;
if ( cookie ) {
2023-10-24 13:56:37 +00:00
validate _cookie _admin ( cookie , basic _auth ) ;
2022-01-11 13:33:30 +00:00
} else {
2023-10-24 13:56:37 +00:00
login _menu ( basic _auth ) ;
2022-01-11 13:33:30 +00:00
}
2021-12-12 16:31:15 +00:00
}
}
} ;
xhttp . withCredentials = true ;
2022-12-03 12:06:48 +00:00
xhttp . open ( "post" , api _url + "get/admin-state" ) ;
2021-12-12 16:31:15 +00:00
xhttp . send ( ) ;
return ;
2022-01-11 13:33:30 +00:00
}
// Validate admin login
2023-10-24 13:56:37 +00:00
function validate _cookie _admin ( cookie , basic _auth ) {
2022-01-11 13:33:30 +00:00
var xhttp = new XMLHttpRequest ( ) ;
xhttp . onreadystatechange = function ( ) {
2022-07-04 15:47:59 +00:00
if ( this . readyState == 4 ) {
2022-01-11 13:33:30 +00:00
try {
var result = JSON . parse ( this . responseText ) ;
} catch ( error ) {
console . log ( 'Failed to parse API response. Response: ' + this . responseText )
}
if ( result . error ) {
set _cookie ( "wrapperr-admin" , "" , 1 ) ;
2023-10-24 13:56:37 +00:00
login _menu ( basic _auth ) ;
2023-10-25 13:14:02 +00:00
document . getElementById ( "password_login_form_error" ) . innerHTML = result . error ;
2022-01-11 13:33:30 +00:00
} else {
get _config ( get _cookie ( 'wrapperr-admin' ) ) ;
}
}
} ;
xhttp . withCredentials = true ;
2022-12-03 12:06:48 +00:00
xhttp . open ( "post" , api _url + "validate/admin" ) ;
2022-07-04 15:47:59 +00:00
xhttp . setRequestHeader ( "Content-Type" , "application/json;charset=UTF-8" ) ;
2023-10-25 13:14:02 +00:00
xhttp . setRequestHeader ( "Authorization" , cookie ) ;
2022-07-04 15:47:59 +00:00
xhttp . send ( ) ;
2022-01-11 13:33:30 +00:00
return ;
}
// Get config for admin to configure
function get _config ( cookie ) {
var xhttp = new XMLHttpRequest ( ) ;
xhttp . onreadystatechange = function ( ) {
2022-07-04 22:11:19 +00:00
if ( this . readyState == 4 ) {
try {
var result = JSON . parse ( this . responseText ) ;
}
catch {
alert ( "Failed to parse API response." ) ;
return ;
}
2022-01-11 13:33:30 +00:00
if ( result . error ) {
2023-10-25 13:14:02 +00:00
alert ( result . error ) ;
2022-01-11 13:33:30 +00:00
location . reload ( ) ;
} else {
2022-11-27 17:12:11 +00:00
tautulli = result . data . tautulli _config ;
2022-01-11 13:33:30 +00:00
timezone = result . data . timezone ;
create _share _links = result . data . create _share _links ;
2022-07-04 15:47:59 +00:00
plex _auth = result . data . plex _auth ;
2023-10-25 13:14:02 +00:00
basic _auth = result . data . basic _auth ;
2022-01-11 13:33:30 +00:00
use _cache = result . data . use _cache ;
use _logs = result . data . use _logs ;
clientID = result . data . clientID ;
wrapperr _root = result . data . wrapperr _root ;
application _name _str = result . data . application _name ;
application _url _str = result . data . application _url ;
2022-07-04 15:47:59 +00:00
winter _theme = result . data . winter _theme ;
2022-01-11 13:33:30 +00:00
wrapped _start = new Date ( 0 ) ;
wrapped _start . setUTCSeconds ( result . data . wrapped _start ) ;
wrapped _end = new Date ( 0 ) ;
wrapped _end . setUTCSeconds ( result . data . wrapped _end ) ;
2022-07-04 15:47:59 +00:00
stats _order _by _plays = result . data . wrapperr _customize . stats _order _by _plays ;
stats _order _by _duration = result . data . wrapperr _customize . stats _order _by _duration ;
wrapperr _front _page _title = result . data . wrapperr _customize . wrapperr _front _page _title ;
wrapperr _front _page _subtitle = result . data . wrapperr _customize . wrapperr _front _page _subtitle ;
stats _intro _title = result . data . wrapperr _customize . stats _intro _title ;
stats _intro _subtitle = result . data . wrapperr _customize . stats _intro _subtitle ;
stats _outro _title = result . data . wrapperr _customize . stats _outro _title ;
stats _outro _subtitle = result . data . wrapperr _customize . stats _outro _subtitle ;
2022-10-15 20:07:15 +00:00
stats _top _list _length = result . data . wrapperr _customize . stats _top _list _length ;
2023-02-07 07:52:38 +00:00
obfuscate _other _users = result . data . wrapperr _customize . obfuscate _other _users ;
2022-07-04 15:47:59 +00:00
get _user _movie _stats = result . data . wrapperr _customize . get _user _movie _stats ;
get _user _movie _stats _title = result . data . wrapperr _customize . get _user _movie _stats _title ;
get _user _movie _stats _subtitle = result . data . wrapperr _customize . get _user _movie _stats _subtitle ;
get _user _movie _stats _subsubtitle = result . data . wrapperr _customize . get _user _movie _stats _subsubtitle ;
get _user _movie _stats _subtitle _one = result . data . wrapperr _customize . get _user _movie _stats _subtitle _one ;
get _user _movie _stats _subsubtitle _one = result . data . wrapperr _customize . get _user _movie _stats _subsubtitle _one ;
get _user _movie _stats _subtitle _none = result . data . wrapperr _customize . get _user _movie _stats _subtitle _none ;
get _user _movie _stats _subsubtitle _none = result . data . wrapperr _customize . get _user _movie _stats _subsubtitle _none ;
get _user _movie _stats _top _movie = result . data . wrapperr _customize . get _user _movie _stats _top _movie ;
get _user _movie _stats _top _movie _plural = result . data . wrapperr _customize . get _user _movie _stats _top _movie _plural ;
get _user _movie _stats _movie _completion _title = result . data . wrapperr _customize . get _user _movie _stats _movie _completion _title ;
get _user _movie _stats _movie _completion _title _plural = result . data . wrapperr _customize . get _user _movie _stats _movie _completion _title _plural ;
get _user _movie _stats _movie _completion _subtitle = result . data . wrapperr _customize . get _user _movie _stats _movie _completion _subtitle ;
get _user _movie _stats _pause _title = result . data . wrapperr _customize . get _user _movie _stats _pause _title ;
get _user _movie _stats _pause _subtitle = result . data . wrapperr _customize . get _user _movie _stats _pause _subtitle ;
get _user _movie _stats _pause _title _one = result . data . wrapperr _customize . get _user _movie _stats _pause _title _one ;
get _user _movie _stats _pause _subtitle _one = result . data . wrapperr _customize . get _user _movie _stats _pause _subtitle _one ;
get _user _movie _stats _pause _title _none = result . data . wrapperr _customize . get _user _movie _stats _pause _title _none ;
get _user _movie _stats _pause _subtitle _none = result . data . wrapperr _customize . get _user _movie _stats _pause _subtitle _none ;
get _user _movie _stats _oldest _title = result . data . wrapperr _customize . get _user _movie _stats _oldest _title ;
get _user _movie _stats _oldest _subtitle = result . data . wrapperr _customize . get _user _movie _stats _oldest _subtitle ;
get _user _movie _stats _oldest _subtitle _pre _1950 = result . data . wrapperr _customize . get _user _movie _stats _oldest _subtitle _pre _1950 ;
get _user _movie _stats _oldest _subtitle _pre _1975 = result . data . wrapperr _customize . get _user _movie _stats _oldest _subtitle _pre _1975 ;
get _user _movie _stats _oldest _subtitle _pre _2000 = result . data . wrapperr _customize . get _user _movie _stats _oldest _subtitle _pre _2000 ;
get _user _movie _stats _spent _title = result . data . wrapperr _customize . get _user _movie _stats _spent _title ;
get _user _show _stats = result . data . wrapperr _customize . get _user _show _stats ;
get _user _show _stats _buddy = result . data . wrapperr _customize . get _user _show _stats _buddy ;
get _user _show _stats _title = result . data . wrapperr _customize . get _user _show _stats _title ;
get _user _show _stats _subtitle = result . data . wrapperr _customize . get _user _show _stats _subtitle ;
get _user _show _stats _subsubtitle = result . data . wrapperr _customize . get _user _show _stats _subsubtitle ;
get _user _show _stats _subtitle _one = result . data . wrapperr _customize . get _user _show _stats _subtitle _one ;
get _user _show _stats _subsubtitle _one = result . data . wrapperr _customize . get _user _show _stats _subsubtitle _one ;
get _user _show _stats _subtitle _none = result . data . wrapperr _customize . get _user _show _stats _subtitle _none ;
get _user _show _stats _subsubtitle _none = result . data . wrapperr _customize . get _user _show _stats _subsubtitle _none ;
get _user _show _stats _top _show = result . data . wrapperr _customize . get _user _show _stats _top _show ;
get _user _show _stats _top _show _plural = result . data . wrapperr _customize . get _user _show _stats _top _show _plural ;
get _user _show _stats _spent _title = result . data . wrapperr _customize . get _user _show _stats _spent _title ;
get _user _show _stats _most _played _title = result . data . wrapperr _customize . get _user _show _stats _most _played _title ;
get _user _show _stats _most _played _subtitle = result . data . wrapperr _customize . get _user _show _stats _most _played _subtitle ;
get _user _show _stats _buddy _title = result . data . wrapperr _customize . get _user _show _stats _buddy _title ;
get _user _show _stats _buddy _subtitle = result . data . wrapperr _customize . get _user _show _stats _buddy _subtitle ;
get _user _show _stats _buddy _title _none = result . data . wrapperr _customize . get _user _show _stats _buddy _title _none ;
get _user _show _stats _buddy _subtitle _none = result . data . wrapperr _customize . get _user _show _stats _buddy _subtitle _none ;
2022-01-11 13:33:30 +00:00
2022-07-04 15:47:59 +00:00
get _user _music _stats = result . data . wrapperr _customize . get _user _music _stats ;
get _user _music _stats _title = result . data . wrapperr _customize . get _user _music _stats _title ;
get _user _music _stats _subtitle = result . data . wrapperr _customize . get _user _music _stats _subtitle ;
get _user _music _stats _subsubtitle = result . data . wrapperr _customize . get _user _music _stats _subsubtitle ;
get _user _music _stats _subtitle _one = result . data . wrapperr _customize . get _user _music _stats _subtitle _one ;
get _user _music _stats _subsubtitle _one = result . data . wrapperr _customize . get _user _music _stats _subsubtitle _one ;
get _user _music _stats _subtitle _none = result . data . wrapperr _customize . get _user _music _stats _subtitle _none ;
get _user _music _stats _subsubtitle _none = result . data . wrapperr _customize . get _user _music _stats _subsubtitle _none ;
get _user _music _stats _top _track = result . data . wrapperr _customize . get _user _music _stats _top _track ;
get _user _music _stats _top _track _plural = result . data . wrapperr _customize . get _user _music _stats _top _track _plural ;
get _user _music _stats _top _album _plural = result . data . wrapperr _customize . get _user _music _stats _top _album _plural ;
get _user _music _stats _top _artist _plural = result . data . wrapperr _customize . get _user _music _stats _top _artist _plural ;
get _user _music _stats _spent _title = result . data . wrapperr _customize . get _user _music _stats _spent _title ;
get _user _music _stats _spent _subtitle = result . data . wrapperr _customize . get _user _music _stats _spent _subtitle ;
get _user _music _stats _oldest _album _title = result . data . wrapperr _customize . get _user _music _stats _oldest _album _title ;
get _user _music _stats _oldest _album _subtitle = result . data . wrapperr _customize . get _user _music _stats _oldest _album _subtitle ;
get _year _stats _title = result . data . wrapperr _customize . get _year _stats _title ;
get _year _stats _subtitle = result . data . wrapperr _customize . get _year _stats _subtitle ;
get _year _stats _subsubtitle = result . data . wrapperr _customize . get _year _stats _subsubtitle ;
get _year _stats _movies = result . data . wrapperr _customize . get _year _stats _movies ;
get _year _stats _movies _title = result . data . wrapperr _customize . get _year _stats _movies _title ;
get _year _stats _movies _duration _title = result . data . wrapperr _customize . get _year _stats _movies _duration _title ;
get _year _stats _shows = result . data . wrapperr _customize . get _year _stats _shows ;
get _year _stats _shows _title = result . data . wrapperr _customize . get _year _stats _shows _title ;
get _year _stats _shows _duration _title = result . data . wrapperr _customize . get _year _stats _shows _duration _title ;
get _year _stats _music = result . data . wrapperr _customize . get _year _stats _music ;
get _year _stats _music _title = result . data . wrapperr _customize . get _year _stats _music _title ;
get _year _stats _music _duration _title = result . data . wrapperr _customize . get _year _stats _music _duration _title ;
get _year _stats _leaderboard = result . data . wrapperr _customize . get _year _stats _leaderboard ;
2022-10-15 21:47:53 +00:00
get _year _stats _leaderboard _numbers = result . data . wrapperr _customize . get _year _stats _leaderboard _numbers ;
2022-07-04 15:47:59 +00:00
get _year _stats _leaderboard _title = result . data . wrapperr _customize . get _year _stats _leaderboard _title ;
get _year _stats _duration _sum _title = result . data . wrapperr _customize . get _year _stats _duration _sum _title ;
2022-01-11 13:33:30 +00:00
2022-07-04 15:47:59 +00:00
wrapperr _and = result . data . wrapperr _customize . wrapperr _and ;
wrapperr _play = result . data . wrapperr _customize . wrapperr _play ;
wrapperr _play _plural = result . data . wrapperr _customize . wrapperr _play _plural ;
wrapperr _day = result . data . wrapperr _customize . wrapperr _day ;
wrapperr _day _plural = result . data . wrapperr _customize . wrapperr _day _plural ;
wrapperr _hour = result . data . wrapperr _customize . wrapperr _hour ;
wrapperr _hour _plural = result . data . wrapperr _customize . wrapperr _hour _plural ;
wrapperr _minute = result . data . wrapperr _customize . wrapperr _minute ;
wrapperr _minute _plural = result . data . wrapperr _customize . wrapperr _minute _plural ;
wrapperr _second = result . data . wrapperr _customize . wrapperr _second ;
wrapperr _second _plural = result . data . wrapperr _customize . wrapperr _second _plural ;
wrapperr _sort _plays = result . data . wrapperr _customize . wrapperr _sort _plays ;
wrapperr _sort _duration = result . data . wrapperr _customize . wrapperr _sort _duration ;
username = result . username ;
2022-01-11 13:33:30 +00:00
admin _menu ( ) ;
}
}
} ;
xhttp . withCredentials = true ;
2022-12-03 12:06:48 +00:00
xhttp . open ( "post" , api _url + "get/config" ) ;
2022-07-04 15:47:59 +00:00
xhttp . setRequestHeader ( "Content-Type" , "application/json;charset=UTF-8" ) ;
2023-10-25 13:14:02 +00:00
xhttp . setRequestHeader ( "Authorization" , cookie ) ;
2022-07-04 15:47:59 +00:00
xhttp . send ( ) ;
2021-12-12 16:31:15 +00:00
}