Update sleeky
This commit is contained in:
		
							
								
								
									
										144
									
								
								plugins/sleeky-backend/assets/js/theme.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										144
									
								
								plugins/sleeky-backend/assets/js/theme.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,144 @@ | ||||
| // Sleeky Admin Theme | ||||
| // 2019 Flynn Tesoriero | ||||
|  | ||||
| console.log("Sleeky Admin Theme Running"); | ||||
|  | ||||
| $( document ).ready(function() { | ||||
|   // Get the theme URL | ||||
|   var url; | ||||
|   if ($('meta[name=pluginURL]').attr("content")) { | ||||
|     url = $('meta[name=pluginURL]').attr("content"); | ||||
|   } else { | ||||
|     // If for some reason we can't find the URL attribute | ||||
|     url = "/user/plugins/sleeky_backend"; | ||||
|   } | ||||
|  | ||||
|   // Detect theme | ||||
|   var theme; | ||||
|   if ($('meta[name=sleeky_theme]').attr("content") == 'light') { | ||||
|     theme = "light"; | ||||
|   } else if ($('meta[name=sleeky_theme]').attr("content") == 'dark') { | ||||
|     theme = "dark"; | ||||
|   } | ||||
|    | ||||
|   console.log("Theme is", theme) | ||||
|  | ||||
|   // Update favicon | ||||
|   $('link[rel="shortcut icon"]').attr('href', url + "/assets/img/favicon.ico"); | ||||
|  | ||||
|   // Update meta viewport | ||||
|   $('head').append('<meta name="viewport" content="width=device-width, initial-scale=1.0">'); | ||||
|  | ||||
|   // Detect pages | ||||
|   if ($("body").hasClass("login")) { | ||||
|     // Login page | ||||
|     console.log("Login page"); | ||||
|  | ||||
|     if (theme == "light") { | ||||
|       $("#login").prepend(`<img class="login-logo" src="${url}/assets/img/logo_black.png">`); | ||||
|     } else if (theme == "dark") { | ||||
|       $("#login").prepend(`<img class="login-logo" src="${url}/assets/img/logo_white.png">`); | ||||
|     } | ||||
|  | ||||
|      | ||||
|   } else if ($("body").hasClass("index")) { | ||||
|     // Index page | ||||
|     console.log("Index page"); | ||||
|  | ||||
|     handleNav() | ||||
|  | ||||
|     // Hide YOURLS new URL section | ||||
|     $("#new_url").hide(); | ||||
|  | ||||
|     // Grab the nonce id | ||||
|     var nonce = $("#nonce-add").val(); | ||||
|  | ||||
|     // Remove the YOURLS new URL Section | ||||
|     $("#new_url").remove(); | ||||
|  | ||||
|     // Create the sleeky new URL section from the template | ||||
|     $("nav").append($('<div>').load(`${url}/assets/html/form.html`, function () { | ||||
|       $("#nonce-add").val(nonce); | ||||
|     })); | ||||
|   } else if ($("body").hasClass("tools")) { | ||||
|     // Tools page | ||||
|     console.log("Tools page"); | ||||
|  | ||||
|     handleNav() | ||||
|  | ||||
|   } else if ($("body").hasClass("plugins")) { | ||||
|     // Plugins page | ||||
|     console.log("Plugins page"); | ||||
|  | ||||
|     handleNav() | ||||
|  | ||||
|   } else if ($("body").hasClass("plugin_page_sleeky_settings")) { | ||||
|     // Tools page | ||||
|     console.log("Sleeky Settings Page"); | ||||
|  | ||||
|     handleNav() | ||||
|  | ||||
|     $("#ui_selector").val($("#ui_selector").attr("value")); | ||||
|  | ||||
|   }  else if ($("body").hasClass("infos")) { | ||||
|     // Information page | ||||
|     console.log("Information page"); | ||||
|  | ||||
|     handleNav() | ||||
|  | ||||
|     $("#historical_clicks li").each(function (index) { | ||||
|       if (index % 2 != 0) { | ||||
|         $("#historical_clicks li").eq(index).css("background", ""); | ||||
|       } | ||||
|     }) | ||||
|  | ||||
|     // Update tab headers | ||||
|     var titles = ['Statistics', 'Location', 'Sources'] | ||||
|     for (let i = 0; i < 3; i++) { | ||||
|       $($('#headers > li')[i]).find('h2').text(titles[i]); | ||||
|     } | ||||
|   } else { | ||||
|     console.warn("Unknown page"); | ||||
|      | ||||
|     handleNav(); | ||||
|   } | ||||
|  | ||||
|   function handleNav() { | ||||
|     // Add logo | ||||
|     $("#wrap").prepend(`<img class="logo" src="${url}/assets/img/logo_white.png">`); | ||||
|  | ||||
|     // Add mobile nav hamburger | ||||
|     $("#wrap").prepend(`<div class="nav-open" id="navOpen"><i class="material-icons">menu</i></div>`); | ||||
|  | ||||
|     // Add frontend link | ||||
|     $('#admin_menu').append('<li class="admin_menu_toplevel frontend_link"><a href="/"><i class="material-icons">arrow_back</i> Frontend Interface</a></li>'); | ||||
|  | ||||
|     // admin_menu | ||||
|     $('#navOpen').on('click', function() { | ||||
|       $('#admin_menu').slideToggle(); | ||||
|     }) | ||||
|  | ||||
|     $(window).resize(function () { | ||||
|       if ($(window).width() > 899) { | ||||
|         $('#admin_menu').show(); | ||||
|       } else { | ||||
|         $('#admin_menu').hide(); | ||||
|       } | ||||
|     }); | ||||
|   } | ||||
|  | ||||
|   // Update P elements | ||||
|   $("p").each(function (index) { | ||||
|     if (/Display/.test($(this).text()) || /Overall/.test($(this).text())) { | ||||
|       // Move info on index page to the bottom | ||||
|       $("main").append("<p>" + $(this).html() + "</p>"); | ||||
|       $(this).remove(); | ||||
|     } else if (/Powered by/.test($(this).text())) { | ||||
|         // Update footer | ||||
|         var content = $(this).html(); | ||||
|         var i = 77 | ||||
|         var updated_content = "Running on" + content.slice(13, i) + '& <a href="https://sleeky.flynntes.com/" title="Sleeky">Sleeky</a>' + content.slice(i-1) | ||||
|         $(this).html(updated_content); | ||||
|       } | ||||
|   }); | ||||
| }); | ||||
		Reference in New Issue
	
	Block a user