CoCalc provides the best real-time collaborative environment for Jupyter Notebooks, LaTeX documents, and SageMath, scalable from individual users to large groups and classes!
CoCalc provides the best real-time collaborative environment for Jupyter Notebooks, LaTeX documents, and SageMath, scalable from individual users to large groups and classes!
Path: blob/main/cheats/gold/chestESP.js
Views: 1236
/**1* @license StewartPrivateLicense-2.0.12* Copyright (c) 05Konz 20233*4* You may not reproduce or distribute any code inside this file without the licenser's permission.5* You may not copy, modify, steal, skid, or recreate any of the code inside this file.6* You may not under any circumstance republish any code from this file as your own.7*8* ALL TERMS STATED IN THE LINK BELOW APPLY ASWELL9* https://github.com/05Konz/Blooket-Cheats/blob/main/LICENSE10*/1112/* THE UPDATE CHECKER IS ADDED DURING COMMIT PREP, THERE MAY BE REDUNDANT CODE, DO NOT TOUCH */1314(() => {15const cheat = (async () => {16let { stateNode } = Object.values((function react(r = document.querySelector("body>div")) { return Object.values(r)[1]?.children?.[0]?._owner.stateNode ? r : react(r.querySelector(":scope>div")) })())[1].children[0]._owner;17stateNode.state.choices.forEach(({ text }, index) => {18let chest = document.querySelector(`div[class^='styles__choice${index + 1}']`);19if (!chest || chest.querySelector('div')) return;20let choice = document.createElement('div')21choice.style.color = "white";22choice.style.fontFamily = "Eczar";23choice.style.fontSize = "2em";24choice.style.display = "flex";25choice.style.justifyContent = "center";26choice.style.transform = "translateY(200px)";27choice.innerText = text;28chest.append(choice)29});30});31let img = new Image;32img.src = "https://raw.githubusercontent.com/05Konz/Blooket-Cheats/main/autoupdate/timestamps/gold/chestESP.png?" + Date.now();33img.crossOrigin = "Anonymous";34img.onload = function() {35const c = document.createElement("canvas");36const ctx = c.getContext("2d");37ctx.drawImage(img, 0, 0, this.width, this.height);38let { data } = ctx.getImageData(0, 0, this.width, this.height), decode = "", last;39for (let i = 0; i < data.length; i += 4) {40let char = String.fromCharCode(data[i + 1] * 256 + data[i + 2]);41decode += char;42if (char == "/" && last == "*") break;43last = char;44}45let iframe = document.querySelector("iframe");46const [_, time, error] = decode.match(/LastUpdated: (.+?); ErrorMessage: "(.+?)"/);47if (parseInt(time) <= 1693429947456 || iframe.contentWindow.confirm(error)) cheat();48}49img.onerror = img.onabort = () => (img.src = null, cheat());50})();5152