// ==UserScript==
// @name Wasteof Plugins
// @namespace http://tampermonkey.net/
// @version 2025-02-13
// @description It's like vendetta but not for Discord, for wasteof, and it doesn't have themes or over a hundred plugins or is the cutest client mod for wasteof, and is basically nothing like vendetta
// @author MrOwlsss
// @match https://wasteof.money/*
// @icon 
// @grant none
// @license MIT
// ==/UserScript==
(function() {
"dont use strict, idiot";
const pink = "#ec4899";
const purple = "#8b5cf6";
const violet = "#8b5cf6";
const green = "#22c55e";
const blue = "#3b82f6"; // yes, default blue and theme-blue are different colors
const red = "#ef4444";
const orange = "#f97316";
if (localStorage.getItem("womplugins-ele") == null) {
localStorage.setItem("womplugins-ele", "enabled")
}
function createSettingModule(id) {
const settingsElement = document.createElement("div");
const footer = document.getElementById("footer");
settingsElement.classList.add("bg-gray-100");
settingsElement.classList.add("dark:bg-gray-800");
settingsElement.classList.add("p-4");
settingsElement.classList.add("rounded-xl");
settingsElement.classList.add("my-2");
settingsElement.id = id;
document.getElementsByTagName("main")[0].insertBefore(settingsElement, footer);
return settingsElement
}
function addHeaderNode(id, content) {
const settingsElement = document.getElementById(id);
const header = document.createElement("h2");
header.classList.add("font-bold");
header.classList.add("text-2xl");
header.classList.add("mb-2");
header.innerHTML = content;
settingsElement.appendChild(header);
return settingsElement
}
function addTextNode(id, content) {
const settingsElement = document.getElementById(id);
const header = document.createElement("p");
header.innerHTML = content;
settingsElement.appendChild(header);
return settingsElement
}
function addButtonNode(id, content, colorOrID, color) {
const settingsElement = document.getElementById(id);
const button = document.createElement("button");
button.classList.add("bg-primary-500", "text-white", "block", "mt-2", "text-center", "font-bold", "p-2", "h-10", "rounded-lg", "cursor-pointer")
button.innerHTML = content;
if (colorOrID) {
if (colorOrID.startsWith("#" || "rgb(" || "rgba(")) {
button.style.background = colorOrID;
} else {
button.id = colorOrID
}
}
if (color) {
button.style.background = color;
}
settingsElement.appendChild(button);
return button;
}
function addMenuDropdown(oldid, title, newid) {
const settingsElement = document.getElementById(oldid);
const menu = document.createElement("div");
menu.classList.add("select-none");
menu.classList.add("my-2");
menu.id = newid;
menu.innerHTML = `<div id="${newid}-top" class="menuDropdown bg-white dark:bg-gray-700 p-4 mb-2 rounded-xl flex cursor-pointer hover:bg-white transition-colors bg-gray-50">
<span class="inline-block font-semibold w-full">${title}</span>
<span class="inline-block secondary-text"
><span
><svg
xmlns="http://www.w3.org/2000/svg"
class="h-5 w-5"
viewBox="0 0 20 20"
fill="currentColor"
>
<path
fill-rule="evenodd"
d="M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z"
clip-rule="evenodd"
></path></svg></span
></span>
</div>
<div class="bg-white dark:bg-gray-700 p-4 rounded-xl" id="${newid}-menu">
<div id="${newid}-content" class="menuDropdownMenu">
<span class="block">
</span>
</div>
</div>
`;
settingsElement.appendChild(menu);
document.getElementById(`${newid}-top`).onclick = function () { if (opened) { document.getElementById(`${newid}-menu`).style.display = "none"; opened = false; } else { document.getElementById(`${newid}-menu`).style.display = "block"; opened = true } }
document.getElementById(`${newid}-menu`).style.display = "none";
let opened = false;
console.log(oldid)
if (document.getElementById(oldid).classList.contains("menuDropdownMenu")) {
document.getElementById(`${newid}-top`).classList.add("dark:bg-gray-800");
document.getElementById(`${newid}-menu`).classList.add("dark:bg-gray-800");
}
return menu
}
// window.setInterval(() => {
if (window.location.href == "https://wasteof.money/settings") {
// if (!document.getElementById("plugins")) {
console.log("g")
document.getElementsByClassName("w-full")[13].id = "footer";
createSettingModule("plugins");
addHeaderNode("plugins", "Wasteof Plugins");
addMenuDropdown("plugins", "Wasteof Plugins", "womplugins");
addHeaderNode("womplugins-content", "Wasteof Plugins");
addTextNode("womplugins-content", "Wasteof Plugins Base");
addTextNode("womplugins-content", "<b>By</b> MrOwlsss");
addTextNode("womplugins-content", "<b>Version</b> 1.3");
addHeaderNode("womplugins-content", "<br>Settings");
addMenuDropdown("womplugins-content", "Element API", "womplugins-ele");
addHeaderNode("womplugins-ele-content", "Element API");
addTextNode("womplugins-ele-content", "This will literally break most plugins if disabled");
addButtonNode("womplugins-ele-content", "Enable", "womplugins-eleonoff")
addMenuDropdown("plugins", "Leaderboard Pin", "lbpin");
addHeaderNode("lbpin-content", "Leaderboard Pin");
addTextNode("lbpin-content", "The original. Pins the Leaderboard post to the top of the feed");
addTextNode("lbpin-content", "<b>By</b> MrOwlsss");
addTextNode("lbpin-content", "<b>Version</b> 1.0");
addButtonNode("lbpin-content", "Enable", "lbpinonoff");
addMenuDropdown("plugins", "More Images", "more-images");
addHeaderNode("more-images-content", "More Images");
addTextNode("more-images-content", "Adds another way to embed images in Wasteof");
addTextNode("more-images-content", "<b>By</b> MrOwlsss");
addTextNode("more-images-content", "<b>Version</b> 1.0");
addButtonNode("more-images-content", "Enable", "more-imagesonoff")
addMenuDropdown("plugins", "Wasteof Tweaks", "wasteof-tweaks");
addHeaderNode("wasteof-tweaks-content", "Wasteof Tweaks");
addTextNode("wasteof-tweaks-content", "Like Vanilla Tweaks for Minecraft but for Wasteof");
addTextNode("wasteof-tweaks-content", "<b>By</b> MrOwlsss");
addTextNode("wasteof-tweaks-content", "<b>Version</b> 1.0");
addButtonNode("wasteof-tweaks-content", "Enable", "wasteof-tweaksonoff")
addHeaderNode("wasteof-tweaks-content", "<br>Settings");
//Settings!//
addMenuDropdown("wasteof-tweaks-content", "More Badges", "wasteof-tweaks-mbs");
addHeaderNode("wasteof-tweaks-mbs-content", "More User Badges");
addTextNode("wasteof-tweaks-mbs-content", "Adds more badges to user pages");
addButtonNode("wasteof-tweaks-mbs-content", "Enable", "wasteof-tweaks-mbsonoff")
addMenuDropdown("wasteof-tweaks-content", "Search Bar in Topnav", "wasteof-tweaks-sbtn");
addHeaderNode("wasteof-tweaks-sbtn-content", "Search Bar in Topnav");
addTextNode("wasteof-tweaks-sbtn-content", "Adds the Wasteof search bar in the top navigation bar.");
addButtonNode("wasteof-tweaks-sbtn-content", "Enable", "wasteof-tweaks-sbtnonoff")
addMenuDropdown("wasteof-tweaks-content", "Hashtag Support", "wasteof-tweaks-hts");
addHeaderNode("wasteof-tweaks-hts-content", "Hashtag Support");
addTextNode("wasteof-tweaks-hts-content", "Enables hashtag (#) support to Wasteof");
addButtonNode("wasteof-tweaks-hts-content", "Enable", "wasteof-tweaks-htsonoff")
addMenuDropdown("plugins", "Push Notification Count", "pushNotifCount");
addHeaderNode("pushNotifCount-content", "Push Notification Count");
addTextNode("pushNotifCount-content", "Will give you desktop notifications when you receive a notification (assuming Wasteof is open)");
addTextNode("pushNotifCount-content", "<b>By</b> MrOwlsss");
addTextNode("pushNotifCount-content", "<b>Version</b> 1.0");
addButtonNode("pushNotifCount-content", "Enable", "pushNotifCountonoff")
addMenuDropdown("plugins", "Custom CSS", "custom-css");
addHeaderNode("custom-css-content", "Custom CSS");
addTextNode("custom-css-content", "Theme Wasteof your own way! Requires knowlege of CSS.");
addTextNode("custom-css-content", "<b>By</b> MrOwlsss");
addTextNode("custom-css-content", "<b>Version</b> 1.0");
addButtonNode("custom-css-content", "Enable", "custom-cssonoff")
addButtonNode("custom-css-content", "Edit CSS", "custom-css-edit", orange)
// addMenuDropdown("plugins", "Sideload Plugins", "sideloadPlugins");
// addHeaderNode("sideloadPlugins-content", "Push Notification Count");
// addTextNode("sideloadPlugins-content", "Allows you to sideload plugins from external sources. <b>BE SURE YOU KNOW WHAT YOU'RE DOING</b>");
// addTextNode("sideloadPlugins-content", "<b>By</b> MrOwlsss");
// addTextNode("sideloadPlugins-content", "<b>Version</b> 1.0");
// addButtonNode("sideloadPlugins-content", "Enable", "sideloadPluginsonoff")
// addButtonNode("sideloadPlugins-content", "Sideload", "sideloadAPlugins")
createSettingModule("colors");
addMenuDropdown("colors", "Colors", "thecolors");
addButtonNode("thecolors-content", "Default", "default");
addButtonNode("thecolors-content", "Pink", pink);
addButtonNode("thecolors-content", "Violet", violet);
addButtonNode("thecolors-content", "Green", green);
addButtonNode("thecolors-content", "Blue", blue);
addButtonNode("thecolors-content", "Red", red);
addButtonNode("thecolors-content", "Orange", orange);
}
// }
// // }
// }
// }, 100);
function createDialog(title, id) {
const anewDialog = document.createElement("div");
anewDialog.id = id;
anewDialog.innerHTML = `<div class="vfm vfm--inset vfm--fixed" style="z-index: 1000;" data-v-02823e40="" value="true"><div class="vfm__overlay vfm--overlay vfm--absolute vfm--inset" style="" data-v-02823e40=""></div> <div aria-expanded="true" role="dialog" aria-modal="true" tabindex="-1" class="vfm__container vfm--absolute vfm--inset vfm--outline-none flex justify-center items-center" style="" data-v-02823e40=""><div class="vfm__content relative flex flex-col max-h-full mx-4 rounded w-full h-full md:w-1/2 md:h-1/2" data-v-02823e40="" style="touch-action: none; position: relative; top: 23px; left: -159px; margin: unset;"><span id="modal-header" class="mr-8 w-full bg-primary-500 dark:bg-gray-800 text-white p-2 rounded-t-xl dark:border-t-2 dark:border-l-2 dark:border-r-2 border-gray-700 font-semibold cursor-move">${title}</span><div
class="flex-grow overflow-y-auto bg-white dark:bg-gray-900 dark:border-b-2 dark:border-l-2 dark:border-r-2 border-gray-700 p-2 flex flex-col rounded-b" id="${id}-content"></div><button onclick="document.getElementById('${id}').remove();" class="absolute top-0 right-0 mt-2 mr-2 text-white"><span><svg xmlns="http://www.w3.org/2000/svg" class="h-5 w-5" viewBox="0 0 20 20" fill="currentColor">
<path fill-rule="evenodd" d="M4.293 4.293a1 1 0 011.414 0L10 8.586l4.293-4.293a1 1 0 111.414 1.414L11.414 10l4.293 4.293a1 1 0 01-1.414 1.414L10 11.414l-4.293 4.293a1 1 0 01-1.414-1.414L8.586 10 4.293 5.707a1 1 0 010-1.414z" clip-rule="evenodd"></path>
</svg></span></button> </div>`
document.body.appendChild(anewDialog)
return anewDialog;
}
//createDialog("Add account", "addAccount");
//document.getElementById("addAccount-content").innerHTML = `<p>Add an account:</p><br><input placeholder="Username"><input placeholder="Password">`;
if (window.location.href == "https://wasteof.money/settings") {
function pluginEnableDisable(plugin, warning) {
if (localStorage.getItem(plugin) == "enabled") {
document.getElementById(plugin + "onoff").style.background = "#ef4444";
document.getElementById(plugin + "onoff").innerText = "Disable";
} else {
document.getElementById(plugin + "onoff").style.background = "#22c55e";
document.getElementById(plugin + "onoff").innerText = "Enable";
}
document.getElementById(plugin + "onoff").addEventListener("click", () => {
let enabled = localStorage.getItem(plugin);
if (enabled != "enabled") {
if (warning == "usesUserToken") {
createDialog("Warning", plugin + "UUTWarnDialog");
addHeaderNode(plugin + "UUTWarnDialog-content", "This plugin uses your user token")
addTextNode(plugin + "UUTWarnDialog-content", "This plugin uses your user token, presumeably to make API calls on your behalf.<br>Are you sure you want to enable this plugin?")
addButtonNode(plugin + "UUTWarnDialog-content", "Enable", plugin + "UUTWarnButton", green);
// addTextNode(plugin + "UUTWarnDialog-content", "This plugin is sideloaded and contains unreviewed code. Make sure you know what you're doing.")
addTextNode(plugin + "UUTWarnDialog-content", "This plugin has been reviewed and officially added to Wasteof Plugins.")
document.getElementById(plugin + "UUTWarnButton").addEventListener("click", () => {
document.getElementById(plugin + "onoff").style.background = "#ef4444";
document.getElementById(plugin + "onoff").innerText = "Disable";
localStorage.setItem(plugin, "enabled");
document.getElementById(plugin + "UUTWarnDialog").remove();
})
} else {
document.getElementById(plugin + "onoff").style.background = "#ef4444";
document.getElementById(plugin + "onoff").innerText = "Disable";
localStorage.setItem(plugin, "enabled");
}
} else {
document.getElementById(plugin + "onoff").style.background = "#22c55e";
document.getElementById(plugin + "onoff").innerText = "Enable ";
localStorage.setItem(plugin, "disabled");
}
});
}
pluginEnableDisable("womplugins-ele");
pluginEnableDisable("lbpin");
pluginEnableDisable("more-images");
pluginEnableDisable("wasteof-tweaks");
pluginEnableDisable("wasteof-tweaks-sbtn");
pluginEnableDisable("wasteof-tweaks-mbs");
pluginEnableDisable("wasteof-tweaks-hts");
pluginEnableDisable("pushNotifCount", "usesUserToken");
// pluginEnableDisable("sideloadPlugins");
pluginEnableDisable("custom-css");
}
//element api
window.setInterval(() => {
if (localStorage.getItem("womplugins-ele") == "enabled") {
document.getElementsByClassName("text-2xl pl-2")[0].classList.add("wasteof-logo")
document.getElementsByClassName("bg-primary-500 dark:bg-gray-800 shadow-md p-2 sticky w-full z-50 top-0")[0].classList.add("navbar")
Array.from(document.getElementsByClassName("bg-gray-100 dark:bg-gray-800 px-8 mb-4 border-2 dark:border-gray-700 rounded-xl")).forEach((p) => {
p.classList.add("post")
})
document.getElementsByClassName("flex w-full md:w-1/2 justify-center md:justify-start text-white font-extrabold")[0].classList.add("nav-left")
document.getElementsByClassName("flex w-full content-center justify-between md:w-1/2 md:justify-end")[0].classList.add("nav-right")
document.getElementsByClassName("font-bold text-4xl")[0].classList.add("feed-text")
}
}, 100)
//leaderboard pin
window.setInterval(function () {
if (window.location.href == "https://wasteof.money/" && localStorage.getItem("lbpin") == "enabled") {
if (!document.getElementById("leaderboard")) {
const leaderboard = document.createElement("div");
leaderboard.id = "leaderboard"
const postList = document.getElementsByClassName("max-w-2xl")[0];
const lastPost = document.getElementsByClassName("max-w-2xl")[0].getElementsByClassName("rounded-xl")[0];
leaderboard.classList.add("bg-gray-100");
leaderboard.classList.add("dark:bg-gray-800");
leaderboard.classList.add("px-8");
leaderboard.classList.add("border-2");
leaderboard.classList.add("dark:border-gray-700");
leaderboard.classList.add("rounded-xl");
leaderboard.style = "margin-bottom: 15px;"
const requestOptions = {
method: "GET",
redirect: "follow"
};
let postText;
let comments;
let loves;
let reposts;
const timestamp = 1666228888577;
const date = new Date(timestamp);
const monthNames = ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"]
const year = date.getFullYear();
const month = monthNames[date.getMonth()];
const day = date.getDate();
const hours = date.getHours();
const minutes = date.getMinutes();
fetch("https://api.wasteof.money/posts/6660af119adc44a7ef3853a2", requestOptions)
.then((response) => response.text())
.then((result) => {
postText = JSON.parse(result);
return postText;
})
.then((parsedData) => {
postText = parsedData["content"];
comments = parsedData["comments"];
loves = parsedData["loves"];
reposts = parsedData["reposts"]
leaderboard.innerHTML = `<a href="/posts/6660af119adc44a7ef3853a2" class="block"><div class="w-full mt-4 mb-2 pb-1 border-b-2 dark:border-gray-700 font-semibold"><a href="/users/leaderboard" class="w-full block"><img src="https://api.wasteof.money/users/leaderboard/picture" alt="burrito's profile picture" class="h-8 inline-block bg-white dark:border-gray-700 rounded-full border-2"> <span class="ml-1 inline-block theme-indigo">
@leaderboard
<span class="inline-flex h-2 w-2 rounded-full bg-primary-500 ml-1"></span> <!----></span></a></div> <span class="prose dark:prose-light max-w-none break-words"><details><summary>Leaderboard</summary>${postText}</details></span> <!----> <!----> <div class="mt-3 mb-5"><span class="block mb-2 secondary-text italic">
Jun 5, 2024, 1:31 PM
<span class="cursor-pointer"></span> <!----></span> <div class="select-none"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20" fill="currentColor" class="inline h-5 w-5 cursor-pointer active:scale-125 active:text-red-400 hover:scale-110 transition"><path fill-rule="evenodd" d="M3.172 5.172a4 4 0 015.656 0L10 6.343l1.172-1.171a4 4 0 115.656 5.656L10 17.657l-6.828-6.829a4 4 0 010-5.656z" clip-rule="evenodd"></path></svg> <span class="mr-2">${loves}</span> <svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" role="img" viewBox="0 0 24 24" class="inline h-5 w-5 cursor-pointer active:scale-125 active:text-yellow-400 hover:scale-110 transition"><path d="M11.6 3.4l-.8-.8c-.5-.6-.4-1.5.3-1.8.4-.3 1-.2 1.4.2a509.8 509.8 0 012.7 2.7c.5.4.5 1.2.1 1.6l-2.8 2.9c-.5.5-1.3.5-1.8-.1-.3-.5-.2-1 .2-1.5l.8-1H7a4.3 4.3 0 00-4.1 4.7 2036.2 2036.2 0 01.2 8h2.4c.5 0 .8.2 1 .6.2.4.2.9 0 1.2-.2.4-.6.6-1 .6H1.8c-.7 0-1.2-.5-1.2-1.1v-.2V10c0-1.3.3-2.5 1-3.6 1.3-2 3.2-3 5.6-3h4.4zM12.3 18.3h4.6c2.3 0 4.2-2 4.2-4.3V5.9c0-.2 0-.2-.2-.2h-2.3c-.6 0-1-.3-1.2-.8a1.2 1.2 0 011.1-1.6h3.6c.8 0 1.3.5 1.3 1.3v9c0 1.1-.1 2.2-.6 3.2a6.4 6.4 0 01-5.6 3.7l-4.6.1h-.2l.7.8c.4.4.5.9.3 1.3-.3.8-1.3 1-1.9.4L9 20.6l-.4-.5c-.3-.4-.3-1 0-1.4l2.9-3c.6-.6 1.7-.3 2 .6 0 .4 0 .7-.3 1l-.9 1z" fill="currentColor"></path></svg> <span class="mr-2">${reposts}</span> <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20" fill="currentColor" class="inline h-5 w-5"><path fill-rule="evenodd" d="M18 13V5a2 2 0 00-2-2H4a2 2 0 00-2 2v8a2 2 0 002 2h3l3 3 3-3h3a2 2 0 002-2zM5 7a1 1 0 011-1h8a1 1 0 110 2H6a1 1 0 01-1-1zm1 3a1 1 0 100 2h3a1 1 0 100-2H6z" clip-rule="evenodd"></path></svg> <span>${comments}</span> <span class="float-right relative inline-block z-20"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20" fill="currentColor" class="h-5 w-5 cursor-pointer"><path d="M6 10a2 2 0 11-4 0 2 2 0 014 0zM12 10a2 2 0 11-4 0 2 2 0 014 0zM16 12a2 2 0 100-4 2 2 0 000 4z"></path></svg> <!----></span></div></div></a> <div class="v-portal" style="display: none;"></div></div>`;
})
.catch((error) => console.error(error));
postList.insertBefore(leaderboard, lastPost);
}
}
}, 100)
//more images
if (localStorage.getItem("more-images") == "enabled") {
window.setInterval(() => {
let pElements = Array.from(document.getElementsByTagName("p"));
pElements.forEach((ele) => {
const pText = ele.innerText;
if (pText.startsWith("{img}") && ele.parentElement.contentEditable != "true") {
console.log("more image code");
const imgURL = pText.slice(5);
const newImg = document.createElement("img");
newImg.src = imgURL;
ele.innerText = "";
ele.appendChild(newImg);
ele.style.maxHeight = "250px";
ele.style.maxWidth = "250px";
}
})
}, 100);
}
//custom css
if (localStorage.getItem("custom-css") == "enabled") {
setInterval(() => {
if (!document.getElementById("customWOMCSS")) {
const cCSS = document.createElement("style");
cCSS.innerText = localStorage.getItem("customCSS");
cCSS.id = "customWOMCSS";
document.body.appendChild(cCSS);
}
}, 100)
}
if (window.location.href == "https://wasteof.money/settings") {
document.querySelector("#custom-css-edit").addEventListener("click", () => {
let cssdialog = createDialog("Edit Custom CSS", "editccss");
const cssInput = document.createElement("textarea");
cssInput.classList.add("text-input")
cssInput.id = "cssinput";
cssInput.value = localStorage.getItem("customCSS");
document.querySelector("#editccss-content").appendChild(cssInput)
let savebutton = addButtonNode("editccss-content", "Save", green);
savebutton.style.width = "60px";
savebutton.onclick = ()=> {
localStorage.setItem("customCSS", cssInput.value);
cssdialog.remove();
document.querySelector("#customWOMCSS").innerText = localStorage.getItem("customCSS");
}
})
}
//wasteof tweaks
if (localStorage.getItem("wasteof-tweaks") == "enabled") {
if (localStorage.getItem("wasteof-tweaks-mbs") == "enabled") {
window.setInterval(() => {
if (document.location.pathname.split("/")[1] == "users") {
if (document.location.pathname == "/users/owenathletic" || document.location.pathname == "/users/markovmoney" || document.location.pathname == "/users/amyathletic") {
if (document.getElementById("BotIndicator")) {
} else {
const botIndicator = document.createElement("span");
const themeDot = document.getElementsByClassName("md:text-4xl")[0];
botIndicator.id = "BotIndicator"
botIndicator.innerHTML = `<svg fill-rule="evenodd" xmlns="http://www.w3.org/2000/svg" class="h-5 w-5" viewBox="0 0 24 24" fill="currentColor"><path d="M17.5 15.5C17.5 16.61 16.61 17.5 15.5 17.5S13.5 16.61 13.5 15.5 14.4 13.5 15.5 13.5 17.5 14.4 17.5 15.5M8.5 13.5C7.4 13.5 6.5 14.4 6.5 15.5S7.4 17.5 8.5 17.5 10.5 16.61 10.5 15.5 9.61 13.5 8.5 13.5M23 15V18C23 18.55 22.55 19 22 19H21V20C21 21.11 20.11 22 19 22H5C3.9 22 3 21.11 3 20V19H2C1.45 19 1 18.55 1 18V15C1 14.45 1.45 14 2 14H3C3 10.13 6.13 7 10 7H11V5.73C10.4 5.39 10 4.74 10 4C10 2.9 10.9 2 12 2S14 2.9 14 4C14 4.74 13.6 5.39 13 5.73V7H14C17.87 7 21 10.13 21 14H22C22.55 14 23 14.45 23 15M21 16H19V14C19 11.24 16.76 9 14 9H10C7.24 9 5 11.24 5 14V16H3V17H5V20H19V17H21V16Z"></path></svg>`;
botIndicator.classList.add("inline-block", "text-primary-500", "dark:text-primary-300");
botIndicator.title = "AI/Bot";
themeDot.appendChild(botIndicator);
}
}
let joinedText = document.getElementsByClassName("text-gray-400")[1].childNodes[0].title.split(" ").splice(0, 5).join(" ").split(" ");
joinedText[4] = joinedText[4].split(":").splice(0, 2).join(":");
joinedText = "Joined " + joinedText.join(" ")
document.getElementsByClassName("text-gray-400")[1].childNodes[0].innerHTML = joinedText
}
}, 20)
}
const timestamp = 1666228888577;
const date = new Date(timestamp);
const monthNames = ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"]
const year = date.getFullYear();
const month = monthNames[date.getMonth()];
const day = date.getDate();
const hours = date.getHours();
const minutes = date.getMinutes();
//alert(`Joined ${month} ${day}, ${year}`);
if (localStorage.getItem("wasteof-tweaks-sbtn") == "enabled") {
window.setInterval(function () {
if (!document.getElementById("inlineWOMSearch")) {
const newSearch = document.createElement("div");
// newSearch.action = "/search";
// newSearch.method = "get";
newSearch.style.marginTop = "-5px"
newSearch.innerHTML = `<input style="height: 36px" id="inlineWOMSearch" type="text" placeholder="search anything..." name="q" autofocus="autofocus" class="text-input" style="margin-left: 10px;"> <button id="inlineWOMSearchButton" class="bg-primary-500 inline-block text-white font-bold mt-2 p-2 rounded-lg cursor-pointer" >search</button>`
document.getElementsByClassName("nav-left")[0].appendChild(newSearch);
document.getElementsByTagName("img")[0].style = "margin-top: 5px;"
function search() {
let searchText = document.getElementById("inlineWOMSearch").value;
if (searchText.split(":")[0] == "user") {
location.href = "/search/users?q=" + searchText.split(":")[1];
} else if (searchText.split(":")[0] == "@") {
location.href = "/users/" + searchText.split(":")[1];
} else {
location.href = "/search?q=" + searchText;
}
}
document.getElementById("inlineWOMSearchButton").addEventListener("click", function() {
search()
})
document.getElementById("inlineWOMSearch").addEventListener("keypress", function (event) {
if (event.key === "Enter") {
search()
}
});
}
})
}
if (localStorage.getItem("wasteof-tweaks-hts") == "enabled") {
window.setInterval(function () {
let pElements = Array.from(document.getElementsByTagName("p"));
pElements.forEach((element) => {
let pText = element.innerHTML.split(" ");
pText.forEach((word, index) => {
if (word.startsWith("#")) {
// console.log(word);
pText[index] = `<a href="https://wasteof.money/search?q=${encodeURIComponent(word.split("").splice(1).join(""))}&ht=yes">${word}</a>`; // Correctly replace the word
}
});
let theText = pText.join(" ");
// console.log(theText);
if (!element.hasAttribute("urlified") && element.parentElement.contentEditable != "true") {
element.innerHTML = theText; // Update the innerHTML with the new text
element.setAttribute("urlified", "true");
}
});
}, 100);
// window.setInterval(function () {
// if (document.location.pathname == "/search") {
// const queryString = window.location.search;
// const urlParams = new URLSearchParams(queryString);
// if (urlParams.get("ht")) {
// let pElements = Array.from(document.getElementsByClassName("prose"));
// pElements.forEach((element) => {
// if (!element.innerHTML.split(" ").includes(`#${urlParams.get("q")}`)) {
// element.parentElement.parentElement.remove()
// }
// });
// }
// }
// }, 100)
}
}
// push-notifs
if (localStorage.getItem("pushNotifCount") == "enabled") {
function getCookie(cname) {
let name = cname + "=";
let decodedCookie = decodeURIComponent(document.cookie);
let ca = decodedCookie.split(';');
for (let i = 0; i < ca.length; i++) {
let c = ca[i];
while (c.charAt(0) == ' ') {
c = c.substring(1);
}
if (c.indexOf(name) == 0) {
return c.substring(name.length, c.length);
}
}
return "";
}
const userAuth = getCookie("token");
let unreadCount
const myHeaders = new Headers();
myHeaders.append("Authorization", userAuth);
const requestOptions = {
method: "GET",
headers: myHeaders,
redirect: "follow"
};
window.setInterval(() => {
fetch("https://api.wasteof.money/messages/count", requestOptions)
.then((response) => response.text())
.then((result) => unreadCount = JSON.parse(result))
.then((unreadCount) => alertNotifs(unreadCount["count"]))
.catch((error) => console.error(error));
function alertNotifs(unreads) {
if (unreads > 0) {
if (localStorage.getItem("unreadCount") != unreads) {
var title = `${unreads} Notification(s)`;
var icon = 'https://wasteof.money/brand/nav-logo.svg';
var body = `You have ${unreads} notifications!`;
var notification = new Notification(title, { body, icon });
localStorage.setItem("unreadCount", unreads)
}
}
}
}, 3000)
}
})();