您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
A small suite of tools to make Lemmy easier.
当前为
// ==UserScript== // @name LemmyTools // @namespace https://thesimplecorner.org/c/lemmytools // @version 0.1.2 // @description A small suite of tools to make Lemmy easier. // @author [email protected] // @include https://* // @run-at document-end // ==/UserScript== //todo: // const ltConfig = ` // ------------ EDIT THIS VARIABLE --------------------- var homeInstance = 'https://thesimplecorner.org'; // ------------ END EDIT AREA -------------------------- // Fixes remote Instance home linl //Nothing below needs edited. // -------------- VERSION ------------------- const ltVer = '0.1.2'; const ltTestedVer = '0.18'; var comm = ''; //-------------------------------------------- `; const funcs = ` function isltMobile(){ if (/Android|iPhone/i.test(navigator.userAgent)) { console.log("LemmyTools: " + "is mobile!"); return true; } else { console.log("LemmyTools: " + "is desktop!"); return false; } } let remoteCommunityArray = []; function update(comm, page, subString, hI) { var el = document.getElementById("myDiv"); try{ if (comm) { var browsedComm = "<li><h5>" + comm + "</h5><a href=" + subString + " target='_blank'><button class='ltbutton'>Easy Subscribe</button></a></li>"; remoteCommunityArray.push(browsedComm); } } catch{} return remoteCommunityArray; } function Toggle(overide) { let settings = options(); var s = document.getElementById("searchdiv"); var size = s.getBoundingClientRect(); var x = document.getElementById("myDiv"); var b = document.getElementById("toggle"); var h = document.getElementById("ltBarHeader"); var cs = document.getElementById("commsearch"); //on remote instance just hide the bar. if (overide == 0) { console.log("LemmyTools: " + "overiding bar to hide."); x.style.display = "none"; } if (x.style.display === "none") { x.style.display = "block"; s.style.height = "100%"; cs.style.display = "inline"; h.innerHTML = "<h6 style='font-size: 0.93rem !important;'><a href=" + settings.theInstance + ">Home</a> - <a href='https://lemmyverse.net/communities' target='_new'>Find Comms</a> - <a href='#' id='LToptions' onclick='options(" + 1 + ")'>Options</a></h6>"; s.style[settings.positionSide] = "0%"; } else { x.style.display = "none"; s.style.height = "auto"; h.innerHTML = '<img style="margin-' + settings.positionSide + ': 120px !Important; position:static;" class="targetImg" src="" width="32" height="32" />'; cs.style.display = "none"; if (size.width > 261){ s.style[settings.positionSide] = "-7.33%"; } else{ s.style[settings.positionSide] = "-190px"; } } } function searchComms(id, full, commsdiv) { console.log("LemmyTools: " + "commsearch evt searchinput" + id + commsdiv); var url = window.location.href; var query = id.toLowerCase(); if (query == "") { var commsCount = localStorage.getItem("commsCount"); if ((commsCount == null) || (full.length < 1)) { commsdiv.innerHTML = "<hr /><b>Welcome to LemmyTools! Ver " + ltVer + "</b><br /><br />If this is your first time running the script, set your lemmy homeinstance in the option page. [" + ltVer + "] - Manually enter your home lemmy instance in script for offsite home button functionality. (temporary)]. <br /><br /> If you dont see your subscribed communities here simply login to your lemmy and then click the LemmyTools home button above. "; } else { commsdiv.innerHTML = "Communities: " + commsCount + '<hr />'; commsdiv.innerHTML += full; } } else { commsdiv.innerHTML = full; console.log("LemmyTools: " + "Searching for:" + query); var children = commsdiv.getElementsByTagName("li"); console.log("LemmyTools: " + "Children found: " + children.length); let data = [""]; var found; for (var i = 0; i < children.length; i++) { if (children[i].innerHTML.toLowerCase().indexOf(query) !== -1) { found = children[i].innerHTML + '<br /><hr />'; console.log("LemmyTools: " + "Found: " + found); data.push(found); } } let dup = [...new Set(data)]; data = dup; data.sort(); commupdate(commsdiv, url, data); } } function commupdate(id, page, data) { console.log("LemmyTools: " + "Comm Update"); var count = -1; //console.log("LemmyTools: " + "updating " + id + " commsearch with: " + data); data.forEach(_ => count++); id.innerHTML = ""; id.innerHTML += "Results: " + count + "<hr /><br />"; id.innerHTML += data; } function options(open){ var odiv = document.getElementById("ltOptions"); console.log("LemmyTools: " + "Options Functions"); if (open == 1) { odiv.style.display = "block"; } else if (open == 2){ //First run set defaults or pull from localstorage. mobile = isltMobile(); commposSide = localStorage.getItem("option_commposSide"); reverseSide = localStorage.getItem("option_reverseSide"); var instance = localStorage.getItem("option_homeInstance"); commposVertical = localStorage.getItem("option_commposVertical"); expandImages = localStorage.getItem("option_expandImages"); expandImagesize = localStorage.getItem("option_expandImageSize"); hoverCheck = localStorage.getItem("option_hoverCheck"); hideSideBar = localStorage.getItem("option_hideSideBar"); unblurNSFW = localStorage.getItem("option_unblurNSFW"); alienSiteOld = localStorage.getItem("option_alienSiteOld"); if (localStorage.getItem('option_commposSide') == null) { console.log("LemmyTools: First Run Defaults"); commposSide = "right"; reverseSide = "left"; if (mobile) { commposSide = "left"; reverseSide = "right"; } else { commposSide = "right"; reverseSide = "left"; } } if (localStorage.getItem('option_homeInstance') == null) { if (homeInstance != '') { instance = homeInstance; } else { //alert('Welcome to LemmyTools. LemmyTools has defaulted to this lemmy instance.'); //instance = window.location.origin; } } if (localStorage.getItem('option_commposVertical') == null) { if (mobile) { commposVertical = "5"; } else { commposVertical = "5"; } } if (localStorage.getItem('option_expandImages') == null) { expandImages = "true"; } if (localStorage.getItem('option_hideSideBar') == null) { hideSideBar = "false"; } if (localStorage.getItem('option_expandImageSize') == null) { if (mobile) { expandImagesize = "100"; } else { expandImagesize = "50"; } } if (localStorage.getItem('option_hoverCheck') == null) { hoverCheck = "false"; } if (localStorage.getItem('option_unblurNSFW') == null) { unblurNSFW = "false"; } if (localStorage.getItem('option_alienSiteOld') == null) { if (mobile) { alienSiteOld = "false"; } else { alienSiteOld = "true"; } } localStorage.setItem("option_commposSide", commposSide); localStorage.setItem("option_reverseSide", reverseSide); localStorage.setItem("option_homeInstance", instance); localStorage.setItem("option_commposVertical", commposVertical); localStorage.setItem("option_expandImages", expandImages); localStorage.setItem("option_expandImageSize", expandImagesize); localStorage.setItem("option_hideSideBar", hideSideBar); localStorage.setItem("option_hoverCheck", hoverCheck); localStorage.setItem("option_unblurNSFW", unblurNSFW);alienSiteOld localStorage.setItem("option_alienSiteOld", alienSiteOld); } else if (open == 3) { //save button odiv.style.display = "none"; var commposSide = document.getElementsByName("option_commposSide")[0]; var value = commposSide.options[commposSide.selectedIndex].value; commposSide = value; theHomeinstance = document.getElementsByName("option_homeInstance")[0]; value = theHomeinstance.value; theHomeinstance = value; var commposVertical = document.getElementsByName("option_commposVertical")[0]; value = commposVertical.value; commposVertical = value; var expandImages = document.getElementsByName("option_expandImages")[0]; value = expandImages.checked; expandImages = value; var expandImagesize = document.getElementsByName("option_expandImageSize")[0]; value = expandImagesize.value; expandImagesize = value; var hideSideBar = document.getElementsByName("option_hideSideBar")[0]; value = hideSideBar.checked; hideSideBar = value; var hoverCheck = document.getElementsByName("option_hoverCheck")[0]; value = hoverCheck.checked; hoverCheck = value; var unblurNSFW = document.getElementsByName("option_unblurNSFW")[0]; value = unblurNSFW.checked; unblurNSFW = value; var alienSiteOld = document.getElementsByName("option_alienSiteOld")[0]; value = alienSiteOld.checked; alienSiteOld = value; if (commposVertical > 85) { commposVertical = 85; } else if (commposVertical <= -1) { commposVertical = 0; } var reverseSide = ""; if (commposSide == "left") { reverseSide = "right"; } else { reverseSide = "left"; } localStorage.setItem("option_commposSide", commposSide); localStorage.setItem("option_reverseSide", reverseSide); localStorage.setItem("option_homeInstance", theHomeinstance); localStorage.setItem("option_commposVertical", commposVertical); localStorage.setItem("option_hideSideBar", hideSideBar); localStorage.setItem("option_expandImages", expandImages); localStorage.setItem("option_expandImageSize", expandImagesize); localStorage.setItem("option_hoverCheck", hoverCheck); localStorage.setItem("option_unblurNSFW", unblurNSFW); localStorage.setItem("option_alienSiteOld", alienSiteOld); location.reload(true); } commposSide = localStorage.getItem("option_commposSide"); reverseSide = localStorage.getItem("option_reverseSide"); instance = localStorage.getItem("option_homeInstance"); commposVertical = localStorage.getItem("option_commposVertical"); expandImages = localStorage.getItem("option_expandImages"); expandImagesize = localStorage.getItem("option_expandImageSize"); hideSideBar = localStorage.getItem("option_hideSideBar"); hoverCheck = localStorage.getItem("option_hoverCheck"); unblurNSFW = localStorage.getItem("option_unblurNSFW"); alienSiteOld= localStorage.getItem("option_alienSiteOld"); const userOptions = {theInstance: instance, positionSide: commposSide, reverseSide: reverseSide, positionVertical: commposVertical,expandImages: expandImages, expandImagesize: expandImagesize, hideSideBar: hideSideBar, hoverCheck: hoverCheck, unblurNSFW: unblurNSFW, alienSiteOld: alienSiteOld}; return userOptions; } function scrollToElement(pageElement) { var positionX = 0, positionY = -130; while(pageElement != null){ positionX += pageElement.offsetLeft; positionY += pageElement.offsetTop; pageElement = pageElement.offsetParent; window.scrollTo(positionX, positionY, "smooth"); } } function removeClassByWildcard(divClass) { // If the class ends with a "*", then it matches all classes that start with the given class name. if (divClass.endsWith("*")) { divClass = divClass.replace('*', ''); // Get all elements with the given class name. var elements = document.getElementsByTagName("div"); var re = new RegExp("(^|\\s)" + divClass + "(\\s|$)"); let result = []; let className = ""; for (var i=0; i<elements.length; i++) { if (re.test(elements[i].className)) { console.log("Match: " + elements[i]); result.push(elements[i]); for (var y=0; y<elements[i].classList.length; y++) { if (elements[i].classList[y].indexOf(divClass) !== -1) { className = elements[i].classList[y]; console.log(className); } } } } // Remove the class from all elements. for (var i = 0; i < result.length; i++) { result[i].classList.remove(className); } } else { // Otherwise, the class must match exactly. var elements = document.querySelectorAll("[class=" + divClass + "]"); // Remove the class from all elements. for (var i = 0; i < elements.length; i++) { elements[i].classList.remove(divClass); } } } `; /*--- */ const main = ` // LemmyTools //check if first run or load saved settings let settings = options("2"); //settings.alienSiteOld = "true"; if (settings.alienSiteOld == "true") { alienSiteOldStyle_compact(); } /* Script */ var url = window.location.href; var currentPage = url; var broken = url.split('/c/'); var site = broken[0]; site = site.replace('https://', ''); var community = broken[1]; var subString = settings.theInstance + "/search?q=!" + community + "@" + site + "&type=All&listingType=All&page=1"; subString = subString.replace('#', ''); var count = 0; if (isltMobile()) { //Toggle(0); } //Better Subscription List -------------------------- const mouseReference = { mouseMove: false, buttonDown: false, x: false, y: false } setInterval(function() { document.onmousedown = e => { if (settings.expandImages == "true") { //Hide Existing Expanded images (stop pages from scrolling weird) if (e.srcElement.classList.contains('img-expanded')) { var mouseX = document.clientX; var mouseY = document.clientY; try{ var alreadySeen = document.getElementsByClassName('hasExpanded'); for (var i = 0; i < alreadySeen.length; i ++) { alreadySeen[i].style.display = 'none'; } } //end try catch {} e.srcElement.closest("a").setAttribute('onclick', 'return false;'); e.srcElement.closest("a").setAttribute('overflow', 'auto;'); e.preventDefault(); var img = e.srcElement var imgwidth = img.width; var imgheight = img.height; ratio = imgheight / imgwidth; mouseReference.buttonDown = true; img.style.cursor = "move"; img.classList.remove('overflow-hidden'); var initialX = img.offsetTop; var initialY = img.offsetLeft; document.addEventListener("dblclick", function(e) { mouseReference.buttonDown = false; window.location = img.src; }); document.addEventListener("mousemove", function(e) { mouseMove = true; document.addEventListener("mouseup", function(e) { e.preventDefault(); mouseReference.buttonDown = false; clearTimeout(imgTimeout); }); if(e.which === 1 && mouseReference.buttonDown && mouseMove) { scrollToElement(img); document.addEventListener("mouseup", function(e) { e.preventDefault(); mouseReference.buttonDown = false; img.style.cursor = "auto"; clearTimeout(imgTimeout); delete window.img; if (img.classList.contains('thumbnail') == false) { img.classList.add("hasExpanded"); } }); //mouse up e.preventDefault(); mouseX = e.clientX; mouseY = e.clientY; var deltaY = mouseY; var deltaX = mouseX ; deltaY = ((initialY / 2) + mouseY) * 1.1; imgTimeout = setTimeout(function() { img.style.height = deltaY + "px"; img.style.width = img.height / ratio + "px"; }, 10); } // if e.which }); } else if ((e.target.id == 'searchdiv') || (e.target.id == 'myDiv') || (e.target.classList.contains('card-header')) || (e.target.classList.contains('clickAble')) || (e.target.classList.contains('targetImg')) ) { if (settings.hoverCheck !== "true") { Toggle(); } } } // if expand images } // document body e //Removes the offset from images. try{removeClassByWildcard("offset-*");}catch{} //sidebar settings do if (settings.hideSideBar == "true"){ try{ var sidebarSubscribed = document.getElementById("sidebarContainer"); sidebarSubscribed.style.display = 'none'; removeClassByWildcard("site-sideba*"); var serverInfo = document.getElementById("sidebarInfo"); var serverInfoString = serverInfo.innerHtml; serverInfo.style.display = 'none'; } catch {} } }, 100); //Option Divs if (settings.expandImages == "true") { eIcheck = 'checked'; } else { eIcheck = ''; } if (settings.hideSideBar == "true") { hSBcheck = 'checked'; } else { hSBcheck = ''; } if (settings.hoverCheck == "true") { hoverCheck = 'checked'; } else { hoverCheck = ''; } if (settings.unblurNSFW == "true") { unblurCheck = 'checked'; } else { unblurCheck = ''; } if (settings.alienSiteOld == "true") { aSOcheck = 'checked'; } else { aSOcheck = ''; } var odiv = document.createElement("div"); odiv.setAttribute("id", "ltOptions"); odiv.classList.add("ltoptions", "border-secondary", "card"); odiv.innerHTML = "<h4>LemmyTools " + ltVer + " Options</h4></hr>" + "<div class='table-responsive'><table class='table'>" + "<thead class='pointer'>" + "<tr><th>Option:</th>" + "<th>Value:</th>" + "</thead></tr>" + "<tbody>" + "<tr><td><b>LemmyTools Settings:</b></td><td></td></tr>" + "<tr><td><b>HomeInstance URL</b><br /> Make sure to edit the homeInstance variable of<br /> the UserScript for the remote instance Home button fix. (Temporary workaround).<br />(Ex: https://yourinstance.lemmy)</td><td><textarea name='option_homeInstance'>" + settings.theInstance + "</textarea></td></tr>" + "<tr><td><b>LemmyTools bar window side</b><br /> - default: right</td><td><select name='option_commposSide'><option value='" + settings.positionSide + "'>" + settings.positionSide + "</option><option value='right'>right</option><option value='left'>left</option></select></td></tr>" + "<tr><td><b>LemmyTools bar vertical position </b><br />% from top [0-85] - default: desktop-5, mobile-65</td><td><textarea name='option_commposVertical'>" + settings.positionVertical + "</textarea></td></tr>" + "<tr><td><b>Hover to activate LemmyTools bar</b><br />Otherwise click.</td><td><input type='checkbox' name='option_hoverCheck'" + hoverCheck + "/></td></tr>" + "<tr><td><br /><br /></td><td></td></tr>" + "<tr><td><b>Site Style and Behaviors:</b></td><td></td></tr>" + "<tr><td><b>Compact Lemmy to old.Reddit Re-format (Lemmy v0.18) style</b><br />Like the old alien.site but lemmy! <br />Defaults - Desktop: On / Mobile: Off</td><td><input type='checkbox' name='option_alienSiteOld'" + aSOcheck + "/></td></tr>" + "<tr><td><b>Hide Lemmy Sidebars</b><br /> (Trending, ServerInfo, Communities)<br /> More room for images on feed.</td><td><input type='checkbox' name='option_hideSideBar'" + hSBcheck + "/></td></tr>" + "<tr><td><b>Expandable Images</b><br />Acts as an auto-expander and adds the ability to manually<br /> expand images by clicking and dragging.<br />Doubleclick to open full image.</td><td><input type='checkbox' name='option_expandImages' " + eIcheck + "/></td></tr>" + "<tr><td><b>Auto Expand Size</b><br />Size of post image after opening a image post.<br /> Desktop Default: 50 / Mobile: 100</td><td><textarea name='option_expandImageSize'>" + settings.expandImagesize + "</textarea></td></tr>" + "<tr><td><b>Auto unblur NSFW images</b><br /></td><td><input type='checkbox' name='option_unblurNSFW'" + unblurCheck + "/></td></tr>" + "<tr><td></td><td><button id='LTsaveoptions' onclick='options(3)'>Save / Close</button></td></tr></tbody></table></div>" + "<p> Tested on Lemmy Version: " + ltTestedVer + " on firefox. " + "<br /><h5>LemmyTools Links</h5><hr /><a href='https://thesimplecorner.org/c/lemmytools'>[email protected]</a><br />Get it here: <a href='https://github.com/howdy-tsc/LemmyTools'>Github</a> or <a href='https://greasyfork.org/en/scripts/469169-lemmytools'>GreasyFork</a>" + "<br />Please submit issues to the github for feature requests and problems: <a href='https://github.com/howdy-tsc/LemmyTools/issues'>Github LemmyTools Issues</a><br /></p>" + "<br /><a href='https://ko-fi.com/lemmytools'><img src='https://storage.ko-fi.com/cdn/nav-logo-stroke.png' width='32' /><br />Enjoy LemmyTools?<br />Tip with coffee!</a>" + "<br /><br /><b>Attributes/Credit: </b><br /><li>The provided style pack option of 'Compact Lemmy to old.Reddit Re-format (Lemmy v0.18)' was graciously used with permission from the developer(s). <br />Please support their project here:" + "<a href='https://github.com/soundjester/lemmy_monkey'> Compact Lemmy to old.Reddit Re-format (Lemmy v0.18)</a></li>"; document.body.appendChild(odiv); var height = window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight; height = (height/100 * 1); //Comm divs var touchdiv = document.createElement("div"); touchdiv.setAttribute("id", "touchdiv"); var idiv = document.createElement("div"); idiv.setAttribute("id", "searchdiv"); idiv.classList.add("ltmenu", "border-secondary", "card"); idiv.innerHTML = "<span class='clickAble' style='float:" + settings.reverseSide + ";'> <header id='ltBarHeader' class='card-header'><h6 style='font-size: 0.93rem !important;'><a href=" + settings.theInstance + ">Home</a> - <a href='https://lemmyverse.net/communities' target='_new'>Find Comms</a> - <a href='#' id='LToptions' onclick='options(" + 1 + ")'>Options</a></h6></header><input type='text' id='commsearch' name='commsearchinput' oninput='searchComms(commsearch.value, communityArray, div)' placeholder='Search your subscriptions (or visted subs)' /></span><b class='clickAble'>LemmyTools " + ltVer + "</b><div style='clear:both;'></div>"; var div = document.createElement("div"); div.setAttribute("id", "myDiv"); div.classList.add("ltcommsbar"); var styleString = ".ltmenu {position: fixed; top: " + settings.positionVertical +"%;" + settings.positionSide + ": 0; font-size: .75em; display: block; height: 100%; min-height: auto; z-index:999; overflow:scroll; border: thick double; border-right:none !important; outline: 1px solid grey !important;}" + ".ltmenu input { width: 100%;}" + ".ltcommsbar { word-wrap: break-word; overflow:auto; height:100%; width:240px;}" + ".ltcommsbar hr {display:block;}" + ".ltbutton {background-color: #ccffe5;}" + ".img-fluid {width: " + settings.expandImagesize + "%}" + "#searchdiv {position: fixed; height: 100%; min-height: auto; width: 240px; display:block; z-index:999; overflow: auto; display: block; transition-timing-function: ease; transition: " + settings.positionSide + " .25s; " + settings.positionSide + " : 0; transition-delay: 0, 1s; overflow: auto;}" + ".ltoptions {position: fixed; min-width: auto; min-height: auto; width: auto; height:100%; top:0;" + "display:none; left: 0; overflow:scroll; z-index:1000; padding:0.5%; border: thick double;}"; //Hover ltBar if (settings.hoverCheck == "true") { styleString += "#searchdiv:not(:hover) { transition-timing-function: ease; transition: " + settings.positionSide + ".25s; " + settings.positionSide + " : -215px;transition-delay: 1s, 2s;} "; } else { styleString += "#searchdiv:not(:hover) {}"; } if (settings.unblurNSFW == "true") { styleString += " .img-blur {filter: none !important; -webkit-filter: none !important; -moz-filter: none !important; -o-filter: none !important; -ms-filter: none !important;} "; } else { styleString += " .img-blur {filter: blur !important; -webkit-filter: blur !important; -moz-filter: blur !important; -o-filter: blur !important; -ms-filter: blur !important;} "; } if (settings.hideSideBar == "true") { styleString += ".container, .container-lg, .container-md, .container-sm, .container-xl { }" + ".col-md-8 {flex: 0 0 80% !important;max-width: 80%;}"; } else { styleString += ".container, .container-lg, .container-md, .container-sm, .container-xl {}"; } // ADD MAIN CSS const addCSS = css => document.head.appendChild(document.createElement("style")).innerHTML = css; addCSS(styleString); url = location.href; console.log("LemmyTools: " + "url is " + url) // ----------------------------------------------- //Add divs to page; document.body.appendChild(idiv); idiv.appendChild(div); let rCommunityArray = []; //Easier Subscribe Buttons --------------------------- //Browsing remote instance setInterval(function() { var url = window.location.href; var currentPage = url; var broken = url.split('/c/'); var site = broken[0]; site = site.replace('https://', ''); var community = broken[1]; var subString = settings.theInstance + "/search?q=!" + community + "@" + site + "&type=All&listingType=All&page=1"; subString = subString.replace('#', ''); url = window.location.href; if (currentPage != location.href) { console.log("LemmyTools: " + "Easy Sub Running..."); if (document.querySelector('meta[name="Description"]').content.includes("Lemmy")) { console.log("LemmyTools: " + "On remote lemmy"); if ((url.includes(settings.theInstance) == false) && ((url.includes("/c/") || url.includes("/post/") || url.includes("/comment/") || url.includes("/communities")))) { console.log("LemmyTools: " + "On remote instance community" + "Button to: " + subString); rCommunityArray = update(community, url, subString, settings.theInstance); let rDup = [...new Set(rCommunityArray)]; rCommunityArray = rCommunityArray.reverse(); div.innerHTML = ''; div.innerHTML += rCommunityArray; communityArray = rCommunityArray; } } }else if (document.querySelector('meta[name="Description"]').content.includes("Lemmy")) { console.log("LemmyTools: " + "On lemmy"); if ((url.includes(settings.theInstance) == false) && ((url.includes("/c/") || url.includes("/post/") || url.includes("/comment/") || url.includes("/communities")))) { console.log("LemmyTools: " + "On remote instance community - DIRECT -" + "Button to: " + subString); rCommunityArray = update(community, url, subString, settings.theInstance); let rDup = [...new Set(rCommunityArray)]; rCommunityArray = rDup; rCommunityArray = rCommunityArray.reverse(); div.innerHTML = ''; div.innerHTML += rCommunityArray; communityArray = rCommunityArray; } } currentPage = location.href; }, 1000); //Logged in // ----------------------------------------------- let communityArray = new Array(); if (url.includes(settings.theInstance)) { console.log("LemmyTools: " + "home instance do bar"); document.querySelectorAll('[class="list-inline-item d-inline-block"]').forEach(function(el) { communityArray.push("<li>" + el.innerHTML + "</li>"); }); let dup = [...new Set(communityArray)]; communityArray = dup; if ((count == 0) || (count == null)) { count = 0; communityArray.forEach(_ => count++); } div.innerHTML += communityArray; if (div.innerHTML.length >= 20) { console.log("LemmyTools: Got Results >20"); console.log("LemmyTools: " + "setting localcomms localstore"); localStorage.setItem("localComms", communityArray); localStorage.setItem("commsCount", count); //force update the page searchComms("", communityArray, div); } else { console.log("LemmyTools: " + "get localcomms from localstore"); communityArray = localStorage.getItem("localComms"); div.innerHTML += communityArray; //force update the page searchComms("", communityArray, div); } } else { console.log("LemmyTools: On Remote Instance - Bar"); //div.innerHTML = localStorage.getItem("remoteComms"); //Toggle(0); } `; /* The provided restyling was graciously used with permission from the developer(s) of Compact Lemmy to old.Reddit Re-format (Lemmy v0.18) // @name Compact Lemmy to old.Reddit Re-format (Lemmy v0.18) // @namespace https://github.com/soundjester/lemmy_monkey // @description Reformat widescreen desktop to look more like Reddit // @version 2.4 // @author mershed_perderders, DarkwingDuck, [email protected], Djones4822, Jakylla Thank you. */ const alienSiteOldStyle = ` ${ function alienSiteOldStyle_compact(){ 'use strict'; /***********************************/ /* set desired thumbnail size here */ /* 70px - compact default */ /* 100px - large thumbnail default */ /***********************************/ var thumbnailSize = 70; var readingWidth = 940; /*controls the width of comments and text posts on individual post pages - default=940*/ /***********************************/ function AppendCommentCountText(container) { var svgElem = container.querySelectorAll("svg")[0].outerHTML; var numComms = container.title; var spanElem = container.querySelectorAll("span"); var spanElemHTML = ""; if(spanElem[0]){ spanElemHTML = " " + spanElem[0].outerHTML } container.innerHTML = svgElem + numComms + spanElemHTML; } function ApplyCommentCountText(element) { const observer = new MutationObserver(function(mutationsList) { for (let mutation of mutationsList) { if (mutation.type === 'childList') { for (let addedNode of mutation.addedNodes) { try { var comm_count = addedNode.querySelectorAll(".btn.btn-link.btn-sm.text-muted.ps-0"); comm_count.forEach(AppendCommentCountText); } catch (_er) { console.log(_er); return; } } } } }); observer.observe(element, { childList: true, subtree: true }); } function AppendPostURL(container) { var tld_link = container.querySelectorAll(".d-flex.text-muted.align-items-center.gap-1.small.m-0")[0]; var post_details = container.querySelectorAll("span.small")[0]; if (tld_link) { var post_detail = tld_link.nextSibling.innerText; post_details.innerHTML += " • " + tld_link.innerHTML } } function ApplyAppendPostURL(element) { const observer = new MutationObserver(function(mutationsList) { for (let mutation of mutationsList) { if (mutation.type === 'childList') { for (let addedNode of mutation.addedNodes) { try { var comm_count = addedNode.querySelectorAll("article > .col-12.col-sm-9 > .row > .col-12"); comm_count.forEach(AppendPostURL); } catch (_er) { console.log(_er); return; } } } } }); observer.observe(element, { childList: true, subtree: true }); } const css = ` /**************************/ /* NSFW automatic un-blur */ /**************************/ .img-blur { filter: none !important; -webkit-filter: none !important; -moz-filter: none !important; -o-filter: none !important; -ms-filter: none !important; } /***************************/ /* bootstrap column widths */ /***************************/ /*main container*/ .container, .container-lg, .container-md, .container-sm, .container-xl { max-width: 100% !important; } .home { padding-left: 1em !important; } /*sidebar width*/ .col-md-4 { flex: 0 0 20% !important; max-width: 20%; padding-right: unset !important; } /*main post area (witdh optimized for widescreen)*/ .col-md-8 { flex: 0 0 80% !important; max-width: 80%; } .col-sm-2 { flex: 0 0 10% !important; max-width: 10%; } .col-sm-9 { flex: 0 0 80% !important; max-width: 80%; } .col-8 { max-width: 100% !important; } /* specific column combos that need padding adjustment*/ /* .col-12.col-md-8 { padding-left: unset !important; } */ /* .col-12.col-sm-9 { padding-left: unset !important; } */ /* navbar padding*/ .navbar { /*padding-left: 0 !important; */ padding-right: 1em !important; } .navbar-nav { margin-top: 0px !important; margin-bottom: 0px !important; } /* control vertical padding*/ .mb-1, .my-1 { margin-bottom: 0.1rem !important; } .mb-2, .my-2 { margin-bottom: 0.1rem !important; } .mt-3, .my-3 { margin-top: 0.1rem !important; } .mt-4, .my-4 { margin-top: 0.1rem !important; } /***************/ /* voting area */ /***************/ /*can be modified as you like*/ .vote-bar { font-size: 0.85em !important; flex: 0 0 4% !important; max-width: 4% !important; margin-top:unset !important; } /******************/ /* thumbnail area */ /******************/ /*keep thumbnails as square as we can and about the size of each post row*/ .post-media { min-width: +thumbnailSize+px !important; max-width: +thumbnailSize+px !important; margin-right: 1em !important; } .thumbnail { min-height: +thumbnailSize+px !important; max-height: +thumbnailSize+px !important; min-width: +thumbnailSize+px !important; max-width: +thumbnailSize+px !important; background-color: #333; object-fit: scale-down; /* instead of "cover" */ } /*this is needed for videos/gifs*/ .embed-responsive { min-height: +thumbnailSize+px !important; max-height: +thumbnailSize+px !important; min-width: +thumbnailSize+px !important; max-width: +thumbnailSize+px !important; } /*apply specific styling to text posts*/ .post-media a[href^="/post/"] .thumbnail { border: 1px solid #333; background-color: unset !important; } /*******************/ /* main page posts */ /*******************/ /* post title font size*/ .h5, h5 { font-size: 1rem !important; margin-bottom: 0.1rem !important; } .small, small { font-size: 80%; font-weight: 400; } /*can be adjusted smaller, but beyond .25 is gets too tight and individual post spacing starts to appear overlapping*/ .post-listing { margin: 0.25rem 0 !important; padding: 0.25rem 0 !important; } .post-listing picture img.rounded-circle { width: 1.25rem; height: 1.25rem; } /*hide link TLD until it is moved back to the old spot*/ p.d-flex.text-muted.align-items-center.gap-1.small.m-0 { display: none !important; } /*thumbnail width control (keep it square, dang it!)*/ .post-listing .d-none .row .col-sm-2 { max-width: 100px; } .post-listing .d-none .row .col-sm-9 { display: flex; align-items: unset !important; } /*comment number and fediverse/lemmy links*/ .ps-0 { font-size: 0.75rem !important; } /*the below .btn is deprecated as .py-0 (above) provides more consistent spacing; however, some may prefer the look of smaller text on buttons*/ /*.btn { font-size:0.75rem !important; } */ /*media collapse/expand button - appears after post title for offsite links that have a thumbnail*/ .btn.btn-sm.text-monospace.text-muted.d-inline-block { padding-top: 0; padding-bottom: 0; } .text-body.mt-2.d-block{ font-size: 0.8rem; display: none !important; } /************/ /* comments */ /************/ /* restrict post and comment width - adjust to preference */ /* may use li[role="comment"] instead of .md-div - this fully restricts all comment elements (eg. divider lines_ */ #postContent, .md-div, .alert-warning { max-width: +readingWidth+px; } .mb-3.row { max-width: +(readingWidth+25)+px; /*top-comment textarea needs extra width*/ } /*top comment doesn't need to hug the comment sort buttons.*/ .comments:first-child { margin-top: 0.5rem !important; } /*allow top-level comment box to be resized*/ div > textarea { resize: both !important; } /*increase the indent for child comments*/ .ms-1 { margin-left: 1em !important; } /***********/ /* sidebar */ /***********/ #sidebarContainer { padding-right: 1em; } /******************************/ /* entire page display tweaks */ /******************************/ #app > div > .container-lg { margin-left: 1em !important; max-width: 99% !important; margin-left: unset !important; } #app > nav > .container-lg { max-width: 100% !important; } #app > navbar > .container-lg { margin-left: unset !important; } /* post index layout*/ #app > .mt-4 > .container-lg hr.my-3 { display: none; } #app > .mt-4 > .container-lg > .row { margin: unset !important; } /* post layout*/ #app > .mt-4 > .container-lg > .row > main { max-width: 100%; } #app > .mt-4 > .container-lg > .row > .col-md-8 { width: calc(100% - 450px); } #app > .mt-4 > .container-lg > .row > .col-md-4 { width: 450px; } hr { display: none; } /* highlight number of new comments */ .text-muted.fst-italic { color: var(--bs-orange) !important; } /* Fix user drop down menu position*/ .dropdown-content { right: 0px; } .dropdown-menu.show { width: 100%; } /* Profile and Community Banner size */ .position-relative.mb-2 { max-width: 730px; } /*table styles - primarily used on the "Communities" page*/ .table-responsive { margin-top: 0.5em; } .table-sm td, .table-sm th { padding: 0.1rem; vertical-align: middle; } /**********************************************/ /** Specific screen size (mobile) adjustments */ /**********************************************/ @media screen and (min-width: 1981px) { #app { max-width: 1980px; margin-left: auto; margin-right: auto; } } @media screen and (min-width: 1200px) and (max-width: 1640px) { .col-md-4 { flex: 0 0 25% !important; max-width: 25%; } .col-md-8 { flex: 0 0 75% !important; max-width: 75%; } } @media screen and (max-width: 1199px) and (min-width: 992px) { .col-12 { flex: 0 0 100% !important; max-width: 75%; } .col-md-4 { flex: 0 0 25% !important; max-width: 25%; } .vote-bar { flex: 0 0 8% !important; max-width: 8% !important; } } @media screen and (max-width: 768px) and (min-width: 576px) { .col-12 { flex: 0 0 100% !important; max-width: 100%; } .col-sm-9 { flex: 0 0 72% !important; max-width: 72%; } .vote-bar { flex: 0 0 8% !important; max-width: 8% !important; } } @media screen and (max-width: 575px) { #tagline { padding-right: 1em; } .col-12 { flex: 0 0 100% !important; max-width: 100%; } .col-8 { flex: 0 0 75% !important; max-width: 75%; } .col-4 { flex: 0 0 25% !important; max-width: 25%; justify-content: flex-end !important; display: flex !important; } }` const styleTag = document.createElement('style'); styleTag.appendChild(document.createTextNode(css)); document.head.appendChild(styleTag); /*append comment icon with "comment" text*/ var comm_count = document.querySelectorAll(".btn.btn-link.btn-sm.text-muted.ps-0"); comm_count.forEach(AppendCommentCountText); /*Apply AppendCommentCountText to dynamically loaded elements */ ApplyCommentCountText(document.documentElement); /*append post TLD link to post detail area*/ var post_info = document.querySelectorAll("article > .col-12.col-sm-9 > .row > .col-12"); post_info.forEach(AppendPostURL); /* Apply AppendPostURL to dynamically loaded elements */ ApplyAppendPostURL(document.documentElement); } }`; (function() { 'use strict'; if(typeof $ == 'undefined'){ var $ = unsafeWindow.jQuery; } let isLemmy; try { isLemmy = true; isLemmy = document.head.querySelector("[name~=Description][content]").content === "Lemmy"; } catch (_er) { isLemmy = false; } if (isLemmy) { document.head.appendChild(document.createElement("script")).innerHTML = alienSiteOldStyle; document.body.appendChild(document.createElement("script")).innerHTML = ltConfig; document.head.appendChild(document.createElement("script")).innerHTML = funcs; document.body.appendChild(document.createElement("script")).innerHTML = main; } })();